位置:51电子网 » 技术资料 » 其它综合

Integer寄存器类型

发布时间:2008/6/5 0:00:00 访问次数:847

整数寄存器包含整数值。整数寄存器可以作为普通寄存器使用,典型应用为高层次行为建模。使用整数型说明形式如下:

integer integer1, integer2,. . . intergern [msb:1sb] ;

msb和lsb是定义整数数组界限的常量表达式,数组界限的定义是可选的。注意容许无位界限的情况。一个整数最少容纳32位。但是具体实现可提供更多的位。下面是整数说明的实例。

integer a, b, c; //三个整数型寄存器。
integer hist [3:6]; //一组四个寄存器。

一个整数型寄存器可存储有符号数,并且算术操作符提供2的补码运算结果。
整数不能作为位向量访问。例如,对于上面的整数b的说明,b[6]和b[20:10]是非法的。一种截取位值的方法是将整数赋值给一般的reg类型变量,然后从中选取相应的位,如下所示:

reg [31:0] breg;
integer bint;
. . .
//bint[6]和bint[20:10]是不允许的。
. . .
breg = bint;
/*现在,breg[6]和breg[20:10]是允许的,并且从整数bint获取相应的位值。*/

上例说明了如何通过简单的赋值将整数转换为位向量。类型转换自动完成,不必使用特定的函数。从位向量到整数的转换也可以通过赋值完成。例如:

integer j;
reg [3:0] bcq;

j = 6; //j的值为32'b0000...00110。
bcq = j; // bcq的值为4'b0110。

bcq = 4'b0101.
j = bcq; //j的值为32'b0000...00101。

j = -6; //j 的值为 32'b1111...11010。
bcq = j; //bcq的值为4'b1010。

注意赋值总是从最右端的位向最左边的位进行;任何多余的位被截断。如果你能够回忆起整数是作为2的补码位向量表示的,就很容易理解类型转换。


整数寄存器包含整数值。整数寄存器可以作为普通寄存器使用,典型应用为高层次行为建模。使用整数型说明形式如下:

integer integer1, integer2,. . . intergern [msb:1sb] ;

msb和lsb是定义整数数组界限的常量表达式,数组界限的定义是可选的。注意容许无位界限的情况。一个整数最少容纳32位。但是具体实现可提供更多的位。下面是整数说明的实例。

integer a, b, c; //三个整数型寄存器。
integer hist [3:6]; //一组四个寄存器。

一个整数型寄存器可存储有符号数,并且算术操作符提供2的补码运算结果。
整数不能作为位向量访问。例如,对于上面的整数b的说明,b[6]和b[20:10]是非法的。一种截取位值的方法是将整数赋值给一般的reg类型变量,然后从中选取相应的位,如下所示:

reg [31:0] breg;
integer bint;
. . .
//bint[6]和bint[20:10]是不允许的。
. . .
breg = bint;
/*现在,breg[6]和breg[20:10]是允许的,并且从整数bint获取相应的位值。*/

上例说明了如何通过简单的赋值将整数转换为位向量。类型转换自动完成,不必使用特定的函数。从位向量到整数的转换也可以通过赋值完成。例如:

integer j;
reg [3:0] bcq;

j = 6; //j的值为32'b0000...00110。
bcq = j; // bcq的值为4'b0110。

bcq = 4'b0101.
j = bcq; //j的值为32'b0000...00101。

j = -6; //j 的值为 32'b1111...11010。
bcq = j; //bcq的值为4'b1010。

注意赋值总是从最右端的位向最左边的位进行;任何多余的位被截断。如果你能够回忆起整数是作为2的补码位向量表示的,就很容易理解类型转换。


相关IC型号

热门点击

 

推荐技术资料

罗盘误差及补偿
    造成罗盘误差的主要因素有传感器误差、其他磁材料干扰等。... [详细]
版权所有:51dzw.COM
深圳服务热线:13692101218  13751165337
粤ICP备09112631号-6(miitbeian.gov.cn)
公网安备44030402000607
深圳市碧威特网络技术有限公司
付款方式


 复制成功!