fpga设计心得体会.docxVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
fpga设计心得体会

fpga设计心得体会   篇一:fpga设计的几个实例   Verilog HDL设计 练习一.简单的组合逻辑设计   练习一.简单的组合逻辑设计   目的: 掌握基本组合逻辑电路的实现方法。   这是一个可综合的数据比较器,很容易看出它的功能是比较数据a与数据b,如果两个数据相同,则给出结果1,否则给出结果0。在Verilog HDL中,描述组合逻辑时常使用assign结构。注意equal=(a==b)?1:0,这是一种在组合逻辑实现分支判断时常使用的格式。 模块源代码:   //--------------- -----------------   module compare(equal,a,b);   input a,b;   output equal;   assign equal=(a==b)?1:0; //a等于b时,equal输出为1;a不等于b时, //equal输出为0。   endmodule   测试模块用于检测模块设计得正确与否,它给出模块的输入信号,观察模块的内部信号和输出信号,如果发现结果与预期的有所偏差,则要对设计模块进行修改。   测试模块源代码:   `timescale 1ns/1ns//定义时间单位。   `include ./ //包含模块文件。在有的仿真调试环境中并不需要此语句。 //而需要从调试环境的菜单中键入有关模块文件的路径和名称 module comparetest;   reg a,b;//在测试文件中需要进行赋值的变量要定义成ren型,一般为inputwire equal;//在测试文件中只要进行连接定义成wire型,一般为output   initial //initial常用于仿真时信号的给出。   begin //initial语句就是给出在什么时间给定什么样的值   a=0;   b=0;   #100 a=0; b=1;   #100 a=1; b=1;   #100 a=1; b=0;   #100 $stop;//系统任务,暂停仿真以便观察仿真波形。   end   compare//模块名// compare1(.equal(equal),.a(a),.b(b)); //调用模块。 //括号内的为测试文件的信号,而.a等为模块要连接的信号   endmodule   仿真波形(部分):   练习:   设计一个字节(8位)比较器。   要求:比较两个字节的大小,如a[7:0]大于 b[7:0]输出高电平,否则输出低电平,改写测试模型,使其能进行比较全面的测试。   练习二. 简单时序逻辑电路的设计   目的:掌握基本时序逻辑电路的实现。   在Verilog HDL中,相对于组合逻辑电路,时序逻辑电路也有规定的表述方式。在可综合的Verilog HDL模型,我们通常使用always块和 @(posedge clk)或 @(negedge clk)的结构来表述时序逻辑。下面是一个1/2分频器的可综合模型。   // half_:   module half_clk(reset,clk_in,clk_out);   input clk_in,reset;   output clk_out;   reg clk_out;   always @(posedge clk_in)   begin   if(!reset) clk_out=0;   elseclk_out=~clk_out;   end   endmodule   在always块中,被赋值的信号都必须定义为reg型,这是由时序逻辑电路的特点所决定的。对于reg型数据,如果未对它进行赋值,仿真工具会认为它是不定态。为了能正确地观察到仿真结果,在可综合风格的模块中我们通常定义一个复位信号reset,当reset为低电平时,对电路中的寄存器进行复位。   测试模块的源代码:   //------------------- clk_ -----------------------------   `timescale 1ns/100ps   `define clk_cycle 50   module clk_   reg clk,reset;   wire clk_out;   always #`clk_cycle clk = ~clk;   initial   begin   clk = 0;   reset = 1;   #100 r

文档评论(0)

mmrs369 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档