数字电路设计之GoldSchmidt除法的verilog实现

本文介绍了如何使用Verilog实现GoldSchmidt除法方法,适用于二进制表示的数字电路设计。该方法通过迭代公式x(i+1)= x(i)*r(i),y(i+1)= y(i)*r(i)和r(i+1)= 2 - y(i + 1)来计算a/b。在0.5到1之间的数值a和b,可以转化为a*r0*r1*r2.../(b*r0*r1*r2...)的形式。
摘要由CSDN通过智能技术生成

             若a和b均有.1xxxxxx的形式,这是二进制表示(a,b在0.5到1之间)。那么有(a*r0*r1*r2...)/(b*r0*r1*r2...) = a/b。x0 = a,y0 = b,r0 = 2 - y0。

             通过推导可得:

                     x(i+1)= x(i)*r(i);

                     y(i+1)= y(i)*r(i);

                     r(i+1) = 2 - y(i + 1);


代码实现:

//
// Company:        SMIE
// Engineer:       Chen Yu
// Create Date:    12:58:27 10/06/2014 
// Design Name:    divider
// Module Name:    goldschmidt 
// Project Name:   divide 
// Revision: 1.0
// Address:        http://blog.csdn.net/c602273091
// Revision 0.01 - File Created
//
module goldschmidt(a,b,q,times,clk,stt,rst,busy,ready);
	input   [31:0] a,b;                      //input a/b
	
  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值