第一章:verilog基础

#verilog 学习笔记


前言

首先说明一下,这些内容仅限“小白”,中高手请自行滤过;

一、进制表示方式

二级制(b):8’b0001_1000;
十进制(d):8’d24;
十六进制(h)8’h18:

二、寄存器类型reg

寄存器表示一个抽象的数据存储单元,通过赋值语句可以改变寄存器储存的值
寄存器数据类型的关键字是 reg,reg 类型数据的默认初始值为不定值x

reg类型的数据只能在 always 语句和 initial 语句中被赋值。
如果该过程语句描述的是时序逻辑,即always语句带有时钟信号,则该寄存器变量对应为触发器;
如果该过程语句描述的是组合逻辑,即always语句不带有时钟信号,则该寄存器变量对应为硬件连线;

二、线网类型wire

线网数据类型表示结构实体(例如门)之间的物理连线。
线网类型的变量不能储存值,它的值是由驱动它的元件所决定的。
驱动线网类型变量的元件有门、连续赋值语句、assign等。
如果没有驱动元件连接到线网类型的变量上,则该变量就是高阻的,即其值为z。

三、运算符

算术运算符

在这里插入图片描述

关系运算符

在这里插入图片描述

逻辑运算符

在这里插入图片描述

条件运算符

在这里插入图片描述

位运算符

在这里插入图片描述

移位运算符

在这里插入图片描述
两种移位运算都用0来填补移出的空位。
左移时,位宽增加;右移时,位宽不变。
4’b1001 << 2 = 6’b100100;
4’b1001 >> 1 = 4’b0100;

拼接运算符

在这里插入图片描述
运算符的优先级
在这里插入图片描述

四、verilog关键字

常用关键字

在这里插入图片描述

五、模块结构

模块 block
在这里插入图片描述
功能定义部分有三种方法:
1、assign语句
描述组合逻辑
2、always语句
描述组合/时序逻辑
3、例化实例元件
如:and #2 u1(q,a,b);

注意: 在always块中,逻辑是顺序执行的。 而多个always块之间是并行的。

模块调用

举例说明:
特别注意的是参数之间的调用在调用时加“#”
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

六、结构语句

initial

语句它在模块中只执行一次。
它常用于测试文件的编写,用来产生仿真测试信号(激励信号),或者用于对存储器变量赋初值。

always

  1. 语句一直在不断地重复活动。 但是只有和一定的时间控制结合在一起才有作用。
  2. always 的时间控制可以是沿触发,也可以是电平触发;
  3. 可以是单个信号,也可以是多个信号,多个信号中间要用关键字 or 连接;
  4. always语句后紧跟的过程块是否运行,要看它的触发条件是否满足。

电平触发的 always 块常常描述组合逻辑行为;
在这里插入图片描述
如果组合逻辑块语句的输入变量很多,那么编写敏感列表会很烦琐并且容易出错。
在这里插入图片描述

@( * )表示对后面语句块中所有输入变量的变化都是敏感的。

组合逻辑电路

组合逻辑电路中,任意时刻的输出仅仅取决于该时刻的输入,与电路原来的状态无关。

时序逻辑电路

时序逻辑电路中,任一时刻的输出不仅取决于当时的输入信号,而且还取决于电路原来的状态。或者说还与以前的输入有关,因此时序逻辑必须具备记忆功能。

七、赋值语句

阻塞赋值

可以认为只有一个步骤的操作:b=a;即计算 RHS 并更新 LHS 。
所谓阻塞的概念是指,在同一个always块中,后面的赋值语句是在前一句赋值语句结束后才开始赋值的。
在这里插入图片描述
在这里插入图片描述

非阻塞赋值

非阻塞赋值的操作过程可以看作两个步骤:
(1) 赋值开始的时候,计算 RHS ;
(2) 赋值结束的时候,更新 LHS 。
所谓非阻塞的概念是指,在计算非阻塞赋值的RHS以及更新LHS期间,允许其他的非阻塞赋值语句同时计算RHS和更新LHS。

非阻塞赋值只能用于对寄存器类型的变量进行赋值,因此只能用在initial块和always块等过程块中。

举例说明
在这里插入图片描述
在这里插入图片描述

阻塞与非阻塞赋值何时使用?

在描述组合逻辑的 always 块中用阻塞赋值 = ,综合成组合逻辑的电路结构;
这种电路结构只与输入电平的变化有关系。
在描述时序逻辑的 always 块中用非阻塞赋值 <=,综合成时序逻辑的电路结构;
这种电路结构往往与触发沿有关系,只有在触发沿时才可能发生赋值的变化。

注意: 在同一个always块中不要既用非阻塞赋值又用阻塞赋值 不允许在多个always块中对同一个变量进行赋值!

八、条件语句

条件语句必须在过程块中使用。

过程块语句是指由initial和always语句引导的块语句。

if_else

if语句对表达式的值进行判断,若为0,x,z,则按假处理;若为1,按真处理。

If/else要配对以避免latch的产生

在这里插入图片描述

case

1、分支表达式的值互不相同;
2、所有表达式的位宽必须相等;
不能用 ’bx 来代替 n’bx
3、casez
比较时,不考虑表达式中的高阻值
4、casex
不考虑高阻值z 和 不定值x

case要配对default使用以避免latch的产生

在这里插入图片描述

在这里插入图片描述

九、状态机

状态机(State Machine)
有限状态机(Finite State Machine,简称FSM)
在有限个状态之间按一定规律转换的时序电路。

在这里插入图片描述
在这里插入图片描述

mealy 状态机

在这里插入图片描述
状态寄存器由一组触发器组成,用来记忆状态机当前所处的状态,状态的改变只发生在时钟的跳变沿。
状态是否改变、如何改变,取决于组合逻辑F的输出,F是当前状态和输入信号的函数。
状态机的输出是由输出组合逻辑G提供的,G也是当前状态和输入信号的函数。 。

Moore状态机

在这里插入图片描述
在这里插入图片描述

如何设计?

四段论

  1. 状态空间定义
  2. 状态跳转
  3. 下个状态判断
  4. 各个状态下的动作

1、状态空间定义

尽量使用读热码

在这里插入图片描述
2、状态跳转(时序逻辑)
在这里插入图片描述

在这里插入图片描述
3、下个状态判断(组合逻辑)
在这里插入图片描述
在这里插入图片描述
4、各个状态下的动作(组合逻辑)
在这里插入图片描述
在这里插入图片描述
一个三段式状态机的典型例子
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

三段式可以在组合逻辑后再增加一级寄存器来实现时序逻辑输出:
1、可以有效地滤去组合逻辑输出的毛刺;
2、可以有效地进行时序计算与约束;
3、另外对于总线形式的输出信号来说,容易使总线数据对齐,从而减小总线数据间 的偏移,减小接收端数据采样出错的频率。

在这里插入图片描述
至此,基础知识部分就讲解完了,这个基础部分建议大家是不是的回头看下。

数据治理是确保数据准确性、可靠性、安全性、可用性和完整性的体系和框架。它定义了组织内部如何使用、存储、保护和共享数据的规则和流程。数据治理的重要性随着数字化转型的加速而日益凸显,它能够提高决策效率、增强业务竞争力、降低风险,并促进业务创新。有效的数据治理体系可以确保数据在采集、存储、处理、共享和保护等环节的合规性和有效性。 数据质量管理是数据治理中的关键环节,它涉及数据质量评估、数据清洗、标准化和监控。高质量的数据能够提升业务决策的准确性,优化业务流程,并挖掘潜在的商业价值。随着大数据和人工智能技术的发展,数据质量管理在确保数据准确性和可靠性方面的作用愈发重要。企业需要建立完善的数据质量管理和校验机制,并通过数据清洗和标准化提高数据质量。 数据安全与隐私保护是数据治理中的另一个重要领域。随着数据量的快速增长和互联网技术的迅速发展,数据安全与隐私保护面临前所未有的挑战。企业需要加强数据安全与隐私保护的法律法规和技术手段,采用数据加密、脱敏和备份恢复等技术手段,以及加强培训和教育,提高安全意识和技能水平。 数据流程管理与监控是确保数据质量、提高数据利用率、保护数据安全的重要环节。有效的数据流程管理可以确保数据流程的合规性和高效性,而实时监控则有助于及时发现并解决潜在问题。企业需要设计合理的数据流程架构,制定详细的数据管理流程规范,并运用数据审计和可视化技术手段进行监控。 数据资产管理是将数据视为组织的重要资产,通过有效的管理和利用,为组织带来经济价值。数据资产管理涵盖数据的整个生命周期,包括数据的创建、存储、处理、共享、使用和保护。它面临的挑战包括数据量的快速增长、数据类型的多样化和数据更新的迅速性。组织需要建立完善的数据管理体系,提高数据处理和分析能力,以应对这些挑战。同时,数据资产的分类与评估、共享与使用规范也是数据资产管理的重要组成部分,需要制定合理的标准和规范,确保数据共享的安全性和隐私保护,以及建立合理的利益分配和权益保障机制。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值