Car 2 x:精确的sqrt(1+ (x/2)^ 2)+ x/2

关于Car 2 x的问题,在square root of x2中经常遇到, 我需要在数值上计算sqrt(1 + (x/2)^2) + x/2,对于正x。对于非常大的x值,使用此表达式直接失败。如何重写它以获得更准确的评估?

我需要在数值上计算sqrt(1 + (x/2)^2) + x/2,对于正x。对于非常大的x值,使用此表达式直接失败。如何重写它以获得更准确的评估?

6

对于非常大的x,您可以计算出x/2

sqrt(1 + (x/2)^2) + x/2
 = (x/2) * sqrt( 1/(x/2)^2 + (x/2)^2/(x/2)^2) + x/2
 = (x/2) * sqrt( (2/x)^2 + 1 ) + x/2

对于x > 2/sqrt(eps),平方根实际上将计算为 1,您的整个表达式将简化为x假设您需要覆盖整个范围[0, infinity],我建议只在该点分支并返回x在这种情况下和您的原始公式,否则:

if x > 2/sqrt(eps)  // eps is the machine epsilon of your float type
    return x
else
    return sqrt(1 + (x/2)^2) + x/2
4

许多编程语言提供了计算sqrt (x*x + y*y)的函数hypot(x,y),同时避免了中间计算中的上溢和下溢。hypot的许多实现也比朴素表达式更准确地计算结果。这些优点是以运行时间的适度增加为代价的。

有了这个函数,给定的表达式可以写成hypot (1.0, 0.5*x) + 0.5*x。如果您选择的编程语言不支持hypot或等效函数,您可以调整我在this answer中提供的实现。

3

注意有人指出,Herbie 生成的表达式可能不适用于所有上下文。特别是,Herbie 用于“改进”表达式的指标可能会生成在特定情况下性能较差的表达式。因此,请使用谷物盐获取其输出。我认为您仍然可以咨询 Herbie 以获得想法,但是不要将其用作直接替换。

Herbie (https://herbie.uwplse.org/) 建议使用以下表达式替换:

enter image description here

或者,在 C:

double code(double x) {
    return ((double) (((double) sqrt(((double) (1.0 + ((double) pow((x / 2.0), 2.0)))))) + (x / 2.0)));
}

变为:

double code(double x) {
    double VAR;
    if (((x / 2.0) <= -8569.643649604539)) {
        VAR = (1.0 / ((double) ((1.0 / ((double) pow(x, 3.0))) - ((double) (x + (1.0 / x))))));
    } else {
        double VAR_1;
        if (((x / 2.0) <= 7.229769585372425e-11)) {
            VAR_1 = ((double) ((x / 2.0) + ((double) sqrt(((double) (1.0 + ((double) pow((x / 2.0), 2.0))))))));
        } else {
            VAR_1 = ((double) ((x / 2.0) + ((double) (((double) ((1.0 / x) + ((double) (x * 0.5)))) - (1.0 / ((double) pow(x, 3.0)))))));
        }
        VAR = VAR_1;
    }
    return VAR;
}

它生成了一份详细的报告,说明为什么将它分成三个区域。Herbie 的输出可能很难阅读,据报道它可能不会更好,但也许它可以提供另一种观点。

1
hypot()

假设函数计算 x 和 y 的平方和的平方根,而不会出现过度的上溢或下溢。可能会出现范围错误。

代码可能会得到更好的结果hypot(1,x/2) + x/2;

本站系公益性非盈利分享网址,本文来自用户投稿,不代表码文网立场,如若转载,请注明出处

(996)
Excel表格宏编辑代码:如何避免在Excel中编辑宏(edit macro in excel)
上一篇
C罗抢伊瓜因单刀gif:伊瓜齐奥的工作停留在“待定”状态
下一篇

相关推荐

  • cvt和自动挡哪个好提升驾驶体验的最佳选择

    CVT(可变转换器)是一种由传动带及传动轮组成的无级变速器,它可以在没有传动档位的情况下,根据驾驶者的驾驶习惯,自动调整传动轮之间的转速比,从而实现无级变速。自动挡是指车辆自动变速箱,它使用液力传动来实现变速,可以自动适应车辆的行驶状态,减少司机的疲劳,提高行车的舒适性。…

    2023-06-08 07:42:19
    0 67 57
  • cv一叶扁舟和清影轩阳:漫游在一叶扁舟和清影轩阳之间

    cv一叶扁舟是一款开源的计算机视觉库,用于图像处理、计算机视觉等。它提供了丰富的API,可以帮助开发者快速实现各种图像处理任务,如图像分割、目标检测、图像识别等。清影轩阳是一款开源的计算机视觉框架,用于图像处理、目标检测、分类等。它提供了丰富的API,可以帮助开发者快速实现各种图像处理任务,如图像分割、目标检测、图像识别等。…

    2023-08-05 07:06:20
    0 46 37
  • css设置滚动条宽度设置:This is a title

    CSS设置滚动条宽度的方法:使用CSS3的。-webkit-属性:…

    2023-06-06 10:53:01
    0 37 90
  • xl和xe汽车cvt:探索XL和XE汽车的CVT技术优势

    XL和XE汽车CVT是一种变速器,它使用液力变矩器代替传统的机械变速器,以达到更高的效率。它的工作原理是,当发动机输出功率时,液力变矩器就会将这些功率转换为液压能量,然后将能量传递到变速器的输出轴上,从而实现变速。…

    2023-04-09 00:41:04
    0 37 98
  • cordon bleu是什么意思:法式炸鸡卷——Cordon Bleu的经典之作

    Cordon Bleu是一种烹饪技术,其中肉片被置于奶酪和火腿之间,然后用面包屑裹上,最后煎炸或烤熟。这种技术通常用于制作鸡肉,但也可以用于制作其他类型的肉类,如牛肉或猪肉。…

    2024-01-27 15:13:30
    0 46 14
  • countif 非空:非空单元格的计数

    Countif 非空是指计算某个单元格不为空的数量。代码如下:…

    2023-04-22 15:54:15
    0 39 89
  • java double保留一位小数:How to Round a Double to One Decimal Place in

    示例示例使用类可以轻松实现java double保留一位小数的功能,具体代码如下:// 创建对象…

    2023-05-14 07:40:03
    0 63 92
  • linux如何写c语言一个完整的指南

    示例示例在Linux系统中,可以使用C语言编写源代码文件,然后使用GCC编译器来编译源代码文件,生成可执行文件。下面是一个简单的C语言代码示例:…

    2023-05-16 02:02:45
    0 26 51

发表评论

登录 后才能评论

评论列表(72条)