博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
verilog中符号位的扩展问题
阅读量:7094 次
发布时间:2019-06-28

本文共 1906 字,大约阅读时间需要 6 分钟。

以下内容转自 艾米电子 - 使用有符号数,Verilog(http://www.cnblogs.com/yuphone/archive/2010/12/12/1903647.html)

 

Verilog-1995中的有符号数

在Verilog-1995中,只有integer数据类型被转移成有符号数,而reg和wire数据类型则被转移成无符号数。由于integer类型有固定的32位宽,因此它不太灵活。我们通常使用手动加上扩展位来实现有符号数运算。下面的代码片段将描述有符号数和无符号数的运算:

1 reg [7:0] a, b; 2 reg [3:0] c, 3 reg [7:0] sum1, sum2, sum3, sum4; 4 . . . 5 // same width. can be applied to signed and unsigned 6 sum1 = a + b; 7 // automatica 0 extension 8 sum2 = a + c; 9 // manual 0 extension10 sum3 = a + {
{
4{
1'b0}}, c};11 // manual sign extension12 sum4 = a + {
{
4{c[3]}}, c};

在第一条语句中,a、b和sum1有相同的位宽,因此无论是转译成有符号数还是无符号数,它都将引用相同的加法器电路。

在第二条语句中,c的位宽仅为4,在加法运算中,它的位宽会被调整。因为reg类型被作为无符号数看待,所以c的前面会被自动置入0扩展位。

在第三条语句中,我们给c手动前置4个0,以实现和第二个表达式一样的效果。

在第四条语句中,我们需要把变量转译成有符号数。为了实现所需的行为,c必须扩展符号位到8位。没有其他的办法,只好手动扩展。在代码中,我们重复复制c的最高位4次(4{c[3]})来创建具有扩展符号位的8位数。

3 Verilog-2001中的有符号数

在Verilog-2001中,有符号形式也被扩展到reg和wire数据类型中。哈哈,新加一个关键字,signed,可以按照下面的方式定义:

reg signed [7:0] a, b

使用有符号数据类型, 第2节所述代码可以被改写为:

reg signed [7:0] a, b;reg signed [3:0] c;reg signed [7:0] sum1, sum4;. . .// same width. can be applied to signed and unsignedsum1 = a + b;// automatic sign extensionsum4 = a + c;

第一条语句将引用一个常规的加法器,因为a、b和sum1具有相同的位宽。

第二条语句,所有的右手边变量都具有signed数据类型,c被自动扩展符号位到8位。因此,无需再手动添加符号位。

 

在小型的数字系统中,我们通常可以选用有符号数或者无符号数。然而,在一些大型的系统中,会包括不同形式的子系统。Verilog是一种弱类型语言,无符合变量和有符号变量可以在同一表达式中混用。根据Verilof的标准,只有当所有右手边的变量具有signed数据类型属性的时候,扩展符号位才被执行。否则,所有的变量都只扩展0。考虑下面的代码片段:

1 reg signed [7:0] a, sum;2 reg signed [3:0] b;3 reg [3:0] c;4 . . .5 sum = a + b + c;

由于c不具有signed数据类型属性,因此右手边的变量b和c的扩展位为0。

Verilog有两个系统函数,$signed和$unsigned(),用以将括号内的表达式转换为signed和unsigned数据类型。比方说,我们可以转换c的数据类型,

sum = a + b + $signed(c);

现在,右手边的所有变量都具有signed数据类型属性,因此b和c将扩展符号位。

在复杂的表达式中,混用signed和unsigned数据类型将引入一些微妙的错误,因此应当避免混用。如果真的很有必要,那么表达式需要保持简单,同时通用转换函数,以确保数据类型的一致性。

posted on
2016-07-01 12:24 阅读(
...) 评论(
...)

转载于:https://www.cnblogs.com/christsong/p/5632644.html

你可能感兴趣的文章
如何保证CAN网络中通讯的可靠性和节点数
查看>>
衡量云性能:我们需要一把不同于以往的标尺
查看>>
干货|大数据应用:前端模块化开发的价值
查看>>
美国互联网瘫痪谁背锅?安全机构曝光部分厂商名单
查看>>
开发者论坛一周精粹(第十八期) :第一期阿里云高校工作坊申办启动
查看>>
人工智能、机器学习、深度学习的区别在哪?
查看>>
基于Java Socket的自定义协议,实现Android与服务器的长连接(一)
查看>>
中了敲诈者病毒,文件恢复有可能吗?你长着一张被勒索木马敲诈的脸?| 硬创公开课...
查看>>
能否预测下一个安全漏洞?
查看>>
第三季度服务器DRAM合约价续扬,预估季增3%~8%
查看>>
流处理技术谬见大消除
查看>>
是什么让5G的峰值速度高达20Gb/s?一文看懂毫米波技术
查看>>
PyPy 双版本同步更新,不仅仅是快
查看>>
图表绘制与处理的常用软件
查看>>
TensorFlow教程之API DOC 6.1.14 Struct tensorflow::Status::State
查看>>
成立金融创新实验室,香港金管局在Fintech上又迈了一步
查看>>
【智驾深谈】曝光Waymo无人车商业化三大专利:方向盘,运营系统和远程诊断...
查看>>
2016中美项目秋季交流会,来自硅谷的人工智能有哪些新创意?
查看>>
给数字世界加道“安全阀门”
查看>>
全国首个健康城市大数据平台落地平度
查看>>