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 # $(()) 的数学运算, ...
随机推荐
- div+css样式
Div+Css 随着页面上的需求变大,许多的东西不再使用单纯的图片.按钮.文字,而是通过Div+Css来实现按钮,公司的需求就是这样,一直在弄这个模块,顺便的总结一下 列如下面的页面都是通过div+c ...
- 建工财务搬家NC变更|rman各种测试|
1,使用全备份之后的还原不需要建立表空间. 2,归档日志备份之后,使用delete all input,在backup database plus achivelog之后,会在完成备份之后自动删除归档 ...
- Hibernate5.2之HQL查询
Hibernate5.2之HQL查询 一. 介绍 Hibernate的 ...
- 【转】JVM内存模型
http://longdick.iteye.com/blog/473866 图解JVM内存模型 博客分类: JVM JVM活动SUN /** * 转载请注明作者longdick http:/ ...
- 排列 && 组合
最近编程经常遇到需要 排列&&组合(求子集) 的问题:遂整理一下. 1. 数字的排列与组合(递归):O(n!),O(nC(n,k)) * O(n) #include <stdio ...
- C#EXCEL 操作类--C#DataToExcel帮助类
using System; using System.Diagnostics; //using Excel; namespace DotNet.Utilities { /// <summ ...
- 黑盒测试与白盒测试(Black box Testing)
黑盒测试和白盒测试的优缺点 类别 优点 缺点 黑盒测试 不需要了解软件代码 从用户角度出发 无法保证代码内各个路径被覆盖到 白盒测试 强制测试开发工程师关注代码的具体实现 揭露隐藏在代码中的Bug 是 ...
- JS的join函数用法
无意中在网上看到一个关于join比for循环更有效率的说法.虽然不明白为什么,先记一笔. join函数用于数组.返回值为一个字符串.实现的效果就是将数组连成自己想要的字符串,当然是有规律可循的字符串. ...
- JS跨域知识整理
在“跨域”一词经常性地出现以前,我们其实已经频繁地使用它了.如在A网站的img,src指向B网站的某一图片地址,毫无疑问,这在通常情况下都是能正常显示的(且不论防盗链技术):同样,可以使script标 ...
- primefaces 知识点整理
database组件中设置数据中一行的颜色 需要设置属性: rowStyleClass="#{data.tradeMoney le 0 ? 'exp' : null}"exp样式: ...