Verilog之基本算数运算
1.加减法
- module addsub
- (
- input [:] dataa,
- input [:] datab,
- input add_sub, // if this is 1, add; else subtract
- input clk,
- output reg [:] result
- );
- always @ (posedge clk)
- begin
- if (add_sub)
- result <= dataa + datab; //or "assign {cout,sum}=dataa+datab;"
- else
- result <= dataa - datab;
- end
- endmodule
补码不仅可以执行正值和负值转换,其实补码存在的意义,就是避免计算机去做减法的操作。
1101 -3 补
+ 1000 8
01015
假设 -3 + 8,只要将 -3 转为补码形式,亦即 0011 => 1101,然后和 8,亦即 1000 相加
就会得到 5,亦即 0101。至于溢出的最高位可以无视掉
2.乘法
- module mult(outcome,a,b);
- parameter SIZE=;
- input[SIZE:] a,b;
- output reg[*SIZE:] outcome;
- integer i;
- always @(a or b)
- begin outcome<=;
- for(i=,i<=SIZE;i=i+)
- if(b[i]) outcome<=outcome+(a<<(i-));
- end
- endmodule
乘法-带符号位,在初始化之际,取乘数和被乘数的正负关系,然后取被乘数和乘数的正值。输出结果根据正负关系取得。
- else if( Start_Sig )
- case( i )
- :
- begin
- isNeg <= Multiplicand[] ^ Multiplier[];
- Mcand <= Multiplicand[] ? ( ~Multiplicand + 'b1 ) : Multiplicand;
- Mer <= Multiplier[] ? ( ~Multiplier + 'b1 ) : Multiplier;
- Temp <= 'd0;
- i <= i + 'b1;
- end
- 1: // Multipling
- if( Mer == 0 ) i <= i + 1'b1;
- else begin Temp <= Temp + Mcand; Mer <= Mer - 1'b1; end //浪费时钟
- :
- begin isDone <= 'b1; i <= i + 1'b1; end
- :
- begin isDone <= 'b0; i <= 2'd0; end
- endcase
- /*************************/
- assign Done_Sig = isDone;
- assign Product = isNeg ? ( ~Temp + 'b1 ) : Temp;
- /*************************/
- endmodule
乘法器.vt示例
- `timescale ps/ ps
- module multiplier_module_simulation();
- reg CLK;
- reg RSTn;
- reg Start_Sig;
- reg [:] Multiplicand;
- reg [:] Multiplier;
- wire Done_Sig;
- wire [:]Product;
- /***********************************/
- initial
- begin
- RSTn = ; #; RSTn = ;
- CLK = ; forever # CLK = ~CLK;
- end
- /***********************************/
- multiplier_module U1
- (
- .CLK(CLK),
- .RSTn(RSTn),
- .Start_Sig(Start_Sig),
- .Multiplicand(Multiplicand),
- .Multiplier(Multiplier),
- .Done_Sig(Done_Sig),
- .Product(Product)
- );
- /***********************************/
- reg [:]i;
- always @ ( posedge CLK or negedge RSTn )
- if( !RSTn )
- begin
- i <= 'd0;
- Start_Sig <= 'b0;
- Multiplicand <= 'd0;
- Multiplier <= 'd0;
- end
- else
- case( i )
- : // Multiplicand = 10 , Multiplier = 2
- if( Done_Sig ) begin Start_Sig <= 'b0; i <= i + 1'b1; end
- else begin Multiplicand <= 'd10; Multiplier <= 8'd2; Start_Sig <= 'b1; end
- : // Multiplicand = 2 , Multiplier = 10
- if( Done_Sig ) begin Start_Sig <= 'b0; i <= i + 1'b1; end
- else begin Multiplicand <= 'd2; Multiplier <= 8'd10; Start_Sig <= 'b1; end
- : // Multiplicand = 11 , Multiplier = -5
- if( Done_Sig ) begin Start_Sig <= 'b0; i <= i + 1'b1; end
- else begin Multiplicand <= 'd11; Multiplier <= 8'b11111011; Start_Sig <= 'b1; end
- : // Multiplicand = -5 , Multiplier = -11
- if( Done_Sig ) begin Start_Sig <= 'b0; i <= i + 1'b1; end
- else begin Multiplicand <= 'b11111011; Multiplier <= 8'b11110101; Start_Sig <= 'b1; end
- :
- begin i <= 'd4; end
- endcase
- /***********************************/
- endmodule
循环除法器
- module streamlined_divider_module
- (
- input CLK,
- input RSTn,
- input Start_Sig,
- input [:]Dividend,
- input [:]Divisor,
- output Done_Sig,
- output [:]Quotient,
- output [:]Reminder,
- /**************************/
- output [:]SQ_Diff,
- output [:]SQ_Temp
- );
- /******************************/
- reg [:]i;
- reg [:]s;
- reg [:]Temp;
- reg [:]Diff;
- reg isNeg;
- reg isDone;
- always @ ( posedge CLK or negedge RSTn )
- if( !RSTn )
- begin
- i <= 'd0;
- s <= 'd0;
- Temp <= 'd0;
- Diff <= 'd0;
- isNeg <= 'b0;
- isDone <= 'b0;
- end
- else if( Start_Sig )
- case( i )
- :
- begin
- isNeg <= Dividend[] ^ Divisor[];
- s <= Divisor[] ? { 'b1, Divisor } : { 1'b1 , ~Divisor + 'b1 };
- Temp <= Dividend[] ? { 'd0 , ~Dividend + 1'b1 } : { 'd0 , Dividend };
- Diff <= 'd0;
- i <= i + 'b1;
- end
- ,,,,,,,:
- begin
- Diff = Temp + { s , 'd0 };
- if( Diff[] ) Temp <= { Temp[:] , 'b0 };
- else Temp <= { Diff[:] , 'b1 };
- i <= i + 'b1;
- end
- :
- begin isDone <= 'b1; i <= i + 1'b1; end
- :
- begin isDone <= 'b0; i <= 2'd0; end
- endcase
- /*********************************/
- assign Done_Sig = isDone;
- assign Quotient = isNeg ? ( ~Temp[:] + 'b1 ) : Temp[7:0];
- assign Reminder = Temp[:];
- /**********************************/
- assign SQ_Diff = Diff;
- assign SQ_Temp = Temp;
- /**********************************/
- endmodule
Verilog之基本算数运算的更多相关文章
- 数组名取地址所算数运算应注意的"trap"
数组名取地址所算数运算应注意的"trap" 直接看代码: #include <stdio.h> int main() { int array[5]; printf(&q ...
- 初学 Java Script (算数运算及逻辑术语)
在JS中常用的算数运算符与其他编程类语言类似,逻辑术语也近乎相同. 一.常用算数运算符 1.基本算数运算符 赋值运算符:= : 加号:+ : 减号: - : 乘号: * : 除号: / : 求余: % ...
- python魔法方法-单目运算及一般算数运算
在比较的魔法方法中,我们讨论了魔法方法其实就是重载了操作符,例如>.<.==等.而这里,我们继续讨论有关于数值的魔法方法. 1.单目运算符或单目运算函数 __pos__(self) 实现一 ...
- Shell学习笔记——算数运算与条件测试
算数运算 1. 使用let命令 #!/sbin/bash var1=2 var2=3 let sum=var1+var2 echo $sum 使用let命令式,变量前不需要加$号 只用于整数运算,不适 ...
- NumPy算数运算
NumPy - 算数运算 用于执行算术运算(如add(),subtract(),multiply()和divide())的输入数组必须具有相同的形状或符合数组广播规则. 示例 import numpy ...
- java的数组index[]方括号内是可以进行算数运算的
java的数组index[]方括号内饰可以进行算数运算的 如: String[] stringArray = testString.split("\\."); System.out ...
- linux bash编程之算数运算和测试类型(第二篇)
写在最前边:在bash中数据类型有两种,分别是数值型和字符型.其中字符型是默认的. 1.算数运算 · 运算符 · 语法 1.1.运算符:+.-.*./.%.** 注意:有些时候 *(乘号)需要转义 1 ...
- pandas读书笔记 算数运算和数据对齐
pandas最重要的一个功能是,它可以对不同索引的对象进行算数运算.在对象相加时,如果存在不同的索引对,则结果的索引就是该索引对的并集. Series s1=Series([,3.4,1.5],ind ...
- Linux - Shell - 算术表达式 - 算数运算
概述 shell 中基于 $(()) 的 算数运算 背景 复习 shell 脚本 凑数吧 准备 环境 os centos7 1. 算数运算 代码 #!/bin/bash # $(()) 的数学运算, ...
随机推荐
- WeX5之xid相关API
WeX5针对xid提供了以下js api: 1.根据xid获取id:this.getIDByXID(xid): 2.根据xid获取HTML节点:this.getElementByXid(xid),此a ...
- Hadoop学习19--推测式执行
所谓推测式执行,就是计算框架判断,如果有一个task执行的过慢,则会启动备份任务,最终使用原任务+备份任务中执行较快task的结果.产生原因一般是程序bug.负载倾斜. 那么这个较慢,是怎么判断的呢? ...
- ThinkPad E440 Ubuntu 13.1无线网卡 RTL8723BE 驱动解决办法总结
方法一.在使用网线链接到情况下 第一步.执行下边到命令,即从github上下载驱动程序并安装 sudo apt-get install linux-headers-generic build-esse ...
- SQL 养成一个好习惯是一笔财富
来源:MR_ke 链接:http://www.cnblogs.com/MR_ke/archive/2011/05/29/2062085.html 我们做软件开发的,大部分人都离不开跟数据库打交道,特别 ...
- bzoj2006 noi2010 超级钢琴 主席树 + 优先队列
Time Limit: 20 Sec Memory Limit: 552 MBSubmit: 2435 Solved: 1195 Description 小 Z是一个小有名气的钢琴家,最近C博士送 ...
- eclipse中没有R文件
换了台电脑,把eclipse安装上去,很久没用,最近用了一下.发现R文件无法生成.试了各种方法. Project-->Clean:从其他的项目中,复制一个R.java过来:检查语法:勾选上了Pr ...
- iOS官方Sample大全
转载自:http://blog.csdn.net/yangtb2010/article/details/7005471 http://developer.apple.com/library/ios/s ...
- 11.tftp和nfs服务器
宿主机产生嵌入式软件的机器 运行程序的是目标机上运行 基于网络的下载 目标机通过tftp下载到目标机 1. 安装tftp依赖xinetd [root@cfm880 Packages]# rpm -iv ...
- Android test---monkey
一.在使用monkey之前,需要用到模拟器,那么怎么启动模拟器呢,先看一下电脑有什么模拟器,通过命令行查看一下 android list avd 二.看到了模拟器列表了,下来就是启动模拟器了.在命令行 ...
- AX 4.0 调用打印设定的功能
PrintJobSettings printJobSettings; PrintJobSettings printJobSettings2; Boolean ok; container packPri ...