Java实现Fisher‘s Exact Test 的置信区间的计算

2023-10-24 22:45

本文主要是介绍Java实现Fisher‘s Exact Test 的置信区间的计算,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

实现代码
package com.bgi.aigi.common.utils;public class FisherExactUtils {public static double[]  getConfidenceInterval(double[][] data) {if (data==null||data.length!=2||data[0].length!=2||data[1].length!=2) {return null;}double[] interval=new double[2];double a=data[0][0];double b=data[0][1];double c=data[1][0];double d=data[1][1];double r= (a / c) / (b / d);double cinit = Math.sqrt((1 / a) + (1 / b) + (1 / c) + (1 / d));double y = Math.log(r) - (1.96 * cinit);double z = Math.log(r) + (1.96 * cinit);y = Math.exp(y);z = Math.exp(z);y = Math.round(y * 10000d) / 10000d;z = Math.round(z * 10000d) / 10000d;interval[0]=y;interval[1]=z;return interval;}public static double  getOddsRatio(double[][] data) {if (data==null||data.length!=2||data[0].length!=2||data[1].length!=2) {return Double.NaN;}double a=data[0][0];double b=data[0][1];double c=data[1][0];double d=data[1][1];return (a / c) / (b / d);}public static void main(String[] args) {double[][] data= {{4,20},{1,80}};System.out.println("下限:"+getConfidenceInterval(data)[0]);System.out.println("上限:"+getConfidenceInterval(data)[1]);System.out.println(getOddsRatio(data));}
}
说明

这段算法是从一个网站(https://www.easycalculation.com/statistics/odds-ratio.php)源码中发现,仅仅是php转换成了java。
我没有找到具体的公式说明,包括计算fisher exact的置信区间公式是什么,为什么这样计算等等,有知道的朋友也欢迎指出,提前感谢。

这篇关于Java实现Fisher‘s Exact Test 的置信区间的计算的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/278275

相关文章

JAVA保证HashMap线程安全的几种方式

《JAVA保证HashMap线程安全的几种方式》HashMap是线程不安全的,这意味着如果多个线程并发地访问和修改同一个HashMap实例,可能会导致数据不一致和其他线程安全问题,本文主要介绍了JAV... 目录1. 使用 Collections.synchronizedMap2. 使用 Concurren

Java Response返回值的最佳处理方案

《JavaResponse返回值的最佳处理方案》在开发Web应用程序时,我们经常需要通过HTTP请求从服务器获取响应数据,这些数据可以是JSON、XML、甚至是文件,本篇文章将详细解析Java中处理... 目录摘要概述核心问题:关键技术点:源码解析示例 1:使用HttpURLConnection获取Resp

python实现svg图片转换为png和gif

《python实现svg图片转换为png和gif》这篇文章主要为大家详细介绍了python如何实现将svg图片格式转换为png和gif,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录python实现svg图片转换为png和gifpython实现图片格式之间的相互转换延展:基于Py

Python利用ElementTree实现快速解析XML文件

《Python利用ElementTree实现快速解析XML文件》ElementTree是Python标准库的一部分,而且是Python标准库中用于解析和操作XML数据的模块,下面小编就来和大家详细讲讲... 目录一、XML文件解析到底有多重要二、ElementTree快速入门1. 加载XML的两种方式2.

Java的栈与队列实现代码解析

《Java的栈与队列实现代码解析》栈是常见的线性数据结构,栈的特点是以先进后出的形式,后进先出,先进后出,分为栈底和栈顶,栈应用于内存的分配,表达式求值,存储临时的数据和方法的调用等,本文给大家介绍J... 目录栈的概念(Stack)栈的实现代码队列(Queue)模拟实现队列(双链表实现)循环队列(循环数组

C++如何通过Qt反射机制实现数据类序列化

《C++如何通过Qt反射机制实现数据类序列化》在C++工程中经常需要使用数据类,并对数据类进行存储、打印、调试等操作,所以本文就来聊聊C++如何通过Qt反射机制实现数据类序列化吧... 目录设计预期设计思路代码实现使用方法在 C++ 工程中经常需要使用数据类,并对数据类进行存储、打印、调试等操作。由于数据类

Python实现图片分割的多种方法总结

《Python实现图片分割的多种方法总结》图片分割是图像处理中的一个重要任务,它的目标是将图像划分为多个区域或者对象,本文为大家整理了一些常用的分割方法,大家可以根据需求自行选择... 目录1. 基于传统图像处理的分割方法(1) 使用固定阈值分割图片(2) 自适应阈值分割(3) 使用图像边缘检测分割(4)

Android实现在线预览office文档的示例详解

《Android实现在线预览office文档的示例详解》在移动端展示在线Office文档(如Word、Excel、PPT)是一项常见需求,这篇文章为大家重点介绍了两种方案的实现方法,希望对大家有一定的... 目录一、项目概述二、相关技术知识三、实现思路3.1 方案一:WebView + Office Onl

Java中Switch Case多个条件处理方法举例

《Java中SwitchCase多个条件处理方法举例》Java中switch语句用于根据变量值执行不同代码块,适用于多个条件的处理,:本文主要介绍Java中SwitchCase多个条件处理的相... 目录前言基本语法处理多个条件示例1:合并相同代码的多个case示例2:通过字符串合并多个case进阶用法使用

Java中的Lambda表达式及其应用小结

《Java中的Lambda表达式及其应用小结》Java中的Lambda表达式是一项极具创新性的特性,它使得Java代码更加简洁和高效,尤其是在集合操作和并行处理方面,:本文主要介绍Java中的La... 目录前言1. 什么是Lambda表达式?2. Lambda表达式的基本语法例子1:最简单的Lambda表