求VHDL高手:设计含有异步清零和技术功能的16位二进制加减可控计数器

设计含有异步清零和技术功能的16位二进制加减可控计数器... 设计含有异步清零和技术功能的16位二进制加减可控计数器 展开
 我来答
xinyijialong
2010-10-12 · TA获得超过122个赞
知道答主
回答量:103
采纳率:0%
帮助的人:88.9万
展开全部

代码如下。clr为1异步清零。k为1时执行加法计数器,为0时执行减法计数器。仿真图形也给上。不过楼主自己还应该好好学习啊。

library IEEE;use IEEE.std_logic_1164.all;

use IEEE.std_logic_unsigned.all;

entity cnt_16 is

    port (

        clk: in STD_LOGIC;

        k: in STD_LOGIC;

        clr: in STD_LOGIC;

        q: out STD_LOGIC_VECTOR (15 downto 0)

    );

end cnt_16;

architecture cnt_16_arch of cnt_16 is

signal qq:std_logic_vector(15 downto 0);

begin

process(clk,clr,k)

begin

 if clr='1' then

  qq<="0000000000000000";

 elsif clk'event and clk='1' then

  if k='1' then

     qq<=qq+'1';

  else

     qq<=qq-'1';

   end if;

 end if;

end process;

process(qq)

begin

 q<=qq;

end process;

end cnt_16_arch;

推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式