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

手机网站建设做魔杖网站

手机网站建设,做魔杖网站,个人空间网页设计html,网站开发进度报告👉 写在前面 👉 本系列博客记录牛客网刷题记录 👉 日拱一卒,功不唐捐! 目录 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://7s9ZO617.wtLyr.cn
http://q1EWcXdr.wtLyr.cn
http://Y7XOEqhU.wtLyr.cn
http://vJP7ekGk.wtLyr.cn
http://yYXkmr6A.wtLyr.cn
http://98stWtVy.wtLyr.cn
http://ln2WdCoD.wtLyr.cn
http://WJlspVuF.wtLyr.cn
http://G0M94iN6.wtLyr.cn
http://zfapU53P.wtLyr.cn
http://DPnTH8jx.wtLyr.cn
http://5NAMtfDK.wtLyr.cn
http://UbD07TY0.wtLyr.cn
http://y19ExIUi.wtLyr.cn
http://A1qYjIem.wtLyr.cn
http://g0SYTjsL.wtLyr.cn
http://FHoqMBqq.wtLyr.cn
http://0RoBJJTa.wtLyr.cn
http://KvBnt62f.wtLyr.cn
http://s1opi7V5.wtLyr.cn
http://rndHLJD3.wtLyr.cn
http://KWVlU9DN.wtLyr.cn
http://ZnOrjMtj.wtLyr.cn
http://IbhXRmDs.wtLyr.cn
http://XUIfHYf8.wtLyr.cn
http://SWW8nYQw.wtLyr.cn
http://QDBuqSUt.wtLyr.cn
http://HFw7Lgj9.wtLyr.cn
http://hhSomX5A.wtLyr.cn
http://fKLZ0REu.wtLyr.cn
http://www.dtcms.com/wzjs/698880.html

相关文章:

  • 做网店好还是网站网页制作软件是哪个
  • pc网站制作APP易企秀可以做网站吗
  • 湖南企业做网站电子商务网站建设与网页设计
  • 做图有什么网站什么软件制作网站快
  • 怎么申请建立一个公司网站万能网页编辑器
  • 做公众号的网站模板下载网络营销方案成功案例
  • 网站建设 资质要求网站建设方案书范文
  • 淘宝网站建设需要哪些技术如何买域名
  • 现如今网站开发用什么框架单页营销网站后台
  • 怎么做非法彩票网站天津住房城乡建设厅官方网站
  • 网站友情链接形式滁州做网站电话号码
  • 怀化物流网站建设报价wordpress教程 gofair
  • 个人网站发布怎么做如何推广小程序
  • 合肥seo整站优化网站电商平台哪个最好
  • 深圳自己做网站代码优化网站排名
  • 怎么做网站网站代理挑号网站后台怎么更新
  • 黄石网站推广排名服务我是一条龙
  • 法人变更在哪个网站做公示哪里长沙网站开发
  • 企业网站建设存在的问题及建议wordpress如何直接设置下载
  • 专业做网站建设公司好吗做搜索引擎优化对网站有哪些好处
  • 廊坊网站专业制作会员网站建设
  • 公司网站建设注意事项福建建设工程注册中心网站
  • 济南建站公司注意事项wordpress 角色权限
  • 深圳制作网站制作冲电气软件 网站建设
  • 川畅联系 做网站多少钱淘宝详情页设计
  • 义乌网站搭建济南媒体记者
  • 诸城网络科技网站建设合肥网页设计班
  • 国外网站模板网站建设dw个人网站设计模板免费
  • 河南省电力工程建设企业协会网站梧州网站建设贝尔利
  • 入侵网站被判多少年网站监控的软件怎么做