Verilog HDL语言设计实验指导书(2004)(7)
20
会出现一些多余的状态,即一些无效的状态,需要增加default分支项,以便这些状态下能自动回到起始状态。
? 状态编码的定义可以用parameter或者`define语句。建议采用前者。尽量采用同步电路设计;
`define state0 2’b00 //不要加分号 `define state1 2’b01 …. case (state)
`state0: …; //不能少“`” ….
? 状态转换一般使用case/casex/casez描述。Case语句比if-else语句更清晰明了。此外,case
语句的最后不要忘了default分支语句以避免锁存器的产生。
2、状态机设计实例
功能是检测一个5位二进制序列“10010”。考虑到序列重叠的可能,有限状态机共提供8个状态(包括初始状态IDLE)。
模块源代码: //seqdet.v
module seqdet(x,z,clk,rst,state);
input x,clk,rst; output z; output[2:0] state; reg[2:0] state; wire z;
parameter IDLE='d0, A='d1, B='d2,C='d3, D='d4,E='d5, F='d6,G='d7;
assign z = ( state==E && x==0 )? 1 : 0; //当x=0时,状态已变为E, //状态为D时,x仍为1。因此
//输出为1的条件为( state==E && x==0 )。
always @(posedge clk)
if(!rst)
begin end
state <= IDLE;
else
casex(state)
IDLE : if(x==1)
begin
21
end
state <= A;
A: if(x==0)
begin end
state <= B;
B: if(x==0)
begin end
state <= C;
else
begin end
state <= F;
C: if(x==1)
begin end
state <= D;
else
begin end
state <= G;
D: if(x==0)
begin end
state <= E;
else
begin end
state <= A;
E: if(x==0)
begin end
state <= C;
else
begin
22
end
state <= A;
F: if(x==1)
begin end
state <= A;
else
begin end
state <= B;
G: if(x==1)
begin end
state <= F;
default:state=IDLE; //缺省状态为初始状态。
endcase
endmodule
测试模块源代码:
//------------------ seqdet.v ------------------- `timescale 1ns/1ns `include \module seqdet_Top;
reg clk,rst; reg[23:0] data; wire[2:0] state; wire z,x;
assign x=data[23]; always #10 clk = ~clk; always @(posedge clk)
data={data[22:0],data[23]};
initial
begin
clk=0; rst=1; #2 rst=0;
23
相关推荐:
- [基础教育]2016-2022年中国钢芯铝绞线市场现状调
- [基础教育]语文部编版初一语文下册练习题 句式变
- [基础教育]南京继续教育参考答案--深入学习贯彻习
- [基础教育]国旗下讲话稿——珍惜时间好读书
- [基础教育]北师大版六年级数学下册圆锥的体积教学
- [基础教育]人教版-音乐-四年级下册-四年级下册音
- [基础教育]乔布斯2019年斯坦福大学毕业典礼致辞.d
- [基础教育]2015年加油站安全知识竞赛试题及答案
- [基础教育]2020年教师年度考核个人工作总结
- [基础教育]2019年中考历史试题-2019年大庆市初中
- [基础教育]初三仁爱英语第一轮总复习教案
- [基础教育]SG-A094电气配管安装工程隐蔽验收记录
- [基础教育]冀教版小学数学三年级下册第六单元教材
- [基础教育]青岛版(五制)小学科学二年级下册16《制
- [基础教育]2018-2019年初中科学初一中考真卷测试
- [基础教育]幼儿园大班期末简短评语精选
- [基础教育]2018云南临沧公务员考试申论技巧:这样
- [基础教育]学校食堂经营管理方案
- [基础教育]新中国砥砺奋进的七十年原文
- [基础教育]真空泵的选型及常用计算公式
- 高职田径课程教学现状与对策
- 全髋关节置换术在老年股骨颈骨折患者中
- 青人社厅函〔2016〕576号(附件)工资
- cp101-07砂子检验作业指导书 - secret
- 微观经济学 第八章 博弈论 习题
- 2014高考真题(词语运用)汇编及答案
- 2018年人教版七年级语文下册《第三单元
- 苏教版数学四年级上册第一单元试题 - M
- 四川大学新闻与传播考研2000-2010年真
- 浙江万里学院英语专业四年制本科教学计
- 最新2018马年事业祝福语-范文word版(2
- 最全模具行业术语英文翻译
- 皮亚杰的发展心理学理论
- 64篇高考情景式默写 练习题及答案
- 仿写(学生稿)
- 《SQL Server数据库技术》试卷A
- 第七章作业答案
- 江苏省赣榆县海头高级中学高中语文必修
- 浙江省2001年10月自考正常人体解剖学答
- 2012英语重点短语




