FPGA学习笔记1.1——10人表决器

举报
nimo的小舔狗 发表于 2022/05/11 00:07:29 2022/05/11
【摘要】 设计思路: 十人裁决器,当多于5人,输出为10,等于5人则为00,小于5人则为01;同时可以用sum统计十人的1的数目,进行判定。 原理图: 功能模块代码: module decision_circuit_10(a,out); input[9:0] a; output out; reg[1:...

设计思路:

十人裁决器,当多于5人,输出为10,等于5人则为00,小于5人则为01;同时可以用sum统计十人的1的数目,进行判定。

原理图:

功能模块代码:

module decision_circuit_10(a,out);
input[9:0] a;
output out;
reg[1:0] out;
reg[3:0] sum;
always@(a,sum,out)
begin
sum=a[0]+a[1]+a[2]+a[3]+a[4]+a[5]+a[6]+a[7]+a[8]+a[9];
if(sum>5) out=2'b10;
else if(sum<5) out=2'b01;
else out=2'b00;
end
endmodule

测试代码:

`timescale 1 ps/ 1 ps
module decision_circuit_10_vlg_tst();
reg [9:0] a;                                             
wire[1:0] out;
decision_circuit_10 i1 (  
.a(a),
.out(out)
);
initial                                                
begin
$display("Running testbench"); 
#0 a[0] = 1; a[1] = 1; a[2] = 1; a[3] = 1; a[4] = 1; a[5] = 1; a[6] = 1;a[7]=1;a[8]=1;a[9]=1;
#1 $display("input:%b -- out:%b", a, out);
#0 a[0] = 1; a[1] = 1; a[2] = 1; a[3] = 1; a[4] = 1; a[5] = 1; a[6] = 1;a[7]=1;a[8]=1;a[9]=0;
#1 $display("input:%b -- out:%b", a, out);
#0 a[0] = 1; a[1] = 1; a[2] = 1; a[3] = 1; a[4] = 1; a[5] = 1; a[6] = 1;a[7]=1;a[8]=0;a[9]=0;
#1 $display("input:%b -- out:%b", a, out);
#0 a[0] = 1; a[1] = 1; a[2] = 1; a[3] = 1; a[4] = 1; a[5] = 1; a[6] = 1;a[7]=0;a[8]=0;a[9]=0;
#1 $display("input:%b -- out:%b", a, out);
#0 a[0] = 1; a[1] = 1; a[2] = 1; a[3] = 1; a[4] = 1; a[5] = 1; a[6] = 0;a[7]=0;a[8]=0;a[9]=0;
#1 $display("input:%b -- out:%b", a, out);
#0 a[0] = 1; a[1] = 1; a[2] = 1; a[3] = 1; a[4] = 1; a[5] = 0; a[6] = 0;a[7]=0;a[8]=0;a[9]=0;
#1 $display("input:%b -- out:%b", a, out);
#0 a[0] = 1; a[1] = 1; a[2] = 1; a[3] = 1; a[4] = 0; a[5] = 0; a[6] = 0;a[7]=0;a[8]=0;a[9]=0;
#1 $display("input:%b -- out:%b", a, out);
#0 a[0] = 1; a[1] = 1; a[2] = 1; a[3] = 0; a[4] = 0; a[5] = 0; a[6] = 0;a[7]=0;a[8]=0;a[9]=0;        
#1 $display("input:%b -- out:%b", a, out);
#0 a[0] = 1; a[1] = 1; a[2] = 0; a[3] = 0; a[4] = 0; a[5] = 0; a[6] = 0;a[7]=0;a[8]=0;a[9]=0;        
#1 $display("input:%b -- out:%b", a, out);
#0 a[0] = 1; a[1] = 0; a[2] = 0; a[3] = 0; a[4] = 0; a[5] = 0; a[6] = 0;a[7]=0;a[8]=0;a[9]=0;        
#1 $display("input:%b -- out:%b", a, out);
#0 a[0] = 0; a[1] = 0; a[2] = 0; a[3] = 0; a[4] = 0; a[5] = 0; a[6] = 0;a[7]=0;a[8]=0;a[9]=0;        
#1 $display("input:%b -- out:%b", a, out);
#9;
end                                                                                         
endmodule

运行结果图:

文章来源: blog.csdn.net,作者:渣渣ye,版权归原作者所有,如需转载,请联系作者。

原文链接:blog.csdn.net/yyfloveqcw/article/details/123755154

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。