VerilogHDL的无符号数和有符号数运算_第1页
VerilogHDL的无符号数和有符号数运算_第2页
VerilogHDL的无符号数和有符号数运算_第3页
VerilogHDL的无符号数和有符号数运算_第4页
VerilogHDL的无符号数和有符号数运算_第5页
已阅读5页,还剩2页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、verilog分类:资料摘录2011-05-0917:161213人阅读评论(2)收藏举报目录(?)+在数字电路中,出于应用的需要,我们可以使用无符号数,即包括0及整数的集合;也可以使用有符号数,即包括0和正负数的集合。在更加复杂的系统中,也许这两种类型的数,我们都会用到。有符号数通常以2的补码形式来表示。图1列出了4位二进制表示法所对应正负数。进一步观察,我们发现两种类型数的加减法是一样的,做加法和减法就是在数轮上按正时钟转转或按反时钟转。比方说,1001+0100,意味着从1001按照顺时钟方向移动4个位置,其结果为1101。在无符号数类型中,它代表(+9)+(+4)=+13;而在有符号数

2、类型中,它则代表(-7)+(+4)=-3。从数轮上看,若是加法所得的结果溢出了,那么也就是穿越了数轮的临界点。注意这个临界点对于无符号数和有符号数来说,是不一样的:无符号数,是介于1111和0000之间;有符号数,则是介于0111和1000之间。物理加减法的行为正好和数轮的移动类似。只要所有的运算子和结果具有相同的位宽,那么有符号数或无符号数的形式就可用于相同的电路。比方说,设a、b和sum都是8位信号,表达式无论这些信号被转译成有符号数或无符号数,它都会引用相同的硬件且使用相同的二进制表示法。这种现象在其他算术运算中也是正确的(但是它不可用于非算术运算中,比方说有理数运算或溢出标志位的生成)

3、。ThrasholdofoverflowforunsignediDim吕t$ub|r4cia阿塔他阳日mounlTreibclddorerflawitwsignedformat图14位二进制数轮此外,当运算子或其结果的位宽不同时,我们需要区分它究竟使用哪一种符号类型。因为不同的符号类型需要不同的扩展位。对于无符号数,前置一个0,即所谓的零扩展位;对于有符号数来说,需要前置n个所谓的符号扩展位。比方说4位二进制表示的-5为1011;当其扩展成8位时,应该变为1111_1011,而不是0000_1011。举个例子,设a和sum为8位信号,b为4位信号即b3b2b1b0。表达式需要将b扩展为8位。如

4、果是无符号数形式,那么b扩展为0000_b3b2b1b0;如果是有符号数形式,那么b扩展为b3b3b3b3_b3b2b1b0。上述表达式所引用的硬件包括位宽扩展电路和加法器。因为对于有符号数和无符号数来说,扩展电路是不同的;所以上面那个表达式,对应有符号数和无符号数形式,要使用不同的硬件实现。2Verilog-1995中的有符号数在Verilog-1995中,只有integer数据类型被转移成有符号数,而reg和wire数据类型则被转移成无符号数。由于integer类型有固定的32位宽,因此它不太灵活。我们通常使用手动加上扩展位来实现有符号数运算。下面的代码片段将描述有符号数和无符号数的运算:

5、在第一条语句中,a、b和suml有相同的位宽,因此无论是转译成有符号数还是无符号数,它都将引用相同的加法器电路。在第二条语句中,c的位宽仅为4,在加法运算中,它的位宽会被调整。因为reg类型被作为无符号数看待,所以c的前面会被自动置入0扩展位。在第三条语句中,我们给c手动前置4个0,以实现和第二个表达式一样的效果。在第四条语句中,我们需要把变量转译成有符号数。为了实现所需的行为,c必须扩展符号位到8位。没有其他的办法,只好手动扩展。在代码中,我们重复复制c的最高位4次(4c3)来创建具有扩展符号位的8位数。3Verilog-2001中的有符号数在Verilog-2001中,有符号形式也被扩展到

6、reg和wire数据类型中。哈哈,新加一个关键字,signed,可以按照下面的方式定义:使用有符号数据类型,第2节所述代码可以被改写为:第一条语句将引用一个常规的加法器,因为a、b和suml具有相同的位宽。第二条语句,所有的右手边变量都具有signed数据类型,c被自动扩展符号位到8位。因此,无需再手动添加符号位。在小型的数字系统中,我们通常可以选用有符号数或者无符号数。然而,在一些大型的系统中,会包括不同形式的子系统。Verilog是一种弱类型语言,无符合变量和有符号变量可以在同一表达式中混用。根据Verilof的标准,只有当所有右手边的变量具有signed数据类型属性的时候,扩展符号位才被

7、执行。否则,所有的变量都只扩展0。考虑下面的代码片段:由于c不具有signed数据类型属性,因此右手边的变量b和c的扩展位为0。Verilog有两个系统函数,$signed和$口门signed(),用以将括号内的表达式转换为signed和unsigned数据类型。比方说,我们可以转换c的数据类型,现在,右手边的所有变量都具有signed数据类型属性,因此b和c将扩展符号位。在复杂的表达式中,混用signed和unsigned数据类型将引入一些微妙的错误,因此应当避免混用。如果真的很有必要,那么表达式需要保持简单,同时通用转换函数,以确保数据类型的一致性。VerilogHDL分类:技术心得201

8、1-04-2922:44422人阅读评论(0)收藏举报执行算术操作和赋值时,注意哪些操作数为无符号数、哪些操作数为有符号数非常重要。无符号数存储在:*线网*一般寄存器基数格式表示形式的整数有符号数存储在:整数寄存器十进制形式的整数下面是一些赋值语句的实例:reg0:5Bar;integerTab;Bar=-4d12;/寄存器变量的十进制数为,向量值为Tab=-4d12;整数的十进制数为,位形式为。-4d12/4/结果是10737。41821-12/4/结果是-3因为是普通寄存器类型变量,只存储无符号数。右端表达式的值为(的二进制补码)。因此在赋值后,存储十进制值。在第二个赋值中,右端表达式相同

9、,值为,但此时被赋值为存储有符号数的整数寄存器。存储十进制值一(位向量为)。注意在两种情况下,位向量存储内容都相同;但是在第一种情况下,向量被解释为无符号数,而在第二种情况下,向量被解释为有符号数。下面为具体实例:Bar=-4d12/4;Tab=-4d12/4;Bar=-12/4Tab=-12/4在第一次赋值中,被赋于十进制值(位向量为)。而在第二个赋值中,被赋于与十进制(位值为)。在第三个赋值中赋于与第一个赋值相同的值。这是因为只存储无符号数。在第四个赋值中,被赋于十进制值一。下面是另一些例子:Bar=4-6;Tab=4-6;Bar被赋于十进制值(一的二进制补码),而被赋于十进制值一(位向量为,)。,注面为另一个实例:Bar=-2+(-4);Tab=-2+(-4);Bar被赋于十进制值(位向量为),而被赋于十进制值一(位向量为1110)1。0因为对跟型变量的乘法(都默认为无符号数相乘,所以不能直接用号来表示。我是这样处理的:先把两个操作数变为源码,再用循环进行移位相加,结果是对的,但是综合出来的结果占有的资源比较多,比直接调用库里的乘法器占用资源

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论