news 2026/1/11 7:31:41

verilog简单入门day9-组合逻辑

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
verilog简单入门day9-组合逻辑

case1

已经给你一个BCD 的“1 位(1 个十进制数字)加法器”,名字叫bcd_fadd
它可以把两个 BCD 数字一个输入进位相加,并产生BCD 的和进位输出

module bcd_fadd ( input [3:0] a, input [3:0] b, input cin, output cout, output [3:0] sum );
module top_module( input [399:0] a, b, input cin, output cout, output [399:0] sum ); wire [99:0]c; bcd_fadd u_bcd_fadd_0( .a(a[3:0]), .b(b[3:0]), .cin(cin), .cout(c[0]), .sum(sum[3:0]) ) ; genvar i; generate for(i=1;i<100;i=i+1)begin:GEN bcd_fadd u_bcd_fadd_i( .a(a[4*i+3:4*i]), .b(b[4*i+3:4*i]), .cin(c[i-1]), .cout(c[i]), .sum(sum[4*i+3:4*i]) ) ; end endgenerate assign cout = c[99]; endmodule

case2真值表

真值表 = 把“所有可能的输入”和“对应的输出”全部列出来的表

如果输入是这样 → 输出应该是什么

想一个“最简单的开关例子”

场景:

有一个灯,两个开关AB

规则是:

只要有任意一个开关打开,灯就亮

那“真值表”在干嘛?

它只是把所有可能情况全部列出来:

两个开关,每个只有 0 / 1 两种状态

一共:

2 × 2 = 4 种情况

AB灯(out)
000
011
101
111

SOP(与或式)的规则是:
👉输出为 1 的“每一行” → 写一个 AND 项
👉把所有这些 AND 项用 OR 连起来

module top_module( input x3, input x2, input x1, // three inputs output f // one output ); assign f = (~x3&x2&~x1)| (~x3&x2&x1)| (x3&~x2&x1)| (x3&x2&x1); endmodule

case3看波形图写代码

相同为1,不同为0,同或

assign y=~(x^y);

case4

假设你正在设计一个电路,用来控制手机的铃声振动马达

当手机因为来电需要响铃时(输入ring = 1),
你的电路必须要么打开铃声,要么打开振动马达
但不能两个同时打开

如果手机处于振动模式vibrate_mode = 1),
就打开振动马达
否则(vibrate_mode = 0),
就打开铃声

尽量只使用assign语句
看看你能不能把这个“文字描述的问题”翻译成一组逻辑门。

module top_module ( input ring, input vibrate_mode, output ringer, // Make sound output motor // Vibrate ); assign ringer=(~vibrate_mode)&ring; assign motor =vibrate_mode&ring; endmodule

case5

一个冷热恒温器,用来控制加热器(冬天)空调(夏天)


Implement a circuit that will turn on and off the heater, air conditioning, and blower fan as appropriate.

实现一个电路,能正确地打开/关闭:

  • 加热器(heater)

  • 空调(air conditioner)

  • 风扇(blower fan)


The thermostat can be in one of two modes: heating (mode = 1) and cooling (mode = 0).

恒温器有两种模式:

  • 加热模式:mode = 1

  • 制冷模式:mode = 0


In heating mode, turn the heater on when it is too cold (too_cold = 1) but do not use the air conditioner.

加热模式下:

  • 如果太冷(too_cold = 1),打开加热器

  • 绝不能打开空调


In cooling mode, turn the air conditioner on when it is too hot (too_hot = 1), but do not turn on the heater.

制冷模式下:

  • 如果太热(too_hot = 1),打开空调

  • 绝不能打开加热器


When the heater or air conditioner are on, also turn on the fan to circulate the air.

只要加热器 或 空调打开了:

  • 风扇也要打开(用来送风)


In addition, the user can also request the fan to turn on (fan_on = 1), even if the heater and air conditioner are off.

另外:

  • 即使加热器和空调都关着

  • 用户也可以手动请求打开风扇(fan_on = 1


Try to use only assign statements…

尽量只用assign,把文字描述翻译成逻辑门。

module top_module ( input too_cold, input too_hot, input mode, input fan_on, output heater, output aircon, output fan ); assign heater=mode&too_cold; assign aircon=(~mode)&too_hot; assign fan = heater|aircon|fan_on; endmodule

case6

统计1

module top_module( input [2:0] in, output [1:0] out ); integer i; always@(*)begin out=0; for(i=0;i<3;i=i+1)begin if(in[i]) out = out+1; end end endmodule

case7

out_both的每一位表示:
当前输入位它左边的邻居(索引更大的那一位)是否都为 1

out_any的每一位表示:
当前输入位它右边的邻居(索引更小的那一位)是否至少有一个是 1

out_different的每一位表示:
当前输入位是否和左边的邻居不同。

module top_module( input [3:0] in, output [2:0] out_both, output [3:1] out_any, output [3:0] out_different ); integer i ; always@(*)begin for(i=0;i<3;i=i+1)begin out_both[i]=in[i]&in[i+1]; end end always@(*)begin for(i=1;i<4;i=i+1)begin out_any[i]=in[i]|in[i-1]; end end always@(*)begin for(i=0;i<4;i=i+1)begin out_different[i]=(i==3)?in[i]^in[0]:in[i]^in[i+1]; end end endmodule
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/1/7 13:19:02

dart特性之 --- mixin

mixin官网介绍 对于mixin的介绍和基本使用大家可以直接点击上面的官网链接产看&#xff0c;本篇主要探究混入链中的方法的调用顺序&#xff0c;起因来自于在查看flutter入口方法runApp()的源码处的疑问&#xff0c;下面以简化源码的方式进行分析。 abstract class BindingBas…

作者头像 李华
网站建设 2025/12/20 19:12:31

边缘设备能跑EmotiVoice吗?树莓派部署尝试

边缘设备能跑EmotiVoice吗&#xff1f;树莓派部署尝试 在智能语音助手越来越“听得懂人话”的今天&#xff0c;我们似乎也对它的声音提出了更高要求&#xff1a;不再满足于冰冷的机械朗读&#xff0c;而是期待它能“高兴地打招呼”、或“严肃地提醒天气”。这种对情感化语音输出…

作者头像 李华
网站建设 2025/12/21 22:16:31

ELK 是一套**开源的日志收集、存储、分析与可视化的技术栈

ELK 是一套开源的日志收集、存储、分析与可视化的技术栈&#xff0c;由 Elastic 公司&#xff08;原 Elasticsearch BV&#xff09;开发的三款核心产品的首字母缩写组成&#xff0c;是目前企业级日志管理、运维监控、安全审计的主流解决方案之一。 E&#xff1a;Elasticsearch …

作者头像 李华
网站建设 2026/1/9 5:06:20

绿色工厂建设中能碳管理的 12 个关键技术环节解析

在绿色工厂和“双碳”目标背景下&#xff0c;工业企业对能碳管理的认知正在发生变化。 与早期以节能为目的的能耗统计不同&#xff0c;当前政策更关注企业是否具备长期运行、可追溯、可核查的能碳管理体系。 《工业企业和园区数字化能碳管理中心建设指南》&#xff08;工信厅节…

作者头像 李华
网站建设 2025/12/22 15:15:08

【Linux命令大全】001.文件管理之chmod命令(实操篇)

【Linux命令大全】001.文件管理之chmod命令&#xff08;实操篇&#xff09; ✨ 本文全面解析Linux系统中chmod命令的功能、参数及实际应用&#xff0c;帮助系统管理员和高级用户更好地管理文件和目录的访问权限。文章涵盖参数详解、基础用法、进阶技巧以及常见场景的实际操作。…

作者头像 李华