当前位置:网站首页>【Verilog】HDLBits题解——验证:阅读模拟
【Verilog】HDLBits题解——验证:阅读模拟
2022-08-03 12:10:00 【wjh776a68】
Finding bugs in code
Mux
题目链接
module top_module (
input sel,
input [7:0] a,
input [7:0] b,
output [7:0] out );
assign out = ({
8{
sel}} & a) | ({
8{
~sel}} & b);
endmodule
NAND
题目链接
module top_module (input a, input b, input c, output out);//
wire out_reverse;
andgate inst1 (out_reverse, a, b, c, 1, 1);
assign out = ~out_reverse;
endmodule
Mux
题目链接
module top_module (
input [1:0] sel,
input [7:0] a,
input [7:0] b,
input [7:0] c,
input [7:0] d,
output [7:0] out ); //
wire [7:0] mux0, mux1;
mux2 mux2_0 ( sel[0], a, b, mux0 );
mux2 mux2_1 ( sel[0], c, d, mux1 );
mux2 mux2_2 ( sel[1], mux0, mux1, out );
endmodule
Add/Sub
题目链接
// synthesis verilog_input_version verilog_2001
module top_module (
input do_sub,
input [7:0] a,
input [7:0] b,
output reg [7:0] out,
output reg result_is_zero
);//
always @(*) begin
case (do_sub)
0: out = a+b;
1: out = a-b;
endcase
if (&(~out))
result_is_zero = 1;
else
result_is_zero = 0;
end
endmodule
Case Statement
题目链接
module top_module (
input [7:0] code,
output reg [3:0] out,
output reg valid=1 );//
always @(*)
case (code)
8'h45: begin out <= 0; valid <= 1; end
8'h16: begin out <= 1; valid <= 1; end
8'h1e: begin out <= 2; valid <= 1; end
8'h26: begin out <= 3; valid <= 1; end
8'h25: begin out <= 4; valid <= 1; end
8'h2e: begin out <= 5; valid <= 1; end
8'h36: begin out <= 6; valid <= 1; end
8'h3d: begin out <= 7; valid <= 1; end
8'h3e: begin out <= 8; valid <= 1; end
8'h46: begin out <= 9; valid <= 1; end
default: begin out <= 0; valid <= 0; end
endcase
endmodule
Build a circuit from a simulation waveform
Combinational circuit 1
题目链接
module top_module (
input a,
input b,
output q );//
assign q = a & b; // Fix me
endmodule
Combinational circuit 2
题目链接
module top_module (
input a,
input b,
input c,
input d,
output q );//
assign q = ~(a ^ b ^ c ^ d); // Fix me
endmodule
Combinational circuit 3
题目链接
module top_module (
input a,
input b,
input c,
input d,
output q );//
assign q = (c | d) & (a | b); // Fix me
endmodule
Combinational circuit 4
题目链接
module top_module (
input a,
input b,
input c,
input d,
output q );//
assign q = c | b; // Fix me
endmodule
Combinational circuit 5
题目链接
module top_module (
input [3:0] a,
input [3:0] b,
input [3:0] c,
input [3:0] d,
input [3:0] e,
output [3:0] q );
reg [3:0] q_reg;
assign q = q_reg;
always @ (*) begin
case(c)
0: q_reg = b;
1: q_reg = e;
2: q_reg = a;
3: q_reg = d;
default: q_reg = 'hf;
endcase
end
endmodule
Combinational circuit 6
题目链接
module top_module (
input [2:0] a,
output [15:0] q );
reg [15:0] q_reg;
assign q = q_reg;
always @ (*) begin
case(a)
0: q_reg = 'h1232;
1: q_reg = 'haee0;
2: q_reg = 'h27d4;
3: q_reg = 'h5a0e;
4: q_reg = 'h2066;
5: q_reg = 'h64ce;
6: q_reg = 'hc526;
7: q_reg = 'h2f19;
endcase
end
endmodule
Sequential circuit 7
题目链接
module top_module (
input clk,
input a,
output q );
always @ (posedge clk) begin
q <= ~a;
end
endmodule
Sequential circuit 8
题目链接
module top_module (
input clock,
input a,
output p,
output q );
reg q_reg = 0;
reg p_reg = 0;
assign p = p_reg;
assign q = q_reg;
always @ (*) begin
if(clock)
p_reg <= a;
end
always @ (negedge clock) begin
q_reg <= a;
end
endmodule
Sequential circuit 9
题目链接
module top_module (
input clk,
input a,
output [3:0] q );
reg [3:0] q_reg;
assign q = q_reg;
always @ (posedge clk) begin
if (a) begin
q_reg <= 4;
end
else begin
q_reg <= (q_reg + 1) % 7;
end
end
endmodule
Sequential circuit 10
题目链接
module top_module (
input clk,
input a,
input b,
output q,
output state );
reg state_reg;
assign state = state_reg;
assign q = a ^ b ^ state;
always @ (posedge clk) begin
state_reg <= (a & b) | (a & state_reg) | (b & state_reg);
end
endmodule
边栏推荐
- fastposter v2.9.0 programmer must-have poster generator
- LeetCode-1161. 最大层内元素和
- LyScript implements memory stack scanning
- Blazor Server(6) from scratch--policy-based permission verification
- 零拷贝、MMAP、堆外内存,傻傻搞不明白...
- 【Verilog】HDLBits题解——Verification: Writing Testbenches
- 微信为什么使用 SQLite 保存聊天记录?
- ThreadLocal源码解析及使用场景
- RTP协议分析
- 学习软件测试需要掌握哪些知识点呢?
猜你喜欢
随机推荐
Take you understand the principle of CDN technology
mysql advanced (twenty-four) method summary of defense against SQL injection
bash while loop and until loop
【Mysql】清理binlog日志的方法
数据库系统原理与应用教程(073)—— MySQL 练习题:操作题 131-140(十七):综合练习
如图,想批量读取mysql,批量处理,有哪个地方参数需要改变呢?
苹果发布 AI 生成模型 GAUDI,文字生成 3D 场景
【Verilog】HDLBits题解——Verification: Writing Testbenches
bash for loop
常用lambda表达式
QGIS绘制演习区域示意图
零拷贝、MMAP、堆外内存,傻傻搞不明白...
TiKV & TiFlash 加速复杂业务查询丨TiFlash 应用实践
mysql进阶(二十四)防御SQL注入的方法总结
【Verilog】HDLBits题解——Circuits/Sequential Logic/Latches and Flip-Flops
深度学习中数据到底要不要归一化?实测数据来说明!
Simple implementation of a high-performance clone of Redis using .NET (1)
net start mysql 启动报错:发生系统错误5。拒绝访问。
随机森林项目实战---气温预测
-找树根2-









