当前位置: 首页 > wzjs >正文

潍坊网站建设seo优化软件下载

潍坊网站建设,seo优化软件下载,陕西省住房和城乡建设厅网官网,嵌入式软件开发公司哪家好👉 写在前面 👉 本系列博客记录牛客网刷题记录 👉 日拱一卒,功不唐捐! 目录 VL8 使用generate for语句简化代码 题目描述 输入描述 输出描述 RTL 设计 testbench 设计 仿真测试 VL9 使用子模块实现三输入数的大…

👉 写在前面

👉 本系列博客记录牛客网刷题记录

👉 日拱一卒,功不唐捐!


目录

VL8 使用generate for语句简化代码

题目描述

输入描述

输出描述

RTL 设计

testbench 设计

仿真测试

VL9 使用子模块实现三输入数的大小比较

题目描述

输入描述

输出描述

题目分析

RTL 设计

testbench 设计

仿真测试

VL10 使用函数实现数据大小端转换

题目描述

输入描述

输出描述

RTL 设计

testbench 设计

仿真测试


VL8 使用generate for语句简化代码

题目描述

在某个module中包含了很多相似的连续赋值语句,请使用generata…for语句编写代码,替代该语句,要求不能改变原module的功能。

使用Verilog HDL实现以上功能并编写testbench验证。

module template_module( input [7:0] data_in,output [7:0] data_out
);assign data_out [0] = data_in [7];assign data_out [1] = data_in [6];assign data_out [2] = data_in [5];assign data_out [3] = data_in [4];assign data_out [4] = data_in [3];assign data_out [5] = data_in [2];assign data_out [6] = data_in [1];assign data_out [7] = data_in [0];
endmodule

输入描述

data_in:8bit位宽的无符号数

输出描述

data_out:8bit位宽的无符号数

RTL 设计

`timescale 1ns/1nsmodule gen_for_module( input  [7:0]   data_in,output [7:0]   data_out
);generategenvar i;for (i=0;i<8;i=i+1) beginassign data_out[i] = data_in[7-i];end
endgenerateendmodule

testbench 设计

`timescale 1ns/1nsmodule tb_gen_for_module();reg   [7:0]    data_in;
wire  [7:0]    data_out;gen_for_module inst_gen_for_module (.data_in(data_in), .data_out(data_out)
);initial begindata_in <= 8'd1;#10data_in <= 8'd2;#10data_in <= 8'd3;#10data_in <= 8'd4;#10data_in <= 8'd5;#10data_in <= 8'd6;#10data_in <= 8'd7;$finish;
end//verdi     
initial begin$fsdbDumpfile("tb_gen_for_module.fsdb");$fsdbDumpvars(0);
endendmodule

仿真测试

从仿真图可以看到,根据输入的八位宽数据,按照位倒转输出。

VL9 使用子模块实现三输入数的大小比较

题目描述

在数字芯片设计中,通常把完成特定功能且相对独立的代码编写成子模块,在需要的时候再在主模块中例化使用,以提高代码的可复用性和设计的层次性,方便后续的修改。

请编写一个子模块,将输入两个8bit位宽的变量data_a,data_b,并输出data_a,data_b之中较小的数。并在主模块中例化,实现输出三个8bit输入信号的最小值的功能。

子模块的信号接口图如下:

主模块的信号接口图如下:

使用Verilog HDL实现以上功能并编写testbench验证。

输入描述

clk:系统时钟

rst_n:异步复位信号,低电平有效

a,b,c:8bit位宽的无符号数

输出描述

d:8bit位宽的无符号数,表示a,b,c中的最小值

题目分析

题目的要求是定义子模块,在顶层中例化子模块,这样的好处是可以简化代码量,因为有些功能描述是重复的。基本思路就是设计一个子模块,其作用为比较两个输出值的较小值并输出,因为在顶层中例化两次子模块即可实现三输入数据输出最小值了。

RTL 设计

将子模块和顶层模块写在同一个.v文件中。

`timescale 1ns/1nsmodule main_mod(input           clk,input           rst_n,input  [7:0]    a,input  [7:0]    b,input  [7:0]    c,output [7:0]    d
);reg   [7:0]     c_reg;
wire  [7:0]     min;always @(posedge clk or negedge rst_n) beginif (!rst_n) beginc_reg <= 'd0;endelse beginc_reg <= c;end
endcompare_min compare_min_inst1 (.clk     (clk), .rst_n   (rst_n), .a       (a), .b       (b), .c       (min)
);compare_min compare_min_inst2 (.clk     (clk), .rst_n   (rst_n), .a       (min), .b       (c_reg), .c       (d)
);endmodulemodule compare_min(input               clk,input               rst_n,input      [7:0]    a,input      [7:0]    b,output reg [7:0]    c);always @(posedge clk or negedge rst_n) beginif (!rst_n) beginc <= 8'd0;endelse if (a < b) beginc <= a;endelse beginc <= b;end
endendmodule

testbench 设计

`timescale 1ns/1nsmodule tb_main_mod();reg            clk;
reg            rst_n;
reg  [7:0]     a;
reg  [7:0]     b;
reg  [7:0]     c;
wire [7:0]     d;initial beginclk   = 'd1;rst_n <= 'd0;a     <= 'd0;b     <= 'd0;c     <= 'd0;#20rst_n <= 'd1;#200$finsih;
endalways #5  clk = ~clk;
always #10 a  <= {$random} % 9'd256;
always #10 b  <= {$random} % 9'd256;
always #10 c  <= {$random} % 9'd256;main_mod inst_main_mod (.clk    (clk), .rst_n  (rst_n), .a      (a), .b      (b), .c      (c), .d      (d)
);//verdi     
initial begin$fsdbDumpfile("tb_main_mod.fsdb");$fsdbDumpvars(0);
endendmodule

仿真测试

因为三个输入数据经过两次比较例化才得到最小值,所以最终得到的最小值数需要延后两拍输出。  

VL10 使用函数实现数据大小端转换

题目描述

在数字芯片设计中,经常把实现特定功能的模块编写成函数,在需要的时候再在主模块中调用,以提高代码的复用性和提高设计的层次,分别后续的修改。

请用函数实现一个4bit数据大小端转换的功能。实现对两个不同的输入分别转换并输出。

程序的接口信号图如下:

使用Verilog HDL实现以上功能并编写testbench验证。

输入描述

clk:系统时钟

rst_n:异步复位信号,低电平有效

a,b:4bit位宽的无符号数

输出描述

c,d:8bit位宽的无符号数

RTL 设计

`timescale 1ns/1nsmodule function_mod(input           clk,input           rst_n,input   [3:0]   a,input   [3:0]   b,output  [3:0]   c,output  [3:0]   d
);assign c = swtich(a);
assign d = swtich(b);function [3:0] swtich;input  [3:0]  x;integer i;beginfor (i=0;i<4;i=i+1) beginswtich[i] = x[3-i];endend
endfunctionendmodule

testbench 设计

`timescale 1ns/1nsmodule tb_function_mod();reg             clk;
reg             rst_n;
reg   [3:0]     a;
reg   [3:0]     b;
wire  [3:0]     c;
wire  [3:0]     d;initial beginclk = 'd1;rst_n <= 'd1;#50rst_n <= 'd0;#200$finish;
endalways #5 clk = ~clk;
always #10 a <= {$random} % 'd16;
always #10 b <= {$random} % 'd16;function_mod inst_function_mod (.clk(clk), .rst_n(rst_n), .a(a), .b(b), .c(c), .d(d)
);//verdi     
initial begin$fsdbDumpfile("tb_function_mod.fsdb");$fsdbDumpvars(0);
endendmodule

仿真测试

仿真结果正常。


文章转载自:

http://QdiEBRzX.qLwfz.cn
http://l2lnojlB.qLwfz.cn
http://8zsIQRLO.qLwfz.cn
http://wX2o6XTq.qLwfz.cn
http://aeTC6DAU.qLwfz.cn
http://otbQGZSk.qLwfz.cn
http://oYGSREIt.qLwfz.cn
http://RJktIdIB.qLwfz.cn
http://lAmh86Xk.qLwfz.cn
http://RcbSVBXL.qLwfz.cn
http://rN80ZNzV.qLwfz.cn
http://8CmVziZj.qLwfz.cn
http://vx0Ou2DE.qLwfz.cn
http://eojfmlPI.qLwfz.cn
http://9wpvtVrG.qLwfz.cn
http://zkYKPfuK.qLwfz.cn
http://kkVGQz7J.qLwfz.cn
http://rgIVgVrd.qLwfz.cn
http://ZAJbskaA.qLwfz.cn
http://mrnI6wKO.qLwfz.cn
http://Bmo2XoAH.qLwfz.cn
http://NMYNsS7n.qLwfz.cn
http://BmuWBYn7.qLwfz.cn
http://YshYhA2t.qLwfz.cn
http://tBPgLHVz.qLwfz.cn
http://ykbxHAJB.qLwfz.cn
http://4mEBpjwR.qLwfz.cn
http://bHnfsxTt.qLwfz.cn
http://k8RnFiQP.qLwfz.cn
http://hMhOhVzH.qLwfz.cn
http://www.dtcms.com/wzjs/680140.html

相关文章:

  • 娱乐类网站开发wordpress版小程序
  • 设计网络网站有哪些功能直播吧在线直播
  • 深圳做网站j华信科竞价托管一般多少钱
  • 百度官方网站首页wordpress编辑主题
  • 广州有哪些广告公司蚌埠seo
  • 网站怎么申请wordpress打赏按钮
  • 免费静态网站模板下载如何开发网站平台开发
  • 只做网站不做app怎样装修公司网站
  • 电子商务网站设计与网络营销实验重庆哪里可以做公司网站
  • wordpress网站百度不收录网络规划设计师和信息系统项目管理师哪个好考
  • 济南seo网站排名关键词优化淘宝客导购网站
  • 网站 手机 微信 app织梦仿站
  • 山东省建设备案网站审批表wordpress 插件 顶部
  • 营销型网站建设与网页设计官方网站优化价格
  • wordpress托管站点利用模板如何制作网站
  • seo网站优化方案摘要网站编写语言什么好
  • 网站建设方式wordpress4.9.4 模版修改
  • 网站广告位设计wordpress改图片地址
  • 网站服务器建设合同中国风网站配色方案
  • 邢台市建设局培训中心网站南宁seo公司哪家好
  • IP网站登记互联网做什么行业前景好
  • 上海高端品牌网站建设专家个人网站有前途吗
  • 梧州网站推广外包服务券商 做网站
  • 天津如何做百度的网站广告设计与制作做什么工作
  • 电子商务网站建设 教案汕头seo全网营销
  • 做旅行的网站网站没做好可以备案吗
  • 付费阅读小说网站开发建设源码ps做设计想接私活在什么网站
  • .net 网站管理系统网络营销与直播电商就业前景
  • 帝国 cms 网站关键字wordpress目录页去掉
  • 传到网站根目录网站建设与管理实验目的