Verilog 入门(九)(建模实例)

文章目录

  • 建模的不同方式
  • 条件操作建模
  • 通用移位寄存器
  • 状态机建模
  • Moore 有限状态机建模
  • Mealy 型有限状态机建模

建模的不同方式

分别使用数据流方式、行为方式和结构方式对下图所示的电路进行建模:

在这里插入图片描述
数据流方式:使用连续赋值语句对电路建模

module Save_Mult_Df(A, C, ClkB, Z);input[0:7] A;input[0:3] C;input ClkB;output[0:11] Z;wire S1;assign Z = S1 * C;assign S1 = ClkB ? A : S1;
endmodule

行为方式:使用带有顺序程序块的 always 语句,将电路建模为顺序程序描述。

module Save_Mult_Df(A, C, ClkB, Z);input[0:7] A;input[0:3] C;input ClkB;output[0:11] Z;reg[0:11] Z;always@(A or C or ClkB) begin:SEQreg[0:7] S1;if(ClkB)S1 = A;Z = S1 * C;end
endmodule

结构方式:是假定已存在 8 位寄存器和 8 位乘法器,将电路建模为线网表。

module Save_Mult_Df(A, C, ClkB, Z);input[0:7] A;input[0:3] C;input ClkB;output[0:11] Z;wire[0:7] S1, S3;wire[0:15] S2;Reg8 R1(.Din(A), .Clk(ClkB), .Dout(S1));Mult8 M1(.A(S1), .B({4'b0000, C}), .Z(Z));
endmodule

条件操作建模

在特定条件下发生的操作可以使用带有条件操作符的连续赋值语句,或在 always 语句中用 if 语句或 case 语句建模。如下面描述的一个算术逻辑电路:

module Simple_ALU(A, B, C, PM, ALU);input[0:3] A, B, C;input PM;output[0:3] ALU;assign ALU = PM ? A + B : A - B;
endmodule

多路选择开关也能够使用 always 语句建模。首先确定选线的值,然后,case 语句根据这个值选择相应的输入赋值到输出。

`timescale 1ns/1ns
module Multiplexer(Sel, A, B, C, D, Mux_Out);input[0:1] Sel;input A, B, C, D;output Mux_Out;reg Mux_Out;reg Temp;parameter MUX_DELAY = 15;always@(Sel or A or B or C or D)begin:P1case(Sel)0: Temp = A;1: Temp = B;2: Temp = C;3: Temp = D;endcaseMux_Out = #MUX_DELAY Tempend
endmodule

通用移位寄存器

通用串行输入、串行输出移位寄存器能够使用 always 语句块内的 for 循环语句建模。寄存器的数量被定义为参数,这样通用移位寄存器的数量在其他设计中被引用时,可以修改。

module Shift_Reg(D, Clock, Z);input D, Clock;output Z;parameter NUM_REG = 6;reg[1:NUM_REG] Q;integer P;always@(negedge Clock) begin// 寄存器右移一位for(P=1; P<NUM_REG; P=P+1)Q[P+1] = Q[P]// 加载串行数据Q[1] = D;end// 从最右端寄存器获取输出;assign Z = Q[NUM_REG];
endmodule

状态机建模

状态机通常可使用带有 always 语句的 case 语句建模。状态信息存储在寄存器中。case 语句的多个分支包含每个状态的行为。下面是表示状态机简单乘法算法的实例:

在这里插入图片描述

module Multiply(Mplr, Mcnd, Clock, Reset, Done, Acc);input[0:15] Mplr, Mcnd;input Clock, Reset;output Done;reg Done;output[31:0] Acc;reg[31:0] Acc;parameter INIT = 0, ADD = 1, SHIFT = 2;reg[0:1] Mpy_State;reg[31:0] Mcnd_Temp;initial Mpy_State = INIT;always@(negedge Clock) begin:PROCESSinteger Count;case(Mpy_State)INIT:if(Reset)Mpy_State = INIT;elsebeginAcc = 0;Count = 0;Mpy_State = ADD;Done = 0;Mcnd_Temp[15:0] = Mcnd;Mcnd_Temp[31:16] = 1'd0;endADD:beginif(Mplr[Count])Acc = Acc + Mcnd_TempMpy_State = SHIFT;endSHIFT:beginMcnd_Temp = {Mcnd_Temp[30:0], 1'b0};Count = Count + 1;if(Count == 16)beginMpy_State = INIT;Done = 1;endelseMpy_State = ADD;endendcaseend
endmodule

Moore 有限状态机建模

Moore 有限状态机(FSM)的输出只依赖于状态而不依赖其输入。这种类型有限状态机的行为能够通过使用带有在状态值上转换的 case 语句的 always 语句建模。

在这里插入图片描述

module Moore_FSM(A, Clock, Z);input A, Clock;output Z;reg Z;parameter STO = 0, ST1 = 1, ST2 = 2, ST3 = 3;reg[0:1] Moore_State;always@(negedge Clock)case(Moore_State)ST0: beginZ = 1;if(A)Moore_State = ST2;endST1: beginZ = 0;if(A)Moore_State = ST3;endST2: beginZ = 0;if(~A)Moore_State = ST1;elseMoore_State = ST3;endST3: beginZ = 1;if(A)Moore_State = ST0;endendcase
endmodule

Mealy 型有限状态机建模

在 Mealy 型有限状态机中,输出不仅依赖机器的状态而且依赖于它的输入。

在这里插入图片描述

module Mealy_FSM(A, Clock, Z);input A, Clock;output Z;reg Z;parameter STO = 0, ST1 = 1, ST2 = 2, ST3 = 3;reg[1:2] P_State, N_State;always@(negedge Clock)P_State = N_State;always@(P_State or A) begin:COMB_PARTcase(P_State)ST0:if(A) beginZ = 1;N_State = ST3;endelseZ = 0;ST1:if(A) beginZ = 0;N_State = ST0;endelseZ = 1;ST2:if(~A)Z = 0;else beginZ = 1;N_State = ST1;endST3:beginZ = 0;if(~A)N_State = ST2;elseN_State = ST1;endendcaseend
endmodule

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/194757.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【MySQL 20题练习 包含:select,join,union,where 等复合语句】

MySQL 20题练习 数据介绍一&#xff1a;基于数据结构编写每张表建表语句二&#xff1a;将下列数据加载到MySQL中三、使用SQL完成下面需求1&#xff0e; 列出至少有一个员工的所有部门。2&#xff0e; 列出薪金比“SMITH”多的所有员工。3&#xff0e; 列出所有员工的姓名及其直…

viple模拟器使用(四):unity模拟器中实现两距离局部最优迷宫算法

名字解读 两距离&#xff1a;指的是左侧距离和右侧距离 局部最优&#xff1a;对当前状态来说最好的选择&#xff0c;至于整体能不能达到最优&#xff0c;是无法确定的。 从节点1到节点5&#xff0c;一共有3条路 第1条路线&#xff1a;1→2→4→5&#xff0c;对应的花销是&…

机器学习笔记 - 什么是模型量化压缩技术?

一、简述 我们都知道现实世界是连续的状态,而计算机世界是离散的状态,这是什么意思呢?我们看一下下图,最右边的马力欧(高清)的状态,可以想象现实世界是连续的状态,而电脑世界在图像上呈现的是一格一格子的状态(左图)是离散的状态。 所以在计算机世界如果想要…

51单片机应用从零开始(十)·指针

指针 C语言指针是一种保存变量地址的数据类型。它可以让程序直接访问内存中的数据&#xff0c;而不需要通过变量名来访问。指针变量存储的是一个地址&#xff0c;这个地址指向内存中的某个位置&#xff0c;该位置存储了一个值。 在C语言中&#xff0c;可以使用&运算符取得一…

【计算机网络笔记】物理层——数据通信基础

系列文章目录 什么是计算机网络&#xff1f; 什么是网络协议&#xff1f; 计算机网络的结构 数据交换之电路交换 数据交换之报文交换和分组交换 分组交换 vs 电路交换 计算机网络性能&#xff08;1&#xff09;——速率、带宽、延迟 计算机网络性能&#xff08;2&#xff09;…

绝地求生在steam叫什么?

绝地求生在Steam的全名是《PlayerUnknowns Battlegrounds》&#xff0c;简称为PUBG。作为一款风靡全球的多人在线游戏&#xff0c;PUBG于2017年3月23日正式上线Steam平台&#xff0c;并迅速成为一部热门游戏。 PUBG以生存竞技为核心玩法&#xff0c;玩家将被投放到一个辽阔的荒…

【Unity入门】脚本生命周期简介及MonoBehaviour常用方法

脚本生命周期简介 脚本作为我们游戏的“灵魂”&#xff0c;往往不单独存在&#xff0c;而是经常作为组件的形式挂载到特定的游戏物体身上&#xff0c;比如: 游戏主角&#xff0c;敌人&#xff0c;Boss&#xff0c;子弹&#xff0c;建筑物…脚本的生命周期&#xff0c;也就是所…

CRM简单小结

思想 对于三层架构&#xff0c;一个模块对应一个controller&#xff0c;controller实际就是Servlet&#xff1b;一张表对应一个domain类对应一个dao接口对应一个mapper文件&#xff1b;service层没有严格规定&#xff0c;如果两张表内容相近&#xff0c;用一个service接口也可以…

集成学习(Ensemble Learning)

集成学习&#xff08;Ensemble Learning&#xff09;详解 集成学习是一种机器学习方法&#xff0c;它结合了多个模型的预测结果以提高整体性能。这种方法的基本思想是&#xff0c;多个模型一起工作比单个模型单独工作更有效。 集成学习的核心概念 1. 弱学习器&#xff08;We…

数据结构:图文详解双向链表的各种操作(头插法,尾插法,任意位置插入,查询节点,删除节点,求链表的长度... ...)

目录 一.双向链表的概念 二.双向链表的数据结构 三.双向链表的实现 节点的插入 头插法 尾插法 任意位置插入 节点的删除 删除链表中第一次出现的目标节点 删除链表中所有与关键字相同的节点 节点的查找 链表的清空 链表的长度 四.模拟实现链表的完整代码 前言&am…

检测下我的饺子皮擀的怎么样(圆度)

&#x1f604;&#x1f60a;&#x1f606;&#x1f603;&#x1f604;&#x1f60a;&#x1f606;&#x1f603; 各位老铁周末愉快。 快乐的时间做充实的事&#xff0c;好久没有吃饺子了&#xff0c;俗话说好吃不过饺子。 我个人觉得会包饺子不算本事&#xff0c;会擀饺子皮…

Linux 上的容器技术

容器实现封闭的环境主要要靠两种技术&#xff0c;一种是看起来是隔离的技术&#xff0c;称为 namespace&#xff08;命名空间&#xff09;。在每个 namespace 中的应用看到的&#xff0c;都是不同的 IP 地址、用户空间、进程 ID 等。另一种是用起来是隔离的技术&#xff0c;称为…

C/C++STL学习[1]---顺序容器阐述、对比、选择vector,deque,list,forward_list,array,string

文章目录 前言1. 顺序介绍2. 容器对比说明3. 容器选择总结 前言 STL系列博客开篇&#xff0c;记录一下自己学CSTL相关的心得。 这篇博客主要是写顺序容器的类型以及各个容器之间的异同还有平时对容器使用的选择。 1. 顺序介绍 顺序容器表示这个容器提供了快速顺序访问元素的能…

【csdn默认使用操作详解】

这里写自定义目录标题 欢迎使用Markdown编辑器新的改变功能快捷键合理的创建标题&#xff0c;有助于目录的生成如何改变文本的样式插入链接与图片如何插入一段漂亮的代码片生成一个适合你的列表创建一个表格设定内容居中、居左、居右SmartyPants 创建一个自定义列表如何创建一个…

芋道源码ruoyi-vue-pro项目前端yarn下载报错

安装了node最新的版本20.10.0&#xff0c;结果yarn下载依赖报错。 D:\code\IdeaProject\ruoyi-vue-pro\yudao-ui\yudao-ui-admin-vue2-master>yarn -install error achrinza/node-ipc9.2.2: The engine "node" is incompatible with this module. Expected versi…

使用PCSS实现的实时阴影效果

PCSS的技术可以使得阴影呈现出近硬远软的效果&#xff0c;并且能够实时实现。 其核心理念是通过模拟光源的面积来产生更自然、更柔和的阴影边缘。 具体步骤&#xff1a; 1、生成shadowmap 2、在进行阴影的比较时候进行平均&#xff0c;并非之前的shadow map 或者之后完全的阴影…

纯代码压缩WordPress前端Html

易于阅读的前端代码对开发而言是无比重要的&#xff0c;但对于浏览器来说就显得无比鸡肋了&#xff0c;毕竟浏览器不是像人眼一样看代码&#xff0c;过多的换行和空格&#xff0c;对前台加载是有一定影响的&#xff0c;对使用大带宽高配置服务器的网站&#xff0c;这么点影响可…

【Arduino库之:FastLED库】

FastLED 是一款功能强大&#xff0c;简单易用的控制WS2812, LPD8806, 等LED光带的Arduino第三方库。 第一&#xff1a;基础显示 led [ 0 ] CRGB::Red; //为第一个灯珠设置红色 FastLED.show(); //这个作用才会显示 示例程序&#xff1a; 此程序展示了FASTLED库控制WS2821…

YOLOv8创新魔改教程(二)如何添加注意力机制

YOLOv8创新魔改教程&#xff08;二&#xff09;如何添加注意力机制 &#xff08;一&#xff09;找代码 github找各种注意力机制的代码 &#xff08;二&#xff09;融合 1.创建文件 在ultralytics/nn/attention.py创建attention.py 文件 将找到的代码粘贴进来 2.修改task…

【计算机组成原理】存储器知识

目录 1、存储器分类 1.1、按存储介质分类 1.2、按存取方式分类 1.3、按信息的可改写性分类 1.4、按信息的可保存性分类 1.5、按功能和存取速度分类 2、存储器技术指标 2.1、存储容量 2.2、存取速度 3、存储系统层次结构 4、主存的基本结构 5、主存中数据的存放 5.…