Verilog - ABS代码重构
https://mp.weixin.qq.com/s/-KUviTzO3Hdir_mI57L24g
module ABS
#(
parameter DATA_WIDTH =
)
(
input [DATA_WIDTH-:] din,
output reg [DATA_WIDTH-:] dout
); always @(*) begin
if (din[DATA_WIDTH-] == 'b1) begin // negative data
if (din[DATA_WIDTH-:] == {(DATA_WIDTH-){'b0}}) begin // Max
dout = {'b0,{(DATA_WIDTH-1){1'b1}}};
end
else begin
dout = {'b0,((~din[DATA_WIDTH-2:0])+1'b1)};
end
end
else begin
dout = din;
end
end endmodule
module ABS
#(
parameter DATA_WIDTH =
)
(
input [DATA_WIDTH-:] din,
output reg [DATA_WIDTH-:] dout
); localparam W = DATA_WIDTH;
localparam MSB = DATA_WIDTH - ; always @(*) begin
if (din[MSB] == 'b1) begin // negative data
if (din[W-:] == { (W-){'b0} }) begin // Max
dout = {'b0,{(W-1){1'b1}}};
end
else begin
dout = {'b0,((~din[W-2:0])+1'b1)};
end
end
else begin
dout = din;
end
end endmodule
module ABS
#(
parameter DATA_WIDTH =
)
(
input [DATA_WIDTH-:] din,
output reg [DATA_WIDTH-:] dout
); localparam W = DATA_WIDTH;
localparam MSB = DATA_WIDTH - ; wire din_sign = din[MSB];
wire [W-:] din_data = din[W-:];
wire [W-:] pad0 = { (W-){'b0} };
wire [W-:] pad1 = { (W-){'b1} }; always @(*) begin
if (din_sign == 'b1) begin // negative data
if (din_data == pad0) begin // Max
dout = {'b0, pad1};
end
else begin
dout = {'b0,((~din_data)+1'b1)};
end
end
else begin
dout = din;
end
end endmodule
module ABS
#(
parameter DATA_WIDTH =
)
(
input [DATA_WIDTH-:] din,
output reg [DATA_WIDTH-:] dout
); localparam W = DATA_WIDTH;
localparam MSB = DATA_WIDTH - ; wire din_sign = din[MSB];
wire [W-:] din_data = din[W-:];
wire [W-:] pad1 = { (W-){'b1} }; always @(*) begin
if (din_sign == 'b1) begin // negative data
if (din_data == ) begin // Max
dout = {'b0, pad1};
end
else begin
dout = {'b0,((~din_data)+1'b1)};
end
end
else begin
dout = din;
end
end endmodule
module ABS
#(
parameter DATA_WIDTH =
)
(
input [DATA_WIDTH-:] din,
output reg [DATA_WIDTH-:] dout
); localparam W = DATA_WIDTH;
localparam MSB = DATA_WIDTH - ; wire din_sign = din[MSB];
wire [W-:] din_data = din[W-:];
wire [W-:] pad1 = { (W-){'b1} }; always @(*) begin
if (din_sign == 'b1) begin // negative data
if (din_data == ) begin // Max
dout = ~din;
end
else begin
dout = {'b0,((~din_data)+1'b1)};
end
end
else begin
dout = din;
end
end endmodule
module ABS
#(
parameter DATA_WIDTH =
)
(
input [DATA_WIDTH-:] din,
output reg [DATA_WIDTH-:] dout
); localparam W = DATA_WIDTH;
localparam MSB = DATA_WIDTH - ; wire din_sign = din[MSB];
wire [W-:] din_data = din[W-:]; always @(*) begin
if (din_sign == 'b1) begin // negative data
if (din_data == ) begin // Max
dout = ~din;
end
else begin
dout = ~din + ;
end
end
else begin
dout = din;
end
end endmodule
module ABS
#(
parameter DATA_WIDTH =
)
(
input [DATA_WIDTH-:] din,
output reg [DATA_WIDTH-:] dout
); localparam W = DATA_WIDTH; wire din_sign = din[W-];
wire [W-:] din_data = din[W-:]; always @(*) begin
if (din_sign == 'b1) begin // negative data
if (din_data == ) begin // Max
dout = ~din;
end
else begin
dout = ~din + ;
end
end
else begin
dout = din;
end
end endmodule
Verilog - ABS代码重构的更多相关文章
- Android Studio在代码重构中的妙用
代码重构几乎是每个程序员在软件开发中必须要不断去做的事情,以此来不断提高代码的质量.Android Stido(以下简称AS)以其强大的功能,成为当下Android开发工程师最受欢迎的开发工具,也是A ...
- 让代码重构渐行渐远系列(3)——string.Equals取代直接比较与非比较
重构背景及原因 最近由于项目组的人员在不断扩充,导致项目中代码风格各异,大有百花齐放甚至怒放之势.考虑到团队的生存与发展,经过众人多次舌战之后,最终决定项目组根据业务分成几个小分队,以加强团队管理与提 ...
- C++代码重构——从C global到C++ template
在学数据结构的时候,我常有这样目标--写出能够最大程度复用的代码(算法正确,封装优秀).我常想--如何能在短时间内达成"算法正确,封装优秀"这样的目标.经过一段时间的摸索,我的结论 ...
- ASP.NET SignalR 与 LayIM2.0 配合轻松实现Web聊天室(十二) 代码重构使用反射工厂解耦(一)缓存切换
前言 上一篇中,我们用了反射工厂来解除BLL和UI层耦合的问题.当然那是最简单的解决方法,再复杂一点的程序可能思路相同,但是在编程细节中需要考虑的就更多了,比如今天我在重构过程中遇到的问题.也是接下来 ...
- CSS代码重构与优化之路
作者:@狼狼的蓝胖子 网址:http://www.cnblogs.com/lrzw32/p/5100745.html 写CSS的同学们往往会体会到,随着项目规模的增加,项目中的CSS代码也会越来越多, ...
- NET代码重构
记一次.NET代码重构 好久没写代码了,终于好不容易接到了开发任务,一看时间还挺充足的,我就慢慢整吧,若是遇上赶进度,基本上直接是功能优先,完全不考虑设计.你可以认为我完全没有追求,当身后有鞭子使 ...
- 代码重构 & 常用设计模式
代码重构 重构目的 相同的代码最好只出现一次 主次方法 主方法 只包含实现完整逻辑的子方法 思维清楚,便于阅读 次方法 实现具体逻辑功能 测试通过后,后续几乎不用维护 重构的步骤 1 新建一个方法 ...
- ASP.NET SignalR 与 LayIM2.0 配合轻松实现Web聊天室(十一) 代码重构使用反射工厂解耦
前言 自从此博客发表以及代码开源以来,得到了许多人的关注.也没许多吧,反正在我意料之外的.包括几位大牛帮我做订阅号推广,真的很感谢他们.另外,还有几个高手给我提了一些架构上的问题.其实本身这个项目是没 ...
- CSS代码重构
CSS代码重构的目的 我们写CSS代码时,不仅仅只是完成页面设计的效果,还应该让CSS代码易于管理,维护.我们对CSS代码重构主要有两个目的:1.提高代码性能2.提高代码的可维护性 提高代码性能 提高 ...
随机推荐
- SpringBoot系列(十四)集成邮件发送服务及邮件发送的几种方式
往期推荐 SpringBoot系列(一)idea新建Springboot项目 SpringBoot系列(二)入门知识 springBoot系列(三)配置文件详解 SpringBoot系列(四)web静 ...
- Java for 嵌套循环
嵌套循环 可以是for循环 while循环也可以是do-while循环 这三着进行组合嵌套 循环思路:先执行外层循环,内层循环作为外层循环的循环体,直到内层循环执行完毕,再次计算外层循环,根据条件决 ...
- Mysql常用sql语句(16)- inner join 内连接
测试必备的Mysql常用sql语句系列 https://www.cnblogs.com/poloyy/category/1683347.html 前言 利用条件表达式来消除交叉连接(cross joi ...
- 【hdu1024】简单dp
http://acm.hdu.edu.cn/showproblem.php?pid=1024 最大m字段和,题目就不多说了,经典dp 这题坑爹...首先不说明m的范围(n<=1000000),还 ...
- 深度学习中的序列模型演变及学习笔记(含RNN/LSTM/GRU/Seq2Seq/Attention机制)
[说在前面]本人博客新手一枚,象牙塔的老白,职业场的小白.以下内容仅为个人见解,欢迎批评指正,不喜勿喷![认真看图][认真看图] [补充说明]深度学习中的序列模型已经广泛应用于自然语言处理(例如机器翻 ...
- netty零基础入门
直接上代码,从最基本的接收消息规则开始 package cn.qdl; import io.netty.buffer.ByteBuf; import io.netty.channel.ChannelH ...
- 关于QQ可以发消息但是网页刷不出来问题
相信很多人都遇到过这个问题,明明可以登陆QQ,但是网页就是打不开,而且这种情况经常伴有网卡图标显示叹号的情况.笔者这里就教你一个方法,保证好用. 首先,在开始菜单输入cmd,在命令符模式下点击右键选择 ...
- Echarts关于tree树数据渲染图例最新实例
最近做项目接到新的需求,根据本身系统结构数据做一个图形化展示,要求好看易用,有交互,就说了这么多,然后就要求两天给一版瞅瞅,MMP,真把前端当神了(你倒是把待遇提到神的地位啊...) 唉,吐槽归吐槽, ...
- 我的linux学习日记day4
一.打包压缩与搜索命令 1.tar命令 -c 创建压缩文件 -x 解开压缩文件 -t 查看压缩包里有哪些文件 -j 用bzip2来压缩或解压 -z 用gzip压缩或解压 -v 显示过程 -f 目标文件 ...
- Redis的几种集群方式分析
一 单机版 分析: 无论多少用户,都访问这一台服务器 .服务器一旦挂了,所有用户都无法访问.风险很大,一般不会有人使用. 二 主从模式(master/slaver) 分析: 主从模式中, 无论多少用户 ...