std::numeric_limits::epsilon() 可以用来做什么?

2024-02-20

  unsigned int updateStandardStopping(unsigned int numInliers, unsigned int totPoints, unsigned int sampleSize)
    {
        double max_hypotheses_=85000;
        double n_inliers = 1.0;
        double n_pts = 1.0;
        double conf_threshold_=0.95

        for (unsigned int i = 0; i < sampleSize; ++i)
        {
            n_inliers *= numInliers - i;//n_linliers=I(I-1)...(I-m+1)
            n_pts *= totPoints - i;//totPoints=N(N-1)(N-2)...(N-m+1)
        }
        double prob_good_model = n_inliers/n_pts;

        if ( prob_good_model < std::numeric_limits<double>::epsilon() )
        {
            return max_hypotheses_;
        }
        else if ( 1 - prob_good_model < std::numeric_limits<double>::epsilon() )
        {
            return 1; 
        }
        else 
        {
            double nusample_s = log(1-conf_threshold_)/log(1-prob_good_model);
            return (unsigned int) ceil(nusample_s); 
        }
    }

以下是选择声明:

if ( prob_good_model < std::numeric_limits<double>::epsilon() )
{...}

据我理解,判断语句与(或近似)相同

prob_good_model < 0

所以无论我是否正确以及在哪里std::numeric_limits<double>::epsilon()除此之外还可以用吗?


epsilon 的目的是让您(相当)轻松地找出两个数字之间可以看到的最小差异。

不过,您通常不会完全按原样使用它。您需要根据要比较的数字的大小来缩放它。如果您有两个 1e-100 左右的数字,那么您将使用以下顺序的数字:std::numeric_limits<double>::epsilon() * 1.0e-100作为你的比较标准。同样,如果你的数字在 1e+100 左右,你的标准就是std::numeric_limits<double>::epsilon() * 1e+100.

如果您尝试在不缩放的情况下使用它,您可能会得到完全错误(完全没有意义)的结果。例如:

if (std::abs(1e-100 - 1e-200) < std::numeric_limits<double>::epsilon())

是的,这将显示为“true”(即,两者相等),即使它们相差 100 个数量级。另一方面,如果数字远大于 1,则与(未缩放的)epsilon 相比相当于说if (x != y)--它根本不留任何舍入误差的余地。

至少根据我的经验,epsilon不过,为浮点类型指定的值通常没有多大用处。通过适当的缩放,它可以告诉您给定大小的两个数字之间可能存在的最小差异(对于特定的浮点实现)。

然而,在实际使用中,它的实际用途相对较小。更实际的数字通常基于输入的精度,以及对由于舍入(等)可能损失的精度量的估计。

例如,假设您一开始的测量精度为百万分之一,并且您只进行了几次计算,因此您认为由于舍入误差可能会损失多达 2 位的精度。在这种情况下,您关心的“epsilon”大约是 1e-4,根据您正在处理的数字的大小进行缩放。也就是说,在这种情况下,您可以预期 4 位精度的顺序是有意义的,因此,如果您看到前四位数字存在差异,则可能意味着这些值不相等,但如果它们不同仅在第五(或更高)数字中,您应该将它们视为相等。

事实上,您使用的浮点类型可以表示(例如)16 位精度,但这并不意味着您使用的每个测量都将接近精确 - 事实上,基于物理的任何测量都相对较少。测量结果有望接近这一精确度。然而,它确实给了你对计算的期望值的限制——即使你从一个精确到 30 位数字的值开始,计算后你能期望的最大值将由下式定义:std::numeric_limits<T>::epsilon.

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

std::numeric_limits::epsilon() 可以用来做什么? 的相关文章

随机推荐

  • xjc:两个声明导致 ObjectFactory 类中发生冲突

    运行以下命令xjc命令引发错误 xjc ftp ftp ncbi nih gov bioproject Schema Core xsd parsing a schema compiling a schema ERROR Two declar
  • cakePHP 重定向 $this->referer() 无法正常工作

    我有一个 TestController 视图文件 并在其中添加了评论表单 我的页面所在页面的 URL 是 www example com test view slug 现在评论表单发布在 URL www example com 上 comm
  • 即使上传了文件,Laravel Input::hasFile('image') 也会返回 false

    我有一个用于图像上传的表单字段 我用 files gt true 打开它 如下所示 Form label image Image Form file image 在我的控制器中 我想检查文件是否已上传并对其执行某些操作 if Input h
  • IDEA的logcat过滤器可以自动识别正在运行的应用程序吗?

    我找不到这个或 IDEA还没有像 Eclipse 很久以前那样实现了智能过滤器 当我看着logcatIDEA 11 中的选项卡 我没有看到它自动识别正在运行的应用程序并将其添加到All Messages 就像 Eclipse 对每个正在运行
  • JAR 文件不从 ext 加载类文件

    我在Linux系统上安装了JDK 1 6 JAVA HOME目录是 usr java jdk1 6 0 07 我在 Eclipse 上构建了 JAVA HOME 的路径 它通过 Eclipse 顺利运行并加载所有第三方 JAR 文件 usr
  • 预先添加文件的某些行

    我想创建一个脚本来注释掉 Mac OS X 主机文件中包含的行 com 还有一个可以扭转它 So this 127 0 0 1 foo com 127 0 0 1 bar com 127 0 0 1 baz 127 0 0 1 qux 会成
  • CouchDB 附件的自定义属性

    我试图在单个 CouchDB 文档中存储多个独立附件 并为每个附件分配任意属性 即描述 有这样做的约定吗 据我所知 我无法将它们插入 attachments直接构造 提前致谢 您无法修改其中的任何内容 attachments直接使用 因为它
  • 更新特定领域模型属性?

    如何仅更新某些领域模型属性 而不是尝试使用一次又一次地保存完整的领域模型copyToRealmOrUpdate public class User extends RealmObject PrimaryKey public String i
  • Python数据结构的内存大小

    如何找到Python数据结构的内存大小 我正在寻找类似的东西 sizeof 1 hello 2 world 如果它能递归地计算每件事 那就太好了 但即使是基本的非递归结果也有帮助 基本上我想了解各种实现选项 例如元组与元组 列表对比类在内存
  • Youtube IFrame API 来源不受信任

    正如标题所示 我正在使用 IFrame API 我一直在遵循指南API参考 https developers google com youtube iframe api reference 它对我有用 但我发现出现了一些警告并希望解决它们
  • 仅使外部白色透明

    我正在使用 imagick 和 php 来修改上传的图像 我想去除图像周围的白色 使其具有透明背景 使用这个 val 65535 15 val intval val 1 divide by 1 means accept full fuzz
  • 如何从oracle表的多个分区中选择数据

    我正在尝试从分区表中的多个分区中选择数据 它适用于单个分区 select from table partition ParititonName 但不能选择多个分区 select from table partitions Part1 par
  • 添加自定义转换类型以进行字符串格式化

    python 中是否有向字符串格式添加额外的转换类型 使用的标准转换类型 基于字符串的格式化是这样的s对于字符串 d我想要做的是添加一个新字符 我可以为其指定一个自定义处理程序 例如 lambda 函数 该处理程序将返回要插入的字符串 例如
  • 在 C# 中将列表设置为只读

    我有这个示例代码 我想要做的是使 Nums 值只能使用 AddNum 方法写入 namespace ConsoleApplication1 public class Person string myName N A int myAge 0
  • ExecutorService 超时但不阻塞主线程

    我想在有时间限制的后台执行一些工作 问题是 我不想阻塞主线程 简单的实现是有两个执行器服务 一个负责安排 超时 第二个负责完成工作 final ExecutorService backgroundExecutor Executors new
  • F# 如何捕获所有异常

    我知道如何捕获特定异常 如下例所示 let test zip archive candidate zip archive let rc try ZipFile Open candidate zip archive ToString ZipA
  • Laravel 5.8 中 Auth::user() 返回 null

    我的 Laravel 5 8 10 项目中遇到身份验证问题 我没有使用 Laravel 创建的默认表单进行身份验证 当我在浏览器中访问 URL 仪表板时 通常用户会在登录时获得重定向 无论如何 应用程序允许它 另外当我使用时Auth use
  • TYPE_E_CANTLOADLIBRARY 仅当在 Windows 2003 x64 上的单独线程上使用 COM 对象时

    我有一个访问 COM 对象的 Windows 窗体应用程序 编译为 x86 它给了我以下错误 only在 Windows 2003 x64 上 当代码在单独的线程上运行时 创建 IDoc 期间出现异常 无法将类型 PTISG COM Tek
  • 修复 ARC 中潜在的内存泄漏

    以下单例类 SharedManager 辅助方法可能会导致保留周期 在静态分析器中收到警告 在行分配的对象的潜在泄漏 我该如何修复 我确实尝试使 ivar uuid weak 但在分析时仍然出现警告 NSString weak uuid b
  • std::numeric_limits::epsilon() 可以用来做什么?

    unsigned int updateStandardStopping unsigned int numInliers unsigned int totPoints unsigned int sampleSize double max hy