- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
. . .
..........
西安郵電大学
数字控制系统课程设计报告书
院(系)名称
:
自 动 化 学 院
学生姓名
:
专业名称
:
自动化
班 级
:
自动1103
时间
:
2014年9月1日 至2014年9月12日
乘法器设计
设计要求:
计时精度10ms,计时范围59.99秒。
对单人计时,能实现暂停、显示及清零功能,在数码管上实时显示,设置启动/暂停、清零按键;
对多个人同时计时,在数码管上实时显示,并能回显出六个时间。可控制显示,设置清零、取时按键;
采用状态机设计;
百分秒在数码管上实时显示,秒利用多个数码管显示BCD值。
二、设计过程:
1.方案设计:
1)画状态图:
按键 状态 输出
复位:00 开始:S0 清 零:z=0;
启/停:01 计数:S1 不清零:z=1;
存/回显:10 暂停:S2
存/回显:S3
写程序:
·在一个module模块里,有多个always块;
·有分频、计数、存储、输出等模块;
·测试模块的输入输出与源程序的输入输出相反;
系统仿真:
Verilog仿真所需仿真环境: \o Verilog仿真软件 modelsim \t /_blank modelsim
3.管脚配置:
1.
软件设计:
源程序
module paobiao(clk,rst,pause,save,mg,md,bg,bd);//秒高,秒低,百分秒高,百分秒低
input clk,rst,pause,save;
output reg [3:0] mg,md,bg,bd;
reg [15:0] zd,zz,zg;//中间变量
reg [17:0] count1;
reg clk1;//100ms
reg pause_temp,save_temp;//取上升沿
reg [13:0] count2,reg0,reg1,reg2,reg3,reg4,reg5;
reg [2:0] count3;//
reg [1:0] state,next_state;
reg cn1;
parameter S0=2b00,S1=2b01,S2=2b11;
//分频
always @(posedge clk or negedge rst)
begin if(!rst) count1=0;
else if(count1==200000) count1=0;//200000
else count1=count1+1;
end
always @(posedge clk )
begin if(!rst) clk1=0;
else if(count1==99999) clk1=~clk1;//99999
else clk1=clk1;
end
//总计时
always @(negedge clk1 or negedge rst)//clk1
begin if(!rst) count2=0;
else if(state==S1) count2=count2+1;
// else if(state==S2) count2=count2;
else count2=count2;
end
//存储个数计数
always @(negedge rst or negedge save)
begin if(!rst) count3=0;
else if (next_state==S1) count3=count3+1;
else if (next_state==S2) count3=count3-1;
else count3=count3;
end
//毫秒低位显示结果
always @(negedge rst or posedge clk)
begin if(!rst) bd=0;
else if(state==S1) bd=count2%10;
else if(state==S2) begin case (count3)
3b000: bd=reg0%10;
您可能关注的文档
最近下载
- 2023光伏发电工程项目质量管理规程.doc VIP
- 2023光伏逆变器高加速寿命试验技术规范.docx VIP
- NBT 32004-2013光伏发电并网逆变器技术规范.pdf VIP
- LMQ.C型立式灭菌器使用说明书.PDF VIP
- 初中数学_锐角三角函数教学课件设计.ppt VIP
- 《干旱半干旱区光伏电站生态环境保护技术导则》编制情况说明.docx VIP
- 公司章程范本完整.pdf VIP
- NBT 32001-2012 光伏发电站环境影响评价技术规范.docx VIP
- 人教版九年级数学下册第二十八章28.1《锐角三角函数--正弦》 教学设计.doc VIP
- NBT 32008-2013 光伏发电站逆变器电能质量检测技术规程.pdf VIP
文档评论(0)