【FPGA】Verilog:组合逻辑电路应用 | 数码管 | 8421BCD编码 | 转换七段数码管段码

这篇具有很好参考价值的文章主要介绍了【FPGA】Verilog:组合逻辑电路应用 | 数码管 | 8421BCD编码 | 转换七段数码管段码。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

前言:本章内容主要是演示Vivado下利用Verilog语言进行电路设计、仿真、综合和下载

示例:数码管的使用

fpga原理及应用用原理图实现组合逻辑电路,FPGA玩板子,fpga开发,Verilog

  • 功能特性: 采用 Xilinx Artix-7 XC7A35T芯片 
  • 配置方式:USB-JTAG/SPI Flash
  • 高达100MHz 的内部时钟速度 
  • 存储器:2Mbit SRAM   N25Q064A SPI Flash(样图旧款为N25Q032A)
  • 通用IO:Switch :x8LED:x16Button:x5DIP:x8   通用扩展IO:32pin
  • 音视频/显示: 7段数码管:x8 VGA视频输出接口 Audio音频接口 
  • 通信接口:UART:USB转UART   Bluetooth:蓝牙模块 
  • 模拟接口: DAC:8-bit分辨率   XADC:2路12bit 1Msps ADC

目录

 Ⅰ. 前置知识

0x01 七段数码管工作原理

 0x01 多位数码管工作原理

Ⅱ. Verilog实现

0x00 实现内容

0x01  设计代码文件

0x02 仿真代码文件

0x03 观察记录仿真波形

 0x04 添加引脚约束

 Ⅳ 知识扩展

0x00 扩展实验


 Ⅰ. 前置知识

0x01 七段数码管工作原理

fpga原理及应用用原理图实现组合逻辑电路,FPGA玩板子,fpga开发,Verilog

共阴极七段数码管内部结构如图。七个线形LED灯a~g构成七段,其位置序号如图:

fpga原理及应用用原理图实现组合逻辑电路,FPGA玩板子,fpga开发,Verilog

一端并接称为位码;一端分别接收电平信号以控制灯的亮灭,称为段码。

点亮要求为:共阴型数码管位码接低电平,需点亮的段码接高电平。若数码管类型为共阳极,其点亮要求的电平正好相反。

BCD码转七段数码管的电路作用是将BCD码表示的十进制数转换成七段LED数码管的7个驱动段码端。

如输入DB(A3、A2、A1、A0),输出g-a。如输入数据为0000,则控制数码管显示“0”形,即f~a灯亮,g灯灭,若设计的译码器用于控制共阴极数码管,则输出的g~a的信号为0111111。

以8421BCD码转七段数码管段码为例,说明电路原理:

8421BCD码转七段数码管段码是将BCD码表示的十进制数转换成七段LED数码管的7个驱动段码,真值表如下

数字

输入

输出

B8

B4

B2

B1

a

b

c

d

e

f

g

0

0

0

0

0

1

1

1

1

1

1

0

1

0

0

0

1

0

1

1

0

0

0

0

2

0

0

1

0

1

1

0

1

1

0

1

3

0

0

1

1

1

1

1

1

0

0

1

4

0

1

0

0

0

1

1

0

0

1

1

5

0

1

0

1

1

0

1

1

0

1

1

6

0

1

1

0

1

0

1

1

1

1

1

7

0

1

1

1

1

1

1

0

0

0

0

8

1

0

0

0

1

1

1

1

1

1

1

9

1

0

0

1

1

1

1

1

0

1

1

10

1

0

1

0

d

d

d

d

d

d

d

...

15

1

1

1

1

d

d

d

d

d

d

d

下面以a为例介绍原理与过程。首先绘制输出a的卡诺图如下表:

B2B1

B8B4

00

01

11

10

00

1

0

1

1

01

0

1

1

1

10

1

1

d

d

11

d

d

d

d

然后考虑无关项的必要质蕴含项,如图:

fpga原理及应用用原理图实现组合逻辑电路,FPGA玩板子,fpga开发,Verilog

接着就可以得到最简与或式了。

同样方法,根据真值表画出每个输出项的卡诺图,化简得到b-g的逻辑表达式。a-g的逻辑表达式如下:

fpga原理及应用用原理图实现组合逻辑电路,FPGA玩板子,fpga开发,Verilog

 根据上述逻辑表达式,可用Verilog语言编写设计源代码

或用IP包搭建电路如图:

fpga原理及应用用原理图实现组合逻辑电路,FPGA玩板子,fpga开发,Verilog

 0x01 多位数码管工作原理

下图示意了四个数码管组合的结构:

fpga原理及应用用原理图实现组合逻辑电路,FPGA玩板子,fpga开发,Verilog

由于实验板内部采用驱动电路控制数码管,其内部结构和控制方法采用以下规则:四个数码管的段码引脚按序号分别并接,用位码控制某一个数码管的亮灭。

如:要让图中第1、3个数码管显示“0”,其他2、4数码管全灭,可以给a~g送段码8'b11111100,给1~4送位码4'b1010。

这里我们EG01 实验板卡为 FPGA 板级验证平台:

fpga原理及应用用原理图实现组合逻辑电路,FPGA玩板子,fpga开发,Verilog

实验板上共有8个八段数码管,分为两组,因此段码a~h的连接方案有两种,分别为:B4、A4、A3、B1、A1、B3、B2、D5(0组);D4、E3、D3、F4、F3、E2、D2、H2(1组)。位码1-8的引脚编号分别为:G2、C2、C1、H1、G1、F1、E1、G6。在编写引脚约束时,也可结合实验板丝印进行填写。

Ⅱ. Verilog实现

0x00 实现内容

采用Verilog设计一个编码转换电路,将输入的8421BCD编码转换七段数码管段码,并利用EGO1实验板上的数码管上显示与输入数据对应的十进制值。

0x01  设计代码文件

Veriog HDL 共有三种建模方式。

其描述风格分为结构描述、数据流描述、行为描述以及混合描述。

为了方便读者,本篇博客使用行为描述和数据流描述两种建模方法进行建模

行为描述建模:

module hex7seg(input wire [3:0] x,output reg [6:0] a_to_g);
always @ (x)
	case(x)
		0:a_to_g=7'b1111110;
		1:a_to_g=7'b0110000;
		2:a_to_g=7'b1101101;
		3:a_to_g=7'b1111001;
		4:a_to_g=7'b0110011;
		5:a_to_g=7'b1011011;
		6:a_to_g=7'b1011111;
		7:a_to_g=7'b1110000;
		8:a_to_g=7'b1111111;
		9:a_to_g=7'b1111011;
		default:a_to_g=7'b0000001;
	endcase
endmodule



module hex7seg_top(sw,a_to_g,an,dp);
	input wire [3:0] sw;
	output wire [6:0] a_to_g;
	output wire [3:0] an;
	output wire dp;
		assign an=4'b1111;
		assign dp=0;
	hex7seg D4(.x(sw),.a_to_g(a_to_g));
endmodule

数据流描述建模:

module Nixielight(input[3:0] B,output [7:0]SEG,output [3:0]bC);
 assign SEG[0]=B[3]|((~B[2])&(~B[0]))|B[1]|(B[2]&B[0]);
 assign SEG[1]=(~B[2])|(B[1]&B[0])|((~B[1]&(~B[0])));
 assign SEG[2]=B[2]|(~B[1])|B[0];
 assign SEG[3]=B[3]|((~B[2])&(~B[0]))|((~B[2])&B[1])|(B[1]&(~B[0]))|(B[2]&(~B[1])&B[0]);
 assign SEG[4]=((~B[2])&(~B[0]))|(B[1]&(~B[0]));
 assign SEG[5]=B[3]|((~B[1])&(~B[0]))|(B[2]&(~B[1]))|(B[2]&(~B[0]));
 assign SEG[6]=B[3]|(B[1]&(~B[0]))|((~B[2])&B[1])|(B[2]&(~B[1])); 
 assign SEG[7]=0;
 assign bC=15;
endmodule

0x02 仿真代码文件

行为描述建模:

module sim1();
reg [3:0] sw;
wire [6:0] a_to_g;
wire [3:0] an;
wire dp;
hex7seg_top uu1(sw,a_to_g,an,dp);
initial sw=4'b0000;
always #100 sw=sw+1;
endmodule

数据流描述建模:

module sim_Nixielight();
 reg [3:0]B;
 wire [7:0]SEG;
 wire [3:0]bC;
 Nixielight test(.B(B),.SEG(SEG),.bC(bC));
 always begin
 B[3]=0;B[2]=0;B[1]=0;B[0]=0;#100;
 B[3]=0;B[2]=0;B[1]=0;B[0]=1;#100;
 B[3]=0;B[2]=0;B[1]=1;B[0]=0;#100;
 B[3]=0;B[2]=0;B[1]=1;B[0]=1;#100;
 B[3]=0;B[2]=1;B[1]=0;B[0]=0;#100;
 B[3]=0;B[2]=1;B[1]=0;B[0]=1;#100;
 B[3]=0;B[2]=1;B[1]=1;B[0]=0;#100;
 B[3]=0;B[2]=1;B[1]=1;B[0]=1;#100; 
 B[3]=1;B[2]=0;B[1]=0;B[0]=0;#100;
 B[3]=1;B[2]=0;B[1]=0;B[0]=1;#100; 
 end
endmodule

0x03 观察记录仿真波形

fpga原理及应用用原理图实现组合逻辑电路,FPGA玩板子,fpga开发,Verilog

 分析仿真波形,记录输出结果,对所设计的电路功能是否满足设计要求给出结论。

fpga原理及应用用原理图实现组合逻辑电路,FPGA玩板子,fpga开发,Verilog

 0x04 添加引脚约束

按照 EG01 硬件手册提供的资料,选择输入和输出设备,设置引脚约束。

设置完毕,保存管脚约束文件。

本次实验利用 SW7-SW4 作为数据输入,DK5-8 及对应的八个段码作为显示电路输出.

引脚约束关系如下:

fpga原理及应用用原理图实现组合逻辑电路,FPGA玩板子,fpga开发,Verilog

引脚约束设置完成后,综合,点击“PROGRAM AND DEBUG”选项中的“Generate Bitstream”在经过综合、实现两个阶段后,可生成 bit 文件。

下载 bit 文件到 FPGA

正确得到 bit 文件后,将 EG01 板与电脑用板卡包里提供 USB 数据线进行连接。

连接完毕,打开 EG01 电源开关,可看到电源指示灯点亮。

随后,点击“Open Hardware Manager”选择 “Auto Connect”,连接 EG01

连接成功后,点击“Program Device”bit 文件下载至 EG01 FPGA

下载完毕,利用设计时选择的开关输入不同的值,对电路进行测试

fpga原理及应用用原理图实现组合逻辑电路,FPGA玩板子,fpga开发,Verilog fpga原理及应用用原理图实现组合逻辑电路,FPGA玩板子,fpga开发,Verilog

 Ⅳ 知识扩展

0x00 扩展实验

结合前期实验内容,实现能完成下列功能的电路,

要求在Vivado中完成设计与仿真,并下载至EGO1实验板进行验证与分析。

用1个数码管显示开关的编号,电路功能如下:

开关1按下,在第一个数码管显示1;开关2按下,在第二个数码管显示2;开关3按下,在第三个数码管显示3;开关4按下,在第四个数码管显示4。参考真值表如下:

输入

输出

SW1

SW2

SW3

SW4

a

b

c

d

e

f

g

h

1

0

0

0

0

1

1

0

0

0

0

0

0

1

0

0

1

1

0

1

1

0

1

0

0

0

1

0

1

1

1

1

0

0

1

0

0

0

0

1

0

1

1

0

0

1

1

0

x

x

x

x

d

d

d

d

d

d

d

d

根据真值表,写出设计代码如下:

module SY3_KZ(input [3:0]b,output [7:0]seg,output [3:0]bc);
assign seg[0]=(~b[0])&(~b[3]);
assign seg[1]=1;
assign seg[2]=(~b[1])&(~b[3])|((~b[0])&(~b[1])&(~b[2]));
assign seg[3]=(~b[0])&(~b[3]);
assign seg[4]=b[1];
assign seg[5]=b[3];
assign seg[6]=((~b[0])&(~b[3]))|((~b[0])&(~b[1])&(~b[2]));
assign seg[7]=0;
assign bc=b;
endmodule

仿真代码:

module sim_SY3_KZ();
 reg [3:0]b;
 wire [7:0]seg;
 SY3_KZ test(.b(b),.seg(seg));
 always begin
 b[0]=1;b[1]=0;b[2]=0;b[3]=0;#100;
 b[0]=0;b[1]=1;b[2]=0;b[3]=0;#100;
 b[0]=0;b[1]=0;b[2]=1;b[3]=0;#100;
 b[0]=0;b[1]=0;b[2]=0;b[3]=1;#100;
 end
endmodule

引脚约束:

fpga原理及应用用原理图实现组合逻辑电路,FPGA玩板子,fpga开发,Verilog

 波形图:

fpga原理及应用用原理图实现组合逻辑电路,FPGA玩板子,fpga开发,Verilog

引脚约束设置完成后,综合,点击“PROGRAM AND DEBUG”选项中的“Generate Bitstream”在经过综合、实现两个阶段后,可生成 bit 文件。

下载 bit 文件到 FPGA

正确得到 bit 文件后,将 EG01 实验板与电脑用板卡包里提供 USB 数据线进行连接。

连接完毕,打开 EG01 电源开关,可看到电源指示灯点亮。

随后,点击“Open Hardware Manager”选择 “Auto Connect”,连接 EG01。连接成功后,点击“Program Device”bit 文件下载至 EG01 FPGA

下载完毕,利用设计时选择的开关输入不同的值,对电路进行测试

fpga原理及应用用原理图实现组合逻辑电路,FPGA玩板子,fpga开发,Verilog文章来源地址https://www.toymoban.com/news/detail-777053.html

到了这里,关于【FPGA】Verilog:组合逻辑电路应用 | 数码管 | 8421BCD编码 | 转换七段数码管段码的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【FPGA】Verilog:实现十六进制七段数码管显示 | 7-Segment Display

    写在前面: 本章主要内容为理解七点数码管显示的概念,并使用 Verilog 实现。生成输入信号后通过仿真确认各门的动作,通过 FPGA 检查在 Verilog 中实现的电路的操作。 七段数码管是利用多重输出功能的非常有用的元件。该元件用于字符化,如十进制、十六进制数等。适当配

    2024年02月02日
    浏览(50)
  • FPGA课程设计——数字电子时钟VERILOG(基于正点原子新起点开发板,支持8位或6位共阳极数码管显示时分秒毫秒,可校时,可设闹钟,闹钟开关,led指示)

    2019   级    电子科学与技术   专业FPGA课程设计 报   告 2022  年 5 月 20 日 多功能数字电子钟的设计 摘要 电子设计自动化(EDA)是一种实现电子系统或电子产品自动化设计的技术,使用EDA技术设计的结果既可以用FPGA / CPLD来实施验证,也可以直接做成专用集成电路(ASIC)。

    2024年02月03日
    浏览(45)
  • verilog实现数码管静态显示

    六个数码管同时间隔0.5s显示0-f。要求:使用一个顶层模块,调用计时器模块和数码管静态显示模块。 本文介绍了数码管显示原理,数码管驱动方式等等,并通过代码实现了数码管静态显示

    2024年02月16日
    浏览(41)
  • 【FPGA】组合逻辑电路三种建模方式(Verilog HDL 门级建模、Verilog HDL 数据流建模、组合电路行为级建模)

    目录   Verilog HDL 门级建模 各种逻辑门的表示和使用 门级建模书写实例 Verilog HDL 数据流建模 数据流建模 数据流建模书写实例 组合电路行为级建模 always语句 条件语句 多路分支语句 循环语句 for while repeat forever 行为级建模示例   可以理解为对逻辑电路中各个门依次进行描述

    2024年04月13日
    浏览(49)
  • 可编程逻辑器件之数码管显示实验

    一、实验目标 能够熟练的进行可编程逻辑器件开发,能够通过具体工程需求进行需求分析、模块划分、代码编写、功能仿真、综合分析、板级验证,能够独立正确的进行实验操作,培养学生的工程实践研究能力和动手实践能力,具备借助可编程逻辑器件开发平台和仿真工具科

    2024年02月02日
    浏览(133)
  • verilog学习笔记- 15)动态数码管显示实验

    目录 简介: 实验任务: 硬件设计: 程序设计: 下载验证: 由于一般的静态驱动操作虽然方便,但占用的 I/0 口较多,例如要驱动6 位 8 段数码管,以静态驱动方式让数码管各个位显示不同的数值,如“123456”,需要占用6 × 8 = 48个I/O 口,虽然对于 FPGA 这种 I/O 口较多的芯片

    2024年02月07日
    浏览(48)
  • 静态数码管——FPGA

    环境: 1、Quartus18.0 2、vscode 3、板子型号:EP4CE6F17C8 要求: 六位数码管全选,每间隔0.5s轮流显示0~F。 静态与动态数码管: 静态数码管 : 在静态显示中,只考虑段选信号。在不同的时刻,各个位选信号保持不变,并根据真值表,选择要显示的数字或者字母。 动态数码管 :

    2024年02月16日
    浏览(45)
  • FPGA——静态数码管

    quartus 18.1 modelsim vscode Cyclone IV开发板 我们使用的数码管是8段数码管,每段是由led组成。通过控制每段led的亮灭,来控制数码管显示不同的数字和字母。 数码管分为共阴极和共阳极,共阳极数码管如图所示,a—dp为输入端,全部在二极管的负极,二极管的正极极共同接+5v(高电

    2024年02月16日
    浏览(38)
  • 【数电实验】实验 5 数码管动态扫描显示电路设计

    【2023-11-16:修改Y为4位宽,支持显示学号8和9】 实验要求 一、实验目的 1. 学习动态扫描显示数码管的使用。 2. 学习数据选择器及其信号分配方法。 3. 巩固 Verilog HDL 层次化设计电路的方法。 利用modelsim仿真 模块代码 1.modelsim仿真代码 2.程序源代码 RTL电路图 验收波形图 引脚

    2024年02月03日
    浏览(51)
  • FPGA_数码管显示

    一位数码管: 数码管等效电路(共阴极 和 共阳极) 数码管显示的值: 假设我们需要b,c亮,我们只需要给b,c接高电平,其他接低电平就可。 seg[7:0]  = 8\\\'b0000_0110 对于数码管显示的值,seg值如下图: 多位数码管-----如下图(以3位为例) 假设现在需要LED1亮,那么就让sel0为1,

    2024年01月23日
    浏览(50)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包