5

这是设置:

对于我的学士论文,我想测试 LHC 使用的喷射算法。基本上第一步是以下步骤:给定一些 4-momentum

p[0] = nullvector(45.0000000000106,33.03951484238976,14.97124733712793,26.6317895033428)

我想通过以 10^(-12) 的顺序向最后三个分量添加一些(如 50 个)随机生成的 4 向量来模拟实验数据,这样它们就很小(这就是有趣的物理学发生的地方),但是显着高于 15 位小数的双浮点精度。因此,快速而肮脏的解决方案如下:

seed=time(NULL);
srand(seed);
random=(rand()%9001)*1.0E-15;
random=random+1E-12;
printf("%.15E\n",random);

这给了我 1E-12 和 10E-12 (=1E-11) 之间的随机数,最多三位小数,所以在“真实”双打中,这给了我 15 位小数。

现在重点是:我可以在不超过双浮点精度的情况下以超过三位小数的顺序存储数字吗?

PS:有没有更好的方法来生成小的随机数?(这听起来像是另一个话题;))

4

1 回答 1

1

创建浮点随机数的传统方法是通过取 - 使其成为范围 [0-1),double x = (double)rand()/RAND_MAX;然后乘以将9001E-1范围缩放1E-121E-15值 [包括零]。

于 2013-03-07T16:49:45.460 回答