ImageVerifierCode 换一换
格式:DOCX , 页数:10 ,大小:149KB ,
资源ID:1094352      下载积分:20 文钱
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,省得不是一点点
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.wenke99.com/d-1094352.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: QQ登录   微博登录 

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(用状态机实现序列检测器实验报告.docx)为本站会员(龙***)主动上传,文客久久仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知文客久久(发送邮件至hr@wenke99.com或直接QQ联系客服),我们立即给予删除!

用状态机实现序列检测器实验报告.docx

1、实验报告用状态机实现序列检测器实验1、实验目的1.用 Verilog HDL描述有限状态机电路。2.IPCORE的概念与设计。2、实验内容1.应用有限状态机的设计思路,检测从 FPGA片上 ROM读出的串行数据是否是特定的数据。2.每个人需要检测的数据是所用的电脑编号+200 后转换的 8位二进制数。3、实验要求1.拟用按键、拨动开关实现系统的时钟,复位信号的输入。2.一个 7段数码显示译码器作为检测结果的输出显示,如果串行序列为”100101”,显示 A,否则显示 b(系统需要设计一个 7段数码显示译码器模块)仍使用消抖模块,对由按键输入的时钟进行消抖处理。3.读取的串行数据为 rom中固化

2、的一个宽度为 1bit,深度为 16bits的数据。4、设计思路软件的设计框图如下,该实验可以分为几个模块,rom 数据读出模块,串行检测模块,数码管显示模块,顶层模块。输入的 clk 为按键消抖后输出的数据,按下一次检测一次,在时钟的上升沿读出数据,时钟的下降沿检测数据,串行模块输出的 4bits 的数据,直接送给数码管译码模块,译码输出。5、设计原理1.ROM IP核的生成首先在 ISE自己的工程中新建一个块内存,Block Memory Generator,配置深度为16,宽度为 1bit,选择生成的类型为单端 ROM,然后选择一个已经编写好的 memory初始化文件。Memory 初始

3、化文件,编写 coe 文件:这里我要写入的是 226,所以二进制是11100010,写入的内容如下,:memory_initialization_radix=10;memory_initialization_vector=1 1 1 0 0 0 1 1 1 0 1 0 1 0 1 0;保存并选择载入。2. 读取 rom 中的数据根据时钟上升沿读取数据,所以可以写出 rom 读的代码,代码如下:module read_rom(clk,da,rst);input clk;input rst;output da;reg3:0 counter;always(posedge clk or posedge

4、 rst) beginif(rst)counter=1b0;else counter=counter+1b1;enddata_rom u1(.clka(clk), / input clka.addra(counter), / input 3 : 0 addra.douta(da) / output 0 : 0 douta);编写仿真激励文件,得到如下波形,分析可以知道,时钟上升沿数据被读取,读取的数据与我们在配置文件中写入的相同。3. 串行检测本人的编号为 226,转换为二进制数为 11100010,根据二进制数,画出状态转移图,状态转移图如下:根据状态转移图,编写 verilog 代码,代码

5、如下:/检测:11100011module ser_read(input clk,input r_bit,input rst,output reg out_flag);reg3:0 status;always(negedge clk,posedge rst)beginif(rst=1)beginstatus=4b0;out_flag=1b0;end else begincase(status)4d0:beginif(r_bit)status=4d1;out_flag=1b0;end4d1:if(r_bit)status=4d2;elsestatus=4d0;4d2:if(r_bit)statu

6、s=4d3;else status=4d0;4d3:if(!r_bit)status=4d4;4d4:if(!r_bit)status=4d5;/11100elsestatus=4d0;4d5:if(!r_bit)status=4d6;/111000else status=4d0;/1110014d6:if(r_bit)status=4d7;/1110001else status=4d0;/11100004d7:if(r_bit)beginstatus=4d0;/11100011out_flag=1b0;end else beginstatus=4d0;/11100010out_flag=1b

7、1;endendcaseendendEndmodule编写仿真激励文件,得到如下波形,因为 rom 数据是上升沿读取,所以串行检测是在下降沿完成的,通过波形可以看出,当检测到 11100010 是,out_flag 输出为高,反之输出为低,满足要求。4. 数码管显示数码管显示代码如下:(静态数码管)module decled(ledin,ledout);input ledin;output6:0ledout;reg6:0ledout;always(ledin)begin case(ledin)1b1: ledout=7b1110111;/b1b0: ledout=7b0011111;/adef

8、ault: ledout=7b0011111;endcaseendendmodule5. 顶层设计顶层设计,按照之前的原理框图进行连接,连接完成后的代码如下:module top(clk_50m,reset,data,clk_key);input clk_50m,reset,clk_key;output 6:0data;wire Pin_Out;wire flag_out;debounce_module uut1 (.CLK(clk_50m), .RSTn(reset), .Pin_In(clk_key), .Pin_Out(Pin_Out);/消抖decled uut2 (.ledin(fl

9、ag_out), .ledout(data);/数码管显示read_rom uut3 (.clk(Pin_Out), .da(da),.rst(reset);/数据读取schk uut4 (.r_bit(da), .clk(Pin_Out), .rst(reset), .out_flag(flag_out);/检测endmodule编写仿真激励文件,得到如下波形,可以看到当,按键按下 8 次后,数码管输出 a,当数码管又按下 16 次后,数码管输出 b,满足要求。6. 引脚锁定1.选择一个拨动开关为复位信号输入。2.选择一个按键作为时钟输入。3.50MHZ 板上时钟为消抖计时时钟,引脚锁定是

10、V10。引脚锁定代码如下:NET “clk_key“ LOC = “G9“ | CLOCK_DEDICATED_ROUTE = FALSE ;NET “clk_50m“ LOC = V10;NET “reset“ LOC = D14;NET “data6“ LOC = U5;NET “data5“ LOC = V5;NET “data4“ LOC = R5;NET “data3“ LOC = T5;NET “data2“ LOC = U8;NET “data1“ LOC = V8;NET “data0“ LOC = N6;6、 思考题1、 什么是 IPCORE?本次设计中 ROM 模块是如何进

11、行设计输入的?IP(Intellectual Property)在嵌入式 FPGA 设计中,指的是某些设计好的模块,分为软件模块和硬件模块。这些模块,一般都是已经测试好,所有功能完善的,由一些用户自己设计的。有些模块是免费的,也有收费的模块。所有用户都可以将这些 IP 核(IP Core)导入到自己的工程中,同样,所有用户也都可以定制自己的 IP 核。本次设计中的rom 的输入是通过.coe 文件在配置 ip 核的使用进行指定的,编写规则按照 xilinx 官方给出的文档进行定义。2、说明状态机代码表达的是什么类型的状态机,它的优点是什么?详述其功能和对序列数检测的逻辑过程;由于状态机输出与输

12、入有关,所以该状态机为 Mealy 状态机。状态机在系统时钟的控制下,电路按照预先设定的状态运行,有良好的同步时序,较好的解决了竞争冒险和毛刺现象。状态的的结构使其在一个时钟周期内可以完成许多并行的运算和控制操作,与 Moore 有限状态机不同,Mealy 有限状态机的输出不单与当前状态有关,而且与输入信号的当前值有关,Mealy 有限状态机的输出直接受输入信号的当前值影响,而输入信号可能在一个时钟周期内任意时刻变化,这使得 Mealy 有限状态机对输入的响应发生在当前时钟周期,比 Moore 有限状态机对输入信号的响应要早一个周期。 7、 实验体会通过用状态机实现序列检测器的设计实验,初步熟

13、悉和掌握了 IPCORE 的使用。同时运用状态机实现序列检测器的设计,进一步掌握了课堂上所学到的知识,但同时充分的感觉到了自己的不足之处,今后一定要加强自己弱势方面的学习,用心学好 EDA 教科书上的知识,并抽时间在课外进行深入地学习,相信下次试验情况会有很大程度的改观。附录顶层模块激励文件如下:module test_top;/ Inputsreg clk_50m;reg reset;reg clk_key;/ Outputswire 6:0 data;/ Instantiate the Unit Under Test (UUT)top uut (.clk_50m(clk_50m), .reset(reset), .data(data), .clk_key(clk_key);initial begin/ Initialize Inputsclk_50m = 0;reset = 0;clk_key = 0;#10 reset = 1;#10 reset = 0;/ Wait 100 ns for global reset to finish#10 clk_50m = 0;clk_key = 1;forever begin#10 clk_key=clk_key;end/ Add stimulus hereendendmodule

Copyright © 2018-2021 Wenke99.com All rights reserved

工信部备案号浙ICP备20026746号-2  

公安局备案号:浙公网安备33038302330469号

本站为C2C交文档易平台,即用户上传的文档直接卖给下载用户,本站只是网络服务中间平台,所有原创文档下载所得归上传人所有,若您发现上传作品侵犯了您的权利,请立刻联系网站客服并提供证据,平台将在3个工作日内予以改正。