- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第6章基于EDA的组合电路设计综合及验证(6.16.8)
第6章 基于EDA的组合电路设计、?综合及验证
学习基础:
( 第2章介绍了组合逻辑电路的基础知识,组合逻辑电路在数字系统中起着基本组件的作用。
( 第4章介绍了Verilog HDL的基本语法及简单设计的建模方法。
( ?5.5节~5.7节的综合实例,介绍了EDA工具Libero IDE的使用方法。本章所有综合和验证均基于Libero IDE环境实现。
阅读指南:
( 本章讲述内容对应第2章的知识,把相应组合逻辑电路的功能通过Verilog HDL语言进行实现。对每个电路设计的基础知识和理解请参考第2章。
( 本章多处对同一个设计提供了多种设计思路和实现方法,并不是所有都是最优的方法,只是方便对比和学习。读者可根据情况选择合适的方法。
( ?6.9节中设计了多个综合例子(第2章中没有与这些例子相对应的设计),这些例子综合性强,相对较难理解但却很实用,对于想进入数字系统设计实践阶段的读者来说很有实际意义。
5种基本的2输入门电路:与、或、异或、与非、或非。
module gates(a,b,y1,y2,y3,y4,y5);
input a,b;
output y1,y2,y3,y4,y5;
// 连续赋值语句一般用于描述组合逻辑
assign y1=ab; // 与
assign y2=a|b; // 或
assign y3=a^b; // 异或
assign y4=~(ab); // 与非
assign y5=~(a|b); // 或非
endmodule
6.1.2 基本逻辑门电路的综合
在Synplify综合工具中进行综合操作,将前述Verilog程序转化为门级电路。电路图由综合工具自动生成,点击Synplify的工具栏按钮,可查看“RTL View”。
6.1.3 测试平台设计
基本逻辑门电路测试平台的代码设计如下,针对不同阶段(综合前设计仿真、综合后仿真、布局布线后仿真)的验证,测试平台是一样的。
`timescale 1ns/1ns
module testbench ();
reg a,b;
wire y1,y2,y3,y4,y5;
gates test_gates(a,b,y1,y2,y3,y4,y5); // 调用前述的gates模块,按端口连接
initial
begin // a,b的值将按00-01-11-10的顺序产生
a=0;b=0;
#10 b=1;
#10 a=1;
#10 b=0;
#10;
end
endmodule
6.1.4 基本逻辑门电路的验证
功能验证即前述的综合前仿真,在暂时不考虑延迟等因素的情况下,通过仿真验证功能设计是否正确。
6.2 编 码 器
6.2.1 8-3编码器(一)
1.使用Verilog进行描述
8-3编码器,无优先级,带输出使能端EO(低电平有效)。
module encoder8_3_1(DataIn, EO, Dataout);
input [7:0] DataIn;
output EO;
output [2:0] Dataout;
reg [2:0] Dataout;
reg EO;
integer I;
always @ (DataIn) // 如输入发生变化,则进行编码
begin
Dataout=0; // 初始化数据,让输出为0
EO=1; // 置输出使能端EO为高电平,即无输出
for (I = 0 ; I 8 ; I = I + 1)
begin
if (DataIn [I]) // 逐位检查是否为1
begin
Dataout= I;
EO=0; // 输出结果的同时,置输出使能端EO为低电平
end
end
end
endmodule
程序逐位(从低位到高位)对输入进行检查,如果输入信号有多位为1,则以最后一个1为准,如输入信号为,则计算过程其实有2次,最终以最高位的“1”为准,输出为111。
2.测试平台设计
`timescale 1ns/10ps
module testbench_8_3encoder;
reg [7:0] in;
wire [
您可能关注的文档
最近下载
- 医院中层领导干部任期审计及离任审计实施办法.doc VIP
- 《危险化学品企业特殊作业安全规范》GB30871-2022应用问答.pdf VIP
- 中国柠檬醛项目商业计划书.docx VIP
- 社会调查教程(第七版)教学课件第10章.pptx VIP
- 合力叉车 电动仓储车维修手册.pdf
- 《建设工程施工合同(示范文本)》(GF-2017-0201).doc
- 2025年黑龙江、吉林、辽宁、内蒙古高考化学真题及答案.pdf
- 建设工程施工合同GF-2017年-0201住建部.doc VIP
- 对招投标违规违纪行为为的案例剖析97课件.pptx VIP
- 2025至2030离心机行业市场深度调研及发展趋势与投资报告.docx
文档评论(0)