- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我的问题是从模计算中获得最准确的结果,我得到余数答案以进行另一次舍入计算,因此我确实需要一个准确的结果。
double a = 0.12345678...(可能有很多数字);
double b = fmod(a, 0.01);
结果 b
可能不准确处理二进制存储问题。
我是否必须考虑使用 float
来提高准确性。或者我只是将数字从小数点移动到整数
双 a = 12345678.0;
谢谢
最佳答案
首先,任何严格的 fmod 实现都会以单精度/ double /任何精度回答最接近余数的 float ,就好像以无限精度执行除法一样。(注意:感谢@EricPostpischil 改写)
不过,那已经太晚了。 0.01 的二进制浮点内部表示并不完全像您已经知道的那样表示 1/100。
让我们检查错误是如何累积的。
你想知道除法的余数,比如 a % b = c
.
您有不精确的表示 a1 和 b1,并且您知道这些表示的错误界限:a1=a+ea1
, abs(ea1) < ea
, b1=b+eb1
, abs(eb1) < eb
.
关于 a1 % b1 = c1
,你有什么想说的吗? (确切的操作),c1=c+ec1
那是关于错误界限abs(ec1) < ec
?
a = q * b + c.
a1 = q1 * b1 + c1.
a+ea1 = (q+eq1)*(b+eb1) + (c+ec1).
ea1 = eq1*(b+eb1) + q*eb1 + ec1.
ec1 = ea1 - q*eb1 - eq1*(b+eb1).
ec >= max( ea , abs(q)*eb , eq*abs(b) , eq*eb).
ec <= ea + abs(q)*eb + eq*abs(b) + eq*eb.
你可以控制ea
和 abs(q)*eb
通过提高表示精度(单倍、双倍、扩展、四倍、任意精度...)。
但是这个等式中的重要术语是 eq*abs(b)
,因为如果商可以减一,那么误差范围是 ec > b
!
当然,商可以减一,这种情况非常容易构造。取c=0
和 a1
表示关闭 a
默认情况下 ( ea1<0
) 或 b1
表示关闭 b
超出(eb1>0
),你就完成了,你得到了eq1 = -1
即使是小商和准确的精度。
不要认为仔细控制舍入模式,例如获得 ea1 > 0
(多余)和eb1 <= 0
(默认)会在所有情况下保护你,因为我们可以构造相反的情况
b - smallValue < c < b
不要尝试 remainder
fmod
的变体舍入商而不是截断,这只会使问题接近完美平局(当精确除法 a/b 是 1/2 的倍数时)。
通过对误差范围的仔 segmentation 析,您可以得出 ec
的估计值。并确定商 q
可能不正确四舍五入的不良情况(当 a1/b1
接近整数时),或 abs(q)*eb
达到 1,或 ea>=b
.
在糟糕的情况下,您可以安排引发异常,然后重新开始生产 a1
和 b1
精度更高,但在边缘情况下c=0
, 即使精度任意,也不能保证收敛。
关于c - fmod 十进制数的最佳方法是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17539549/
我研究了旧代码,看到了这样一个函数: inline double mod(double x, double y) { return x-y*floor(x/y); } fmod 是完全等效的,
我遇到了一个非常奇怪的情况:在我正在开发的多线程应用程序中,在某个代码点 fmod(x,y) 返回 -1.#IND00 而 double x = 0.0 和 double y = 1.0。当然,我仔细
这个问题在这里已经有了答案: Is floating point math broken? (31 个答案) 关闭 4 年前。 当我调用我的函数时: formatCurrency(7.5); str
当我在 C++ 中使用 fmod(0.6,0.2) 时,它返回 0.2 我知道这是由浮点精度引起的,但现在看来我必须得到两个双倍的余数 非常感谢对此类问题的任何解决方案 最佳答案 数学值 0.6 和
我试图在 3D 平面中表示声音的频谱,但我只能播放声音而无法将 dsp 放入结构 FMOD_DSP_PARAMETER_FFT,numchannels 和 length 始终 = 0 我的代码是这样的
好的,我希望我不要搞砸了,我已经寻找了一些答案,但找不到任何东西。我正在尝试在 3D 模式下使用 FMOD 声音播放器在 openframeworks 中制作一个简单的采样器。我可以使单个实例正常工作
这可能是 FMOD 的内置功能,但我想看看是否可以覆盖它。 使用 FMOD_System_PlaySound 播放声音时, FMOD_System_PlaySound( system, FMOD_CH
为什么 PHP 的 fmod 函数不能按预期工作。我错过了什么吗? fmod(2.0, 0.1); // outputs 0.1 以下应输出 0,因为 2.0/0.1 = 20,因此没有余数。我知道
任何人都可以帮助我使用 FMOD 或任何其他方式从内存流中播放文件吗? 到目前为止我有这个: 变量 private FMOD.System _fmod = null; private
我想使用 Cpp 计算阶乘中零的个数。问题是当我使用非常大的数字时。 #include #include long zeroesInFact(long n) { long double fact=
我从 fmod 教程中几乎逐字复制了以下代码块,对变量名进行了细微修改,以免与任何内容发生冲突。我的代码在没有任何 fmod 语句的情况下编译得很好。当我放入 FMOD_RESULT fm_resul
我想知道我是否做错了什么。我已经将我的 SoundManager 类设置为有 5 个不同的 channel ,在我的游戏中可能会同时播放一些声音,比如开枪和敌人“受伤”的声音......这就是我设置
在代码中: FMOD_RESULT result; FMOD::System *system; result = FMOD::System_Create(&system); FMODErrorChec
首先,我正在为学校做这个项目,我们不允许使用外部库,因此我不能使用 GMP 之类的东西。问题是,我有一个函数需要一些“艰难”的计算。即, m^e mod n 这是我的代码 #include #inc
使用 FMOD(交互式音频中间件),是否可以在播放轨道时实时计算其每秒节拍数? 我找不到太多关于此的信息,这将非常有用。将使用 c# 但能够翻译。 谢谢 最佳答案 FMOD 不提供任何计算每分钟节拍的
我想播放一个 mp3 文件,所以我搜索并了解了 FMOD。我下载了http://www.fmod.org/download/ (用于 Linux 的 FMOD Studio 程序员 API)。 我还收
我的问题是从模计算中获得最准确的结果,我得到余数答案以进行另一次舍入计算,因此我确实需要一个准确的结果。 double a = 0.12345678...(可能有很多数字); double b = f
我开始使用 FMOD 库,因为我需要在 C# 应用程序中播放没有间隙的声音(循环中的一个声音和序列中的许多声音)。谁能告诉我正确的方法吗?我尝试根据示例制作一些东西,但它没有像我希望的那样工作。首先,
我正在尝试设置我的声音管理器 (FMOD) 以在不同的 channel 上播放背景音乐和其他 Action 声音,据我所知,这是使用 FMOD 同步声音的唯一方法....我的设置是下面,如果我调用 p
我开始使用 FMOD API,但我在播放声音时遇到了问题。我使用了本网站的教程:http://glasnost.itcarlow.ie/~powerk/audio/AddFMODtoaproject.
我是一名优秀的程序员,十分优秀!