蒙特卡罗错误
Monte Carlo error
我写了一个蒙特卡罗程序来计算ln(2)。我生成范围1-2中的随机x和范围0-1中的随机y。如果y<1/x我在计数中加1。我对ln(2)的估计是count/n(即上面的frac)。我正在努力找出我的估计中的错误,这样一旦我的估计准确到2dp,我就可以结束这个程序。我不知道如何以有意义的方式计算标准偏差。帮助
我相信你想要的答案与二项式随机方差有关。
对于二项式变量,你会有一个与它在曲线下的次数相关的计数U
,以及它在曲线上的次数A
。设N = U + A
为样本总数。
U
的标准偏差的合理估计为sigma = sqrt(U/N * A/N * N)
。这是因为U
是一个二项式随机变量,而你对p
的最佳估计,即它在一次试验中处于曲线下的概率,是由U/N
很好地估计的。还要注意,CCD_ 9被CCD_ 10很好地估计。
但你估计的是U/N
,所以你对ln(2)
的估计的标准差的合理估计是sigma / N
。
这将为您提供一个合理的停止标准(当sigma / N
足够小以满足您的需求时)
相关文章:
- 警告处理为错误这里有什么问题
- "error: no matching function for call to"构造函数错误
- boost::进程间消息队列引发错误
- C++,OpenCV,尝试显示图像时"OpenCV(4.3.0) Error: Assertion failed (size.width>0 && size.height>0)"此错误
- 有关插入适配器的错误。[错误]请求从 'back_insert_iterator<vector<>>' 类型转换为非标量类型
- QT在错误的班级中寻找空位
- vector.resize()中的分配错误
- 代码在main()中运行,但在函数中出现错误
- 释放错误后堆使用
- (C++)分析树以计算返回错误值的简单算术表达式
- Project Euler问题4的错误解决方案
- 我的字符计数代码计算错误.为什么
- 从"int*"强制转换为"unsigned int"会丢失精度错误
- 尝试导入pybind-opencv模块时出现libgtk错误
- CMake项目Boost库错误:Boost/config/compiler/gcc.hpp:165:10:致命错误:cs
- 在某些循环内使用vector.push_back时出现分段错误
- MSVC多行宏编译器错误
- 静态数据成员的问题-修复链接错误会导致编译器错误
- 为什么在运行时没有向我们提供有关分段错误的更多信息?
- 蒙特卡罗错误