MATLAB 中的 mvnpdf() 函数
本文将讨论使用 MATLAB 中的 mvnpdf()
函数评估多元正态分布的概率密度函数。
在 MATLAB 中使用 mvnpdf()
函数
广义版本的单变量正态分布对两个或多个变量的多元正态分布。多元正态分布有两个与单变量正态分布相似的参数,包括协方差矩阵和均值向量。
协方差矩阵的非对角元素包含变量之间的协方差,协方差矩阵的对角元素包含每个变量的方差。在 MATLAB 中,我们使用 mvnpdf()
函数来查找多元正态分布的概率密度函数。
mvnpdf()
函数具有以下三种语法。
语法:
output = mvnpdf(input)
output = mvnpdf(input, mu)
output = mvnpdf(input, mu, sigma)
output = mvnpdf(input)
将返回概率密度函数作为输入矩阵的 n×1
向量,包含维度 m 的多元正态分布。该函数将沿维度 n×m 评估每个输入矩阵行的输出。
output = mvnpdf(input, mu)
将根据 mu
变量返回概率密度函数,该变量定义了多元正态分布的平均值。第三种语法还将包括变量 sigma
,它定义了多元正态分布的协方差。
在 output = mvnpdf(input, mu, sigma)
中,如果我们只想指定 sigma
的值并且我们想使用 mu
的默认值,我们可以传递一个空向量作为 mu
变量作为第二个参数,并将 sigma
的值设置为第三个参数。我们可以使用 mvnrnd()
函数来创建包含随机数的多元正态分布矩阵。
为了创建随机多元正态分布,我们必须在 mvnrnd()
函数中传递 mu
和 sigma
变量的值。我们还可以通过将数字定义为 mvnrnd()
函数中的第三个参数来设置输出矩阵的行数。
例如,让我们使用 mrnrnd()
函数创建一个多元正态分布的随机矩阵,然后使用 mvnpdf()
函数找到它的概率密度函数。
示例代码:
mu_v = zeros(1,4);
Sigma_m = eye(4);
rng('default')
random_mvn = mvnrnd(mu_v,Sigma_m,6)
out_pdf = mvnpdf(random_mvn)
输出:
random_mvn =
0.5377 -0.4336 0.7254 1.4090
1.8339 0.3426 -0.0631 1.4172
-2.2588 3.5784 0.7147 0.6715
0.8622 2.7694 -0.2050 -1.2075
0.3188 -1.3499 -0.1241 0.7172
-1.3077 3.0349 1.4897 1.6302
out_pdf =
0.0057
0.0016
0.0000
0.0002
0.0074
0.0000
我们使用 zeros()
函数为 mu
变量创建向量,使用 eye()
函数为 sigma
变量创建矩阵,并使用 rng()
函数来控制随机数字生成器,我们已将其设置为默认值以实现可重复性。上面的输出显示了多元正态分布的随机矩阵和包含概率密度函数值的向量。
假设我们要根据不同的均值求某些点的概率密度函数。我们可以将 mu
变量中的平均值定义为 mvnpdf()
函数中的第二个参数。
mu
矩阵大小应与多元正态分布的输入矩阵大小相同。
假设我们要在某些点根据不同的协方差值求概率密度函数。我们可以将 sigma
变量中的协方差值定义为 mvnpdf()
函数内的第三个参数。
sigma
矩阵的列数应与多元正态分布输入矩阵的列数相同。如果我们想找到相同点的概率密度函数,我们可以在 mu
变量内部重复相同的点,默认情况下,mu
变量是一个零向量,sigma
变量是一个的矩阵。
相关文章
如何在 Matplotlib Pyplot 中显示网格
发布时间:2024/02/04 浏览次数:142 分类:Python
-
本文演示了如何在 Python Matplotlib 中在一个图上画一个网格。使用 grid()函数来绘制网格,并解释了如何改变网格颜色和线条类型。
在 Matplotlib 中的图中添加文字
发布时间:2024/02/04 浏览次数:180 分类:Python
-
本教程展示了我们如何使用 plt.text()方法在 Matplotlib 中为图或轴添加文字。
如何在 Matplotlib 中的多个线条之间进行填充
发布时间:2024/02/04 浏览次数:208 分类:Python
-
`fill_between()` 每次只能填充两条线之间的区域,但是我们可以选择一对行来填充多个线条之间的区域。
如何在 Matplotlib 中画一条任意线
发布时间:2024/02/04 浏览次数:166 分类:Python
-
本教程讲解了我们如何在 Matplotlib 中使用 matplotlib.pyplot.plot()、matplotlib.pyplot.vlines()、matplotlib.pyplot.hlines()方法和 matplotlib.collection.LineCollection 绘制任意线条。
Pandas 在 Matplotlib 柱状图上绘制多列图
发布时间:2024/02/04 浏览次数:189 分类:Python
-
在本教程中,我们将探讨如何使用 `DataFrame` 对象的 `plot()` 方法在柱状图上绘制多列。
如何在 Matplotlib 中绘制数据列表的直方图
发布时间:2024/02/04 浏览次数:178 分类:Python
-
本教程介绍了如何使用 plt.hist()方法从数据列表中绘制直方图。我们可以使用 plt.hist()方法从数据列表中绘制直方图。
Matplotlib 中的叠加条形图
发布时间:2024/02/04 浏览次数:182 分类:Python
-
本教程展示了如何使用 plt.bar()方法将某些数据集的条形图堆叠在另一个数据集上。我们在 Matplotlib 中使用 matplotlib.pyplot.bar()方法生成条形图。
在 Python Matplotlib 中生成反向色彩图
发布时间:2024/02/04 浏览次数:136 分类:Python
-
本教程解释了如何反转 Python Matplotlib Plot 的 Colormap。
设置 Matplotlib 网格间隔
发布时间:2024/02/04 浏览次数:250 分类:Python
-
本教程将介绍我们如何在 Matplotlib 绘图中设置网格间距,并对主要网格和次要网格应用不同的样式。