- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在开发需要浮点确定性的C应用程序。我还希望浮点运算相当快。这包括IEEE754未指定的标准先验功能,例如正弦和对数。与硬件浮点相比,我考虑的软件浮点实现相对较慢,因此我正在考虑简单地从每个答案中舍入一个或两个最低有效位。精度损失对我的应用程序来说是一个足够的折衷,但这是否足以确保跨平台的确定性结果?所有浮点值将为 double 。
我意识到操作顺序是浮点结果差异的另一个潜在来源。我已经有办法解决这个问题。
如果今天使用的是主要浮点硬件实现的软件实现,那就太好了,因此我可以直接检验这样的假设。
最佳答案
据我了解,您有一个先验函数(如sin(x))的软件实现,以IEEE标准操作(例如浮点加法和乘法)表示,并且您希望确保在所有计算机上都得到相同的答案(或至少是您关心的所有机器)。
首先,要了解:这不会移植到所有机器上。例如。 IBM大型机的十六进制浮点不是IEEE,并且不会给出相同的答案。为了获得准确的结果,您将需要IEEEE标准操作的软件实现,例如FP加法和乘法。
我猜您只在乎实现IEEE标准浮点的机器。而且我还猜测您不会担心NaN,因为NaN尚未完全通过IEEE 754-1985标准化,并且出现了两种相反的实现方式:HP和MIPS,几乎所有人都使用vedrsus。 1
有了这些限制,如何获得计算的可变性?
(1)如果代码正在并行化。确保没有发生这种情况。 (这不太可能,但是有些机器可能会。)并行化是FP中结果差异的主要来源。据我所知,至少有一家关心可复制性和并行性的公司拒绝使用FP,而只使用整数。
(2)确保正确设置机器。
例如。大多数计算机以32或64位精度进行计算(C原始标准在任何地方都是64位“ double ”。但是Intel x86/x87可以以80位计算寄存器中的值,溢出时会四舍五入为64或32。1显示了如何更改x86/x87使用内联汇编将精度从80位控制到64位,请注意,该代码是汇编级的,而不是可移植的-但大多数其他计算机已经可以32位或64位精度进行计算,因此您无需担心x87 80位。
(顺便说一句,在x86上,您只能通过使用SSE FP来避免所有问题;旧的旧版Intel x87 FP永远无法给出完全相同的答案(尽管如果您将精度控制(PC)设置为64位而不是80位,您会得到相同的结果,除了中间出现溢出外,因为指数宽度不会受到影响,仅尾数即可))
例如。确保在所有计算机上使用相同的下溢模式。 IE。确保禁用或启用,或者相反,确保所有计算机均处于清零模式。这是Dobson的选择:冲水归零模式尚未标准化,但某些机器(例如GPU根本就没有非规范化的数字。 IE。许多机器具有IEEE标准编号FORMATS,但没有实际的IEEE标准算术(带有定理)。我的要求是要求使用IEEE denorms,但是如果我绝对偏执,我会将flush设置为零,并在软件中强制执行该操作。
(3)确保使用相同的语言ioption。较旧的C程序以“ double ”(64位)进行所有计算,但是现在允许以单精度进行计算。无论如何,您都希望在所有计算机上都以相同的方式进行操作。
(4)一些较小的项目带有您的代码:
避免编译器可能会重新排列的大表达式(如果未正确实现严格的FP开关)
可能以简单的形式编写所有代码,例如
double a = ...;
double b = ...;
double c = a *b;
double d = ...;
double e = a*d;
double f = c + e;
f = (a*b) + (a*c);
f = a*(b+c);
关于我可以使用舍入来确保原子浮点运算的确定性吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9236022/
我有以下对象: dog = { location: { x: 52.1089, y: 16.2323 }, f: function(message) { alert
在 TSQL 中,如果我要搜索有效的 .com 电子邮件地址,我需要确保有一个 @ 符号,它以 .com 结尾,并且在 @ 前后至少有一个字符。 SELECT * FROM CUSTOMER WHER
我正在尝试准备一个信用卡交易列表,以便在 Excel 2010 中进行透视和进一步分析(满足个人需求)。问题是我的银行机构没有遵循标准的日期格式,所以有时日期会显示为 Jun. 1, 2013 , 有
看来您不能在 riak 中进行交易。如何确保数据正确? 假设我们要插入评论。在 redis 我会做 commentId=incr commentCount multi SET comment_post
对于下面给定的模式,是否可以确保至少一个属性包含一个值(即 minLength 为 1): { "$schema": "http://json-schema.org/draft-04/sche
我计划在 Haxe 的一个子集中编写 Haxe 库,这些库将编译为每种 Haxe 目标语言。有什么方法可以验证 Haxe 程序是否可以编译为所有目标语言,是否可以在不手动测试每个目标平台上的编译代码的
如果浏览器窗口未聚焦,则当前页面上的所有 webdriver 标识都失败。 如何使用 webdriver 使浏览器成为焦点? 最佳答案 ((JavascriptExecutor) webDriver)
我从这样的 HTML GET 请求中获取图像链接... www.example.com?image=www.anotherdomain.com/image.jpg if (isset($_GET['i
我有一个 eunit 测试,它生成一个唯一的节点名称并开始分发: {A,B,C} = now(), Nodename = list_to_atom(lists:flatten(io_lib:forma
我正在完成我的 iPhone 应用程序。我只是担心我们的网络服务器级别的安全性。数据通过网络服务被传送到 iPhone 应用程序。 我可以在网络服务上采取哪些安全措施,以免受到攻击? 谢谢 最佳答案
我正在编写一个应用程序,该应用程序启动一个运行简单 Web 服务器的子进程。我正在使用 NSTask 并通过管道与其进行通信,一切看起来或多或少都很好。但是,如果我的程序崩溃,子进程将保持事件状态,并
我有一些应用程序,我调用 ShowMessage('Complete!');在长时间操作结束时。 大多数时候,这效果很好,但每隔一段时间,消息对话框就会显示在主窗体后面。 有什么方法可以确保 Show
我通过将消息插入集合并让模板使用 {{#each}} 打印出集合来创建一个简单的聊天。 我不太熟悉安全性,但是有没有办法让它符合 EFF 规定? https://www.eff.org/secure-
我有一个商店,我想在其中正确管理 id。假设我有以下帖子存储: type Post = { id: number; title: string; body?: string; } type
我有一个使用 ajax post 方法和数据表的程序。经过几周的摆弄,我确定我根本不明白 javascript 是如何工作的。这是我的 JavaScript: $('#SaveTimeSheet').
我有一个系统,如果从 Azure 服务总线丢失消息将是一场灾难,也就是说,数据将永远丢失,并且没有实际方法可以在不造成重大中断的情况下修复损坏。 在这种情况下我可以完全依赖 ASB 吗? (即使它
如何确保 scalatest 测试不会并行运行?在 0.12 之前,我有一个 sbt 设置: parallelExecution in Test := false 新版本引入了一些复杂的机制。这种更简
我的端点有两个如下所示的 promise : request.post({ url: url, json: smsSTART, header
简短版本 当 ui-router 转换到新 View 时(以我不完全理解的方式使用 ngAnimate),它会添加类 ng-leave 和 ng-leave-active 到当前 View 。它还将类
目前正在努力寻找验证 2 个表的方法(有效地验证表 A 的大量行) 我有两张 table 表A ID A B C 表格匹配 ID Number A 1 A 2 A 9 B 1
我是一名优秀的程序员,十分优秀!