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

海西州公司网站建设/青岛疫情最新情况

海西州公司网站建设,青岛疫情最新情况,个人网站可以做百度竞价,dm建站系统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.rdtb.cn/news/528.html

相关文章:

  • 360的网站排名怎么做/seo网络推广招聘
  • 网站建设技术经费预算/上海何鹏seo
  • b2c的运营模式是什么/seo人工智能
  • 安阳网站建设方案/中企动力做网站推广靠谱吗
  • 网站怎么做飘窗/百度推荐现在为什么不能用了
  • 网站建设了/短链接生成器
  • 网站中的滚动字幕怎么做/sem是什么电镜
  • 一个公司做网站需要注意什么/长沙seo
  • 河南建网站 优帮云/网站开发详细流程
  • 网站建设 知识库/百度提交入口网站
  • 手机免费注册网站/微信软文是什么意思
  • 襄阳营销型网站/网络营销型网站
  • wap的网站模板下载/seo快速排名关键词
  • 开发网站做什么/seo的英文全称是什么
  • 禹城建设局网站/公司怎么在网上推广
  • 微信网站价格/盘多多百度网盘搜索引擎
  • 电子商务毕设做网站/石家庄百度快照优化排名
  • 深圳代做网站后台/成人短期就业培训班
  • 网站开发图标下载/百度做网站推广的费用
  • 个人网站做淘宝客违规/环球资源外贸平台免费
  • 携程旅行的网站建设/网址解析ip地址
  • 企业展示网站如何建/建站公司哪家好
  • 越南做企业网站/写软文的app
  • 做美女图片网站需要备案吗/什么软件可以优化关键词
  • 学校网站建设源代码/网站推广途径和要点
  • 吕梁网站制作/应用商店下载安装
  • 做网站 淘宝/深圳最新消息
  • 集团网站目标/广州网站到首页排名
  • 湖北省建设用地预审网站/自己的网站怎么推广
  • 微信做模板下载网站/无锡seo公司