本文主要是介绍异步复位的串联T触发器,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
描述
题目描述:
用verilog实现两个串联的异步复位的T触发器的逻辑,结构如图:
信号示意图:
波形示意图:
输入描述:
输入信号 data, clk, rst
类型 wire
在testbench中,clk为周期5ns的时钟,rst为低电平复位
输出描述:
输出信号 q
类型 reg
解题分析:
·T触发器是进入的值为1的时候,寄存的值发生翻转;
·注意异步复位
·需要注意寄存器翻转的逻辑,第二寄存器是否翻转取决于第一个寄存器是否为1,前者输出情况有三种:在data输入控制为1下从0到1到0不断翻转,data为0锁在1,data为0锁在0
T触发器的特性方程
Qn+1 = T Qn ' +T ' Qn = T⊕Qn
(其中Qn为现态,Qn+1为次态)
T触发器的特性表
T触发器的结构为:
代码如下:
`timescale 1ns/1ns
module Tff_2 (
input wire data, clk, rst,
output reg q
);
//*************code***********//
reg q1;
always @(posedge clk or negedge rst)beginif(!rst)q1 <= 0;elsebeginif(data)q1 <= ~q1;elseq1 <= q1;endendalways @(posedge clk or negedge rst)beginif(!rst)q <= 0;elsebeginif(q1)q <= ~q;elseq <= q;endend
//*************code***********//
endmodule
波形图如图所示:
这篇关于异步复位的串联T触发器的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!