当前位置: 首页 > news >正文

数字IC前端学习笔记:数字乘法器的优化设计(阵列乘法器)

相关阅读

数字IC前端https://blog.csdn.net/weixin_45791458/category_12173698.html?spm=1001.2014.3001.5482


数字信号处理作为微处理器的核心部件,是决定着总体处理器性能的因素之一,而数字乘法器是最常见的一种数字信号处理电路。通常情况下,乘法器是数字系统中制约运算速度的关键路径。本系列将从基本的乘法器入手,再逐渐深入,探究了各种优化乘法器在体系结构,乘法算法等方面的优化策略。

作为最基本的组合逻辑乘法器,阵列乘法器(Array multiplier)虽然已不太常用,但在某些对性能要求不高的应用场景下,还能见到它的使用。

为了简便起见,本文考虑两个四位二进制数A和B相乘,其中A为被乘数,B为乘数,先产生部分积,然后使用加法器累加这些部分积,总体规划如表1所示。从乘数B的最低位B0开始,依次与被乘数A的各位A0、A1、A2、A3相与(乘)形成4组16个部分积项目,分组是根据乘数B的位而言,如所有有B0项目的是第0组部分积。然后每一组根据分组的不同,移动到乘数B每一位对应的位置,最后将部分积累加。注意,在部分积的累加过程中,可能会出现来自低位的进位,此时需要使用全加器,否则使用半加器即可。

表1 无符号4位二进制乘法规划

A3

B3

A2

B2

A1

B1

A0

B0

被乘数

乘数

资源配置

A3B1

C12

A3B0

A2B1

C11

A2B0

A1B1

C10

A1B0

A0B1

A0B0

部分积0

部分积1

低位进位

第1行加法器

C13

A3B2

C22

S13

A2B2

C21

S12

A1B2

C20

S11

A0B2

S10

S00

第1行和

部分积2

低位进位

第2行乘法器

C23

A3B3

C32

S23

A2B3

C31

S22

A1B3

C30

S21

A0B3

S20

第2行和

部分积3

低位进位

第3行乘法器

C33

S33

S32

S31

S30

第3行和

C33

S33

S32

S31

S30

S20

S10

S00

最终结果

27

26

25

24

23

22

21

20

权重

4位乘法器的组合逻辑结构如图1所示,可以看出这种结构十分规则,大多是由加法器和与门构成的基本单元复制得到,但由红线和紫线描绘的路径可以看出其中存在较长的加法器链(即可能的关键路径),换个角度,结构中使用了3组行波进位加法器(Ripple Carry Adder)或者说串行进位加法器(Serial Carry Adder)、进位传播加法器(Carry Propagate Adder),这种乘法器的优点在于可复用性和可配置性强,非常利于集成电路制造,但缺点是进位操作的关键路径较长,控制组合电路输入输出的时钟周期需要与电路中的最长路径相适应。为了提高性能,可以在这种结构中植入流水线来获得更大的数据吞吐量,这是对组合逻辑优化的一个常见方法。具体的Verilog代码实现见附录,Modelsim软件仿真截图如图2所示。使用Synopsys的综合工具Design Compiler综合的结果如图3所示,综合使用了0.13μm工艺库。

图1 基本单元构成的阵列乘法器

图2 阵列乘法器仿真结果

图3 阵列乘法器综合结果

在Design Compiler中使用report_timing命令,可以得到关键路径的延迟,如图4所示,使用report_area命令,报告所设计电路的面积占用情况,如图5所示

图4 阵列乘法器关键路径报告

图5 阵列乘法器面积报告

阵列乘法器的Verilog代码如下所示。

module Array_multiplier( input [3:0] A, input [3:0] B, output [7:0] Sum ); wire [3:0]partial_product[3:0]; // 产生部分积 assign partial_product[0] = B[0]?A:0; assign partial_product[1] = B[1]?A:0; assign partial_product[2] = B[2]?A:0; assign partial_product[3] = B[3]?A:0; // 中间进位 wire C10, C11, C12, C13; wire C20, C21, C22, C23; wire C30, C31, C32, C33; // 中间和 wire S11, S12, S13; wire S21, S22, S23; // 第一行加法器 assign Sum[0] = partial_product[0][0]; Adder_half Adder_half_0(partial_product[0][1], partial_product[1][0], Sum[1], C10); Adder Adder_0(partial_product[0][2], partial_product[1][1], C10, S11, C11); Adder Adder_1(partial_product[0][3], partial_product[1][2], C11, S12, C12); Adder_half Adder_half_1(partial_product[1][3], C12, S13, C13); // 第二行乘法器 Adder_half Adder_half_2(S11, partial_product[2][0], Sum[2], C20); Adder Adder_2(S12, partial_product[2][1], C20, S21, C21); Adder Adder_3(S13, partial_product[2][2], C21, S22, C22); Adder Adder_4(C13, partial_product[2][3], C22, S23, C23); // 第三行加法器 Adder_half Adder_half_3(S21, partial_product[3][0], Sum[3], C30); Adder Adder_5(S22, partial_product[3][1], C30, Sum[4], C31); Adder Adder_6(S23, partial_product[3][2], C31, Sum[5], C32); Adder Adder_7(C23, partial_product[3][3], C32, Sum[6], Sum[7]); endmodule // 半加器 module Adder_half( input Add1, input Add2, output Res, output Carry ); assign Res = Add1 ^ Add2; assign Carry = Add1 & Add2; endmodule // 全加器 module Adder( input Add1, input Add2, input I_carry, output Res, output Carry ); assign Res = Add1 ^ Add2 ^ I_carry; assign Carry = (Add1 & Add2) | ((Add1 ^ Add2) & I_carry); endmodule
http://www.jsqmd.com/news/625222/

相关文章:

  • 告别命令行恐惧:用SmartGit可视化搞定Git分支与合并冲突
  • version `GLIBC_2.38‘ not found简单有效解决方法
  • Tree of Thoughts快速入门指南:5分钟掌握插件式AI推理框架
  • MicroMDM实战案例:企业设备管理的成功经验分享
  • Docker数据持久化:Volume完全指南,从入门到生产环境选型
  • 嵌入式语音交互实战:基于树莓派4B与SYN6288的智能语音播报系统设计
  • hidapi项目贡献指南:如何参与开源HID库的开发
  • GetQzonehistory:一键永久备份你的QQ空间历史说说,让青春记忆永不褪色
  • 基于大疆PSDK与Jetson Nano的无人机实时GPS数据采集与ROS集成实战
  • 告别yum默认Python2!在CentOS7上优雅共存Python3.13与系统Python,并配置pip和虚拟环境
  • LaTeX报错急救指南:如何快速定位并删除U+200B零宽空格(附实用排查技巧)
  • Hack Club硬件编程进阶:七段数码管与伺服电机控制技术
  • STM32步进电机4轴控制源码(相对/绝对/回原点/梯形加减速运动控制 F103 F405版本)
  • 终极指南:C2Rust位域处理模块的核心原理与实战应用
  • 论文插图神器ChemDraw实战:5分钟学会绘制专业级化学反应流程图
  • Maomi.In | .NET 全能多语言解决方案系
  • Cinny移动端适配:响应式设计与用户体验优化策略
  • Spring with AI (): 搜索扩展——向量数据库与RAG(下)餐
  • 2026届学术党必备的十大降重复率工具实际效果
  • TLA+测试框架完全解析:如何编写有效的模型验证用例
  • Vue + G 实战:打造高校学生打卡数据可视化大屏使
  • 清华教授:三个心理资本,决定你能走多远
  • 2026年4月优质的玻璃钢桥架公司口碑推荐,玻璃钢污水池盖板/SMC防火槽盒,玻璃钢桥架源头厂家口碑推荐 - 品牌推荐师
  • Linux解压大文件报错?手把手教你用7zip搞定4GB+压缩包(附详细安装指南)
  • MicroMDM社区生态:开源MDM的未来发展趋势
  • SteamTinkerLaunch命令行工具大全:Steam之外的强大功能探索
  • linux学习进展 主函数的参数
  • 扩散模型是什么: 擅长生成图像、视频、音频、3D点云等
  • 存储那么贵,何不白嫖飞书云文件空间雅
  • 终极PyTorch部署指南:从训练到生产环境的完整路径