打印
[研电赛技术支持]

如何实现快速的开方运算

[复制链接]
316|7
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
tifmill|  楼主 | 2023-9-27 22:44 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
/****************************************/
/*Function: 开根号处理                 */
/*入口参数:被开方数,32位无符号整数          */
/*出口参数:开方结果,16位无符号整数           */
/****************************************/
unsigned int sqrt_16(unsigned long M)
{
    unsigned int N, i;
    unsigned long tmp, ttp;   // 结果、循环计数
    if (M ==0)              // 被开方数,开方结果也为0
        return 0;
   N = 0;
   tmp = (M >> 30);          //获取最高位:B[m-1]
    M <<= 2;
    if (tmp >1)             // 最高位为1
    {
        N++;                // 结果当前位为1,否则为默认的0
        tmp -= N;
    }
   for (i=15; i>0; i--)      // 求剩余的15位
    {
        N <<=1;             // 左移一位
       tmp <<= 2;
        tmp += (M >>30);     // 假设
       ttp = N;
        ttp = (ttp<<1)+1;
       M <<= 2;
        if (tmp >=ttp)       // 假设成立
        {
            tmp -=ttp;
            N ++;
        }
   }

   return N;
}


使用特权

评论回复
沙发
AloneKaven| | 2023-9-29 22:31 | 只看该作者
这个用math库不行吗?

使用特权

评论回复
板凳
tpgf| | 2023-10-12 16:32 | 只看该作者
这个算法的原理是什么呢

使用特权

评论回复
地板
paotangsan| | 2023-10-12 16:48 | 只看该作者
AloneKaven 发表于 2023-9-29 22:31
这个用math库不行吗?

可以呀 但是这样做的话 对单片机的负担就太大了

使用特权

评论回复
5
wakayi| | 2023-10-12 17:05 | 只看该作者
这里边一共需要运行多少个时钟周期啊

使用特权

评论回复
6
xiaoqizi| | 2023-10-12 18:33 | 只看该作者
这种方式需要把16位的数据弄成32位的处理是吧

使用特权

评论回复
7
wowu| | 2023-10-12 19:07 | 只看该作者
位数多的话会不会循环次数过多呢

使用特权

评论回复
8
renzheshengui| | 2023-10-12 19:41 | 只看该作者
主要是对这种算法的原理不太了解

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

27

主题

1136

帖子

0

粉丝