使用R语言计算模拟二项分布

   二项分布理论

  二项分布是一种离散概率分布,描述了在n次独立重复的伯努利试验中成功的次数的概率分布。其中,每次试验的结果只有两个可能:成功或失败,且每次试验的成功概率p是相同的。

  具体来说,如果随机变量X表示在n次试验中成功的次数,那么X服从参数为n和p的二项分布,记为X~B(n,p)。意味着在n次试验中成功的次数为k的概率可以用二项分布的概率质量函数来表示: 

P(X=x)=C_n^k*p^x*q^{(n-x)},x=0,0.1,0.2,...,0.9

   二项分布的期望值和方差分别为:

\mu=E(X)=np,\sigma^{2}=D(X)=npq

 R语言实现

  在以下代码中,使用seq()函数创建了一个名为k的向量,该向量从0.1开始,以0.1的步长递增,直到0.9,这个向量稍后将用于指定二项分布的概率参数。

k <- seq(0.1, 0.9, 0.1)

使用par()函数来设置图形参数,使用mfrow=c(3,3)设置一个3x3的图形布局,在一个页面中绘制9个图形,每行3个。mai参数设置了图形的边距,四个数字分别代表图形的下、左、上、右边距。

par(mfrow=c(3, 3), mai = c(0.6, 0.5, 0.2, 0.1))

使用for循环,用于遍历k向量中的每一个概率值。在循环内部,barplot()函数被用来绘制二项分布的概率条形图。 使用dbinom(0:5, 5,k[i])计算了在给定的概率k[i]下,一个二项随机变量取值为0到5的概率。图形的x轴标签是’x’,y轴标签是’p’。ylim=c(0,0.6)设置了y轴的范围。图形的主标题通过substitute()函数动态生成,显示当前的概率值。最后,col=“lightblue”设置条形图的颜色为浅蓝色。

for(i in 1:9)
  barplot(dbinom(0:5, 5, k[i]), xlab="x", ylab="p", ylim=c(0, 0.6),
                 main=substitute(B(5, b), list(b=k[i])), col="lightblue")

完整版代码:

# 此段代码来源于教材《统计学-基于R语言》
k <- seq(0.1, 0.9, 0.1)
par(mfrow=c(3, 3), mai = c(0.6, 0.5, 0.2, 0.1))
for(i in 1:9)
  barplot(dbinom(0:5, 5, k[i]), xlab="x", ylab="p", ylim=c(0, 0.6),
                 main=substitute(B(5, b), list(b=k[i])), col="lightblue")

生成图像

 

 实例应用 

  这里用一个我们公司自己的数据,维修车间维修后的设备检测不合格率为7%,从中有放回的抽取30台设备。接下来使用二项分布计算的方式计算出:1.没有不合格品的概率; 2.1台不合格品的概率; 3.三台以上不合格品的概率:

library(ggplot2)    
library(dplyr)    

n_trials <- 30    
prob_failure <- 0.07    

df <- tibble(    
  NumberOfFailures = 0:n_trials,    
  Probability = dbinom(0:n_trials, size = n_trials, prob = prob_failure)    
)    

cat("没有不合格品的概率为:", df$Probability[1] * 100, "%\n")    
cat("1到3个不合格品的概率为:", sum(df$Probability[2:4]) * 100, "%\n")    
MoreThanThree <- 1 - sum(df$Probability[1:4])    
cat("3个以上不合格品的概率为:", MoreThanThree * 100, "%\n")    

ggplot(df, aes(x = NumberOfFailures, y = Probability)) +    
  geom_bar(stat = "identity", fill = "blue") +    
  geom_point(data = df %>% slice(1:4), aes(colour = factor(NumberOfFailures)), size = 4) +    
  scale_color_manual(values = c("red", "green", "yellow", "black"), name = "不合格情况说明",    
                     labels = c("无不合格", "一台不合格", "两台不合格", "三台及以上不合格")) + theme_minimal() +    
  labs(x = "维修不合格率", y = "概率", title = "二项分布") +    
  scale_y_continuous(expand = expansion(mult = c(0.05, 0.2)))

输出结果

> 没有不合格品的概率为: 11.33675 %
> 1到3个不合格品的概率为: 73.16518 %
> 3个以上不合格品的概率为: 15.49807 %

 生成很丑的图形

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/457250.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

婚恋源码-婚恋交友系统-源码婚恋交友系统-APP小程序H5公众号-源码交付-支持二开!

本婚恋系统是一款专门为单身人士打造的相亲交友软件&#xff0c;所有用户都必须要身份认证&#xff0c;还有职业认证、学历认证等等全方位认证。智能匹配是本婚恋系统的核心功能&#xff0c;当我们完善好个人资料通过审核&#xff0c;系统会根据个人信息进行匹配&#xff0c;自…

3.1_8 两级页表

文章目录 3.1_8 两级页表&#xff08;一&#xff09;单级页表存在的问题&#xff08;二&#xff09;如何解决单级页表的问题&#xff1f;&#xff08;三&#xff09;两级页表的原理、地址结构&#xff08;四&#xff09;如何实现地址变换&#xff08;五&#xff09;需要注意的几…

SpringBoot之Bean扫描、Bean注册

目录 Bean扫描 Bean注册 Bean lmport 自定义注解 注册条件 Bean扫描 Bean扫描有两种方式 1、标签:<context:component-scan base-package"com.mybatis"/> 2、注解: ComponentScan(basePackages "com.mybatis") springboot启动类注解可以自…

Java垃圾收集器工作原理、优缺点以及使用注意事项

0.前言 Java 垃圾收集器 (GC) 是自动内存管理组件&#xff0c;负责回收不再使用的对象占用的内存。它们在管理 Java 的动态内存分配方面发挥着至关重要的作用&#xff0c;使开发人员能够专注于应用程序逻辑&#xff0c;而无需手动释放内存。JVM运行时需要GC来防止内存泄漏、优…

YOLOv5 | 涨点复现!YOLOv5添加BiFPN有效提升目标检测精度

目录 &#x1f680;&#x1f680;&#x1f680;订阅专栏&#xff0c;更新及时查看不迷路&#x1f680;&#x1f680;&#x1f680; 介绍&#xff1a; BiFPN 代码实现 ⭐欢迎大家订阅我的专栏一起学习⭐ &#x1f680;&#x1f680;&#x1f680;订阅专栏&#xff0c;更新及…

苍穹外卖-后端多模块项目搭建

由于视频中给出了项目一些基础代码,因此自己从0开始搭建一个。 文末附pom.xml。 新建项目并连接github 首先新建项目,项目名称为sky-take-out-1,如下图:父模块任何环境都不要,只需要指定springboot版本。 选定一些依赖:例如Lombok(自动注解)、SpringWeb、MyBatis Fra…

Java数据结构-二叉树

文章目录 前言一、树型结构1.1概念1.2 知识点1.3 树的表示形式1.4 树的应用 二、二叉树2.1 概念2.2 两种特殊的二叉树2.3 二叉树的性质2.4 二叉树的存储2.5 二叉树的基本操作2.5.1 二叉树的遍历2.5.2 二叉树的基本操作 前言 对学习的二叉树的知识进行总结。 一、树型结构 1.1…

学习JAVA的第二十一天(基础)

目录 多线程 线程&#xff1a; 进程&#xff1a; 并发&#xff1a; 并行&#xff1a; 多线程的实现方式&#xff1a; Thread类 Runnable接口 Callable接口和Future接口 成员方法 线程的生命周期 线程的安全问题 前言&#xff1a;学习JAVA的第二十天&…

经典数组和指针笔试题解析——C语言

【本节内容】 1. 数组和指针笔试题解析 2. 指针运算笔试题解析 1. 数组和指针笔试题解析 1.1 一维数组 #include <stdio.h> int main() {int a[] { 1,2,3,4 };printf("%zd\n", sizeof(a));printf("%zd\n", sizeof(a 0));printf("%zd\n&qu…

如何保证Redis和数据库数据一致性

缓存可以提升性能&#xff0c;减轻数据库压力&#xff0c;在获取这部分好处的同时&#xff0c;它却带来了一些新的问题&#xff0c;缓存和数据库之间的数据一致性问题。 想必大家在工作中只要用了咱们缓存势必就会遇到过此类问题 首先我们来看看一致性&#xff1a; 强一致性…

Datawhale【Sora原理与技术实战】| 学习笔记3

目录 一. 训练 Sora 模型二. 数据预处理三. 视频 VQVAE四. Diffusion Transformer 一. 训练 Sora 模型 Open-Sora 在下图中总结了 Sora 可能使用的训练流程&#xff1a; 链路: 二. 数据预处理 目前主流 LLM 框架缺乏针对 video 数据 统一便捷的管理和处理能力&#xff0c;…

第十四届蓝桥杯省赛真题 Java 研究生 组【原卷】

文章目录 发现宝藏【考生须知】试题 A: 特殊日期试题 B: 与或异或试题 C: 棋盘试题 D: 子矩阵试题 E : \mathrm{E}: E: 互质数的个数试题 F: 小蓝的旅行计划试题 G: 奇怪的数试题 H: 太阳试题 I: 高塔试题 J \mathrm{J} J : 反异或 01 串 发现宝藏 前些天发现了一个巨牛的人…

InstantID Zero-shot Identity-Preserving Generation in Seconds

InstantID: Zero-shot Identity-Preserving Generation in Seconds TL; DR&#xff1a;InstantID IP-Adapter (Face) ControlNet&#xff0c;实现了具有较高保真度的人脸 ID 生成。 方法 InstantID 想做到的事情是&#xff1a;给定一张参考人脸 ID 图片&#xff0c;生成该…

6. 面向对象(重点)

1 面向对象 1.1 了解对象 学习面向对象编程都先我们需要先思考三个问题: 1.1.1 面向对象的好处? Java作者詹姆斯.高斯林说过**万物皆对象**汽车的数据可以找汽车对象处理手机数据可以找手机对象处理学生的数据可以找学生对象处理使用面向对象编程符合人类思维习惯, 就好比…

Java的编程之旅41——字符流

目录 1.字符流的简介 2.字符的编码与解码 3.字符流读写操作 1.字符流写入 2.字符流复制文件 4.FileWriter&FileReader 5.缓冲区高效读写 6.序列化与反序列化 1.字符流的简介 在Java中&#xff0c;字符流是用于处理字符数据的输入输出流。它是以字符为单位进行处理&a…

户外大屏:六个必备的户外大屏推广工具助你脱颖而出-华媒舍

1. 大屏幕LED显示屏 大屏幕LED显示屏是一种常见而有效的户外推广工具。它采用LED背光源和高分辨率显示屏&#xff0c;能够在户外环境中展示鲜艳丰富的图像和视频内容。这种显示屏广泛应用于广场、商业街、体育场馆等公共场所&#xff0c;成为吸引人们目光的重要工具。 大屏幕…

AIOps探索 | 国外知名厂商根因分析实践分享新方法探索

文章来源于公众号--布博士&#xff08;擎创科技资深产品专家&#xff09; 哈喽&#xff0c;大家好~转眼又到我们分享干货环节了&#xff0c;上一篇AIOps干货后台收到不少反馈&#xff0c;总体来说效果还不错&#xff0c;感谢大家喜欢&#xff0c;后续楼主会定期更新AIOps相关干…

如何使用“ubuntu移动文件、复制文件到其他文件夹“?

一、移动文件到其他文件夹命令 mv node_exporter-1.5.0.linux-amd64.tar.gz /usr/local/etc/prometheus 二、复制文件到其他文件夹命令 cp node_exporter-1.5.0.linux-amd64.tar.gz /home/master

一个八年工作经验老程序员的分享

作为一个 Java 程序员&#xff0c;我在这个行业中工作了多年。在这个过程中&#xff0c;我经历了许多挑战和机遇&#xff0c;也学到了很多宝贵的经验和教训。在这篇文章中&#xff0c;我想分享一些我的感想和思考&#xff0c;希望能够对其他 Java 程序员有所帮助。 一、技术的…

【linux】进程管理:进程控制块、进程号、fork创建进程、特殊进程及exec函数族解析

一、进程的概述 可执行程序运行起来后&#xff08;没有结束之前)&#xff0c;它就成为了一个进程。程序是存放在存储介质上的一个可执行文件&#xff0c;而进程是程序执行的过程。进程的状态是变化的&#xff0c;其包括进程的创建、调度和消亡。程序是静态的&#xff0c;进程是…