- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我尝试使用超几何分布来计算概率,我在 math.stackexchange 中得到了一些帮助,但我在 java 中计算此问题时遇到问题
我不是这方面的专家,我一直试图弄清楚,但没有运气,我知道问题出在我的java代码上,因为当我在计算器上尝试公式时,我得到了正确的结果,在这种情况下是0.364
这就是公式
二项式是这样计算的
(K k) = K!/((K - k)! * k!)
这就是我尝试在 java 代码中复制它的方式
public static void main(String[] args){
BigDecimal[] prob = HyperGeometricDistribution(20,2,50,5);
String _prob = prob[0] + "." + prob[1];
System.out.println(_prob);
}
private static BigDecimal fact(BigDecimal n) {
BigDecimal result = BigDecimal.ONE;
while (!n.equals(BigDecimal.ZERO)) {
result = result.multiply(n);
n = n.subtract(BigDecimal.ONE);
}
return result;
}
private static BigDecimal Binomial(int a, int b) {
return fact(BigDecimal.valueOf(a)).divide(fact(BigDecimal.valueOf(a-b)).multiply(fact(BigDecimal.valueOf(b))), BigDecimal.ROUND_DOWN);
}
// K : Number of Successes in Population
// k : number of Successes in Sample
// N : Population Size
// m : Sample Size
private static BigDecimal[] HyperGeometricDistribution(int K,int k, int N, int m){
return (Binomial(K,k).multiply(Binomial(N-K,m-k))).divideAndRemainder(Binomial(N,m));
}
这将打印 0.77,但正确答案是 0.364 Online Example
我将在android中使用它,我将在N中传递的最大值是3910,我需要使用BigDecimals,因为我需要计算3910!这是一个巨大的数字。
感谢任何帮助
最佳答案
divideAndRemainder()
的余数不是十进制表示的小数部分。您需要将余数除以实际除数。
但实际上,您不需要 BigDecimal
。您只需要一种聪明的计算方法。让我们检查一下二项式系数的公式,例如 n=5, k=3
。然后:
c(5, 3) = (5 * 4 * 3 * 2 * 1) / ((2 * 1) * (3 * 2 * 1))
如您所见,(n-k)!
部分完全抵消,最终得到
c(5, 3) = (5 * 4 * 3) / (3 * 2 * 1)
= 5/3 * 4/2 * 3/1
所以你只需要乘以k
个分数即可。如果你总是减少分数,你就不需要很大的数字。事实上,超几何分布的计算也是一个分数,你可以再次减少一些东西以保持数字较小。下面是执行此操作的一些 C# 代码。它没什么花哨的,几乎完全可以翻译成 Java:
static class GCDHelper
{
public static long GCD(long a, long b)
{
while(b != 0)
{
var temp = b;
b = a % b;
a = temp;
}
return a;
}
}
class Fraction
{
public long Numerator;
public long Denominator;
public Fraction(long numerator, long denominator)
{
this.Numerator = numerator;
this.Denominator = denominator;
}
public void Reduce()
{
var gcd = GCDHelper.GCD(Numerator, Denominator);
Numerator /= gcd;
Denominator /= gcd;
}
public double ToNumber() { return (double)Numerator / Denominator; }
}
class Program
{
static void MultiplyBinomialCoefficient(int n, int k, bool inverse, Fraction f)
{
if (k > n / 2)
k = n - k;
for(int i = 1; i <= k; ++i)
{
if (!inverse)
{
f.Numerator *= n - i + 1;
f.Denominator *= i;
}
else
{
f.Denominator *= n - i + 1;
f.Numerator *= i;
}
f.Reduce();
}
}
static double Hypergeometric(int K, int k, int N, int m)
{
var f = new Fraction(1, 1);
MultiplyBinomialCoefficient(K, k, false, f);
MultiplyBinomialCoefficient(N - K, m - k, false, f);
MultiplyBinomialCoefficient(N, m, true, f);
return f.ToNumber();
}
static void Main(string[] args)
{
Console.WriteLine(Hypergeometric(20, 2, 50, 5));
}
}
结果:
0.364080877494384
仍有一些参数组合导致数字溢出。幸运的是,您只需将 long
变量替换为 BigInteger
变量(并相应地调整运算符)。其余的应该可以正常工作。
关于java - 超几何分布不能很好地工作java,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39759704/
我在Windows 10中使用一些简单的Powershell代码遇到了这个奇怪的问题,我认为这可能是我做错了,但我不是Powershell的天才。 我有这个: $ix = [System.Net.Dn
var urlsearch = "http://192.168.10.113:8080/collective-intellegence/StoreClicks?userid=" + userId +
我有一个非常奇怪的问题,过去两天一直让我抓狂。 我有一个我试图控制的串行设备(LS 100 光度计)。使用设置了正确参数的终端(白蚁),我可以发送命令(“MES”),然后是定界符(CR LF),然后我
我目前正试图让无需注册的 COM 使用 Excel 作为客户端,使用 .NET dll 作为服务器。目前,我只是试图让概念验证工作,但遇到了麻烦。 显然,当我使用 Excel 时,我不能简单地使用与可
我开发了简单的 REST API - https://github.com/pavelpetrcz/MandaysFigu - 我的问题是在本地主机上,WildFly 16 服务器的应用程序运行正常。
我遇到了奇怪的情况 - 从 Django shell 创建一些 Mongoengine 对象是成功的,但是从 Django View 创建相同的对象看起来成功,但 MongoDB 中没有出现任何数据。
我是 flask 的新手,只编写了一个相当简单的网络应用程序——没有数据库,只是一个航类搜索 API 的前端。一切正常,但为了提高我的技能,我正在尝试使用应用程序工厂和蓝图重构我的代码。让它与 pus
我的谷歌分析 JavaScript 事件在开发者控制台中运行得很好。 但是当从外部 js 文件包含在页面上时,它们根本不起作用。由于某种原因。 例如; 下面的内容将在包含在控制台中时运行。但当包含在单
这是一本名为“Node.js 8 the Right Way”的书中的任务。你可以在下面看到它: 这是我的解决方案: 'use strict'; const zmq = require('zeromq
我正在阅读文本行,并创建其独特单词的列表(在将它们小写之后)。我可以使它与 flatMap 一起工作,但不能使它与 map 的“子”流一起工作。 flatMap 看起来更简洁和“更好”,但为什么 di
我正在编写一些 PowerShell 脚本来进行一些构建自动化。我发现 here echo $? 根据前面的语句返回真或假。我刚刚发现 echo 是 Write-Output 的别名。 写主机 $?
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 4年前关闭。 Improve thi
我将一个工作 View Controller 类从另一个项目复制到一个新项目中。我无法在新项目中加载 View 。在旧项目中我使用了presentModalViewController。在新版本中,我
我对 javascript 很陌生,所以很难看出我哪里出错了。由于某种原因,我的功能无法正常工作。任何帮助,将不胜感激。我尝试在外部 js 文件、头部/主体中使用它们,但似乎没有任何效果。错误要么出在
我正在尝试学习Flutter中的复选框。 问题是,当我想在Scaffold(body :)中使用复选框时,它正在工作。但我想在不同的地方使用它,例如ListView中的项目。 return Cente
我们当前使用的是 sleuth 2.2.3.RELEASE,我们看不到在 http header 中传递的 userId 字段没有传播。下面是我们的代码。 BaggageField REQUEST_I
我有一个组合框,其中包含一个项目,比如“a”。我想调用该组合框的 Action 监听器,仅在手动选择项目“a”完成时才调用。我也尝试过 ItemStateChanged,但它的工作原理与 Action
你能看一下照片吗?现在,一步前我执行了 this.interrupt()。您可以看到 this.isInterrupted() 为 false。我仔细观察——“这个”没有改变。它具有相同的 ID (1
我们当前使用的是 sleuth 2.2.3.RELEASE,我们看不到在 http header 中传递的 userId 字段没有传播。下面是我们的代码。 BaggageField REQUEST_I
我正在尝试在我的网站上设置一个联系表单,当有人点击发送时,就会运行一个作业,并在该作业中向所有管理员用户发送通知。不过,我在失败的工作表中不断收到此错误: Illuminate\Database\El
我是一名优秀的程序员,十分优秀!