用matlab如何画二维高斯分布图

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了用matlab如何画二维高斯分布图相关的知识,希望对你有一定的参考价值。

mu = [3 1]

sigma = [1 1;1 1]
如何画图
我用下列方法 会有错误
mu = [3 1];
sigma = [1 1; 1 1];
x1 = -3:.2:3; x2 = -3:.2:3;
[x1,x2] = meshgrid(x1,x2);
F=mvnpdf([x1(:) x2(:)],mu,sigma);
F = reshape(F,length(x2),length(x1));
contour(x1,x2,F);
xlabel('x'); ylabel('y');
报错
Error using mvnpdf (line 129)
SIGMA must be a square, symmetric, positive definite matrix.
sigma的数值不能改,如果是[2 2;2 2],就能画出图来
求助大神有没有别的方法

参考技术A 人家matlab都所的非常清楚了,sigma必须是正定矩阵。[1 1;1 1]是正定的?它都不可逆。
你自己回去翻翻统计学的书看看。本回答被提问者和网友采纳

信号图像Matlab如何得到高斯滤波器的整数模板

【信号、图像、Matlab】如何得到高斯滤波器的整数模板

如何得到高斯滤波器的整数模板?这个问题困扰了我两天,上网搜索的代码,基本上都生成的小数,有的文档给写了3*3,5*5,7*7的整数形式,但是没有说是怎么得到的,应该说是我没有仔细看吧,现在恍然大悟,只要将左上角的元素化为1就可以了啊。我还以为用什么高级方法得出来的,晕死了。

二维高斯分布公式:

技术分享
要得到高斯滤波器的整数模板就要从这个公式入手,这个公式在三维坐标下的形式是这样的:
技术分享
我们要的高斯滤波器的整数模板相当于这个三维图形在底面(将底面网格化,也就是离散化,计算机不能处理连续的东东)的投影,将曲面的高度换算成网格里面的值,这是我们要的模板了。

计算整数模板的公式

假设我们的模板放在矩阵M中,M的大小为(2k+1)*( 2k+1),那么M(i,j)的值为:
技术分享
说明:这就是由连续公式得到的,只不过这里的M是一个矩阵,原点在矩阵的中间,所以有(i-k-1)以及(j-k-1)为的就是让原点到矩阵中间。

一个Matlab代码

clear;
k=1;              %模板长度的一半
row = 2*k+1;      %模板长度
col = 2*k+1;
sigma2=1;         %方差
for i=1 : row
    for j=1 : col
        fenzi=double((i-k-1)^2+(j-k-1)^2);
        A(i,j)=exp(-fenzi/(2*sigma2))/(2*pi*sigma2);
    end
end
A                           %显示小数形式
C=floor(A.*(1/A(1,1)));      %左上角化为1(想了很久整数是怎么得出来的,只要这样就可以了,郁闷)

这个代码得到的是一个7*7,sigma=1高斯滤波器的小数和整数模板,如下:
小数:
技术分享
整数:
技术分享
当时想了很久怎样才能得到整数形式的模板,无意间从网上看了将左上角的元素化为1就可以了,我只能说自己的脑壳真是迟钝啊。

要说明的两点

  • 上面的整数模板要用于滤波的话,需要归一化,就是在整个模板的前面加一个系数,这个系数是:1/(所有整数总和).
  • 生成的模板,与公式里的一个东西有关:sigma,这对生成的模板数个影响很大。这里给一张不同sigma的一维高斯分布图,二维的类似,理解sigma取值对函数图形的影响就可以了:
    技术分享
    Sigma越大,分布越集中。

再给几个不同大小,不同sigma的整数模板

技术分享
技术分享
技术分享
之所以放这几个模板,可以发现,sigma的取值对模板的影响很大,所以如何取sigma,这应该是个经验性的问题。
















以上是关于用matlab如何画二维高斯分布图的主要内容,如果未能解决你的问题,请参考以下文章

matlab如何产生服从高斯分布的随机整数

如何在 MATLAB 中绘制显示二维高斯函数总和的图像?

MATLAB实现高斯混合分布的EM算法及二维时概率密度曲面置信椭圆绘制

MATLAB实现高斯混合分布的EM算法及二维时概率密度曲面置信椭圆绘制

信号图像Matlab如何得到高斯滤波器的整数模板

高斯分布(总)