booth算法(乘法器).docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
booth算法(乘法器)

Booth算法笔记_verilog(布斯算法) 2009-05-03 14:02 参考程序下载:Booth_mul4_v Booth算法(布斯算法),一个比较推荐的带符号乘法算法.某天在某个群中听某个高手提起乘法运算仅用加法和移位运算来实现.所以当时有心去了解一下,可是!!,当懂哥满怀热情的在百度百科上查询时,竟然发现…也太丑陋了嘛,不晓得哪个小娃娃从哪里复制的,把人家的算法流程图复制没了就忍了,关键是能把2^0转载成20..唉误导啊误导啊,更郁闷的是人民们都喜欢复制并且不加以细看…于是乎百度出来别人空间里写的booth算法都和百科里面雷同啊.So,懂哥才决定讨论哈这个.踏破铁鞋无觅处..竟然在某三级微机原理的辅导里面无意中发现了类似的介绍.废话不说了,懂哥就把这次的笔记整理好.(又,为了帮助被百科误导的小朋友们,懂哥这次用verilog描述的booth硬件实现并不是一个标准的乘法器,而仅仅是比较明确地展现步骤得出结果,并设置的寄存器名和百度百科里寄存器名设为相同.) [具体步骤和举例请参考程序后面的分析] (基于改良Booth算法的4位乘法器笔记见:/hlyrm/blog/item/2b9a4342760d771b73f05d04.html,/hlyrm/blog/item/0a5fa72b891bb6305343c105.html) 先补充一下这次写这个又巩固了的= =|| 无符号数-逻辑移位 有符号数-算术移位 寄存器类型的值可取负数,但若该变量用于表达式运算中,则按无符号类型处理. 而booth算法里面的移位则是算术移位 Booth算法和一般按照普通乘法运算在于算部分积那一块.Booth算法的乘法器仅仅是对乘数的位重新编码以减少乘法运算周期所需要的加法运算次数.且用补码形式表示正数和负数,所以不像一般讨论的那样要讨论负数运算.所以,Booth算法实现的乘法可以直接用于两个补码数相乘.(关键在于booth跳过了乘数中全部是1的字符串,将一系列加法运算用一次加法或减法代替) Booth编码方法(引用百科) 设y=y0,yly2…yn为被乘数,x为乘数,yi是a中的第i位(当前位).操作的方式取决于表达式(yi+1-yi)的值,这个表达式的值所代表的操作为:   0 无操作   +1 加x   -1 减x 流程图(额,补充百科里缺少的算法流程图) 给出懂哥的verilog描述的booth算法硬件实现. 确实写得丑陋啊…还生硬的加了一个ns.由此联想到用状态机来描述4位乘法可能更好. 并且遇到过的问题就是变量不能在多个always里赋值,并且加深了多次赋值可能导致的冲突理解 module mul_4( ?????????????????????????????????????? clk, ?????????????????????????????????????? res_n, ?????????????????????????????????????? mul1, ?????????????????????????????????????? mul2, ?????????????????????????????????????? result); parameter width=4d4; input clk,res_n; input [width-1:0]mul2,mul1;//乘数 output [2*width-1:0]result;//运算结果最多是两倍乘数位数 wire [2*width-1:0]result; reg [width-1:0] R0,R1,R2;//result={R0,R1},multiplier=R2 reg P; reg ns; assign result={R0,R1}; always@(posedge clk or negedge res_n) begin ???? if(!res_n) ???? begin ?????? R0=0; ?????? R1=mul1; ?????? R2=mul2; ?????? P=1b0; ?????? ns=0; ???? end ???? else ???? begin ???????? if(!ns) ???????? begin ???????? case({R1[0],P}) ???????????? 2b01: ???????????? begin ???????????? R0=(R0+R2);ns=1; ???????????? end ???????????? 2b10: ???????????? begin ???????????

文档评论(0)

xjj2017 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档