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

【FGPA】Verilog:JK 触发器 | D 触发器 | T 触发器 | D 触发器的实现


0x00 JK 触发器

JK 触发器是 RS 触发器和 T 触发器的组合,有两个输入端 J 和 K,如果两个输入端都等于 1,则将当前值反转。

行为表

状态图

Timing Diagram

Circuit

JK 触发器的设计目的是防止 RS 触发器在输入 S 和 R 均等于 1 的值时被浪费,因为该值被认为是非法输入。它与 RS 触发器相同,不同之处在于如果输入值为 1,1,它不会作为非法值被接受,而是作为当前存储值的反相值被接受。

0x01 D 触发器

D 型触发器是触发器中最简单的一种。D 型触发器的名称来源于 "延迟"(Delay)一词,因为输出是输入的延迟值,直到下一个有效时钟转换为止。换句话说,D 型触发器的下一个状态是在有效时钟转换发生之前 D 的输入值。触发器有两种类型:跟踪边沿触发和前沿触发。

行为表

D

q

q*

0

0

0

0

1

0

1

0

1

1

1

1

D

q*

0

0

1

1

状态图

Timing Diagram

Circuit

0x02 D 触发器的实现

真值表:

D Flip Flop Truth Table

Input

Output

입력 순서

D

Q

~Q

1

0

0

1

2

0

0

1

3

1

1

0

4

0

0

1

5

1

1

0

6

1

1

0

💬 Design source:

`timescale 1ns / 1psmodule DFF(input clk,input D,input CLR,output Q,output Qp
);reg Q;// falling edge triggered
always @(posedge !clk) beginif(CLR) Q<=1'b0;else beginif((D==1'b0)) Q<=1'b0;else if((D==1'b1)) Q<=1'b1;end
endassign Qp = ~Q;endmodule

💬 Testbench:

`timescale 1ns / 1psmodule DFF_tb;
reg clk, D, CLR;
wire Q, Qp;DFF u_DFF(.clk(clk ),.D(D ),.CLR(CLR ),.Q(Q ),.Qp(Qp ) 
);initial clk = 1'b0;
initial CLR = 1'b1;
initial D = 1'b0;always clk = #50 ~clk;always@(CLR) beginCLR = #125 ~CLR;
endalways@(D) beginD = #375 ~D;D = #50 ~D;
endalways@(D) beginD = #575 ~D;D = #50 ~D;
endalways@(D) beginD = #675 ~D;D = #50 ~D;
endinitial begin#800$finish;
endendmodule

🚩 运行结果如下:

Schematic:

D 触发器在时钟的上升沿或下降沿将其输入端 D 的值直接传递到输出端 Q。设计了一个具有下降沿触发器的 D 触发器,并编写了代码来检查 D 的值和时钟的值,以确保当时钟的值从 1 下降到 0 时,存储在 D 中的值被存储到 Q 中。

📌 [ 笔者 ]   王亦优
📃 [ 更新 ]   2023.11.28
❌ [ 勘误 ]   /* 暂无 */
📜 [ 声明 ]   由于作者水平有限,本文有错误和不准确之处在所难免,本人也很想知道这些错误,恳望读者批评指正!

📜 参考资料 

Introduction to Logic and Computer Design, Alan Marcovitz, McGrawHill, 2008

Microsoft. MSDN(Microsoft Developer Network)[EB/OL]. []. .

百度百科[EB/OL]. []. https://baike.baidu.com/.

http://www.lryc.cn/news/247561.html

相关文章:

  • 【人工智能】人工智能的技术研究与安全问题的深入讨论
  • 苹果提醒事项怎么用?几个简单步骤就能学会!
  • <HarmonyOS第一课>从简单的页面开始 【课后考核】
  • 如何实现按需加载
  • Vue3-admin-template的表格合计计算
  • spring JdbcTemplate 快速入门
  • leetcode:用队列实现栈(后进先出)
  • 使用opencv实现更换证件照背景颜色
  • Unity打出的安卓包切换后台再恢复前台,卡顿许久问题记录
  • Linux常用命令----shutdown命令
  • 美创科技受邀亮相第二届全球数字贸易博览会
  • 有n件物品,每件物品都有一个花费,要求每m个中必须至少选2个,求最小花费
  • Hive数据库与表操作
  • C语言数据结构之顺序表(上)
  • 详解原生Spring中的控制反转和依赖注入-构造注入和Set注入
  • 数组中的第 K 个最大元素(C++实现)
  • C++ day42背包理论基础01 + 滚动数组
  • 数字人透明屏幕是如何工作的?
  • MIGO收货报替代“ZF002“, 步骤““ 中存在语法错误消息号 GB032错误
  • Vue3的transition标签以及animate.css使用详解
  • IDEA不支持Java8了怎么办?
  • flutter的TextField参数、案例整理(上)
  • 【Linux进阶之路】进程间通信
  • 深度学习框架配置
  • 全局配置
  • leetcode算法之字符串
  • mongodb查询数据库集合的基础命令
  • 基于FactoryBean、实例工厂、静态工厂创建Spring中的复杂对象
  • Android 如何让路由器或者其他AP设备获取到主机名
  • java三大集合类--List