EDA实验九报告.docVIP

  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文档。上传文档
查看更多
EDA实验九报告

实验九 任务与函数的使用 一、实验目的 学习和掌握任务与函数的使用方法 二、实验原理 任务(task) 通常用于调试,或对硬件进行行为描述 可以包含时序控制(#延迟,@, wait) 可以有 input,output,和inout参数 可以调用其他任务或函数 函数(function) 通常用于计算,或描述组合逻辑 不能包含任何延迟;函数仿真时间为0 只含有input参数并由函数名返回一个结果 可以调用其他函数,但不能调用任务 三、实验内容 1.分别使用任务和函数描述一个4选1多路选择器。 程序设计: (1)用任务描述 module mux41a_task(a,b,c,d,s,y); input a,b,c,d; input [1:0]s; output y; reg y; task mux41a; input A,B,C,D;input [1:0]S;output Y; begin if(S==2b00) Y=A; else if(S==2b01) Y=B; else if(S==2b10) Y=C; else Y=D; end endtask always @(*)begin mux41a(a,b,c,d,s,y); end endmodule 图9-1 mux41a_task的仿真波形图 图9-2 mux41a_task的RTL图 实验分析: 该程序主要运用任务语句,task和endtask之间为任务的定义,定义之后直接调用任务语句就可以。图9-1为该程序的仿真波形图,从图中可以看出:当a,b,c,d四个输入口分别输入不同的频率信号时,针对选通控制端的s的不同值将有对应的信号输出。例如当s=00时,y口输出来自a端的时钟信号,s=11时,y口输出来自d端的时钟信号,由此可知该程序可实现预定功能。该程序的RTL图如图9-2所示。 (2)用函数描述 程序设计: module mux41a_function(a,b,c,d,s,y); input a,b,c,d; input [1:0]s; output y; function mux41a; input A,B,C,D;input [1:0]S; begin if(S==2b00) mux41a=A; else if(S==2b01) mux41a=B; else if(S==2b10) mux41a=C; else mux41a=D; end endfunction assign y=mux41a(a,b,c,d,s); endmodule 图9-3 mux41a_function的仿真波形图 图9-4 mux41a_function的RTL图 实验分析: 该程序主要运用函数语句,function和endfunction之间为函数的定义,通过将函数作为表达式中的操作数来实现函数的调用。图9-3为该程序的仿真波形图,从图中可以看出当a,b,c,d四个输入口分别输入不同的频率信号时,针对选通控制端的s的不同值将有对应的信号输出。例如当s=01时,y口输出来自b端的时钟信号,s=11时,y口输出来自d端的时钟信号,由此可知该程序可实现预定功能。该程序的RTL图如图9-4所示。 2.上网查询移位相加乘法器的设计方法,使用任务和循环语句设计一个8位移位相加的乘法器。 程序设计: module mul(a,b,y); input [7:0]a,b; output [15:0]y; reg [15:0]y; task mult; input [7:0]A,B;output [15:0]Y; reg [15:0]C,D; integer i; begin C=A;D=B; Y=D[0]?C:0; for(i=1;i=7;i=i+1)begin if(D[i]) Y=Y+(Ci);end end endtask always @(*)begin mult(a,b,y); end endmodule 图9-5 8位移位相加乘法器的仿真波形图 图9-6 8位移位相加乘法器的RTL图 实验分析: 该实验程序主要运用一个任务语句和一个循环语句实现,而且是在任务语句mult当中嵌入循环语句,运用移位相加的原理实现乘法的功能。最后在过程语句always当中调用任务语句使结果输出。该程序的仿真波形图如图9-5所示,从图中可以看出当ab,当a*b=0620H;ab,a*b=0D4DH;当ab,a*b=04

文档评论(0)

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

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

1亿VIP精品文档

相关文档