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 # $(()) 的数学运算, ...
随机推荐
- Struts2通配符问题(待解决)
目录结构如下: 运行结果: 为什么会访问input.jsp?不应该是访问emp-input吗?
- Android开发艺术探索读书笔记——01 Activity的生命周期
http://www.cnblogs.com/csonezp/p/5121142.html 新买了一本书,<Android开发艺术探索>.这本书算是一本进阶书籍,适合有一定安卓开发基础,做 ...
- js零散总结
字符串的查找 index of 指定查找位置 可以查所有,不支持正则 找不到返回-1 var i=-1; while((i=str.indexOf("关键词",i+1))!=- ...
- bootstrap-列表组
<div class="container"> <!-- list-group 列表组 给ul添加 list-group-item 列表项 给li添加 --> ...
- 【转】C# 使用消息队列,包括远程访问
出处:http://www.cnblogs.com/80X86/p/5557801.html 近期做一个小的功能需求,用到了队列,用的时候出了很多问题,现在总结一下,希望能对有需要的人提供帮助. 我的 ...
- 2012年第三届蓝桥杯C/C++程序设计本科B组决赛
1.星期几(取余/excel) 2.数据压缩 3.拼音字母(比较) 4.DNA比对(dp) 5.方块填数 1.星期几[结果填空] (满分5分) 1949年的国庆节(10月1日)是星期六. ...
- [DFNews] 入侵汽车控制刹车和油门?——速度与激情6 的节奏?
原文跳转: http://arstechnica.com/security/2013/07/disabling-a-cars-brakes-and-speed-by-hacking-its-compu ...
- unity3d c#脚本定义Transform
Transform n = Instantiate(newobject,transform.position,transform.rotation) as Transform;Instantiate返 ...
- Chapter6: question 43 - 45
43. 投 n 个骰子,计算点数和出现的概率 递归求解:(空间 O(5*n+1),时间 O(6n)) void count(int N, int curN, int sum, int record[ ...
- JAVA设计模式之不变模式
在阎宏博士的<JAVA与模式>一书中开头是这样描述不变(Immutable)模式的: 一个对象的状态在对象被创建之后就不再变化,这就是所谓的不变模式. 不变模式的结构 不变模式可增强对象的 ...