当前位置: 首页 > article >正文

别怕概率论!用Python的NumPy和SciPy库,帮你一步步验算期末试卷里的12道填空题

用Python玩转概率论NumPySciPy实战12道经典填空题当概率论遇上Python枯燥的公式瞬间变得生动起来。本文不是简单地教你解题而是带你用代码「实验」概率让每个数学概念都变成可运行的代码块。我们将从零开始用Python中最强大的科学计算库NumPy和SciPy重新演绎概率论试卷中那些令人头疼的填空题。1. 环境配置与基础工具工欲善其事必先利其器。在开始之前确保你的Python环境已经安装了以下库import numpy as np import scipy.stats as stats from scipy.special import comb, factorial import matplotlib.pyplot as plt # 用于可视化关键工具介绍numpy.random生成各种概率分布的随机变量scipy.stats包含几乎所有常见概率分布的函数scipy.special提供组合数、阶乘等特殊数学函数提示推荐使用Jupyter Notebook进行实验可以实时看到代码运行结果和可视化效果。2. 事件概率计算的Python实现2.1 事件组合问题让我们从第一道填空题开始「设A,B,C为3个事件则表示A,B,C中至少两个发生的事件是____。」传统解法需要写出所有可能组合而Python可以帮我们验证# 定义三个事件的概率 p_a, p_b, p_c 0.5, 0.5, 0.5 # 蒙特卡洛模拟 n_trials 100000 a np.random.binomial(1, p_a, n_trials) b np.random.binomial(1, p_b, n_trials) c np.random.binomial(1, p_c, n_trials) # 计算至少两个发生的概率 at_least_two ((a b c) 2).mean() print(f模拟概率: {at_least_two:.4f}) # 理论计算 theory_prob (p_a*p_b*(1-p_c) p_a*(1-p_b)*p_c (1-p_a)*p_b*p_c p_a*p_b*p_c) print(f理论概率: {theory_prob:.4f})2.2 独立事件与并集概率第二题考察独立事件「设事件A,B独立且P(A)0.4P(B)0.2则P(A∪B¯)____。」用SciPy验证p_a 0.4 p_b 0.2 # 理论计算 p_not_b 1 - p_b p_a_union_not_b p_a p_not_b - p_a * p_not_b # 用stats模块验证 dist_a stats.bernoulli(p_a) dist_b stats.bernoulli(p_b) samples_a dist_a.rvs(size100000) samples_not_b 1 - dist_b.rvs(size100000) empirical_prob np.mean((samples_a samples_not_b) 0) print(f理论值: {p_a_union_not_b:.4f}) print(f模拟值: {empirical_prob:.4f})3. 随机变量与分布实战3.1 离散型随机变量第五题给出分布函数「设离散型随机变量的X分布函数为F(x)求P{x0}。」用NumPy实现# 定义分布 x_values [-1, 0, 2] cum_probs [0.1, 0.5, 1.0] # 计算P(X0) p_x0 cum_probs[1] - cum_probs[0] # 用PMF验证 probs np.diff([0] cum_probs) print(fP(X0) {probs[1]:.1f})3.2 连续型随机变量第七题涉及正态分布「设X~N(1,4)且Φ(2)0.9772则P{1≤x≤5}____。」SciPy让正态分布计算变得简单mu, sigma 1, 2 # 注意sigma是标准差 # 计算P(1≤X≤5) prob stats.norm.cdf(5, locmu, scalesigma) - stats.norm.cdf(1, locmu, scalesigma) # 标准化验证 z1 (1 - mu)/sigma z2 (5 - mu)/sigma print(fP(1≤X≤5) {stats.norm.cdf(z2) - stats.norm.cdf(z1):.4f})4. 协方差与复杂分布4.1 二维正态分布第九题考察协方差「设(X,Y)~N(-1,0,4,9,0.2)则cov(X,Y)____。」用NumPy生成样本并计算mean [-1, 0] cov [[4, 0.2*2*3], [0.2*2*3, 9]] # 协方差矩阵 # 生成样本 data np.random.multivariate_normal(mean, cov, 10000) # 计算协方差 empirical_cov np.cov(data.T) print(f模拟协方差矩阵:\n{empirical_cov}) print(f理论cov(X,Y): {0.2*2*3:.1f})4.2 随机变量函数的分布第十题涉及随机变量变换「设X~U(0,2)Y~Exp(1)且独立求D(2X-3Y4)。」组合分布的计算# 定义分布 dist_x stats.uniform(loc0, scale2) dist_y stats.expon(scale1) # 理论方差计算 var_2x 4 * (2**2)/12 # 均匀分布方差(b-a)^2/12 var_3y 9 * 1**2 # 指数分布方差1/lambda^2 total_var var_2x var_3y # 模拟验证 samples 2*dist_x.rvs(size100000) - 3*dist_y.rvs(size100000) 4 print(f理论方差: {total_var:.2f}) print(f样本方差: {np.var(samples):.2f})5. 统计推断与估计5.1 无偏估计第十一题关于参数估计「μ̂1/4X₁kX₂1/8X₃是μ的无偏估计求k。」用模拟验证true_mu 5 # 假设真实μ5 n_samples 100000 # 生成样本 x1 np.random.normal(true_mu, 1, n_samples) x2 np.random.normal(true_mu, 1, n_samples) x3 np.random.normal(true_mu, 1, n_samples) # 计算不同k的估计偏差 for k in [0.5, 0.625, 0.7]: mu_hat 0.25*x1 k*x2 0.125*x3 bias np.mean(mu_hat) - true_mu print(fk{k:.3f}, 偏差{bias:.5f})5.2 F分布与样本统计第十二题涉及F分布「Y(X₁²X₂²X₃²)/(CX₄²)~F(3,1)求C。」用随机模拟验证n_samples 100000 dfn, dfd 3, 1 # 生成F分布样本 f_samples stats.f(dfn, dfd).rvs(n_samples) # 生成正态样本并构造统计量 normal_samples np.random.normal(0, np.sqrt(2), (n_samples, 4)) numerator normal_samples[:,:3]**2.sum(axis1) denominator normal_samples[:,3]**2 # 寻找使统计量匹配F分布的C值 for C in [2, 3, 4]: ratio numerator / (C * denominator) ks_stat stats.ks_2samp(ratio, f_samples).statistic print(fC{C}, KS统计量{ks_stat:.4f})6. 可视化辅助理解概率概念通过可视化会变得直观。例如对于正态分布题目# 绘制正态分布曲线 x np.linspace(mu-3*sigma, mu3*sigma, 100) pdf stats.norm.pdf(x, mu, sigma) plt.figure(figsize(10, 5)) plt.plot(x, pdf, labelfN({mu},{sigma**2})) plt.fill_between(x[(x1)(x5)], pdf[(x1)(x5)], alpha0.3) plt.title(正态分布P(1≤X≤5)区域) plt.xlabel(x) plt.ylabel(概率密度) plt.legend() plt.grid(True) plt.show()对于离散分布可以绘制PMF# 第五题的PMF可视化 plt.stem(x_values, probs, use_line_collectionTrue) plt.title(离散随机变量的概率质量函数) plt.xlabel(x) plt.ylabel(P(Xx)) plt.xticks(x_values) plt.grid(True) plt.show()7. 从理论到实践的思考在实际应用中我们常常需要根据问题特点选择合适的计算方法。例如精确计算当理论解已知时直接使用公式数值积分对于复杂连续分布使用scipy.integrate蒙特卡洛模拟当解析解困难时用随机模拟近似# 蒙特卡洛积分示例计算E[sin(X)]X~N(0,1) samples np.random.normal(0, 1, 100000) expected_value np.mean(np.sin(samples)) print(fE[sin(X)] ≈ {expected_value:.5f}) # 与数值积分比较 from scipy.integrate import quad result, _ quad(lambda x: np.sin(x)*stats.norm.pdf(x), -np.inf, np.inf) print(f精确值: {result:.5f})这种「理论代码验证」的学习方法不仅能加深理解还能培养对概率直觉的「数值感觉」。当你看到P值0.03时你的代码经验会告诉你这意味着什么。

相关文章:

别怕概率论!用Python的NumPy和SciPy库,帮你一步步验算期末试卷里的12道填空题

用Python玩转概率论:NumPySciPy实战12道经典填空题 当概率论遇上Python,枯燥的公式瞬间变得生动起来。本文不是简单地教你解题,而是带你用代码「实验」概率,让每个数学概念都变成可运行的代码块。我们将从零开始,用Pyt…...

从随便用到查户口:AI圈的实名暴政,程序员炸了

这两天Anthropic的Claude实名认证风波席卷AI圈,引发全球用户群体的强烈不满和抗议。这一政策变化在科技社区、社交媒体平台上迅速发酵,形成了"全球集体众怒"的舆论风暴。 作为一个写了几十年代码、摸遍国内外AI工具的老程序员,我是…...

YOLOv8性能跃迁:集成可变形注意力机制DAttention的实战指南

1. 为什么YOLOv8需要可变形注意力机制? 目标检测领域近年来最令人头疼的问题之一,就是模型在复杂场景下的表现不稳定。我在实际项目中遇到过这样的情况:同一个检测模型,在空旷场景下mAP能达到85%,但在人群密集的商场监…...

逆向糖豆视频:从动态加载到防盗链破解的实战解析

1. 糖豆视频逆向分析的核心挑战 第一次尝试爬取糖豆视频时,我遇到了几个让人头疼的问题。最明显的就是视频只能播放5秒就中断,这其实是典型的防盗链机制在起作用。糖豆视频采用了动态加载技术,真实视频地址隐藏在层层接口之后,需要…...

5步掌握DoL-Lyra整合包:从零构建个性化游戏体验的完整指南

5步掌握DoL-Lyra整合包:从零构建个性化游戏体验的完整指南 【免费下载链接】DOL-CHS-MODS Degrees of Lewdity 整合 项目地址: https://gitcode.com/gh_mirrors/do/DOL-CHS-MODS Degrees of Lewdity中文模组整合包(DOL-CHS-MODS)是一个…...

告别触摸漂移!手把手教你用tslib校准嵌入式Linux触摸屏(基于Buildroot)

告别触摸漂移!手把手教你用tslib校准嵌入式Linux触摸屏(基于Buildroot) 电阻屏在工业控制、医疗设备等嵌入式场景中依然占据重要地位,但开发者常被一个"幽灵问题"困扰——明明点击了A位置,系统却响应在B位置…...

用ILA抓波形:手把手教你调试XC7K325T的XDMA AXI总线读写时序

用ILA抓波形:深入解析XC7K325T的XDMA AXI总线调试实战 在FPGA开发中,AXI总线协议作为Xilinx系列芯片的核心互联标准,其稳定性和正确性直接决定了系统性能。而XDMA(Xilinx DMA)IP作为PCIe与AXI总线之间的桥梁&#xff0…...

Adobe-GenP终极指南:如何免费解锁Adobe全家桶完整功能?

Adobe-GenP终极指南:如何免费解锁Adobe全家桶完整功能? 【免费下载链接】Adobe-GenP Adobe CC 2019/2020/2021/2022/2023 GenP Universal Patch 3.0 项目地址: https://gitcode.com/gh_mirrors/ad/Adobe-GenP Adobe Creative Cloud系列软件以其强…...

10分钟深度解析:FigmaCN如何实现专业级界面本地化

10分钟深度解析:FigmaCN如何实现专业级界面本地化 【免费下载链接】figmaCN 中文 Figma 插件,设计师人工翻译校验 项目地址: https://gitcode.com/gh_mirrors/fi/figmaCN 对于中文设计师来说,Figma英文界面常常是工作效率的隐形障碍。…...

2026 年苹果高层变动:库克功成身退,特努斯接棒引领未来

【苹果相关链接与信息】有 DF T 恤促销,可通过相关链接进入商店。还有 Daring Fireball 相关内容,作者为 John Gruber。网站提供存档、The Talk Show、Dithering、项目、联系我们、鸣谢、订阅源/社交平台、赞助等信息。此外,Rec League 可分享…...

内存涨价手机普涨,华为苹果稳价抢市场,“荣米OV”危险了?

【华为影像旗舰发布,定价策略引争议】4月20日,华为影像旗舰Pura 90系列发布。对于价格,网上出现两极分化观点:一边夸赞加量不加价,一边质疑改名、减配曲线涨价。不过,华为实现了较为平稳的定价策略&#xf…...

用Python seaborn库5分钟搞定mpg汽车油耗数据集的可视化分析(保姆级教程)

用Python seaborn库5分钟搞定mpg汽车油耗数据集的可视化分析(保姆级教程) 刚接触数据分析的新手常被复杂的代码和理论吓退,但数据科学的魅力恰恰在于用简单工具快速获得洞察。今天我们就用Python的seaborn库,在5分钟内完成mpg汽车…...

AEUX插件:如何从设计工具无缝传输图层到After Effects实现高效动画工作流

AEUX插件:如何从设计工具无缝传输图层到After Effects实现高效动画工作流 【免费下载链接】AEUX Editable After Effects layers from Sketch artboards 项目地址: https://gitcode.com/gh_mirrors/ae/AEUX 在当今的UX动效设计领域,AEUX作为连接设…...

终极指南:5步掌握哔哩下载姬的完整使用体验

终极指南:5步掌握哔哩下载姬的完整使用体验 【免费下载链接】downkyi 哔哩下载姬downkyi,哔哩哔哩网站视频下载工具,支持批量下载,支持8K、HDR、杜比视界,提供工具箱(音视频提取、去水印等)。 …...

ZXPInstaller:Adobe插件安装的完整免费解决方案

ZXPInstaller:Adobe插件安装的完整免费解决方案 【免费下载链接】ZXPInstaller Open Source ZXP Installer for Adobe Extensions 项目地址: https://gitcode.com/gh_mirrors/zx/ZXPInstaller 你是否曾为Adobe创意软件的.zxp插件安装感到困扰?当官…...

大模型小白逆袭之路:从入门到精通,产品经理大模型学习之旅

本文为产品经理提供了一份从零开始学习大模型AI的完整路线图,涵盖学习资源选择、实践操作、深入探索等阶段,并推荐了丰富的学习资料,包括视频教程、电子书、面试题等,旨在帮助读者从“小白”成长为“大牛”,掌握大模型…...

不止于‘能用’:深度体验麒麟V10 SP1的UKUI 3桌面与那些被忽略的‘效率神器’

不止于‘能用’:深度体验麒麟V10 SP1的UKUI 3桌面与那些被忽略的‘效率神器’ 在国产操作系统的浪潮中,银河麒麟V10 SP1以其独特的UKUI 3桌面环境和丰富的内置工具,正在重新定义"生产力工具"的边界。不同于简单的功能罗列&#xf…...

Applite镜像加速:为Homebrew Casks带来流畅的GUI管理体验

Applite镜像加速:为Homebrew Casks带来流畅的GUI管理体验 【免费下载链接】Applite User-friendly GUI macOS application for Homebrew Casks 项目地址: https://gitcode.com/gh_mirrors/ap/Applite Applite是一款专为macOS设计的开源GUI应用程序&#xff0…...

kill-doc终极指南:简单免费解决文档下载难题的完整方案

kill-doc终极指南:简单免费解决文档下载难题的完整方案 【免费下载链接】kill-doc 看到经常有小伙伴们需要下载一些免费文档,但是相关网站浏览体验不好各种广告,各种登录验证,需要很多步骤才能下载文档,该脚本就是为了…...

别再只会用OpenFileDialog选文件了!C# WinForms里这几个隐藏属性和坑你得知道

深度解锁C# OpenFileDialog:从精准过滤到异常处理全攻略 在Windows窗体应用开发中,文件选择对话框是用户与系统交互的重要桥梁。虽然OpenFileDialog控件看似简单,但真正掌握其精髓需要跨越多个技术细节。本文将带您深入探索那些官方文档未曾详…...

抖音批量下载神器:3分钟学会免费下载视频、音乐和图集

抖音批量下载神器:3分钟学会免费下载视频、音乐和图集 【免费下载链接】douyin-downloader A practical Douyin downloader for both single-item and profile batch downloads, with progress display, retries, SQLite deduplication, and browser fallback suppo…...

从限流器到分布式ID生成器:我是如何通过复刻《System Design Interview》里的7个核心组件来准备面试的

从限流器到分布式ID生成器:7个核心组件的实战复刻与面试启示 当我在准备系统设计面试时,书架上的《System Design Interview》已经落了一层薄灰。直到某天深夜,我决定不再被动地阅读理论,而是选择书中最具代表性的7个组件——从限…...

【LaTeX】表格标题与表格间距调整:从基础命令到实战技巧

1. LaTeX表格排版的核心痛点 第一次用LaTeX排表格时,我盯着PDF输出文件皱起了眉头——表格标题几乎要贴到表格内容上,活像被压缩的三明治。这种"亲密无间"的排版在学术论文里特别扎眼,审稿人可能觉得我们连基础排版都不重视。表格标…...

测试人员的极致追求,如何做到不漏测?

什么是漏测? 具体地说,什么是测试漏测?测试漏测是指软件产品在测试结束后出现了在测试过程中没有被发现的bug。 我们知道,漏测是每一个软件测试者最头疼的事,一旦出现漏测: 首先给客户带来了非常不好的影…...

零信任医疗容器网络配置:用eBPF+Docker Compose实现手术机器人通信链路100%加密(实测延迟<8.3ms)

第一章&#xff1a;零信任医疗容器网络配置&#xff1a;用eBPFDocker Compose实现手术机器人通信链路100%加密&#xff08;实测延迟<8.3ms&#xff09;在高可靠性手术机器人系统中&#xff0c;控制指令与实时影像流的传输必须满足毫秒级确定性、端到端不可篡改性及最小化信任…...

保姆级教程:用VS Code调试牛客网C语言百题(附BC33统计成绩单步调试实战)

用VS Code高效调试牛客网C语言百题的完整指南 在牛客网刷C语言百题时&#xff0c;你是否遇到过这样的情况&#xff1a;代码提交后报错&#xff0c;却无法直观地看到程序执行过程中变量的变化&#xff1f;本文将带你搭建一个高效的本地调试环境&#xff0c;让你能够像专业开发者…...

5G网络优化实战笔记:手把手配置NR测量事件门限与迟滞,解决乒乓切换难题

5G网络优化实战&#xff1a;NR测量事件参数配置与乒乓切换抑制策略 在5G网络部署与优化过程中&#xff0c;小区边缘用户的切换性能直接影响着用户体验。当车辆驶过高架桥下&#xff0c;或是用户在密集城区拐角处通话时&#xff0c;频繁出现的掉线、卡顿现象&#xff0c;往往源于…...

分类数据集 - CT图像脊柱骨折检测图像分类数据集下载

数据集介绍&#xff1a;CT图像脊柱骨折检测图像分类数据集&#xff0c;真实临床采集高质量脊柱CT断层扫描图片数据&#xff1b;适用实际项目应用&#xff1a;CT图像脊柱骨折检测图像分类项目&#xff0c;脊柱创伤辅助诊断系统&#xff0c;以及作为通用脊柱骨折检测数据集场景数…...

Unity做桌面悬浮挂件?用C#调用user32.dll实现透明可点击窗口(保姆级教程)

Unity桌面悬浮挂件开发指南&#xff1a;透明窗口与穿透点击实战 在数字工作空间日益复杂的今天&#xff0c;桌面悬浮挂件已成为提升效率的利器。想象一下&#xff0c;你的系统监控数据、待办事项清单或精美时钟始终悬浮在桌面上&#xff0c;既不遮挡其他窗口&#xff0c;又能随…...

Qt中调用相机进行拍照并实现图像处理

在Qt中调用相机进行拍照并实现图像处理&#xff0c;可以通过结合Qt Multimedia模块和图像处理库&#xff08;如OpenCV&#xff09;实现。一、相机调用与拍照&#xff08;Qt Multimedia模块&#xff09; 1. 环境配置 在Qt项目文件&#xff08;.pro&#xff09;中添加多媒体模块依…...