蒙特卡罗模拟: 高级应用的思路和实例
蒙特卡罗模拟不仅仅是一种理论练习,它还是一种强大的工具,在金融、医疗保健、物流等领域都有实际应用。本篇文章将探讨高级和复杂的现实生活场景,深入探讨它们的细微差别,并通过详细的解释在 Python 中实现它们。
什么是蒙特卡罗模拟?
蒙特卡罗模拟(Monte Carlo Simulation)是一种利用重复随机抽样来了解系统行为的计算技术。通过运行数以千计或数以百万计的模拟,你可以估算出概率、风险和其他涉及不确定性问题的统计量。它的核心思想是:通过大量重复的随机实验,逼近真实世界的统计规律。
关键特点:
-
概率驱动:输入变量可以具有概率分布(如正态分布、均匀分布等),模拟结果反映随机性影响。
-
大数定律:模拟次数越多,结果越接近理论预期值。
-
适用性广:适用于金融、工程、物理、医疗、物流等多个领域。
基本步骤:
-
定义模型:确定输入变量及其概率分布(如股票收益率、设备故障率等)。
-
随机抽样:从输入分布中生成大量随机样本。
-
计算输出:运行模拟(如投资组合回报、系统可靠性等)。
-
统计分析:汇总结果(均值、标准差、置信区间等)。
为什么用Python 实现?
Python的numpy
、scipy
和pandas
等库能高效生成随机数并进行统计分析,而matplotlib
和seaborn
可帮助可视化模拟结果。
蒙特卡罗模拟将“不确定性”转化为可量化的概率,是数据驱动决策的重要工具。
1. 投资组合风险评估
问题
投资者经常面临一个关键问题: 资产组合的风险有多大?投资组合风险来自
-
资产回报: 单个资产的收益或损失。
-
相关性: 资产收益的相对变化。
-
波动性: 资产收益的波动性。
蒙特卡罗模拟(Monte Carlo Simulation)允许我们模拟收益的不确定性,并评估特定时间段后投资组合的潜在价值。
步骤
-
根据平均值、标准差和相关性模拟单个资产的收益。
-
计算每次模拟的投资组合总回报。
-
分析结果分布以衡量风险。
# 年均收益率和标准差
mean_returns = np.array([0.08, 0.12, 0.06]) # 资产收益率
std_devs = np.array([0.2, 0.3, 0.15]) # 波动率# 模拟相关矩阵
correlation_matrix = np.array([[1.0, 0.2, 0.4],[0.2, 1.0, 0.3],[0.4, 0.3, 1.0]
])# 模拟相关随机回报
cov_matrix = np.diag(std_devs) @ correlation_matrix @ np.diag(std_devs)
returns = np.random.multivariate_normal(mean_returns, cov_matrix, n_simulations)# 模拟投资组合权重
weights = np.array([0.4, 0.4, 0.2])# 模拟投资组合回报
portfolio_returns = np.dot(returns, weights)# 分析风险
mean_portfolio_return = np.mean(portfolio_returns)
value_at_risk_95 = np.percentile(portfolio_returns, 5) # 5th percentile (95% VaR)
loss_prob = np.mean(portfolio_returns < 0) # Probability of loss
观察到
-
投资组合平均收益: 投资组合的平均预期回报。
-
风险值(VaR): 95% 置信度下的最大潜在损失。
-
损失概率: 投资组合出现亏损的可能性。
2. 疾病传播模拟(流行病学)
问题
像 COVID-19 这样的传染病爆发需要建模来预测传播和评估干预措施。蒙特卡罗模拟法可以通过为感染率和康复率等参数添加随机性来扩展SEIR 模型(易感-暴露-感染-康复)。
步骤
-
使用随机 SEIR 方程模拟疾病的传播。
-
在传播率和恢复率中引入随机性。
-
评估不同干预措施(如疫苗接种率)下的结果。
population = 10000
initial_infected = 10
initial_exposed = 5
transmission_rate = 0.2
incubation_rate = 0.1
recovery_rate = 0.05
time_steps = 100
n_simulations = 100results = []
for _ in range(n_simulations):susceptible = population - initial_infected - initial_exposedexposed = initial_exposedinfected = initial_infectedrecovered = 0s, e, i, r = [], [], [], []for _ in range(time_steps):new_exposed = np.random.binomial(susceptible, transmission_rate * infected / population)new_infected = np.random.binomial(exposed, incubation_rate)new_recovered = np.random.binomial(infected, recovery_rate)susceptible -= new_exposedexposed += new_exposed - new_infectedinfected += new_infected - new_recoveredrecovered += new_recovereds.append(susceptible)e.append(exposed)i.append(infected)r.append(recovered)results.append((s, e, i, r))average_results = np.mean(results, axis=0)
观察到
-
感染高峰: 确定感染率达到峰值的时间,评估医疗保健系统的能力。
-
干预措施的效果: 使用模拟来比较社会隔离或疫苗接种等方案。
比较干预措施的效果(社会隔离与疫苗接种)
模拟假设:
-
人口 : 10,000 人。
-
基准传播率(β) : 0.2(接触率)。
-
潜伏率(σ) :0.1(接触者感染率)。
-
恢复率(γ) :0.05(感染个体的恢复率)。
-
干预:
-
社会隔离 : 将 β 减少 50%。
-
接种疫苗 : 为 30% 的人口接种疫苗,使他们直接进入恢复群体。
-
时间范围: 100 天。
-
模拟次数: 每个方案运行 100 次,以纳入随机性。
population = 10000
initial_infected = 10
initial_exposed = 5
transmission_rate = 0.2 # baseline beta
incubation_rate = 0.1 # sigma
recovery_rate = 0.05 # gamma
time_steps = 100
n_simulations = 100scenarios = {"Baseline": transmission_rate,"Social Distancing": transmission_rate * 0.5, "Vaccination": transmission_rate
}results = {scenario: {"Susceptible": [], "Exposed": [], "Infected": [], "Recovered": []} for scenario in scenarios}for scenario, beta in scenarios.items():for _ in range(n_simulations):susceptible = population - initial_infected - initial_exposedexposed = initial_exposedinfected = initial_infectedrecovered = 0# apply vaccination for the "Vaccination" scenarioif scenario == "Vaccination":vaccinated = int(0.3 * population) # 30% vaccinatedsusceptible -= vaccinatedrecovered += vaccinateds, e, i, r = [], [], [], []for _ in range(time_steps):new_exposed = np.random.binomial(susceptible, beta * infected / population)new_infected = np.random.binomial(exposed, incubation_rate)new_recovered = np.random.binomial(infected, recovery_rate)susceptible -= new_exposedexposed += new_exposed - new_infectedinfected += new_infected - new_recoveredrecovered += new_recovereds.append(susceptible)e.append(exposed)i.append(infected)r.append(recovered)results[scenario]["Susceptible"].append(s)results[scenario]["Exposed"].append(e)results[scenario]["Infected"].append(i)results[scenario]["Recovered"].append(r)
3. 可再生能源系统的能源生产
问题
风能或太阳能发电场等可再生能源系统受天气条件等随机因素的影响。蒙特卡罗模拟有助于估算不确定情况下的能源生产量,并据此规划产能。
步骤
-
使用概率分布模拟天气条件的变化。
-
模拟每日或每小时的能源产出。
-
汇总结果,确定平均和最坏情况下的生产方案。
days = 365
n_simulations = 1000
mean_wind_speed = 12 # m/s
std_dev_wind_speed = 4 # m/s
capacity_factor = 0.3 # efficiency of wind conversion
rated_capacity = 3.0 # mW per turbinedaily_energy = []
for _ in range(n_simulations):wind_speeds = np.random.normal(mean_wind_speed, std_dev_wind_speed, days)wind_speeds = np.clip(wind_speeds, 0, None) # No negative wind speedspower_output = rated_capacity * capacity_factor * (wind_speeds / mean_wind_speed)daily_energy.append(np.sum(power_output))average_annual_energy = np.mean(daily_energy)
percentile_5 = np.percentile(daily_energy, 5) # wrst-case production
percentile_95 = np.percentile(daily_energy, 95) # best-case production
观察到:
-
平均产量: 有助于设定切合实际的预期。
-
最坏情况: 评估低风速时的可靠性。
蒙特卡洛模拟是解决现实世界问题中不确定性的一种通用而强大的技术。从金融到流行病学和能源规划,它的应用范围广泛,影响深远。这里介绍的详细示例展示了其模拟复杂系统和提取可行见解的能力。
4. 抗体亲和力成熟建模
问题
在免疫学中,亲和力成熟是一个 B 细胞经历体细胞超突变和选择以产生对特定抗原具有更高亲和力的抗体的过程。这一过程涉及随机突变和选择压力。蒙特卡罗模拟(Monte Carlo Simulation)可以对这一过程进行建模,分析不同的突变率或选择阈值如何影响结果。
步骤
1. 定义模型:
-
从具有随机初始亲和力的 B 细胞群体开始。
-
在每一代中,根据突变率对群体进行突变。
-
施加选择压力,只保留亲和力高于阈值的 B 细胞。
2. 运行模拟:
-
改变突变率或选择阈值,以探索其影响。
3. 分析:
-
跟踪各代的平均亲和力。
-
比较突变策略或阈值。
写在最后
蒙特卡罗模拟以其独特的概率视角,为复杂现实问题的决策提供了强大的数据驱动支持。从简单的随机抽样到多变量、多层次的复杂系统建模,它能够揭示传统分析方法难以捕捉的不确定性和风险。Python 凭借其丰富的科学计算库(如 NumPy、SciPy 和 Pandas)以及可视化工具(如 Matplotlib 和 Seaborn),使得这些高级应用的实现既高效又可扩展。无论是金融风险评估、医疗方案优化,还是物流网络设计,蒙特卡罗模拟都展现了其作为跨领域决策工具的非凡价值。掌握其核心思想并灵活运用 Python 生态系统,将帮助你在面对不确定性时,做出更明智、更自信的选择。
相关文章:

蒙特卡罗模拟: 高级应用的思路和实例
蒙特卡罗模拟不仅仅是一种理论练习,它还是一种强大的工具,在金融、医疗保健、物流等领域都有实际应用。本篇文章将探讨高级和复杂的现实生活场景,深入探讨它们的细微差别,并通过详细的解释在 Python 中实现它们。 什么是蒙特卡罗…...
Java集合中Stream流的使用
前言 Java 8 引入了 Stream API,它是一种用于处理集合(Collection)数据的强大工具。Stream 不是数据结构,而是对数据源进行操作的一种方式,支持声明式、函数式的操作,如过滤、映射、排序等。 Stream 操作…...
Python批量转换Word、Excel、PPT、TXT、HTML及图片格式到PDF,包含错误处理和日志记录功能
完整的Python脚本,支持批量转换Word、Excel、PPT、TXT、HTML及图片格式到PDF,并包含错误处理和日志记录功能: import os import sys import logging from win32com import client from PIL import Image from fpdf import FPDF import pdfkit import traceback# 配置日志 l…...

数据分析Agent构建
数据分析agent构建 代码资料来源于 Streamline-Analyst,旨在通过该仓库上的代码了解如何使用大语言模型构建数据分析工具; 个人仓库:Data-Analysis-Agent-Tutorial 不同的在于 Data-Analysis-Agent-Tutorial 是在 Streamline-Analyst 基础…...

vscode配置lua
官网下载lua得到如下 打开vscode的扩展下载如下三个 打开vscode的此处设置 搜索 executorMap,并添加如下内容...

【笔记】MSYS2 的 MINGW64 环境 全面工具链
#工作记录 MSYS2 的 MINGW64 环境(mingw64.exe),下面是为该环境准备的最全工具链安装命令(包括 C/C、Python、pip/wheel、GTK3/GTK4、PyGObject、Cairo、SDL2 等)。 这一环境适用于构建原生 64 位 Windows 应用程序。…...

国内头部的UWB企业介绍之品铂科技
一、核心优势与技术实力 厘米级定位精度 自主研发的ABELL无线实时定位系统,在复杂工业环境中实现静态与动态场景下10-30厘米高精度定位,尤其擅长金属设备密集的化工、电力等场景,抗干扰能力行业领先。多技术融合能力 支持卫星…...

Prj10--8088单板机C语言8259中断测试(2)
1.测试结果 2.全部代码 #include "tiny_stdarg.h" // 使用自定义可变参数实现#define ADR_273 0x0200 #define ADR_244 0x0400 #define LED_PORT 0x800 #define PC16550_THR 0x1f0 #define PC16550_LSR 0x1f5 / //基本的IO操作函数 / char str[]"Hel…...
《前端面试题:CSS对浏览器兼容性》
CSS浏览器兼容性完全指南:从原理到实战 跨浏览器兼容性是前端开发的核心挑战,也是面试中的高频考点。查看所有css属性对各个浏览器兼容网站:https://caniuse.com 一、浏览器兼容性为何如此重要? 在当今多浏览器生态中,…...
使用 Docker Compose 安装 Redis 7.2.4
前面是指南,后面是主要步骤实际执行日志 使用 Docker Compose 安装 Redis 7.2.4 以下是使用 Docker Compose 安装 Redis 7.2.4 的完整指南: 1. 创建项目目录和文件 bash 复制 下载 # 创建项目目录 mkdir redis-docker && cd redis-docker#…...

35.x64汇编写法(二)
免责声明:内容仅供学习参考,请合法利用知识,禁止进行违法犯罪活动! 本次游戏没法给 内容参考于:微尘网络安全 上一个内容:34.x64汇编写法(一) 上一个内容写了,汇编调…...

安全大模型的思考
马上要准备2025年的护网了,最近就一直很忙,被事情裹挟着前进,忙的晕头转向,近乎感冒,昨天部门搞了一场AI大模型培训,演讲者有着很深的技术底蕴,我听到了一句关于Sass数据验证这块大为感悟&#…...
SQL Server 2025 预览版新功能
T-SQL 语言增强 正则表达式 (Regex) 支持 功能概述: SQL Server 2025 在 T-SQL 中原生引入了 POSIX 兼容的正则表达式支持,通过内置函数(如 REGEXP_LIKE、REGEXP_REPLACE 等)可直接在查询中对文本进行复杂模式匹配、查找和替换。…...

NineData云原生智能数据管理平台新功能发布|2025年5月版
本月发布 6 项更新,其中重点发布 3 项、功能优化 3 项。 重点发布 数据库 DevOps - 多源敏感数据保护 敏感数据扫描能力大幅扩展,新增支持 TiDB、Doris、SelectDB、OceanBase MySQL、GreatSQL、StarRocks、ClickHouse、SingleStore、Lindorm 9 种大数据…...
数学复习笔记 25
今天能把第五章学完。加油。今年是最好上岸的一年。 5.23:全是单根,笑死,居然难受了。我现在每个题,都要总结。总结。总结实际上也总结不出啥东西。但是我一定要总结。主动让自己思考一下。老师的思路很清奇。他认为考的稀松平常…...

Linux可执行文件ELF文件结构
目标文件格式 编译器编译源代码后生成的文件叫做目标文件,而目标文件经过编译器链接之后得到的就是可执行文件。那么目标文件到底是什么?它和可执行文件又有什么区别?链接到底又做了什么呢?接下来,我们将探索一下目标…...
RAG:大模型微调的革命性增强——检索增强生成技术深度解析
RAG:大模型微调的革命性增强——检索增强生成技术深度解析 当大模型遇到知识瓶颈,RAG(检索增强生成)为模型装上"外部记忆库",让静态知识库与动态生成能力完美融合。本文将深入拆解RAG的技术原理、微调策略及…...

DisplayPort 2.0协议介绍(1)
最近开始学习DisplayPort 2.0协议,相比于DP1.4a,最主要的是速率提升到了10Gbps/lane,还有就是128b/132b编码方式的修改。至于速率13.5Gbps和20Gbps还只是可选项,在DP2.1协议才成为必须支持选项。 那在实现技术细节上有哪些变化呢…...

I2C通信讲解
I2C总线发展史 怎么在一条串口线上连接多个设备呢? 由于速度同步线是由主机实时发出的,所以主机可以按需求修改通信速度,这样在一条线上可以挂接不同速度的器件,单片机和性能差的器件通信,就输出较慢的脉冲信号&#x…...
【信息系统项目管理师-选择真题】2025上半年(第一批)综合知识答案和详解
更多内容请见: 备考信息系统项目管理师-专栏介绍和目录 文章目录 【第1题】【第2题】【第3题】【第4题】【第5题】【第6题】【第7题】【第8题】【第9题】【第10题】【第11题】【第12题】【第13题】【第14题】【第15题】【第16题】【第17题】【第18题】【第19题】【第20题】【第…...
ABP VNext 在 Kubernetes 中的零停机蓝绿发布
ABP VNext 在 Kubernetes 中的零停机蓝绿发布 🚀 📚 目录 ABP VNext 在 Kubernetes 中的零停机蓝绿发布 🚀📌 一、前提准备 ℹ️🧱 二、项目结构与目标 🎯🐳 三、多阶段 Dockerfile 构建 &#…...
linux 故障处置通用流程-36计-14-27
014:查看系统主要日志 查看以下日志: 主要查以下关键字 error/NIC/fs /"link down"/Oout of memory" /var/log/messages /var/log/dmesg 015:主机通讯是否延迟 执行命令: #ping 网关_IP #ping 关联主机_IP …...
https和http有什么区别-http各个版本有什么区别
http和 https的区别 HTTP(超文本传输协议)和 HTTPS(安全超文本传输协议)是两种用于在网络上传输数据的协议,它们的主要区别在于安全性: HTTP(Hypertext Transfer Protocol)&#x…...

基于回归算法的心理健康预测(EDA + 预测)
心理健康涵盖情感、心理与社会福祉,影响认知、情绪和行为模式,决定压力应对、人际交往及健康决策,且在生命各阶段(从童年至成年)均至关重要。心理健康与身体健康同为整体健康的核心要素:抑郁会增加糖尿病、…...
React Native开发鸿蒙运动健康类应用的项目实践记录
项目名称:HarmonyFitness - 基于React Native的鸿蒙运动健康应用 技术栈:React Native 0.72.5 TypeScript HarmonyOS API ArkTS原生模块 一、环境搭建与项目初始化 双环境配置 React Native环境: npx re…...

【新品解读】一板多能,AXRF49 定义新一代 RFSoC FPGA 开发平台
“硬件系统庞杂、调试周期长” “高频模拟前端不稳定,影响采样精度” “接收和发射链路难以同步,难以扩展更多通道” “数据流量大,处理与存储跟不上” 这些是大部分客户在构建多通道、高频宽的射频采样链路时,面临的主要问题。…...

贪心算法应用:线性规划贪心舍入问题详解
贪心算法应用:线性规划贪心舍入问题详解 贪心算法是一种在每一步选择中都采取当前状态下最优的选择,从而希望导致结果是全局最优的算法策略。在线性规划问题中,贪心算法特别是贪心舍入技术有着广泛的应用。下面我将全面详细地讲解这一主题。…...

YOLO在C#中的完整训练、验证与部署方案
YOLO在C#中的完整训练、验证与部署方案 C# 在 YOLO 部署上优势明显(高性能、易集成),但训练能力较弱,通常需结合 Python 实现。若项目对开发效率要求高且不依赖 C# 生态,建议全程使用 Python;若需深度集成…...
洛谷题目:P2761 软件补丁问题 (本题简单)
个人介绍: 题目传送门: P2761 软件补丁问题 - 洛谷 (luogu.com.cn) 前言: 这道题是一个典型的状态搜索问题,核心目标就是利用给定d额多个补丁程序,将包含若干错误的软件修复成没有错误的状态,并且要使得修复过程当中的总耗时最少。下面是小亦为大家阐述滴思路: 1、状态…...

智慧园区数字孪生全链交付方案:降本增效30%,多案例实践驱动全周期交付
在智慧园区建设浪潮中,数字孪生技术正成为破解传统园区管理难题的核心引擎。通过构建与物理园区1:1映射的数字模型,实现数据集成、状态同步与智能决策,智慧园区数字孪生全链交付方案已在多个项目中验证其降本增效价值——某物流园区通过该方案…...