- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
数字跑表的设计与仿真
EDA设计与应用课程设计: 数字跑表的设计与仿真
学院:机械与电子工程学院
专业:电子科学与技术
班级:1221402
学号:201220140223
姓名:杨卡
2014年11月
一、实验目的:
1) 进一步学习更复杂的EDA项目设计,更熟练地掌握VHDL语言设计。
2) 学习动态数码管的VHDL编程。
3) 更加熟练计时显示、进位和校时的编程方法。
二、实验要求:
1)设计一个具有、‘分’、‘秒’、‘1/100秒’的十进制数字显示的数字跑表。
2)要有外部开关,控制计数器的直接清零、启动和暂停/连续计时功能。
三、实验内容:
1)数字跑表功能:计时精度10ms,计时范围为59分59.99秒。设置两种模式,模式一:对单个人计数,能实现暂停、显示及清零功能,并在数码管上实时显示;模式2:实现对多个人的同时计时,在数码管上实时显示,并能在液晶显示屏上回显出6个时间,可控制显示。
2)数字跑表分模块设计:数字跑表设置如下的子模块。分频模块;模式1控制模块;模式2控制模块;计时模块;数码管译码模块;液晶译码模块;液晶显示模块。百分秒、秒和分等信号即采用BCD译码计数方式,根据上述设计要求,用Verilog对数字跑表的描述如下。仍然采用引脚属性定义语句进行引脚的锁定。
四、设计程序(此处只写出与课本中不同的部分)
为了便于显示,百分秒、秒和分钟信号皆采用BCD码计数方式,并直接输出到6个数码管显示出来。根据上述设计要求,用Verilog HDL语言对数字跑表描述如下。
/*信号定义:
CLK: 时钟信号;
CLR: 异步复位信号;
PAUSE: 暂停信号;
MSH,MSL: 百分秒的高位和低位;
SH,SL: 秒的高位和低位;
MH,ML: 分钟的高位和低位。 */
module paobiao(CLK,CLR,PAUSE,MSH,MSL,SH,SL,MH,ML);
input CLK,CLR,PAUSE; output[3:0] MSH,MSL,SH,SL,MH,ML;
reg[3:0] MSH,MSL,SH,SL,MH,ML;
reg cn1,cn2; //cn1为百分秒向秒进位,cn2为秒向分进位
//****************百分秒计数进程,每计满100,cn1产生一个进位*******
always @(posedge CLK or posedge CLR)
begin if(CLR) begin {MSH,MSL}=8h00; cn1=0;end //异步复位
else if(!PAUSE) //PAUSE为0时正常计数,为1时暂停计数
begin
if (MSL==9) begin MSL=0;
if (MSH==9) begin MSH=0;cn1=1;end
else MSH=MSH+1;end
else begin MSL=MSL+1;cn1=0;end
end
end
//******************秒计数进程,每计满60,cn2产生一个进位*********
always @(posedge cn1 or posedge CLR)
begin if(CLR) begin {SH,SL}=8h00;cn2=0; end //异步复位
else if(SL==9) begin SL=0;
if (SH==5) begin SH=0;cn2=1; end
else SH=SH+1;end
else begin SL=SL+1;cn2=0;end
end
//******************分钟计数进程,每计满60,系统自动清零*********
always @(posedge cn2 or posedge CLR)
begin if(CLR) begin {MH,ML}=8h00;end //异步复位
else if (ML==9) begin ML=0;
原创力文档


文档评论(0)