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

贵阳公司网站建设全球网站建设服务商

贵阳公司网站建设,全球网站建设服务商,公司官网制作,公众号推广合作平台北邮22信通一枚~ 跟随课程进度更新北邮信通院数字系统设计的笔记、代码和文章 持续关注作者 迎接数电实验学习~ 获取更多文章,请访问专栏: 北邮22级信通院数电实验_青山如墨雨如画的博客-CSDN博客 目录 一.代码部分 二.管脚分配 三.实现过程讲解及效…

北邮22信通一枚~

跟随课程进度更新北邮信通院数字系统设计的笔记、代码和文章

持续关注作者 迎接数电实验学习~

获取更多文章,请访问专栏:

北邮22级信通院数电实验_青山如墨雨如画的博客-CSDN博客

目录

一.代码部分

 二.管脚分配

三.实现过程讲解及效果


一.代码部分

shift_register.v

module shift_register
(input clk,DS,OE,MR,input wire ST_CP,output reg [7:0] out = 8'b1111_1111,output reg Q7 = 1'b1
);always @ (posedge clk)begin if(!MR)begin out = 8'b1111_1111;Q7 = 1'b1;endelse if(OE)begin out <= 8'bzzzz_zzzz;Q7 <= 1'bz;endelse if(SH_CP)begin out[0] <= !DS;out[7:1] <= out[6:0];Q7 <= out[7];endenddebounce debounce_1(.clk(clk),.rst(MR),.key(ST_CP),.key_pulse(SH_CP));endmodule

debounce.v

module debounce (clk,rst,key,key_pulse);parameter       N  =  1;         //要消除的按键的数量input             clk;input             rst;input 	[N-1:0]   key;          //输入的按键					output  [N-1:0]   key_pulse;        //按键动作产生的脉冲	reg     [N-1:0]   key_rst_pre;  //定义一个寄存器型变量存储上一个触发时的按键值reg     [N-1:0]   key_rst;      //定义一个寄存器变量储存储当前时刻触发的按键值wire    [N-1:0]   key_edge;      //检测到按键由高到低变化是产生一个高脉冲//利用非阻塞赋值特点,将两个时钟触发时按键状态存储在两个寄存器变量中always @(posedge clk  or  negedge rst)beginif (!rst) beginkey_rst <= {N{1'b1}}; //初始化时给key_rst赋值全为1,{}中表示N个1key_rst_pre <= {N{1'b1}};endelse beginkey_rst <= key;       //第一个时钟上升沿触发之后key的值赋给key_rst,//同时key_rst的值赋给key_rst_prekey_rst_pre <= key_rst;    //非阻塞赋值。//相当于经过两个时钟触发,//key_rst存储的是当前时刻key的值,//key_rst_pre存储的是前一个时钟的key的值end    endassign  key_edge = key_rst_pre & (~key_rst);//脉冲边沿检测。//当key检测到下降沿时,//key_edge产生一个时钟周期的高电平reg	[17:0]	  cnt;                       //产生延时所用的计数器,系统时钟12MHz,//要延时20ms左右时间,至少需要18位计数器     //产生20ms延时,当检测到key_edge有效是计数器清零开始计数always @(posedge clk or negedge rst)beginif(!rst)cnt <= 18'h0;else if(key_edge)cnt <= 18'h0;elsecnt <= cnt + 1'h1;end  reg     [N-1:0]   key_sec_pre;                //延时后检测电平寄存器变量reg     [N-1:0]   key_sec;                    //延时后检测key,如果按键状态变低产生一个时钟的高脉冲。如果按键状态是高的话说明按键无效always @(posedge clk  or  negedge rst)beginif (!rst) key_sec <= {N{1'b1}};                else if (cnt==18'h3ffff)key_sec <= key;  endalways @(posedge clk  or  negedge rst)beginif (!rst)key_sec_pre <= {N{1'b1}};else                   key_sec_pre <= key_sec;             end      assign  key_pulse = key_sec_pre & (~key_sec);     endmodule

 二.管脚分配

三.实现过程讲解及效果

 

http://www.yayakq.cn/news/341328/

相关文章:

  • 做养生的网站多吗新吴区推荐做网站价格
  • 做网站考什么赚钱品牌的定义
  • 江苏建设机械网站海洋优质的网站建设
  • app网站开发学习淄博网站推广公司
  • 太原自助模板建站广州网站关键词推广
  • 东莞石排网站建设网站建设服务费怎么写分录
  • 阳谷网站建设价格广州十大装修设计公司
  • 太原网站优化工具方法注册公司流程和费用注册资金
  • 林州网站建设价格网络域名后缀有哪些
  • 视频网站外链怎么做北京海淀科技有限公司
  • 上海广告传媒公司排名网站自动seo
  • 三网合一网站建设费用融资平台排行榜
  • 沧州网站建设怎么做微信版的wordpress
  • 站酷设计官方网站域名查询站长工具
  • 网站建设微信运营公司wordpress不能发邮件
  • 建材类网站模板上海有几个区最好
  • 网站做视频的软件叫什么wordpress教程下载地址
  • 合川网站建设公司如何向百度提交网站地图
  • 怎么为自己的厂做网站网站建设找睿智骄阳
  • 帮忙找人做网站鞍山做网站的公司
  • 网站搭建完手机访问怎么自己制作一个网站下载器
  • 青海学会网站建设公司杭州专业设计网站
  • 电商网站开发平台哪家好百度品牌专区怎么收费
  • 上海网站制作设计公司xuezuo网站建设
  • 安徽人防工程建设网站wordpress的虚拟主机
  • 深圳h5模板建站电商运营 网站运营
  • 手表网站推荐宁波网站建设招聘网
  • 延吉省住房和城乡建设厅网站好网
  • 百度云 网站备案wordpress重启
  • 长沙网站seo费用咸宁网站设计公司