【Math】高斯分布的乘积 Product of Guassian Distribution【附带Python实现】

本文主要是介绍【Math】高斯分布的乘积 Product of Guassian Distribution【附带Python实现】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

【Math】高斯分布的乘积 Product of Guassian Distribution【附带Python实现】

文章目录

  • 【Math】高斯分布的乘积 Product of Guassian Distribution【附带Python实现】
    • 1.推导
    • 2. Code
    • Reference

结果先放在前面

Image

1.推导

在学习PEARL算法的时候,encoder的设计涉及到了高斯分布的乘积,对此有点疑问,进行推导补票。

首先高斯分布(Guassian Distribution)的概率密度函数为

f ( x ) = 1 2 π σ exp ⁡ ( − ( x − μ ) 2 2 σ 2 ) f(x) = \frac{1}{\sqrt{2\pi} \sigma} \exp({-\frac{(x-\mu)^2}{2\sigma^2}}) f(x)=2π σ1exp(2σ2(xμ)2)

通常将单位高斯分布记为 N ∼ ( 0 , 1 ) \mathcal{N}\sim(0,1) N(0,1),一般的高斯分布记为 N ∼ ( μ , σ ) \mathcal{N}\sim(\mu,\sigma) N(μ,σ),其中 μ \mu μ是高斯分布的均值(mean), σ \sigma σ是高斯分布的标准差(standard variance), σ 2 \sigma^2 σ2是高斯分布的方差(variance)。

​ 接下来推导高斯分布的乘积,假设有两个高斯分布,分别为
N 1 ∼ ( μ 1 , σ 1 ) , N 2 ∼ ( μ 2 , σ 2 ) \mathcal{N}_1\sim(\mu_1,\sigma_1),\mathcal{N}_2\sim(\mu_2,\sigma_2) N1(μ1,σ1),N2(μ2,σ2),那么其概率密度函数的乘积为

f 1 ( x ) f 2 ( x ) = 1 2 π σ 1 exp ⁡ ( − ( x − μ 1 ) 2 2 σ 1 2 ) × 1 2 π σ 2 exp ⁡ ( − ( x − μ 2 ) 2 2 σ 2 2 ) = 1 2 π σ 1 σ 2 exp ⁡ ( − ( x − μ 1 ) 2 2 σ 1 2 − ( x − μ 2 ) 2 2 σ 2 2 ) \begin{align} f_1(x)f_2(x) & = \frac{1}{\sqrt{2\pi}\sigma_1}\exp(-\frac{(x-\mu_1)^2}{2\sigma_1^2}) \times \frac{1}{\sqrt{2\pi}\sigma_2}\exp(-\frac{(x-\mu_2)^2}{2\sigma_2^2}) \\ & = \frac{1}{2\pi\sigma_1\sigma_2}\exp(-\frac{(x-\mu_1)^2}{2\sigma_1^2} - \frac{(x-\mu_2)^2}{2\sigma_2^2} ) \end{align} f1(x)f2(x)=2π σ11exp(2σ12(xμ1)2)×2π σ21exp(2σ22(xμ2)2)=2πσ1σ21exp(2σ12(xμ1)22σ22(xμ2)2)

我们单独分析指数部分,

( x − μ 1 ) 2 2 σ 1 2 + ( x − μ 2 ) 2 2 σ 2 2 = ( σ 1 2 + σ 2 2 ) x 2 − 2 x ( μ 2 σ 1 2 + μ 1 σ 2 2 ) + ( μ 1 2 σ 2 2 + μ 2 2 σ 1 2 ) 2 σ 1 2 σ 2 2 = x 2 − 2 x μ 2 σ 1 2 + μ 1 σ 2 2 σ 1 2 + σ 2 2 + μ 1 2 σ 2 2 + μ 2 2 σ 1 2 σ 1 2 + σ 2 2 2 σ 1 2 σ 2 2 σ 1 2 + σ 2 2 = ( x − μ 2 σ 1 2 + μ 1 σ 2 2 σ 1 2 + σ 2 2 ) 2 + μ 1 2 σ 2 2 + μ 2 2 σ 1 2 σ 1 2 + σ 2 2 − ( μ 2 σ 1 2 + μ 1 σ 2 2 σ 1 2 + σ 2 2 ) 2 2 σ 1 2 σ 2 2 σ 1 2 + σ 2 2 = ( x − μ 2 σ 1 2 + μ 1 σ 2 2 σ 1 2 + σ 2 2 ) 2 2 σ 1 2 σ 2 2 σ 1 2 + σ 2 2 + μ 1 2 σ 2 2 + μ 2 2 σ 1 2 σ 1 2 + σ 2 2 − ( μ 2 σ 1 2 + μ 1 σ 2 2 σ 1 2 + σ 2 2 ) 2 2 σ 1 2 σ 2 2 σ 1 2 + σ 2 2 \begin{align} \frac{(x-\mu_1)^2}{2\sigma_1^2} + \frac{(x-\mu_2)^2}{2\sigma_2^2} & = \frac{(\sigma_1^2 + \sigma_2^2)x^2 - 2x(\mu_2\sigma_1^2 + \mu_1\sigma_2^2) + (\mu_1^2\sigma_2^2 + \mu_2^2\sigma_1^2) }{2\sigma_1^2\sigma_2^2} \\ & = \frac{ x^2 - 2x\frac{\mu_2\sigma_1^2 + \mu_1\sigma_2^2}{\sigma_1^2+\sigma_2^2} + \frac{\mu_1^2\sigma_2^2 + \mu_2^2\sigma_1^2}{\sigma_1^2+\sigma_2^2} }{ \frac{2\sigma_1^2\sigma_2^2}{\sigma_1^2+\sigma_2^2}} \\ & = \frac{ (x-\frac{\mu_2\sigma_1^2 + \mu_1\sigma_2^2}{\sigma_1^2+\sigma_2^2})^2 + \frac{\mu_1^2\sigma_2^2 + \mu_2^2\sigma_1^2}{\sigma_1^2+\sigma_2^2} - (\frac{\mu_2\sigma_1^2 + \mu_1\sigma_2^2}{\sigma_1^2+\sigma_2^2})^2 }{ \frac{2\sigma_1^2\sigma_2^2}{\sigma_1^2+\sigma_2^2} } \\ & = \frac{(x-\frac{\mu_2\sigma_1^2 + \mu_1\sigma_2^2}{\sigma_1^2+\sigma_2^2})^2}{\frac{2\sigma_1^2\sigma_2^2}{\sigma_1^2+\sigma_2^2}} + \frac{\frac{\mu_1^2\sigma_2^2 + \mu_2^2\sigma_1^2}{\sigma_1^2+\sigma_2^2} - (\frac{\mu_2\sigma_1^2 + \mu_1\sigma_2^2}{\sigma_1^2+\sigma_2^2})^2}{\frac{2\sigma_1^2\sigma_2^2}{\sigma_1^2+\sigma_2^2}} \end{align} 2σ12(xμ1)2+2σ22(xμ2)2=2σ12σ22(σ12+σ22)x22x(μ2σ12+μ1σ22)+(μ12σ22+μ22σ12)=σ12+σ222σ12σ22x22xσ12+σ22μ2σ12+μ1σ22+σ12+σ22μ12σ22+μ22σ12=σ12+σ222σ12σ22(xσ12+σ22μ2σ12+μ1σ22)2+σ12+σ22μ12σ22+μ22σ12(σ12+σ22μ2σ12+μ1σ22)2=σ12+σ222σ12σ22(xσ12+σ22μ2σ12+μ1σ22)2+σ12+σ222σ12σ22σ12+σ22μ12σ22+μ22σ12(σ12+σ22μ2σ12+μ1σ22)2

继续化简上面的常数部分

μ 1 2 σ 2 2 + μ 2 2 σ 1 2 σ 1 2 + σ 2 2 − ( μ 2 σ 1 2 + μ 1 σ 2 2 σ 1 2 + σ 2 2 ) 2 2 σ 1 2 σ 2 2 σ 1 2 + σ 2 2 = ( μ 1 2 σ 2 2 + μ 2 2 σ 1 2 ) ( σ 1 2 + σ 2 2 ) + ( μ 2 σ 1 2 + μ 1 σ 2 2 ) 2 2 σ 1 2 σ 2 2 ( σ 1 2 + σ 2 2 ) = ( μ 1 − μ 2 ) 2 2 ( σ 1 2 + σ 2 2 ) \begin{align} \frac{\frac{\mu_1^2\sigma_2^2 + \mu_2^2\sigma_1^2}{\sigma_1^2+\sigma_2^2} - (\frac{\mu_2\sigma_1^2 + \mu_1\sigma_2^2}{\sigma_1^2+\sigma_2^2})^2}{\frac{2\sigma_1^2\sigma_2^2}{\sigma_1^2+\sigma_2^2}} & = \frac{(\mu_1^2\sigma_2^2 + \mu_2^2\sigma_1^2)(\sigma_1^2 + \sigma_2^2) + (\mu_2\sigma_1^2 + \mu_1\sigma_2^2)^2}{2\sigma_1^2\sigma_2^2(\sigma_1^2+\sigma_2^2)} \\ & = \frac{(\mu_1 - \mu_2)^2}{2(\sigma_1^2 + \sigma_2^2)} \end{align} σ12+σ222σ12σ22σ12+σ22μ12σ22+μ22σ12(σ12+σ22μ2σ12+μ1σ22)2=2σ12σ22(σ12+σ22)(μ12σ22+μ22σ12)(σ12+σ22)+(μ2σ12+μ1σ22)2=2(σ12+σ22)(μ1μ2)2

则我们可以将概率密度函数的乘积写为

f 1 ( x ) f 2 ( x ) = 1 2 π σ 1 σ 2 exp ⁡ ( − ( x − μ 1 ) 2 2 σ 1 2 − ( x − μ 2 ) 2 2 σ 2 2 ) = 1 2 π σ 1 σ 2 exp ⁡ ( − ( x − μ 2 σ 1 2 + μ 1 σ 2 2 σ 1 2 + σ 2 2 ) 2 2 σ 1 2 σ 2 2 σ 1 2 + σ 2 2 − ( μ 1 − μ 2 ) 2 2 ( σ 1 2 + σ 2 2 ) ) = 1 2 π ( σ 1 2 + σ 2 2 ) exp ⁡ ( − ( μ 1 − μ 2 ) 2 2 ( σ 1 2 + σ 2 2 ) ) ⏟ S g × 1 2 π σ 1 2 σ 2 2 σ 1 2 + σ 2 2 exp ⁡ ( − ( x − μ 2 σ 1 2 + μ 1 σ 2 2 σ 1 2 + σ 2 2 ) 2 2 σ 1 2 σ 2 2 σ 1 2 + σ 2 2 ) = S g × 1 2 π μ exp ⁡ ( − ( x − μ ) 2 2 σ ) \begin{align} f_1(x)f_2(x) & =\frac{1}{2\pi\sigma_1\sigma_2}\exp(-\frac{(x-\mu_1)^2}{2\sigma_1^2} - \frac{(x-\mu_2)^2}{2\sigma_2^2} ) \\ & = \frac{1}{2\pi\sigma_1\sigma_2} \exp( - \frac{(x-\frac{\mu_2\sigma_1^2 + \mu_1\sigma_2^2}{\sigma_1^2+\sigma_2^2})^2}{\frac{2\sigma_1^2\sigma_2^2}{\sigma_1^2+\sigma_2^2}} - \frac{(\mu_1 - \mu_2)^2}{2(\sigma_1^2 + \sigma_2^2)} ) \\ & = \underbrace{\frac{1}{\sqrt{2\pi(\sigma_1^2+\sigma_2^2)}}\exp(-\frac{(\mu_1 - \mu_2)^2}{2(\sigma_1^2 + \sigma_2^2)})}_{S_g} \times \frac{1}{\sqrt{2\pi \frac{\sigma_1^2\sigma_2^2}{\sigma_1^2+\sigma_2^2} }}\exp(- \frac{(x-\frac{\mu_2\sigma_1^2 + \mu_1\sigma_2^2}{\sigma_1^2+\sigma_2^2})^2}{\frac{2\sigma_1^2\sigma_2^2}{\sigma_1^2+\sigma_2^2}}) \\ & = S_g\times \frac{1}{\sqrt{2\pi \mu}} \exp(-\frac{(x-\mu)^2}{2\sigma}) \end{align} f1(x)f2(x)=2πσ1σ21exp(2σ12(xμ1)22σ22(xμ2)2)=2πσ1σ21exp(σ12+σ222σ12σ22(xσ12+σ22μ2σ12+μ1σ22)22(σ12+σ22)(μ1μ2)2)=Sg 2π(σ12+σ22) 1exp(2(σ12+σ22)(μ1μ2)2)×2πσ12+σ22σ12σ22 1exp(σ12+σ222σ12σ22(xσ12+σ22μ2σ12+μ1σ22)2)=Sg×2πμ 1exp(2σ(xμ)2)

其中

μ = μ 2 σ 1 2 + μ 1 σ 2 2 σ 1 2 + σ 2 2 , σ 2 = σ 1 2 σ 2 2 σ 1 2 + σ 2 2 \mu = \frac{\mu_2\sigma_1^2 + \mu_1\sigma_2^2}{\sigma_1^2+\sigma_2^2}, \sigma^2 =\frac{\sigma_1^2\sigma_2^2}{\sigma_1^2+\sigma_2^2} μ=σ12+σ22μ2σ12+μ1σ22,σ2=σ12+σ22σ12σ22

所以两个高斯分布的乘积仍然为高斯分布,且均值为 μ \mu μ,方差为 σ 2 \sigma^2 σ2 S g S_g Sg被称为缩放因子,即相乘后的分布函数为一个被压缩或者放大的高斯分布,相乘后的概率密度的积分不等于1,但其方差和均值性质不变,仍然符合高斯分布。

​ 拓展到多个高斯分布相乘的结果,可以得到

μ = μ 1 σ 2 2 σ 3 2 + μ 2 σ 1 2 σ 3 2 + μ 3 σ 1 2 σ 2 2 σ 1 2 σ 2 2 + σ 1 2 σ 3 2 + σ 2 2 σ 3 2 , σ 2 = σ 1 2 σ 2 2 σ 3 2 σ 1 2 σ 2 2 + σ 1 2 σ 3 2 + σ 2 2 σ 3 2 \mu = \frac{\mu_1\sigma_2^2\sigma_3^2 + \mu_2\sigma_1^2\sigma_3^2 + \mu_3\sigma_1^2\sigma_2^2 }{\sigma_1^2\sigma_2^2 + \sigma_1^2\sigma_3^2 + \sigma_2^2\sigma_3^2}, \sigma^2 = \frac{\sigma_1^2\sigma_2^2\sigma_3^2}{\sigma_1^2\sigma_2^2 + \sigma_1^2\sigma_3^2 + \sigma_2^2\sigma_3^2} μ=σ12σ22+σ12σ32+σ22σ32μ1σ22σ32+μ2σ12σ32+μ3σ12σ22,σ2=σ12σ22+σ12σ32+σ22σ32σ12σ22σ32

2. Code

import numpy as np
import matplotlib.pyplot as plt
from scipy.stats import norm# 设定均值和标准差
mean = np.array([1, 2, 3])
var = np.array([1, 3, 5])x = np.linspace(-15, 15, 1000)
pdfs = []
# 计算高斯分布的概率密度函数(Probability Density Function, PDF)
for mu, sigma in zip(mean, var):pdfs.append(norm.pdf(x, mu, np.sqrt(sigma)))# 绘制高斯分布曲线
plt.plot(x, pdfs[0], 'r-', linewidth=2, label='mean=1, var=1')
plt.fill_between(x, pdfs[0], color='red', alpha=0.5)
plt.plot(x, pdfs[1], 'g-', linewidth=2, label='mean=2, var=3')
plt.fill_between(x, pdfs[1], color='g', alpha=0.5)
plt.plot(x, pdfs[2], 'b-', linewidth=2, label='mean=3, var=5')
plt.fill_between(x, pdfs[2], color='b', alpha=0.5)# 计算三个高斯分布的乘积
prod_mean = 1.0 / np.sum(np.reciprocal(mean), axis=0)
prod_var = prod_mean * np.sum(mean / var, axis=0)
pdf = norm.pdf(x, prod_mean, np.sqrt(prod_var))
plt.plot(x, pdf, 'k--', linewidth=2, label='product')
plt.fill_between(x, pdf, color='y', alpha=0.7)# 添加标签和标题
plt.xlabel('Value')
plt.ylabel('Probability Density')
plt.title('Normal Distribution')
plt.legend()# 显示图形
plt.show()

Reference

https://blog.csdn.net/chaosir1991/article/details/106910668

这篇关于【Math】高斯分布的乘积 Product of Guassian Distribution【附带Python实现】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Python开发文字版随机事件游戏的项目实例

《Python开发文字版随机事件游戏的项目实例》随机事件游戏是一种通过生成不可预测的事件来增强游戏体验的类型,在这篇博文中,我们将使用Python开发一款文字版随机事件游戏,通过这个项目,读者不仅能够... 目录项目概述2.1 游戏概念2.2 游戏特色2.3 目标玩家群体技术选择与环境准备3.1 开发环境3

Python中模块graphviz使用入门

《Python中模块graphviz使用入门》graphviz是一个用于创建和操作图形的Python库,本文主要介绍了Python中模块graphviz使用入门,具有一定的参考价值,感兴趣的可以了解一... 目录1.安装2. 基本用法2.1 输出图像格式2.2 图像style设置2.3 属性2.4 子图和聚

Python使用Matplotlib绘制3D曲面图详解

《Python使用Matplotlib绘制3D曲面图详解》:本文主要介绍Python使用Matplotlib绘制3D曲面图,在Python中,使用Matplotlib库绘制3D曲面图可以通过mpl... 目录准备工作绘制简单的 3D 曲面图绘制 3D 曲面图添加线框和透明度控制图形视角Matplotlib

一文教你Python如何快速精准抓取网页数据

《一文教你Python如何快速精准抓取网页数据》这篇文章主要为大家详细介绍了如何利用Python实现快速精准抓取网页数据,文中的示例代码简洁易懂,具有一定的借鉴价值,有需要的小伙伴可以了解下... 目录1. 准备工作2. 基础爬虫实现3. 高级功能扩展3.1 抓取文章详情3.2 保存数据到文件4. 完整示例

使用Python实现IP地址和端口状态检测与监控

《使用Python实现IP地址和端口状态检测与监控》在网络运维和服务器管理中,IP地址和端口的可用性监控是保障业务连续性的基础需求,本文将带你用Python从零打造一个高可用IP监控系统,感兴趣的小伙... 目录概述:为什么需要IP监控系统使用步骤说明1. 环境准备2. 系统部署3. 核心功能配置系统效果展

基于Python打造一个智能单词管理神器

《基于Python打造一个智能单词管理神器》这篇文章主要为大家详细介绍了如何使用Python打造一个智能单词管理神器,从查询到导出的一站式解决,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 项目概述:为什么需要这个工具2. 环境搭建与快速入门2.1 环境要求2.2 首次运行配置3. 核心功能使用指

Python实现微信自动锁定工具

《Python实现微信自动锁定工具》在数字化办公时代,微信已成为职场沟通的重要工具,但临时离开时忘记锁屏可能导致敏感信息泄露,下面我们就来看看如何使用Python打造一个微信自动锁定工具吧... 目录引言:当微信隐私遇到自动化守护效果展示核心功能全景图技术亮点深度解析1. 无操作检测引擎2. 微信路径智能获

Python中pywin32 常用窗口操作的实现

《Python中pywin32常用窗口操作的实现》本文主要介绍了Python中pywin32常用窗口操作的实现,pywin32主要的作用是供Python开发者快速调用WindowsAPI的一个... 目录获取窗口句柄获取最前端窗口句柄获取指定坐标处的窗口根据窗口的完整标题匹配获取句柄根据窗口的类别匹配获取句

利用Python打造一个Excel记账模板

《利用Python打造一个Excel记账模板》这篇文章主要为大家详细介绍了如何使用Python打造一个超实用的Excel记账模板,可以帮助大家高效管理财务,迈向财富自由之路,感兴趣的小伙伴快跟随小编一... 目录设置预算百分比超支标红预警记账模板功能介绍基础记账预算管理可视化分析摸鱼时间理财法碎片时间利用财

在 Spring Boot 中实现异常处理最佳实践

《在SpringBoot中实现异常处理最佳实践》本文介绍如何在SpringBoot中实现异常处理,涵盖核心概念、实现方法、与先前查询的集成、性能分析、常见问题和最佳实践,感兴趣的朋友一起看看吧... 目录一、Spring Boot 异常处理的背景与核心概念1.1 为什么需要异常处理?1.2 Spring B