简易数字跑表设计
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
西安郵電大学
数字控制系统课程设计报告书
院(系)名称:自动化学院
学生姓名:
专业名称:自动化
班级:自动1103
时间:2014年9月1日至2014年9月12日
乘法器设计
一、设计要求:
计时精度10ms,计时范围59.99秒。
(1)对单人计时,能实现暂停、显示及清零功能,在数码管上实时显示,设置启动/暂停、清零按键;
(2)对多个人同时计时,在数码管上实时显示,并能回显出六个时间。可控制显示,设置清零、取时按键;
(3)采用状态机设计;
(4)百分秒在数码管上实时显示,秒利用多个数码管显示BCD 值。
二、设计过程:
1.方案设计:
1)画状态图:
按键状态输出
复位:00 开始:S0 清零:z=0;
启/停:01 计数:S1 不清零:z=1;
存/回显:10 暂停:S2
存/回显:S3
2)写程序:
·在一个module模块里,有多个always块;
·有分频、计数、存储、输出等模块;
·测试模块的输入输出与源程序的输入输出相反;
2.系统仿真:
Verilog仿真所需仿真环境: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=2'b00,S1=2'b01,S2=2'b11;
//分频
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) 3'b000: bd<=reg0%10;
3'b001: bd<=reg1%10;
3'b010: bd<=reg2%10;
3'b011: bd<=reg3%10;
3'b100: bd<=reg4%10;
3'b101: bd<=reg5%10;
default: bd<=reg0%10;
endcase
end
else bd<=bd;
end
//毫秒高位显示结果
always @(negedge rst or posedge clk)
begin if(!rst) bg<=0;
else if(state==S1) bg<=(count2/10)%10;
else if(state==S2) begin case (count3) 3'b000:
bg<=(reg0/10)%10;
3'b001:
bg<=(reg1/10)%10;
3'b010:
bg<=(reg2/10)%10;
3'b011:
bg<=(reg3/10)%10;
3'b100:
bg<=(reg4/10)%10;
3'b101:
bg<=(reg5/10)%10;
default:
bg<=(reg0/10)%10;
endcase
end
else bg<=bg;
end
//秒位显示结果
always @(negedge rst or posedge clk)
begin if(!rst) md<=0;
else if(state==S1) md<=(count2/100)%10;
else if(state==S2)
begin
case (count3)