当前位置: 首页 > news >正文

FPGA 21 ,深入理解 Verilog 中的基数,以及二进制数与十进制数之间的关系( Verilog中的基数 )

目录

前言
一. 基数基础
1.1 基数介绍
2.1 基数符号
3.1 二进制数
二. 二进制与十进制数
三. 二进制数
3.1 定义寄存器类型变量
3.2 定义线网类型变量
3.3 赋值操作
3.4 解析二进制数为十进制数
四. 代码示例
五. 注意事项
六. 更多操作

前言

在Verilog中,基数(radix)用于指定数字的进制。Verilog 支持多种基数表示法,包括二进制(binary)、八进制(octal)、十进制(decimal)和十六进制(hexadecimal)。这些不同的基数表示法,使得我们可以方便地使用最适合当前上下文的数值表示方式。

因此在数字逻辑设计和FPGA开发中,理解二进制数及其与十进制数之间的关系是至关重要的。本文将详细介绍4位二进制数,可以表示的范围,以及它们如何映射到无符号整数,并通过具体的Verilog代码示例来说明这些概念。此外,我们还将探讨一些编程时需要注意的事项,帮助我们避免常见的错误。

一. 基数基础

基数与二进制数,基础知识

1.1 基数介绍

在Verilog中,基数(或称数制)是用来表示数字常量的一种方式。Verilog 支持几种不同的基数,包括二进制、八进制、十进制和十六进制。这些基数可以用于定义整型数值,并且可以在代码中通过特定的前缀来标识。

以下是 Verilog 中使用不同基数表示数字常量的方法:

  1. 二进制 (Binary): 使用 bB 作为后缀。

    • 示例:4'b0011 表示一个4位宽的二进制数,值为3。
  2. 八进制 (Octal): 使用 oO 作为后缀。

    • 示例:3'o5 表示一个3位宽的八进制数,其值为5(即十进制中的5)。
  3. 十进制 (Decimal): 可以直接书写数字,或者使用 dD 作为后缀。

    • 示例:8 或 4'd8 表示一个4位宽的十进制数,值为8。如果宽度不足以容纳该值,则会发生截断或填充。
  4. 十六进制 (Hexadecimal): 使用 hH 作为后缀。

    • 示例:8'hAA 表示一个8位宽的十六进制数,值为170(AA是十六进制表示)。

当指定一个带宽度的常量时,格式为 <width>'<radix><value>,其中:

  1. <width> 是一个正整数,指定了该数值的位宽。
  2. <radix> 是表示基数的字母(如 b, o, d, h)。
  3. <value> 是根据所选基数的实际数值。

例如:

  1. 8'b1100_1100 表示一个8位宽的二进制数,值为204(允许下划线以提高可读性)。
  2. 16'hFFFF 表示一个16位宽的十六进制数,所有位均为1。

如果没有明确给出宽度,那么默认的宽度将取决于上下文,或者是工具设定的默认值。对于十进制数,如果不指定基数,可以直接写成纯数字形式,如 123,它会被认为是一个十进制数。

2.1 基数符号

  1. 二进制 (Binary): b 或 B
  2. 八进制 (Octal): o 或 O
  3. 十进制 (Decimal): d 或 D (但通常可以省略)
  4. 十六进制 (Hexadecimal): h 或 H

这些符号直接跟在宽度说明之后、数值之前使用。例如,4'b1010 表示一个4位宽的二进制数。

3.1 二进制

这里来着重说一下二进制,二进制是一种基于2的计数系统,它使用0和1两个符号来表示数值。每个二进制位(bit)都可以处于两种状态之一:0 或 1。对于一个n位的二进制数,它可以表示 2n 种不同的值。具体来说,4位二进制数,能够表示从 0 (0000) 到 15 (1111) 的无符号整数,总共16种不同的值。

二进制 (Binary)(4位二进制数)十进制 (Decimal)
00000
00011
00102
00113
01004
01015
01106
01117
10008
10019
101010
101111
110012
110113
111014
111115


二. 二进制与十进制数

解析二进制数为十进制数

要解析一个4位二进制数为十进制数,你可以将每个二进制位乘以其权重,并将结果相加。权重是2的幂次方,从右向左递增,最低位(最右边的一位)的权重是 2020,最高位(最左边的一位)的权重是 2(n−1)2(n−1),其中 nn 是位数。对于4位二进制数,权重如下:

  • 第0位(最右边):20=120=1
  • 第1位:21=221=2
  • 第2位:22=422=4
  • 第3位(最左边):23=823=8

例如,对于二进制数 1101

  • 第0位(最右边)是 1,其权重是 20=120=1,所以 1×1=11×1=1
  • 第1位是 0,其权重是 21=221=2,所以 0×2=00×2=0
  • 第2位是 1,其权重是 22=422=4,所以 1×4=41×4=4
  • 第3位(最左边)是 1,其权重是 23=823=8,所以 1×8=81×8=8

将这些结果相加:1+0+4+8=131+0+4+8=13,因此二进制数 1101 对应的十进制数是 13

计算方式总结:

十进制值=b3×23+b2×22+b1×21+b0×20十进制值=b3​×23+b2​×22+b1​×21+b0​×20

其中 bibi​ 表示第 ii 位的二进制值(0或1)。

图例:


三. 二进制数

Verilog 中的4位二进制数

在Verilog中,我们可以定义不同类型的变量,来存储二进制数据,最常用的是 reg 和 wire 类型。下面我们将介绍,如何在Verilog中定义、赋值和操作4位二进制数。

3.1 定义寄存器类型变量

// 定义一个4位宽的寄存器,用于保存二进制数
reg [3:0] myRegister;
  1. [3:0] 表示这是一个4位宽的寄存器。
  2. myRegister 是变量名。 

3.2 定义线网类型变量

// 定义一个4位宽的线网,用于连接组合逻辑或模块输出
wire [3:0] myWire;
  • 注意,wire 类型不能保存状态,必须由其他逻辑驱动。

3.3 赋值操作

// 使用过程赋值给寄存器
always @(posedge clk) begin // 在时钟上升沿触发myRegister <= 4'b1101; // 给myRegister赋值为二进制1101(即十进制13)
end// 使用连续赋值给线网
assign myWire = 4'b0011; // 给myWire赋值为二进制0011(即十进制3)
  1.  过程赋值使用 <=,而连续赋值使用 =.
  2. clk 是时钟信号,posedge 表示在时钟上升沿触发。 

3.4 解析二进制数为十进制数

// 计算二进制1101对应的十进制值
integer decimalValue;
always @(*) begin // 组合逻辑块decimalValue = 8 * myRegister[3] + 4 * myRegister[2] + 2 * myRegister[1] + 1 * myRegister[0];
end
  1. 这里使用了组合逻辑块 @(*) 来确保每当输入发生变化时都会重新计算。
  2. integer 类型用于存储较大的数值,如十进制结果。


四. 代码示例

以下是一个完整的Verilog代码示例,展示了如何定义、赋值和解析4位二进制数。

module binaryToDecimal(input wire clk, // 时钟信号output reg [3:0] myRegister, // 寄存器输出output wire [3:0] myWire, // 线网输出output integer decimalValue // 十进制输出
);// 给寄存器赋值
always @(posedge clk) beginmyRegister <= 4'b1101; // 在时钟上升沿更新寄存器值
end// 给线网赋值
assign myWire = 4'b0011;// 解析二进制数为十进制
always @(*) begindecimalValue = 8 * myRegister[3] + 4 * myRegister[2] + 2 * myRegister[1] + 1 * myRegister[0];
endendmodule

这段代码创建了一个简单的模块,其中包含了寄存器和线网的定义、赋值,以及将寄存器内的4位二进制数解析为十进制的过程。注意,这里为了简化演示,省略了复位逻辑和其他可能需要的功能。在实际应用中,您应该根据需求添加适当的控制逻辑。


五. 注意事项

  1.  不要混淆 reg 和 wire:虽然它们可以有相同的位宽,但用途不同,reg 用于保存状态,而 wire 必须由其他逻辑驱动。
  2. 初始化问题:在仿真环境中,未初始化的 reg 变量默认为未知状态 'x',这可能导致意外行为。
  3. 溢出处理:当对寄存器进行算术运算时,请确保不会超出其位宽所能表示的最大值,否则会导致溢出。
  4. 资源优化:合理规划位宽可以节省硬件资源,在FPGA上尤为重要。 

本文总结

理解和正确使用二进制数是数字逻辑设计的基础。通过本文,希望你能更好地掌握4位二进制数在Verilog中的表示方法及应用技巧。无论是学习还是实际项目开发中,都应牢记上述注意事项,以编写高效且可靠的代码。


六. 更多操作

早期,之前的基数介绍,请看

FPGA 9 ,Verilog 中的关键字和基数icon-default.png?t=O83Ahttps://blog.csdn.net/weixin_65793170/article/details/141625021完整FPGA系列,请看

FPGA系列,文章目录icon-default.png?t=O83Ahttps://blog.csdn.net/weixin_65793170/article/details/144185217?spm=1001.2014.3001.5501

相关文章:

FPGA 21 ,深入理解 Verilog 中的基数,以及二进制数与十进制数之间的关系( Verilog中的基数 )

目录 前言 一. 基数基础 1.1 基数介绍 2.1 基数符号 3.1 二进制数 二. 二进制与十进制数 三. 二进制数 3.1 定义寄存器类型变量 3.2 定义线网类型变量 3.3 赋值操作 3.4 解析二进制数为十进制数 四. 代码示例 五. 注意事项 六. 更多操作 前言 在Verilog中&#…...

【redis】redis-cli命令行工具的使用

redis-cli命令行工具是一个功能强大的Redis客户端&#xff0c;它允许用户与Redis数据库进行交互和管理。 以下是一些常用参数的使用说明&#xff1a; 基本连接参数 -h, --host <hostname>&#xff1a;指定要连接的Redis服务器的主机名或IP地址。如果未指定&#xff0c;…...

使用Matplotlib显示中文的方法

1 问题提出 使用图1所示的代码进行matplotlib绘图时&#xff0c;因为其默认不支持中文&#xff0c;此时无法显示正确内容&#xff0c;如图2所示。 图1 matplotlib绘图绘图代码 图2 matplotlib无法显示中文 2 问题解决 2.1 设置全局字体 在图1所示的代码中&#xff0c;第13…...

SQL Server2022详细安装教程

1. 打开SQL Server官网&#xff1a;SQL Server 下载 | Microsoft 2. 选择Developer版 3. 下载好安装包&#xff0c;打开&#xff0c;选择自定义 4. 选择下载位置&#xff0c;最好不要在C盘即主磁盘即可。等待下载 5. 下载成功之后会弹出这个框 6. 点击“安装”&#…...

家里温度随心控,假期出行更舒适~

春节假期马上到来啦&#xff01;这是放松身心、陪伴家人的最佳时机~      但旅途结束的温差变化、空气质量问题是否让你有些担忧呢&#xff1f;      别担心&#xff01;有了约克VRF中央空调&#xff0c;让你的假期更加舒心无忧~      清新空气&#xff0c;自在出游…...

压力测试详解

压力测试 压力测试是一种软件测试&#xff0c;用于验证软件应用程序的稳定性和可靠性。压力测试的目标是在极其沉重的负载条件下测量软件的健壮性和错误处理能力&#xff0c;并确保软件在危急情况下不会崩溃。它甚至可以测试超出正常工作点的测试&#xff0c;并评估软件在极端…...

从epoll事件的视角探讨TCP:三次握手、四次挥手、应用层与传输层之间的联系

目录 一、应用层与TCP之间的联系 二、 当通信双方中的一方如客户端主动断开连接时&#xff0c;仅是在客户端的视角下连接已经断开&#xff0c;在服务端的眼中&#xff0c;连接依然存在&#xff0c;为什么&#xff1f;——触发EPOLLRDHUP事件&#xff1a;对端关闭连接或停止写…...

Redis复制(replica)

Redis主从复制 [Redis主从复制]&#xff08;replica&#xff09;是一个多Redis实例进行数据同步的过程&#xff0c;其中一个实例是主实例&#xff08;Master&#xff09;&#xff0c;其他实例是从实例&#xff08;Slave&#xff09;。主实例负责处理命令请求&#xff0c;而从实…...

[云讷科技] 用于软件验证的仿真环境

我们使用Pursuit自动驾驶仪为各种场景设计仿真环境&#xff0c;以便用户可以在模拟环境中直接验证他们的软件&#xff0c;无需现场测试。该环境基于Gazebo引擎。 1. 工作区目录 模拟环境的工作区位于提供的U盘中的~/pursuit_space/sitl_space_pursuit中。用户可以按照用户手册…...

使用 Vite 和 Vue 框架创建组件库

在前端开发中&#xff0c;组件化开发已成为一种高效、可维护的方式。通过创建组件库&#xff0c;不仅可以提高代码复用率&#xff0c;还能方便地在不同项目之间共享组件。本文将详细介绍如何使用 Vite 和 Vue 框架创建一个组件库&#xff0c;并将其导出供其他项目使用。为保持一…...

【数据结构学习笔记】19:跳表(Skip List)

介绍 跳表是一个能在 O ( n l o g n ) O(nlogn) O(nlogn)时间完成查找、插入、删除的数据结构&#xff0c;相比于树形结构优点就是很好写&#xff08;所以也用于实现Redis ZSet&#xff09;。其核心思想就是维护一个元素有序的&#xff0c;能随机提升索引层数的链表。最下面一…...

【8】深入理解 Go 语言中的协程-从基础到高级应用

文章目录 一、引言 &#x1f31f;二、协程基础概念 &#x1f9d0;&#xff08;一&#xff09;什么是协程&#xff08;二&#xff09;协程与线程、进程的区别三、协程的创建与启动 &#x1f680;&#xff08;一&#xff09;使用 go 关键字创建协程&#xff08;二&#xff09;简单…...

深入理解 ECMAScript 2024 新特性:字符串 isWellFormed 方法

ECMAScript 2024 引入了一个新的字符串实例方法&#xff1a;String.prototype.isWellFormed。这一新增功能是为了帮助开发者更容易地验证字符串是否为有效的 Unicode 文本。本文将详细介绍这一方法的使用场景、实现原理及其在实际应用中的价值。 String.prototype.isWellFormed…...

算法分析与设计之贪心算法

文章目录 前言一、Greedy Algorithms1.1 贪心选择性质1.2 最优子结构性质1.3 正确性证明 二、典型例题2.1 Interval Scheduling间隔调度2.2 Interval Partitioning最少间教室排课2.3 Selecting Breakpoints选择加油站停靠点2.4 硬币找零2.5 Scheduling to Minimizing Lateness2…...

Centos 宝塔安装

yum install -y wget && wget -O install.sh http://download.bt.cn/install/install_6.0.sh && sh install.sh 安装成功界面 宝塔说明文档 https://www.bt.cn/admin/servers#wcu 或者可以注册宝塔账号 1 快速部署 安装docker 之后 2 需要在usr/bin下下载do…...

蓝桥与力扣刷题(709 转换成小写字母)

题目&#xff1a;给你一个字符串 s &#xff0c;将该字符串中的大写字母转换成相同的小写字母&#xff0c;返回新的字符串。 示例 1&#xff1a; 输入&#xff1a;s "Hello" 输出&#xff1a;"hello"示例 2&#xff1a; 输入&#xff1a;s "here…...

Redis的过期策略、内存淘汰机制

Redis只能存5G数据&#xff0c;可是你写了10G&#xff0c;那会删5G的数据。怎么删的&#xff1f;还有&#xff0c;你的数据已经设置了过期时间&#xff0c;但是时间到了&#xff0c;为什么内存占用率还是比较高? 一、Redis的过期策略 Redis采用的是定期删除惰性删除策略。 1…...

视觉多模态大模型---MiniMax-vl-01---以闪电般的注意力缩放基础模型

简介 MiniMax-VL-01 是与今年1月15日由上海稀宇科技有限公司&#xff08;MiniMax&#xff09;发布并开源的一款视觉多模态大模型&#xff0c;它与基础语言大模型 MiniMax-Text-01 一同构成了 MiniMax-01 系列。这款模型的设计初衷是为了应对日益增长的长上下文处理需求&#x…...

【微服务】面试 3、 服务监控 SkyWalking

微服务监控的原因 问题定位&#xff1a;在微服务架构中&#xff0c;客户端&#xff08;如 PC 端、APP 端、小程序等&#xff09;请求后台服务需经过网关再路由到各个微服务&#xff0c;服务间可能存在多链路调用。当某一微服务挂掉时&#xff0c;在复杂的调用链路中难以迅速确定…...

【案例81】NMC调用导致数据库的效率问题

问题现象 客户在使用NC系统时&#xff0c;发现系统特别卡顿。需要紧急排查。 问题分析 排查NMC发现&#xff0c;所有的线程都处于执行SQL层面&#xff0c;说明数据库当前出现了异常。查看数据库资源状态发现&#xff0c;Oracle相关进程CPU利用率达到了100%。 查看现在数据库…...

网络六边形受到攻击

大家读完觉得有帮助记得关注和点赞&#xff01;&#xff01;&#xff01; 抽象 现代智能交通系统 &#xff08;ITS&#xff09; 的一个关键要求是能够以安全、可靠和匿名的方式从互联车辆和移动设备收集地理参考数据。Nexagon 协议建立在 IETF 定位器/ID 分离协议 &#xff08;…...

React第五十七节 Router中RouterProvider使用详解及注意事项

前言 在 React Router v6.4 中&#xff0c;RouterProvider 是一个核心组件&#xff0c;用于提供基于数据路由&#xff08;data routers&#xff09;的新型路由方案。 它替代了传统的 <BrowserRouter>&#xff0c;支持更强大的数据加载和操作功能&#xff08;如 loader 和…...

数据库分批入库

今天在工作中&#xff0c;遇到一个问题&#xff0c;就是分批查询的时候&#xff0c;由于批次过大导致出现了一些问题&#xff0c;一下是问题描述和解决方案&#xff1a; 示例&#xff1a; // 假设已有数据列表 dataList 和 PreparedStatement pstmt int batchSize 1000; // …...

Typeerror: cannot read properties of undefined (reading ‘XXX‘)

最近需要在离线机器上运行软件&#xff0c;所以得把软件用docker打包起来&#xff0c;大部分功能都没问题&#xff0c;出了一个奇怪的事情。同样的代码&#xff0c;在本机上用vscode可以运行起来&#xff0c;但是打包之后在docker里出现了问题。使用的是dialog组件&#xff0c;…...

mac 安装homebrew (nvm 及git)

mac 安装nvm 及git 万恶之源 mac 安装这些东西离不开Xcode。及homebrew 一、先说安装git步骤 通用&#xff1a; 方法一&#xff1a;使用 Homebrew 安装 Git&#xff08;推荐&#xff09; 步骤如下&#xff1a;打开终端&#xff08;Terminal.app&#xff09; 1.安装 Homebrew…...

Python Einops库:深度学习中的张量操作革命

Einops&#xff08;爱因斯坦操作库&#xff09;就像给张量操作戴上了一副"语义眼镜"——让你用人类能理解的方式告诉计算机如何操作多维数组。这个基于爱因斯坦求和约定的库&#xff0c;用类似自然语言的表达式替代了晦涩的API调用&#xff0c;彻底改变了深度学习工程…...

PHP 8.5 即将发布:管道操作符、强力调试

前不久&#xff0c;PHP宣布了即将在 2025 年 11 月 20 日 正式发布的 PHP 8.5&#xff01;作为 PHP 语言的又一次重要迭代&#xff0c;PHP 8.5 承诺带来一系列旨在提升代码可读性、健壮性以及开发者效率的改进。而更令人兴奋的是&#xff0c;借助强大的本地开发环境 ServBay&am…...

Rust 开发环境搭建

环境搭建 1、开发工具RustRover 或者vs code 2、Cygwin64 安装 https://cygwin.com/install.html 在工具终端执行&#xff1a; rustup toolchain install stable-x86_64-pc-windows-gnu rustup default stable-x86_64-pc-windows-gnu ​ 2、Hello World fn main() { println…...

消防一体化安全管控平台:构建消防“一张图”和APP统一管理

在城市的某个角落&#xff0c;一场突如其来的火灾打破了平静。熊熊烈火迅速蔓延&#xff0c;滚滚浓烟弥漫开来&#xff0c;周围群众的生命财产安全受到严重威胁。就在这千钧一发之际&#xff0c;消防救援队伍迅速行动&#xff0c;而豪越科技消防一体化安全管控平台构建的消防“…...

32单片机——基本定时器

STM32F103有众多的定时器&#xff0c;其中包括2个基本定时器&#xff08;TIM6和TIM7&#xff09;、4个通用定时器&#xff08;TIM2~TIM5&#xff09;、2个高级控制定时器&#xff08;TIM1和TIM8&#xff09;&#xff0c;这些定时器彼此完全独立&#xff0c;不共享任何资源 1、定…...