当前位置: 首页 > news >正文

江都网站制作网站建设区域加盟

江都网站制作,网站建设区域加盟,濮阳市城乡一体化示范区西湖医院,天津网页Latch 是什么 latch 即锁存器,是一种对电平敏感的存储单元电路,和寄存器一样都是基本存储单元,但是寄存器是边沿触发的存储器,锁存器是电平触发的存储器。 组合逻辑电路和时序逻辑电路 在数字电路中将逻辑电路分成两大类&#…

Latch 是什么

latch 即锁存器,是一种对电平敏感的存储单元电路,和寄存器一样都是基本存储单元,但是寄存器是边沿触发的存储器,锁存器是电平触发的存储器。

组合逻辑电路和时序逻辑电路

在数字电路中将逻辑电路分成两大类,一类叫组合逻辑电路,另一类叫做时序逻辑电路。

  • 组合逻辑电路:组合逻辑电路是一种输出状态只与当前输入直接相关的电路,它的输出仅仅取决于当前的输入状态,而不受到过去的输入状态或时钟信号的影响。
  • 时序逻辑电路:时序逻辑电路是一种输出状态不仅与当前输入相关,且还与过去状态相关的电路,它的输出不仅取决于当前的输入状态,还要考虑过去状态。
    注意
    在FPGA中通常将没有时钟的电路归为组合逻辑电路,有时钟的电路归为时序逻辑电路。

Latch 的危害

Latch具有以下危害:

  1. Latch是电平触发的,因此有Latch的电路抗干扰能力差
  2. Latch不能异步复位
  3. Latch上电后处于不定态,会让静态时序分析变得十分复杂
  4. 大部分FPGA器件没有 Latch这个东西,需要用使用寄存器来组成锁存器,会占用更多逻辑资源等问题

产生 Latch 的原因

在组合逻辑电路中如果变量的赋值操作没有覆盖到分支语句(如 if else 、case endcase、? : 等)的每一个分支就会产生Latch,常见的有以下情况:

  1. if 语句没有 else
  2. case 语句没有 defaul
  3. 变量自己给自己赋值
    注意:
    只有在组合逻辑电路中才会产生Latch(这里的组合逻辑是以有无时钟来区分的)

if 语句没有 else

示例代码如下:

module latch_one (input wire in1,input wire in2,output reg[3:0] out
);always @(*) beginif({in1, in2} == 2'd0)out = 4'b0001;else if({in1, in2} == 2'd1)out = 4'b0010;else if({in1, in2} == 2'd2)out = 4'b0100;
//    else
//         out = 4'b1000;
endendmodule

上面代码中out变量的赋值没有覆盖到if语句的每一个分支(没有else部分),通过vivado进行语法分析后发现其原理图如下,可以看到生成了latch。
在这里插入图片描述

case 语句没有 defaul

示例代码如下:

module latch_tow (input wire in1,input wire in2,output reg[3:0] out
);always @(*) begincase({in1, in2})2'd0: out = 4'd0001;2'd1: out = 4'd0010;2'd2: out = 4'd0100;
//    default:out = 4'd1000;endcase
endendmodule

上面代码中out变量的赋值没有覆盖到case语句的每一个分支(没有default部分),通过vivado进行语法分析后发现其原理图如下,可以看到生成了latch。
在这里插入图片描述

变量自己给自己赋值

示例代码如下:

module latch_three(input in1,input in2,output wire[3:0] out
//    output reg[3:0] out
);//在条件运算符中自己对自己赋值
assign out = (in1 != in2) ? in1 : out;在case语句中自己对自己赋值
//always @(*) begin
//    case({in1, in2})
//    2'd0: out = 4'd0001;
//    2'd1: out = 4'd0010;
//    2'd2: out = 4'd0100;
    default:out = 4'd1000;
    default: out = out;
//    endcase
//end在if语句中自己对自己赋值
//always @(*) begin
//    if({in1, in2} == 2'd0)
//        out = 4'b0001;
//    else if({in1, in2} == 2'd1)
//        out = 4'b0010;
//    else if({in1, in2} == 2'd2)
//        out = 4'b0100;
//    else
//        out = 4'b1000;
    else
        out = out;
//endendmodule

面代码中out变量在条件运算符中存在自己对自己赋值的情况,通过vivado进行语法分析后发现其原理图如下,可以看到生成了latch。
在这里插入图片描述
注意:
在if语句中自己对自己赋值和在case语句中自己对自己赋值也会产生Latch

http://www.yayakq.cn/news/963505/

相关文章:

  • 单页面网站黄骅港信息吧百度贴吧
  • 做网站傻瓜如何给客户更好的做网站分析
  • 珠海企业网站建设费用这么登入wordpress
  • 长春网站建设专业公司东莞app开发定制
  • 国际贸易英文网站北京外包推广
  • 郑州做品牌网站好的公司短视频seo公司
  • 网站用什么做关键词网站建设psd
  • 多城市地方门户网站系统wordpress文章 相册
  • 外网建筑设计网站兰州网站建设怎么选
  • dede 网站模板小程序招商
  • html网站开发企业做网站的费用如果做账
  • 美团网站是用什么做的网店代理免费一件代发
  • 渭南网站建设wifi外包公司属于什么行业
  • 高端网站模板网站建设 技术团队
  • 建站源码wordpress摘要 省略号
  • 网站的栏目和板块设计软件开发需要学什么编程语言
  • 环保类网站建设商城类网站功能
  • 对电子商务网站建设的理解鲸影视官方网站下载
  • 电影采集网站流量下载的网站模板怎么编辑
  • 网站模板 修改广州网站建设哪里买
  • 怎么查网站开发的语言手机中国第一手机门户
  • 网站设计说明书范文做英文网站常用的字体
  • 网站留言板制作济宁网站建设公司电话
  • 嘉峪关市建设局网站Wordpress 淘宝客 页面
  • 做cpa推广用哪种网站好aspnet网站开发 视频
  • 青岛设计网站的公司电子商务怎样建立网站的
  • 外贸电子商务网站牡丹江住房和城乡建设厅网站
  • 如何将一台电脑做网站空间有没有永久免费的服务器
  • 只有企业自己建立网站平台进行食品加工设备建站方案
  • 网站建设 环保素材亚马逊跨境电商开店流程及费用