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 中使用不同基数表示数字常量的方法:
二进制 (Binary): 使用
b
或B
作为后缀。
- 示例:
4'b0011
表示一个4位宽的二进制数,值为3。八进制 (Octal): 使用
o
或O
作为后缀。
- 示例:
3'o5
表示一个3位宽的八进制数,其值为5(即十进制中的5)。十进制 (Decimal): 可以直接书写数字,或者使用
d
或D
作为后缀。
- 示例:
8
或4'd8
表示一个4位宽的十进制数,值为8。如果宽度不足以容纳该值,则会发生截断或填充。十六进制 (Hexadecimal): 使用
h
或H
作为后缀。
- 示例:
8'hAA
表示一个8位宽的十六进制数,值为170(AA是十六进制表示)。
当指定一个带宽度的常量时,格式为 <width>'<radix><value>,其中:
<width>
是一个正整数,指定了该数值的位宽。<radix>
是表示基数的字母(如 b, o, d, h)。<value>
是根据所选基数的实际数值。
例如:
8'b1100_1100
表示一个8位宽的二进制数,值为204(允许下划线以提高可读性)。16'hFFFF
表示一个16位宽的十六进制数,所有位均为1。
如果没有明确给出宽度,那么默认的宽度将取决于上下文,或者是工具设定的默认值。对于十进制数,如果不指定基数,可以直接写成纯数字形式,如 123
,它会被认为是一个十进制数。
2.1 基数符号
- 二进制 (Binary): b 或 B
- 八进制 (Octal): o 或 O
- 十进制 (Decimal): d 或 D (但通常可以省略)
- 十六进制 (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) |
---|---|
0000 | 0 |
0001 | 1 |
0010 | 2 |
0011 | 3 |
0100 | 4 |
0101 | 5 |
0110 | 6 |
0111 | 7 |
1000 | 8 |
1001 | 9 |
1010 | 10 |
1011 | 11 |
1100 | 12 |
1101 | 13 |
1110 | 14 |
1111 | 15 |
二. 二进制与十进制数
解析二进制数为十进制数
要解析一个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;
[3:0]
表示这是一个4位宽的寄存器。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)
- 过程赋值使用
<=
,而连续赋值使用=
. clk
是时钟信号,posedge
表示在时钟上升沿触发。
3.4 解析二进制数为十进制数
// 计算二进制1101对应的十进制值
integer decimalValue;
always @(*) begin // 组合逻辑块decimalValue = 8 * myRegister[3] + 4 * myRegister[2] + 2 * myRegister[1] + 1 * myRegister[0];
end
- 这里使用了组合逻辑块
@(*)
来确保每当输入发生变化时都会重新计算。 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位二进制数解析为十进制的过程。注意,这里为了简化演示,省略了复位逻辑和其他可能需要的功能。在实际应用中,您应该根据需求添加适当的控制逻辑。
五. 注意事项
- 不要混淆
reg
和wire
:虽然它们可以有相同的位宽,但用途不同,reg
用于保存状态,而wire
必须由其他逻辑驱动。 - 初始化问题:在仿真环境中,未初始化的
reg
变量默认为未知状态'x'
,这可能导致意外行为。 - 溢出处理:当对寄存器进行算术运算时,请确保不会超出其位宽所能表示的最大值,否则会导致溢出。
- 资源优化:合理规划位宽可以节省硬件资源,在FPGA上尤为重要。
本文总结
理解和正确使用二进制数是数字逻辑设计的基础。通过本文,希望你能更好地掌握4位二进制数在Verilog中的表示方法及应用技巧。无论是学习还是实际项目开发中,都应牢记上述注意事项,以编写高效且可靠的代码。
六. 更多操作
早期,之前的基数介绍,请看
FPGA 9 ,Verilog 中的关键字和基数https://blog.csdn.net/weixin_65793170/article/details/141625021完整FPGA系列,请看
FPGA系列,文章目录https://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客户端,它允许用户与Redis数据库进行交互和管理。 以下是一些常用参数的使用说明: 基本连接参数 -h, --host <hostname>:指定要连接的Redis服务器的主机名或IP地址。如果未指定,…...

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

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

家里温度随心控,假期出行更舒适~
春节假期马上到来啦!这是放松身心、陪伴家人的最佳时机~ 但旅途结束的温差变化、空气质量问题是否让你有些担忧呢? 别担心!有了约克VRF中央空调,让你的假期更加舒心无忧~ 清新空气,自在出游…...
压力测试详解
压力测试 压力测试是一种软件测试,用于验证软件应用程序的稳定性和可靠性。压力测试的目标是在极其沉重的负载条件下测量软件的健壮性和错误处理能力,并确保软件在危急情况下不会崩溃。它甚至可以测试超出正常工作点的测试,并评估软件在极端…...

从epoll事件的视角探讨TCP:三次握手、四次挥手、应用层与传输层之间的联系
目录 一、应用层与TCP之间的联系 二、 当通信双方中的一方如客户端主动断开连接时,仅是在客户端的视角下连接已经断开,在服务端的眼中,连接依然存在,为什么?——触发EPOLLRDHUP事件:对端关闭连接或停止写…...

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

[云讷科技] 用于软件验证的仿真环境
我们使用Pursuit自动驾驶仪为各种场景设计仿真环境,以便用户可以在模拟环境中直接验证他们的软件,无需现场测试。该环境基于Gazebo引擎。 1. 工作区目录 模拟环境的工作区位于提供的U盘中的~/pursuit_space/sitl_space_pursuit中。用户可以按照用户手册…...
使用 Vite 和 Vue 框架创建组件库
在前端开发中,组件化开发已成为一种高效、可维护的方式。通过创建组件库,不仅可以提高代码复用率,还能方便地在不同项目之间共享组件。本文将详细介绍如何使用 Vite 和 Vue 框架创建一个组件库,并将其导出供其他项目使用。为保持一…...
【数据结构学习笔记】19:跳表(Skip List)
介绍 跳表是一个能在 O ( n l o g n ) O(nlogn) O(nlogn)时间完成查找、插入、删除的数据结构,相比于树形结构优点就是很好写(所以也用于实现Redis ZSet)。其核心思想就是维护一个元素有序的,能随机提升索引层数的链表。最下面一…...
【8】深入理解 Go 语言中的协程-从基础到高级应用
文章目录 一、引言 🌟二、协程基础概念 🧐(一)什么是协程(二)协程与线程、进程的区别三、协程的创建与启动 🚀(一)使用 go 关键字创建协程(二)简单…...

深入理解 ECMAScript 2024 新特性:字符串 isWellFormed 方法
ECMAScript 2024 引入了一个新的字符串实例方法: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 转换成小写字母)
题目:给你一个字符串 s ,将该字符串中的大写字母转换成相同的小写字母,返回新的字符串。 示例 1: 输入:s "Hello" 输出:"hello"示例 2: 输入:s "here…...

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

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

【微服务】面试 3、 服务监控 SkyWalking
微服务监控的原因 问题定位:在微服务架构中,客户端(如 PC 端、APP 端、小程序等)请求后台服务需经过网关再路由到各个微服务,服务间可能存在多链路调用。当某一微服务挂掉时,在复杂的调用链路中难以迅速确定…...

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

Linux_信号
信号的概念 && 知识补充 信号是进程之间事件异步通知的一种方式,是一种软中断。 标准信号:编号为1-31之间都是标准信号,这些都是预定义信号,用于通知进程发生的各种事件。实时信号:编号从32开始起均是实时信号…...

LeetCode100之搜索二维矩阵(46)--Java
1.问题描述 给你一个满足下述两条属性的 m x n 整数矩阵: 每行中的整数从左到右按非严格递增顺序排列。每行的第一个整数大于前一行的最后一个整数。 给你一个整数 target ,如果 target 在矩阵中,返回 true ;否则,返回…...

学员答疑:安卓分屏窗口的TouchableRegion设置流程追踪
背景: vip学员在群里问到了一个分屏触摸区域设置的问题,开始以为就是和普通Activity设置区域没啥差别,都是在InputMonitor中进行的设置,但是仔细研究下来其实并不是哈。本文就带大家来手把手分析一下分屏情况下的触摸区域是怎么设置的。 d…...
[cg] UE5 调试技巧
UE 中 rhi命令的提交是在render 线程,而graphics api 真正的执行是在rhi 线程, 今天想看下rhi的底层调用,但由于是通过task执行的,无法获取到render thread传入的地方,调试起来不太方便。 可通过开启下面的命令来调试 …...

Python Wi-Fi密码测试工具
Python Wi-Fi测试工具 相关资源文件已经打包成EXE文件,可双击直接运行程序,且文章末尾已附上相关源码,以供大家学习交流,博主主页还有更多Python相关程序案例,秉着开源精神的想法,望大家喜欢,点…...
Linux 创建用户
Linux 创建用户 创建用户 sudo useradd -m -s /bin/bash test - -m:自动创建家目录 /home/test - -s /bin/bash:指定默认的 shell 为 bash修改密码 # 修改密码 sudo passwd test删除用户 userdel -r zengshun - -r:把用户的主目录一起删…...

自建RustDesk服务器
RustDesk服务端 下面的截图是我本地的一个服务器做为演示用,你自行的搭建服务需要该服务器有固定的ip地址 1、通过宝塔面板快速安装 2、点击【安装】后会有一个配置信息,默认即可 3、点击【确认】后会自动安装等待安装完成 4、安装完成后点击【打开…...
Spring Boot Web技术栈(官网文档解读)
摘要 Spring Boot框架既支持传统的Servlet技术栈,也支持新兴的响应式(Reactive)技术栈。本篇文章将详细讲述Spring Boot 对两种技术栈的详细支持和使用。 Servlet 概述 基于Java Servlet API构建,它依赖于传统的阻塞I/O模型&…...
【llama_factory】qwen2_vl训练与批量推理
训练llama factory配置文件 文件:examples/train_lora/qwen2vl_lora_sft.yaml ### model model_name_or_path: qwen2_vl/model_72b trust_remote_code: true### method stage: sft do_train: true finetuning_type: lora lora_target: all### dataset dataset: ca…...
wpa_cli命令使用记录
wpa_cli可以用于查询当前状态、更改配置、触发事件和请求交互式用户输入。具体来说,它可以显示当前的认证状态、选择的安全模式、dot11和dot1x MIB等,并可以配置一些变量,如EAPOL状态机参数。此外,wpa_cli还可以触发重新关联和IEE…...