使用74ls161的clr和ld循环计数有什么区别
答案:2 悬赏:0 手机版
解决时间 2021-03-12 12:33
- 提问者网友:相思似海深
- 2021-03-12 03:32
使用74ls161的clr和ld循环计数有什么区别
最佳答案
- 五星知识达人网友:duile
- 2021-03-12 05:04
74LS161为异步清零,同步置数。这是个十进制计数器,你画状态图为0000-0001-0010-0011-0100-0101-0110-0111-1000-1001-1010-1011-1100-1101-1110-1111一共十六个状态,如果用反馈置数法,选取其中任意连续的10个状态,比如从0000-1001,那么就是指最高状态是1001,之后就得回到0000这个状态,你设置初始状态D3D2D1D0为0000,输出端Q3Q2Q1Q0把Q3和Q3用双输入与非门连接,输出到置数端,这样,当计数到1001时,输出为0到置数端,在下一个时钟脉冲到来时计数器将被置数到0000状态,开始一个新的循环。
如果用反馈清零法,输入D3D2D1D0的状态随意,不用管,因为是异步清零,当清零信号使能时,不论时钟脉冲沿是否到来都将对电路进行清零,故应选取从0000开始的11个状态,为1010,所以,电路的连接方式为将输出Q3Q2Q1Q0的Q3和Q1用而输入与非门连接,与非门输出连接到异步清零端(低电平使能),这样,电路的状态为0000-1001-1010,当到达1010时电路会马上清零,因此这个状态相当于不存在,电路将在前面是个状态中循环,这就是反馈清零的电路。
如果用反馈清零法,输入D3D2D1D0的状态随意,不用管,因为是异步清零,当清零信号使能时,不论时钟脉冲沿是否到来都将对电路进行清零,故应选取从0000开始的11个状态,为1010,所以,电路的连接方式为将输出Q3Q2Q1Q0的Q3和Q1用而输入与非门连接,与非门输出连接到异步清零端(低电平使能),这样,电路的状态为0000-1001-1010,当到达1010时电路会马上清零,因此这个状态相当于不存在,电路将在前面是个状态中循环,这就是反馈清零的电路。
全部回答
- 1楼网友:不如潦草
- 2021-03-12 05:36
Library IEEE ;
use IEEE.std_logic_1164.all ;
use IEEE.std_logic_arith.all ;
use IEEE.std_logic_unsigned.all;
ENTITY cnt6 IS
PORT(
d : IN std_logic_vector(3 downto 0);
clk : IN std_logic;
clr : IN std_logic;
en : IN std_logic;
ld : IN std_logic;
q : OUT std_logic_vector(3 downto 0)
);
END cnt6;
ARCHITECTURE cnt6_rtl OF cnt6 IS
SIGNAL cnt : std_logic_vector(3 downto 0);
BEGIN
-- counter
PROCESS (clk, clr)
BEGIN
IF (clr = '1') THEN
cnt <= "0000"; --异步复位
ELSIF (clk'EVENT AND clk = '1') THEN
IF (ld = '1') THEN
cnt <= d; --预置数值
ELSE
IF (en = '1') THEN --同步使能
IF (cnt = "0000") THEN
cnt <= "0101"; --减到0时,继续减则变为5
ELSE
cnt <= cnt - 1; --减法
END IF;
END IF;
END IF;
END IF;
END PROCESS;
q <= cnt;
END cnt6_rtl;
use IEEE.std_logic_1164.all ;
use IEEE.std_logic_arith.all ;
use IEEE.std_logic_unsigned.all;
ENTITY cnt6 IS
PORT(
d : IN std_logic_vector(3 downto 0);
clk : IN std_logic;
clr : IN std_logic;
en : IN std_logic;
ld : IN std_logic;
q : OUT std_logic_vector(3 downto 0)
);
END cnt6;
ARCHITECTURE cnt6_rtl OF cnt6 IS
SIGNAL cnt : std_logic_vector(3 downto 0);
BEGIN
-- counter
PROCESS (clk, clr)
BEGIN
IF (clr = '1') THEN
cnt <= "0000"; --异步复位
ELSIF (clk'EVENT AND clk = '1') THEN
IF (ld = '1') THEN
cnt <= d; --预置数值
ELSE
IF (en = '1') THEN --同步使能
IF (cnt = "0000") THEN
cnt <= "0101"; --减到0时,继续减则变为5
ELSE
cnt <= cnt - 1; --减法
END IF;
END IF;
END IF;
END IF;
END PROCESS;
q <= cnt;
END cnt6_rtl;
我要举报
如以上回答内容为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
点此我要举报以上问答信息
大家都在看
推荐资讯