




下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、西南科技大学实验报告课程名称:基于FPGA勺现代数字系统设计实验名称:基于HDL十进制计数、显示系统设计姓 名:学号:班 级:通信1301指导教师:刘桂华西南科技大学信息工程学院制基于HDL十进制计数、显示系统设计实验目的1 掌握基于语言的ISE 设计全流程;2 熟悉应用VerilogHDL 描述数字电路;3 掌握基于Verilog 的组合和时序逻辑电路的设计方法;4 掌握 chipscope 片内逻辑分析仪的使用与调试方法。实验原理1 实验内容 :设计具有异步复位同步使能的十进制计数器,其计数结果可以通过七段数码管发光二极管等进行显示。2 模块端口信号说明:输入信号:Clk_50m -系统采
2、样时钟clk 待计数的时钟clr 异步清零信号,当clr=0 ,输出复位为0 ,当clr=1 ,正常计数ena 使能控制信号,当ena=1 ,电路正常累加计数,否则电路不工作输出信号:q6 : 0 驱动数码管,显示计数值的个位cout 1bit 数据,显示计数值向十位的进位COM 共阳级数码管, 公共端 (接地, 参考开发板原理图3 、以自顶向下的设计思路进行模块划分:整个系统主要设计的模块是:十进制计数模块和数码管驱动模块, 由 于实验板的按 键为实现硬件防抖,则需要将按键输入的时钟 clk ,先通 过消抖模块消抖后,再输出至后续使用。1) 十进制计数器模块设计输入:CLK 待计数的时钟CL
3、R 异步清零信号,当CLR =0,输出复位为0,当CLR =1,正常计数。EN 使能控制信号,当EN=1,电路正常累加计数,否则电路不工作输出:SUM3:0 计数值的个位。即,在 CLK上升沿检测到SUM=9寸,SUM将被置0 ,开始新一轮的计数。tc 计数值的十位进位,即:只有在时钟CLK上升沿检测至U SUM=9时,TC将被置1 ,其余情况下TC=0;在设计中可以使用always, if-else-if语句实现,设计中注意不要在两个以上的always模块中对同一个变量进行赋值,否则会产生多重赋值源(multi-source )的问题。2) 数码管显示驱动模块() 输入:input43:0
4、待显示的数值 输出:out76:0 驱动数码管的七位数值(注意下表中out的对应位)输出out输入sum数码3210Aout0Bout1Cout2Dout3000000000100011001200100010300110000401001001501010100601100100701110001810000000910010000A10100001b10111100C11000110d11011000E11100110F111101113)消抖模块(1)按键抖动的产生原因:通常的按键所用开关为机械弹性开关,当机械触点断开、闭合时,由于机械触点的弹性作用,- 个按键开关在闭合时不会马上稳定地
5、接通,在断开时也不会一下子断开因而在闭合及断开的瞬间均伴随有一连串的抖动,为了不产生这种现象而作的措施就是按键消抖。( 2)本次实验提供的消抖模块简介电平检查模块:检测输入的按键是否被按下或者释放,并分别将H2L_Sig,L2H_Sig 拉高, 并随后拉低,给出按键的操作信息。延时模块:对输入的信号变化时刻进行计时并观察信号的变换情况,对输出端口进行恰 当地赋值实验资料中将给出消抖模块设计源代码。对模块的具体设计细节不需理解,消抖模块不要求仿真三、 实验步骤1、 创建工程。为工程,为工程命名、指定存储路径个文件夹。2、 计数器及数码管驱动模块设计创建VHD莫块文件,对各个模块进行设计1) 1)
6、 计 数器模块代码编写module cnt10(clk,clr,en,sum,tc);input clk,clr,en;output reg 3:0 sum;output tc;assign tc=(sum=4'b1111);always (posedge clk ,negedge clr)beginif(clr) sum<=4'b0000;else if(en) begin sum=sum+1'b1;if(sum=4b'1010)sum<=4b'0000; endelse sum<=sum;endendmodule2) 数 码管驱动模
7、块代码编写module led(input 3:0 input4,output reg 6:0 out7);always (input4)begincase(input4)4'd0:out7=7'h01;4'd1:out7=7'h4f;4'd2:out7=7'h12;4'd3:out7=7'h06;4'd4:out7=7'h46;4'd5:out7=7'h24;4'd6:out7=7'h20;4'd7:out7=7'h0f;4'd8:out7=7'h0
8、0;4'd9:out7=7'h04;default out7=7'h0;endcaseendendmodule3) cnt10 与 led 模块的组合module top_2(clk,clr,ena,tc,out7);input clk,clr,ena;output tc;output 6:0 out7;wire 3:0 sum;cnt10 cnt(clk,clr,ena,sum,tc);led led1(sum,out7);endmodule4) 综 合仿真首先对计数器和数码管驱动两个模块进行综合,无误后编写测试激励文件,进行仿真。激励文件及仿真结果如下:得到正确的仿
9、真图形后进行这两个模块组合的综合,创建激励文件,进行仿真。激励文件与仿真结果如下:3、 拷贝消抖模块代码:, , ,组合完成消抖模块。4、 将消抖模块,十进制计数器,数码管驱动模块组合为一个系统。编写代码如下:module seg_top(clk_50M,clk,clr,ena,out,cout,com);input clk_50M,clk,clr,ena;output com,cout;output 6:0 out;wire clk_out;assign com=0;debounce_module u3(clk_50M,clr,clk,clk_out);top_2 top2(clk_out,
10、 clr,ena,cout,out);endmodule然后进行顶层综合。5、 引脚锁定根据引脚锁定表,编写约束文件,如下:6、 综合报告阅读综合结果报告,记录其中关于时钟频率、资源消耗等关键数据如下:7、 顶层模块完成后,双击Implement Design ,进行布局布线,双击Generate Programming FileDevice ,按照提示完成下载生成下载文件,双击Configure Target8、 下载后,改变拨动开关和按键,观察结果。9、 使用chipscope 片内逻辑分析仪对设计进行硬件调试,验证设计是否正确。掌握该调试方法和调试步骤。4、 实验结果及分析1、 对计数器
11、时序图分析:当 clr 为低电平时(复位信号采用低电平有效), 计数器输出0000,当 clk, en (高电平有效)为高电平时,计数器开始正常计数,时钟信号每来一个上升沿,sum输出端口从0000增加到1001,进位tc变 为为1,再来一个上升沿后,tc变为0, sum又从0000开始计时。显 然时序图符合预期功能,故功能仿真正确。2、 对数码管驱动时序图分析:当输入信号从0000变化到 1001 时,输出信号对应于数码管真值表中输出的变化。显然功能仿真正确。3、 对数码管驱动与计数器的组合模块时序图分析:当输入复位信号en 为高电平 ,clr 为高电平时,每来一个时钟信号,输出 out7
12、也变化一次,且变化与数码管驱动真值表中输入从一到十变化时的输出变化一致。功能仿真真确。5、 实验思考题解答(实验指导书要求的思考题)1、 如何用两个或一个always 实现十进制计数模块?写出相应代码。module cnt10(clk,clr,en,sum,tc );input clk,clr,en;output reg 3:0 sum;output tc;assign tc=(sum=4'b1111);always (posedge clk ,negedge clr)beginif(clr) sum<=4'b0000;else if(en) begin sum=sum+
13、1'b1;if(sum=4b'1010)sum<=4b'0000; endelse sum<=sum;endendmodule2、 如何用always ,或assign实现数码管的驱动设计?写出相应代码。module led(input 3:0 input4,output reg 6:0 out7);always (input4)begincase(input4)4'd0:out7=7'h01;4'd1:out7=7'h4f;4'd2:out7=7'h12;4'd3:out7=7'h06;4
14、39;d4:out7=7'h46;4'd5:out7=7'h24;4'd6:out7=7'h20;4'd7:out7=7'h0f;4'd8:out7=7'h00;4'd9:out7=7'h04;default out7=7'h0;endcaseendendmodule3、 比较实验一与实验二的实验过程,说明原理图输入法与HDL 输入法的不同的应用环境。实验一中应用的是原理图完成十进制计数器的数显,工作量相对较大,需要绘制8 张原理图,其中还不包扩消抖模块。所以原理图设计适合相对简单的 电路,门电路较
15、少的电路。而实验二应用HDL语言描述要完成的功能,对于较复杂的电路设计起来相对简单,所以HDL语言设计比较复杂的电路。门电路很多的电路。4、 CHIPSCOP朋试和仿真有何区别?modelsim 是写好代码后,对设计的功能进行全面的仿真,检查设计中的问题,不涉及FPGA®件chipscope 是个调试阶段的调试工具,只能检查局部,部分"出问题"的地方的检验,必须涉及 FPG艇件体会1、 实验过程中对verrilog 语言有了进一步的熟悉,对 ISE 设计流程有了更深入的理解与认识。2、 Verilog 硬件描述语言和c 语言或其他编程语言有着一些相似的地方,但是也存在很大差异。在实验过程中,由
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 水泥定价协议书
- 牛奶价格协议书
- 建筑服务保洁合同
- 绿色食品供应链管理系统开发与运营合作协议
- 平安普惠借款合同
- 乡村农业现代化推广协议
- 车队承包维修合同协议
- 运输企业雇车合同协议
- 运输项目合作合同协议
- 油品设备协议书
- 五年级下册科学说课课件 -1.2 沉浮与什么因素有关 |教科版 (共28张PPT)
- 通用城实景三维数据生产项目技术设计书
- 毕业设计(论文)-N402—1300型农用拖拉机履带底盘的设计
- 多重耐药菌感染的预防与控制 课件
- 《出口报关单模板》word版
- 设计公司钉钉考勤管理办法
- 边坡护坡检验批表格模板
- 工会会计制度——会计科目和会计报表(全)
- 砌体结构教案(共34页)
- 《Monsters 怪兽》中英对照歌词
- 煤炭质量分级第2部分 硫分
评论
0/150
提交评论