- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
Math.nextUp(arg)
始终与 arg + Math.ulp(arg)
相同,还是我遗漏了什么?
System.out.println( 0.5 + Math.ulp(0.5)); // 0.5000000000000001
System.out.println( Math.nextUp(0.5)); // EXACTLY same
System.out.println( Math.nextAfter(0.5, 1000)); // EXACTLY same
但 -1、-2、-0.5 是迄今为止发现的上述“规则”中唯一的排除项 (?)。此外,差异总是只打印最右边的小数位:
System.out.println(Math.nextUp(-0.5)); // -0.49999999999999994
System.out.println(-0.5 + Math.ulp(-0.5)); // -0.4999999999999999
System.out.println(Math.nextUp(-1.0)); // -0.9999999999999999
System.out.println(-1.0 + Math.ulp(-1.0)); // -0.9999999999999998
System.out.println(Math.nextUp(-2.0)); // -1.9999999999999998
System.out.println(-2.0 + Math.ulp(-2.0)); // -1.9999999999999996
public static double ulp(double d)
Returns the size of an ulp of the argument. An ulp, unit in the last place, of a double value is the positive distance between this floating-point value and the double value next larger in magnitude.
ulp of a specific real number value is the distance between the two floating-point values bracketing that numerical value.
public static double nextUp(double d)
Returns the floating-point value adjacent to d in the direction of positive infinity.
根据 API,Math.nextUp(arg)
和 arg + Math.ulp(arg)
对于任何 arg 应该是等价的(除了一些特殊值,例如 NaN , 无穷大, MAX_VALUE, MIN_VALUE)...
最佳答案
没有。考虑-1。 -1 的 ULP 是 2−52。区间 (−2, −1] 中的数字间隔为 2−52。但是,区间 (−1, −½] 中的数字间隔为 2−53分开。所以从 −1 开始的下一个数字是 −1+2−53,而不是 −1+2−52。
关于java - Math.nextUp(arg) 总是与 arg + Math.ulp(arg) 相同?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48625232/
我有这个代码。为了让它工作,我必须使用 Args&&... 而不是 Args... 或 Args&... 我注意到 args 从 & 转换为 const& 或 && 转换为 &。 Args...Arg
当我定义类时,我总是去 Class A(object): def __init__(self, arg): self.arg = arg def print_arg(s
假设我想定义两个 {Type} 类的变量。构造函数采用 1 个参数。下面两种方式是否完全等价(编译成相同的目标代码)? Type a(arg), b(arg); 和 Type a(arg); Type
(旁白:我是一名 Perl 程序员,正如您所知,这是我的第一个重要的 Java 程序。简单的术语将不胜感激。) 我有以下启动器作为编码工作: import java.lang.reflect.*; i
Math.nextUp(arg) 始终与 arg + Math.ulp(arg) 相同,还是我遗漏了什么? System.out.println( 0.5 + Math.ulp(0.5));
今天我在学习完美转发,我创建了这个代码示例 #include #include template auto toStdFun(Function&& fun, Args&&...ar
我想知道你会选择哪个选项? putStrLn (show randomNum) putStrLn $ show randomNum (putStrLn . show) randomNum 所有选项在语
我试图在 visual studio 2012 中编译一个库,它最初是用 c++ 为 visual studio 2015 编写的。我有一个错误说 'class' missing tag。 错误消息的
我在下面的代码中遇到了运行时异常ArrayIndexOutOfBoundException,行中: if ( args[0].equals("t") || args[0].equals("time")
我有以下代码 import React, { Component } from "react"; import { Accounts } from "meteor/accounts-base"; ex
这个问题已经有答案了: Difference between Arrays and 3 dots (Varargs) in java (3 个回答) 已关闭 5 年前。 受学校线性代数 I 和 II
所以我定义了一个函数: def getDistnace(self, strings, parentD, nodeName, nodeDistance): 我用它来调用: Node.getDistnac
这个问题在这里已经有了答案: subprocess.call() arguments ignored when using shell=True w/ list [duplicate] (2 个答案
我想将参数传递给 java 应用程序,但喜欢 linux 应用程序风格。 java 中的main 方法对所有参数使用一个String 数组。在 Linux 中,大多数应用程序接受如下参数:ls -l
这是我的代码片段 #include void change(int a[]){ printf("%p\n",&a); } int main(){
我需要使用 python 3.6 subprocess.run() 函数发出以下命令: gsettings set org.gnome.shell enabled-extensions "['appl
这两个函数是否有任何有意义的不同?有什么理由通常更喜欢一个而不是另一个吗? void foo(auto x, auto &... y) { /* ... */ } template void foo(
例如: def m(arg, ...args) { println "arg: $arg" println "args: $args" } m('arg', k:'v') 输出: ar
我对 Java 还很陌生。目前正在尝试将 args[] 中给出的文件名传递给此 FileReader,但当我编译时,它说找不到指定的文件。如果我对文件名进行硬编码,它就可以正常工作。这应该如何运作?
为什么这是一个语法错误??做这件事的合适方法是什么? >>> def f(*args, option=None): File "", line 1 def f(*args, option=
我是一名优秀的程序员,十分优秀!