数字图像处理(3):Verilog中的有符号数、有符号数的计算

(1)原码、补码、反码:

  • 正数的原码、补码、反码都是其本身。
  • 负数的原码:最高位(符号位)等于1,然后再用剩余位表示其相反数。
  • 负数的反码:除了符号位以外的剩余其他位取反。
  • 负数的补码:对应反码+1

(2)有符号数和无符号数

  • 事实上,FPGA内部是不分正还是负的,它就只是二进制数字而已,对于正数和无符号数,存储的就是原码,而对于有符号的负数而言,存储的就是补码,因此一个8位的有符号数,可以表示:-128~127,256个数。其中1000_0000,对应的十进制数是负的(111_1111 + 1 = 1000_0000),即-128。
  • 在FPGA中,可以使用"signed"关键词开定义有符号数,如果没有"signed"修饰,则默认为无符号数。例如: reg signed [7:0] a; 表示定义了一个八位的有符号寄存器变量a。

(3)在进行加法、减法、乘法运算时,有符号数和无符号数会有不同的处理方式。加了signed关键词在运算时,会将数据扩位至相同位宽,然后按照有符号位的运算规则进行处理。

注意:有符号数和无符号数不同混合运算,否则容易出错。

可以看到在有符号数和无符号数进行运算时,会把有符号数看成无符号数进行计算,此时-10的补码是1111_0110,无符号数的246,加上5,等于251。

相关推荐
happyDogg_15 小时前
验证环境采样rtl时序数据遇到的问题
fpga开发
unicrom_深圳市由你创科技17 小时前
项目分析和FPGA器件选型外包服务包括哪些内容?别让选错芯片毁了整个项目
fpga开发
Aaron158817 小时前
27DR/47DR/67DR技术对比及应用分析
人工智能·算法·fpga开发·硬件架构·硬件工程·信息与通信·基带工程
my_daling18 小时前
DSMC通信协议理解,以及如何在FPGA上实现DSMC从设备(2)
学习·fpga开发
珞光电子USRP SDR软件无线电平台1 天前
打破通用瓶颈:珞光电子发布 Luowave Driver V2 定制化驱动方案
fpga开发
9527华安1 天前
FPGA实现PCIe数据通信培训课程,提供工程源码+视频教程+FPGA开发板
fpga开发·pcie·视频教程·培训
my_daling1 天前
FPGA实现IIC主机读写,以及部分IIC传感器控制流程
fpga开发
乌恩大侠2 天前
【AI-RAN】在空ubuntu服务器安装环境和生成TV,高达430G文件
服务器·人工智能·ubuntu·fpga开发·o-ru
qq_150841992 天前
高云FPGA固件下载速成
fpga开发
一个平凡而乐于分享的小比特2 天前
一文读懂MCU与FPGA:核心区别、协同之道与双修秘籍
单片机·fpga开发·职场发展·mcu开发