Loading [MathJax]/jax/output/CommonHTML/config.js
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >确定浮点平方根

确定浮点平方根
EN

Stack Overflow用户
提问于 2012-02-10 22:04:55
回答 4查看 10.7K关注 0票数 7

如何确定浮点数的平方根?牛顿-拉夫森方法是一种好方法吗?我也没有硬件平方根。我也没有硬件除法(但我实现了浮点除法)。

如果可能的话,我更愿意尽可能地减少分割的数量,因为它们是如此昂贵。

另外,减少总迭代次数的初始猜测应该是什么?

非常感谢!

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2012-02-10 23:30:04

当您使用Newton-Raphson来计算平方根时,您实际上希望使用迭代来找到平方根的倒数(之后,您可以简单地乘以输入--需要注意舍入--以产生平方根)。

更准确地说:我们使用函数f(x) = x^-2 - n。显然,如果是f(x) = 0,那么就是x = 1/sqrt(n)。这就产生了牛顿迭代:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
x_(i+1) = x_i - f(x_i)/f'(x_i)
        = x_i - (x_i^-2 - n)/(-2x_i^-3)
        = x_i + (x_i - nx_i^3)/2
        = x_i*(3/2 - 1/2 nx_i^2)

请注意(与平方根的迭代不同),这种平方根倒数的迭代不涉及除法,因此它通常效率更高。

我在你关于divide的问题中提到,你应该看看现有的软浮点库,而不是重新发明轮子。这条建议在这里也适用。这个函数已经在现有的软浮点库中实现了。

编辑:提问者似乎仍然很困惑,所以让我们来做一个例子:sqrt(612)6121.1953125 x 2^9 (或者b1.0011001 x 2^9,如果您更喜欢二进制)。取出指数(9)的偶数部分,将输入写为f * 2^(2m),其中m是整数,f在[1,4]范围内。然后我们将拥有:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
sqrt(n) = sqrt(f * 2^2m) = sqrt(f)*2^m

将这种简化应用到我们的示例中,可以得到f = 1.1953125 * 2 = 2.390625 (b10.011001)和m = 4。现在进行牛顿-拉普森迭代,使用起始猜测0.5 (正如我在评论中提到的,此猜测对所有f都收敛,但使用线性近似作为初始猜测可以做得更好):

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
x_0 = 0.5
x_1 = x_0*(3/2 - 1/2 * 2.390625 * x_0^2)
    = 0.6005859...
x_2 = x_1*(3/2 - 1/2 * 2.390625 * x_1^2)
    = 0.6419342...
x_3 = 0.6467077...
x_4 = 0.6467616...

因此,即使有一个(相对较差的)初始猜测,我们也能快速收敛到1/sqrt(f) = 0.6467616600226026的真实值。

现在我们简单地将最终结果组合在一起:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
sqrt(f) = x_n * f = 1.5461646...
sqrt(n) = sqrt(f) * 2^m = 24.738633...

并检查: sqrt(612) = 24.738633...

显然,如果你想要正确的舍入,需要仔细的分析,以确保你在计算的每个阶段都有足够的精度。这需要仔细的记账,但这不是火箭科学。您只需保持仔细的误差界限,并通过算法传播它们。

如果您希望在不显式检查残差的情况下校正舍入,则需要将sqrt(f)计算为2p +2位的精度(其中p是源和目标类型的精度)。但是,您也可以采用计算sqrt(f)的策略,使其比p位多一点,对该值进行平方,并在必要时逐个调整尾随位(这通常更便宜)。

sqrt很好,因为它是一个一元函数,这使得在商用硬件上对单精度进行详尽的测试是可行的。

您可以在opensource.apple.com上找到OS X软浮点sqrtf函数,它使用上述算法(碰巧是我写的)。它是根据APSL许可的,这可能适合也可能不适合您的需求。

票数 11
EN

Stack Overflow用户

发布于 2012-02-11 05:28:04

可能(仍然)是查找inverse square root和我最喜欢的10行代码的最快实现。

它是基于牛顿近似的,但有一些奇怪的地方。甚至有一个围绕这个的great story

票数 4
EN

Stack Overflow用户

发布于 2012-02-10 22:11:14

最容易实现的(你甚至可以在计算器中实现):

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
def sqrt(x, TOL=0.000001):
    y=1.0
    while( abs(x/y -y) > TOL ):
        y= (y+x/y)/2.0
    return y

这完全等同于牛顿·拉普森:

Y(新)=y- f(y)/f'(y)

f(y) = y^2-x和f'(y) = 2y

替换这些值:

Y(新)=y- (y^2-x)/2y = (y^2+x)/2y = (y+x/y)/2

如果除法成本很高,你应该考虑:http://en.wikipedia.org/wiki/Shifting_nth-root_algorithm

移位算法:

让我们假设你有两个数字a和b,使得最低有效位(等于1)大于b,而b只有一个比特等于(例如:a=1000和b=10)。设s(b) = log_2(b) (它只是b中值为1的位元的位置)。

假设我们已经知道a^2的值。现在(a+b)^2 = a^2 + 2ab + b^2。a^2已经已知,2ab:将a移位s(b)+1,b^2:将b移位s(b)。

算法:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
Initialize a such that a has only one bit equal to one and a^2<= n < (2*a)^2. 
Let q=s(a).    
b=a
sqra = a*a

For i = q-1 to -10 (or whatever significance you want):
    b=b/2
    sqrab = sqra + 2ab + b^2
    if sqrab > n:
        continue
    sqra = sqrab
    a=a+b

n=612
a=10000 (16)

sqra = 256

Iteration 1:
    b=01000 (8) 
    sqrab = (a+b)^2 = 24^2 = 576
    sqrab < n => a=a+b = 24

Iteration 2:
    b = 4
    sqrab = (a+b)^2 = 28^2 = 784
    sqrab > n => a=a

Iteration 3:
    b = 2
    sqrab = (a+b)^2 = 26^2 = 676
    sqrab > n => a=a

Iteration 4:
    b = 1
    sqrab = (a+b)^2 = 25^2 = 625
    sqrab > n => a=a

Iteration 5:
    b = 0.5
    sqrab = (a+b)^2 = 24.5^2 = 600.25
    sqrab < n => a=a+b = 24.5

Iteration 6:
    b = 0.25
    sqrab = (a+b)^2 = 24.75^2 = 612.5625
    sqrab < n => a=a


Iteration 7:
    b = 0.125
    sqrab = (a+b)^2 = 24.625^2 = 606.390625
    sqrab < n => a=a+b = 24.625

and so on.
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/9235456

复制
相关文章
将JSON数组转化为List集合[通俗易懂]
假如我们向redis中存放了一个JSON数组,从中获取的时候需要将JSON数组转化为List集合,然后将List对象返回给前端。
全栈程序员站长
2022/09/07
5.7K1
将JSON字符串反序列化为指定的.NET对象类型
  关于将JSON字符串反序列化为指定的.NET对象类型数据常见的场景主要是关于网络请求接口,获取到请求成功的响应数据。本篇主要讲的的是如何通过使用Newtonsoft.Json中的JsonConvert.DeserializeObject<T>(string value)方法将对应的JSON字符串转化为指定的.NET对象类型数据。
追逐时光者
2020/06/19
3.1K0
python json 编码(dump/dumps:字典转化为json)、解码(load/loads:json转化为字典)
参考链接: python json 1-1:使用json.dump/dumps将JSON写入文件/字符串
用户7886150
2021/01/19
1.9K0
Python: Json串反序列化为自定义类对象
参考链接: Python-Json 5 : python自定义class进行Json格式化
用户7886150
2021/01/17
2.1K0
android将字符串转化为json,将string转换为JsonArray「建议收藏」
只是在这里混合另一种方法,我想build议看看Gson 。 Gson是一个使Java对象序列化和反序列化的库。 例如,用你的string,你可以这样做:
全栈程序员站长
2022/08/31
3.8K0
【Flutter】JSON 模型转换 ( JSON 序列化工具 | JSON 手动序列化 | 根据 JSON 编写 Dart 模型类 | 在线自动根据 JSON 转换 Dart 类 )
JSON 格式比较简单的话 , 使用自带的 dart:convert 包 , 手动进行 JSON 的序列化与反序列化的操作即可 ;
韩曙亮
2023/03/29
2.8K0
【Flutter】JSON 模型转换 ( JSON 序列化工具 | JSON 手动序列化 | 根据 JSON 编写 Dart 模型类 | 在线自动根据 JSON 转换 Dart 类 )
es6将txt数据序列化成json
2、str=(txt里的数据),let arrStr = str.split('\n');
杨肆月
2019/08/15
6490
R语言时间序列TAR阈值模型分析
例如,在药物毒理学应用中,可能低于阈值量的所有剂量都是安全的,而随着剂量增加到阈值量以上,毒性增加。或者,在动物种群丰富度研究中,人口可能会缓慢增加至阈值大小,但一旦人口超过一定规模后可能会迅速减少(由于食物有限)。
拓端
2020/08/21
9930
R语言时间序列TAR阈值模型分析
一种自动的将自定义类序列化为JSON的方法
最近因为项目需求,需要将一些自定义的类序列化为JSON,网上有很多好用的第三方序列化工具,但都只能自动序列化一些基本类型,如NSNumber,NSString与NSDictionary这种,没有一种第三方工具提供直接将自定义类序列化的方法(至少据我所知:),而对于这种序列化自定义的类的需求,网上能查到的方法只有将自定义的类手动的转存为一个NSDictionary,然后再使用第三方工具来序列化。例如对于一个类Foo,有如下定义: @interface Foo : NSObject {   NSStri
阿新
2018/04/12
1.1K0
R语言多元Copula GARCH 模型时间序列预测
和宏观经济数据不同,金融市场上多为高频数据,比如股票收益率序列。直观的来说 ,后者是比前者“波动”更多且随机波动的序列,在一元或多元的情况下,构建Copula函数模型和GARCH模型是最好的选择。
拓端
2022/06/08
7540
R语言多元Copula GARCH 模型时间序列预测
R 机器学习预测时间序列模型
随着疫情的变化,急性传染病数据经常会随时间变化,我们通过对每天传染病的记录,就形成了时间序列数据,周期可以是天,周,月,年。目前我们经常会用到ARIMA来预测疾病在未来的变化趋势。
Jamesjin63
2022/10/25
9590
R 机器学习预测时间序列模型
将流转化为数据产品
每个大型企业组织都在尝试加速其数字化转型战略,以更加个性化、相关和动态的方式与客户互动。在创建和收集数据时对数据执行分析(也称为实时数据流)并生成即时洞察以加快决策制定的能力为组织提供了竞争优势。
大数据杂货铺
2022/12/02
1K0
将流转化为数据产品
R语言时间序列TAR阈值自回归模型
为了方便起见,这些模型通常简称为TAR模型。这些模型捕获了线性时间序列模型无法捕获的行为,例如周期,幅度相关的频率和跳跃现象。Tong和Lim(1980)使用阈值模型表明,该模型能够发现黑子数据出现的不对称周期性行为。
拓端
2020/12/30
8880
R语言时间序列TAR阈值自回归模型
Apache Kafka-Spring Kafka将泛型反序列化为对象而非LinkedHashMap
spring kafka 使用Jackson序列化, 如果存入kafka中的对象 包含 泛型,那么 默认情况下,这个泛型对象会被Jackson反序列为 LinkedHashMap . 抛出类型转换异常…
小小工匠
2021/08/17
1.3K0
Apache Kafka-Spring Kafka将泛型反序列化为对象而非LinkedHashMap
Python将html转化为pdf
前面我们对博客园的文章进行了爬取,结果比较令人满意,可以一下子下载某个博主的所有文章了。但是,我们获取的只有文章中的文本内容,并且是没有排版的,看起来也比较费劲。。。
周小董
2019/03/25
2.2K0
Python将html转化为pdf
js将秒转化为分钟
formatSeconds(value) { // 秒 let second = parseInt(value) // 分 let minute = 0 // 小时 let hour = 0 // 天 // let day = 0 // 如果秒数大于60,将秒数转换成整数 if (second > 60) { // 获取分钟,除以60取整数,得到整数分钟 minute = parseInt(second / 60) // 获
2022/10/31
3.4K0
将 PDF 转化为 Word 文件
最近存在一个问题:项目结题申请需要上交 Word 版本结题报告。然后我是使用 LaTeX 制作的报告,只能生成 PDF 文件。这该怎么办?通过互联网检索发现了以下几种方法:
庄闪闪
2023/01/09
1.8K0
将 PDF 转化为 Word 文件
左手用R右手Python系列之——json序列化与反序列化
json格式数据作为如今越来越流行的数据交换格式,几乎已经成为web端数据交互的标准,主流的数据科学语言R,Python都中都有非常完善的半结构化数据与json数据进行通讯。本篇文章将会通过简单案例介绍R语言与Python中与json数据进行序列化与反序列化的常用函数。 json的数据以键值对形式存在,在R语言中,符合此标准的就是基础数据对象中的list(严格来说,R语言中所有数据对象都可以表示为list,但是可以保存递归结构只有list一种)。 在R语言中,涉及到json数据处理的,主要是list转换为
数据小磨坊
2018/04/12
1.7K0
iOS SwiftyJSON 对应的JSON 转化为 对象
SwiftyJSON确实很好用 不会因为取了某个空对象的值而导致程序的崩溃 但是 一直这样data["a"]["b"]["c"].stringValue的形式也不太好 那怎样把JSON转换成对象呢
码客说
2019/10/22
1.5K0
点击加载更多

相似问题

SSH和Egit与Eclipse

11

auth与Egit (ssh配置)失败

12

Eclipse和EGit:无法导出SSH

211

Egit ssh问题

22

无法使Nusoap服务器与cakephp一起工作

11
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文