Verilog 变量中位的数值类型

Verilog变量中每个位(bit)的数值类型有四种,分别为1,0,Z,X。其中1,0比较明确就是高、低电平。而x, z在逻辑设计中也经常用到来建模。X,Z既可以大写,也可以使用小写字母。

  • 0:逻辑 0 或 “假”
  • 1:逻辑 1 或 “真”
  • x 或 X:未知
  • z 或 Z:高阻
  • X表示其值不确定,可能为0,也可能为1;
  • 从高低电平的角度看,四值含义如下表所示:
Verilog中4个逻辑值
逻辑 0 表示低电平,对应电路 为GND,或逻辑电路输出为低电平。  
逻辑 1 表示高电平,对应电路的 VCC,或逻辑电路输出为高电平  
逻辑 X 表示未知,有可能是高电平,也有可能是低电平。  
逻辑 Z 表示高阻态,是一个悬浮状态,如三态门,OC门,OD门等。  

关于X和Z的用法,可以参见 Verilog中X的用法,Verilog中 Z的用法。

数值表示方法

数字声明时,合法的基数格式有 4 中,包括:十进制(‘d 或 ‘D),十六进制(‘h 或 ‘H),二进制(’b 或 ‘B),八进制(’o 或 ‘O)。数值可指明位宽,也可不指明位宽。位宽就是在进制符号前加一个数字表示该数字对应的二进制的位数。如 8’d11,表示数字的大小是十进制的11,但位的宽度为8位的二进制数。也就是8’b0000_1011;

下划线”_”用来起到隔离的作用,不影响数值的大小,目的是提高代码的可读性。

二进制:

二进制数可以用0,1 ,Z,X;如果使用二进制,必须使用’b 或’B引导。

例:

wire a = 1’b0;

reg   b = 1’b1;

wire c;

assign c = 1’bZ;

wire [7:0] tmp_a = 8’b100Z_XX01;

十进制:

十进制的基数是0,1,2,3,4,5,6,7,8,9。即0~9十个数字。

其中十进制整数可以直接使用,如果没有指定基数格式的整数,默认为十进制。十进制中不能包含X或Z的值。如 wire [7:0] a=7;没有指定位宽,编译器会实现自动匹配,匹配方式为右对齐。 即 a[7:0] = 8’b0000_0111;左边以0补齐。

wire [7:0] a = 7;//等效为 wire [7:0] a = 8’d7;

其中8’表示位宽,是8位二进制位宽,d表示十进制数。

16进制:

十六进制的基数除了0~9十个数字外,还包含a,b,c,d,e,f六个字符,每个16进制字符可以等效4位2进制数。如:4’h6与4’b0110等效。如果使用X或Z,则表示4位二进制的值都是X或Z。如4’hZ 等效为4’bZZZZ,4’hX 等效为4’bXXXX。16‘H12Z0等效于16’b0001_0010_ZZZZ_0000。

8进制:

8进制的基数只有0~7,没有8,9 两个数字,逢8进1.

8进制的用法与16进制的用法类似,每个八进制符号表示3位二进制数。wire [7:0] a=8’o367;等效的2进制表达方式 wire [7:0] a=8’b11_110_111;由于受位宽的限制,该八进制数的最左边的只有两位,因此最大只能是3,

例:

1
2
3
4
5
6
7
wire         a = 1’b1;
wire [3:0]   b = 4’HZ;
 
reg  [7:0]   c = 8’d24;
reg  [15:0]  d = 16’H5ZX3;
reg  [9:0]   count = 10;       //10默认为十进制数
reg  [7:0]   ma = ’b1010_0011; //没有指定位宽,编译器自动推断

Verilog 变量中位的数值类型的更多相关文章

  1. C++11中string与数值类型的转换

    C++中string与数值类型的相互转换记录 string转int.double.long string s = "123.456"; // string -> int co ...

  2. C# 中的基本数值类型

    在之前的文章中(地址:https://www.vinanysoft.com/c-sharp-basics/introducing/),以 HelloWorld 程序为基础,介绍 C# 语言.它的结构. ...

  3. 在javaScript中把非数值类型的数据自动转换为数值类型的两种方式

    一.使用Number()函数. 二.使用parseInt()/parseFloat()函数. 详情: 一.使用Number()函数将非数值类型的数据自动的转化为数组类型 Number()函数可以将任何 ...

  4. php变量中两种特殊类型

    第一种----资源 资源(resource):资源是由专门的函数来建立和使用的,例如打开文件.数据连接.图形画布.我们可以对资源进行操作(创建.使用和释放).任何资源,在不需要的时候应该被及时释放.如 ...

  5. Java中初级数值类型的大小, volatile和包装类wrapped type的比较

    Java中的初级数值类型 Java是静态类型语言, 所有的变量必须先声明再使用. 其初级类型一共8种: boolean: 数据只包含1bit信息, 但是占空间为8-bit, 默认值为false byt ...

  6. verilog中wire与reg类型的区别

    每次写verilog代码时都会考虑把一个变量是设置为wire类型还是reg类型,因此把网上找到的一些关于这方面的资料整理了一下,方便以后查找. wire表示直通,即只要输入有变化,输出马上无条件地反映 ...

  7. Python中的数值类型总结

    本文参考书:<Learning Python>中文版--<Python 学习手册>第四版 Python中包含大量的数值类型,他们中的大部分与其他编程语言保持一致,因此学习他们就 ...

  8. 微软BI 之SSIS 系列 - 2008 版本中变量 Int64 无法保存 bigint 类型数据的BUG

    开篇介绍 这是今天在帮别人看一个 2008R2 版本的项目时发现的一个 Bug,这个 Bug 在 SQL SERVER 2012 有的版本中可能已经解决,但在论坛上看到有的仍然存在. 在 SQL SE ...

  9. 当向计算机中存入一个float类型的数值2.2 后,在从计算机中读出输出,这时2.2 的值已经发生了变化(转)

    problom : 'f1' value hava been changed when output. reason : the binary repersentation of 2.2f is : ...

  10. C#保留2位小数几种场景总结 游标遍历所有数据库循环执行修改数据库的sql命令 原生js轮盘抽奖实例分析(幸运大转盘抽奖) javascript中的typeof和类型判断

    C#保留2位小数几种场景总结   场景1: C#保留2位小数,.ToString("f2")确实可以,但是如果这个数字本来就小数点后面三位比如1.253,那么转化之后就会变成1.2 ...

随机推荐

  1. 日志参数 %n 引起的coredump

    今天测试发现一段代码 coredump,居然是一行日志输出.看参数都乱了,以为是内存溢出造成的.查了半天,也没发现问题 最后把前边的函数调用都注释掉,只运行这一段日志输出,依然挂掉 仔细一看: TRA ...

  2. 《Rust权威指南》学习笔记——4. 认识所有权

    Rust权威指南学习笔记--认识所有权 什么是所有权 1. 所有权规则 Rust中的每一个值都有一个对应的变量作为它的所有者. 在同一时间内,值有且仅有一个所有者. 当所有者离开自己的作用域时,它持有 ...

  3. UI动画练习 - CABasicAnimation:视图绕X/Y轴旋转(3D效果)

    视图 3D 旋转 1 - 代码示例:以绕 X 轴旋转为例 1 #import "ViewController.h" 2 @interface ViewController () 3 ...

  4. NDK 减少 so 库体积方法总结

    . 使用 strip 使用 NDK toolchain 可以把调试的 C++ 符号表(Symbol Table)中数据删除,我们一般我们打成 APK 会自动帮我们做这个工作,当然也可以手动设置: 手动 ...

  5. [Oracle19C 数据库管理] 加载和传输数据库

    移动数据的通用架构 数据泵data pump(impdp, expdp),借助DBMS_DATAPUMP存储过程,可以进行表的导出导入,行记录的导出导入,表空间的导出导入或者整个schema的导出导入 ...

  6. 【NPDP专项练习】第五章 工具与绩效度量

    第五章 工具与绩效度量 1.这是一种使用一系列的迭代轮数通过专家组对未来可能的一种预测 A 决策一制作方法论 B 德尔菲 C 实施路线 D 组合标准 答案:B 解析 德尔菲流程(DelphiProce ...

  7. Excel error - the macros in this project are disabled, please refer to the online help or documentation of the host application to determine how to enable macros.

    alt+F11 进入vba界面,F5运行macro后报错. Sub 合并当前工作簿下的所有工作表() Application.ScreenUpdating = False For j = 1 To S ...

  8. IIS添加MIME类型实现未知文件下载

    application/octet-stream 无需重启

  9. 【笔记】DDD实战课-人保架构欧创新

    目录 开篇 学好DDD,你能做什么? 基础 领域驱动设计:微服务设计为什么要选择 DDD? DDD的两层设计 DDD与微服务的关系 领域.子域.核心域.通用域和支撑域:傻傻分不清? 领域和子域 核心域 ...

  10. php7安装mogodb

    本文教程只在 PHP7 安装使用!!! PHP7 Mongdb 扩展安装 我们使用 pecl 命令来安装: $ /usr/local/php7/bin/pecl install mongodb 执行成 ...