首页 > 其他分享 >简单组合逻辑电路

简单组合逻辑电路

时间:2022-12-10 11:37:29浏览次数:35  
标签:LED 组合 比特 seg 逻辑电路 信号 简单 1001 size


verilog中的数字表示

在 Verilog HDL 中一个信号可能有如下四种基本的值:i.0:逻辑 0 或假ii.1:逻辑 1 或真iii.x:未知iv.z:高阻态(三态)在门电路的输入端或是表达式中的 z 值通常会被译为一个 x 值(待确定)。通常情况下, Verilog HDL 是区分大小写的,但是作为值来表示时是不区分大小写的。

在 Verilog HDL 中有三种常量类型:(i)整型,(ii)实型,和(iii)字符串。在整型常量和实型常量中可以使用下划线(_)来增加可读性。但它不能出现在第一个和最后一个字符的位置上。

整数可以写成 (i) 简单的十进制数或者是 (ii) 带进制格式。一个写成简单十进制形式的整数由一个可省略的+或是一个-和一串数字组成。比如,15-32其中 15 可以被写成 5 比特格 式的二进制数 01111,-32 可以写成 6 比特格式的 100000。简单的十进制数在硬件中最终会占用 32 比特。

一个数也可以被表示为进制格式,语法格式如下: [size]’base value其中size 代表数的比特数,base(基)是 o 或者O(代表八进制 octal),b 或者 B(代表二进制 Binary),d 或者 D(代表十进制Decimal),h 或者 H(代表十六进制hexadecimal)中的一个。Value 是一个在该进制下有效的数字的序列。Value 必须是无符号的。比如, wire [4:0] 5’O37 //5 比特八进制表示reg [3:0] 4’B1x_01 //4 比特二进制wire [3:0] 4’d-4 //不合法,value 不能是负数wire [11:0] 7’Hx //7 比特 x 扩展到 xxxxxxx如果 size 设定得比设定的常数的值的大小要大,这个数会被用 0 扩展到左边,除非最左边的比特是x 或 z,此时也会相应地用x 或 z 扩展。如果 size 设定得更小,那左边的多余的位会被忽略。如果size 未设定,那么就会使用 32 比特。

设计一个BCD码到7段数码管的译码器

数码管原理

7段数码管显示器包含7段,编号从a到g,可以用来显示一个字符。根据不同的输入类型,可能需要做类型转换。如果需要显示4bit的BCD码,则需要一个BCD码到7段数码管的译码器。下表展示了你要显示一个数字的bit图样。(需要注意的是,你如果需要点亮某一段,则要输出逻辑0到这一段,并且这个显示器的阳极需要用板上的逻辑0驱动)。

简单组合逻辑电路_数码管

简单组合逻辑电路_数码管_02

Nexys4 DDR开发板包含两个4位7段数码管LED显示器。每个模块中4位的每1位都由7段组成,每一段都嵌入了一颗LED,顺序如下图。每段的LED可以被单独点亮。因而通过点亮特定的段,熄灭其他段,全部128种图样都可以在1位上实现。在这128种图样中,10种数字的图样最有用。

简单组合逻辑电路_进制_03

简单组合逻辑电路_Verilog_04

组成每一位的7颗LED的阳极被连接在一起,称为“共阳极”的电路节点,但LED的阴极是独立的。共阳极节点的信号可以被获取作为4位显示器的使能信号。不同位,相同段的阴极信号分别接到7个电路节点,从CA 到CG (比如上图中4位的 “D” 笔画的阴极被连接到一起,连接到 “CD”这个电路节点)。这7个阴极节点信号可以被获取作为4位显示器的输入信号。这种信号连接的方案支持了多路复用的显示,虽然每个笔 画的阴极信号是4位共用的,但它们只能点亮阳极信号生效的位上的笔画。

简单组合逻辑电路_进制_05

扫描显示控制器电路可以用来控制这个显示器显示一个4位数。这个电路根据阴极图样,以高于人眼可分辨地频率,对每一位的阳极信号进行重复地、持续地、接连地驱动。如果它的更新或“刷新”率降到大约45 Hz时,大多数人能看出显示在闪烁。从Lab 8(体系结构向导和知识产权目录)开始你将设计和使用一个扫描电路。

参考代码

module lab2_1(
input [3:0]x,
output reg [7:0]seg,
output [7:0]an
);
assign an=8'b1111_1110;
always@(*)
case(x)
0: seg= 8'b 1100_0000;
1: seg= 8'b 1111_1001;
2:seg= 8'b 1010_0100;
3: seg= 8'b 1011_0000;
4: seg= 8'b 1001_1001;
5: seg= 8'b 1001_0010;
6: seg= 8'b 1000_0010;
7: seg= 8'b 1111_1000;
8: seg= 8'b 1000_0000;
9:seg= 8'b 1001_0000;
default seg=8'bxxxx_xxxx;
endcase
endmodule

标签:LED,组合,比特,seg,逻辑电路,信号,简单,1001,size
From: https://blog.51cto.com/u_15641375/5927361

相关文章

  • 复杂组合逻辑电路
    设计实现一个流行IC74138,使用数据流建模和你在1-1中使用的译码器集成三线—八线译码器74138除了3线到8线的基本译码输入输出端外,为便于扩展成更多位的译码电路和实现数据分......
  • Linux Hibernate配置以及流程简单分析(@STM32MP157D)
    关键词:1.Hibernate介绍2.Linux下Hibernate配置及操作在内核中使能Hibernation功能:由于Hibernate镜像需要保存在swap文件中,所以在内核中使能swap功能: 由于在hiber......
  • 算法学习笔记(40)——组合计数
    组合计数组合计数求组合数I——预处理组合数求组合数II——预处理阶乘求组合数III——卢卡斯定理(Lucas)求组合数IV——高精度满足条件的01序列——卡......
  • 组合杂题选讲 #3
    问题描述题意:现在有\(n\)个人要成立若干个社团(一个人可以属于多个社团)满足每个社团的人数均为奇数;任意两个不同的社团所共有的成员数量为偶数。求证:所能成立的社团......
  • python实现简单的商品数据管理系统
    #一个商品名称价格库存总销量#存放商品的数据类型strsetlisttupledict#综合考虑,选择字典dict_data={}#{名称:{price:价格,inventory:库存,sa......
  • xml简单使用
    简介:xml是一种可扩展的标记语言,常用于做配置文件。 基本要求:1、开头有声明信息:<?xmlversion="1.0"encoding="UTF-8"?>2、只有一个根元素。3......
  • 如何简单快速的下载视频号的直播视频到本地?视频号视频下载教程+工具
    大家好今天给大家分享一个下载视频号实时直播以及视频的方法;操作简单!使用这个“​​通用视频下载器​​”就可以轻松下载。注意:1.软件下载好,运行应用程序的时候,一定要“右键......
  • 数据库的简单操作
    数据库常识1.登录数据库:mysql-h127.0.0.1-P3306-uroot-p简写为mysql-uroot-p说明:-h后面是主机名(ip)-P后面是端口号-u后面是登录的用户名-p后面是登录密......
  • Copula估计边缘分布模拟收益率计算投资组合风险价值VaR与期望损失ES|附代码数据
    全文链接:http://tecdat.cn/?p=24753最近我们被客户要求撰写关于Copula的研究报告,包括一些图形和统计输出。在这项工作中,我通过创建一个包含四只基金的模型来探索copula,......
  • Datagrip安装后简单的配置
    1、关闭自动更新  File—Setting—Appearance&Behavior—SystemSetting—Updates取消勾选Automaticallycheckupdates复选框,最后确定即可2.当多条sqlCRTL+ENTER......