Bivariate Guassian mixed model on 1D data
1 次查看(过去 30 天)
显示 更早的评论
Hi, I am trying to plot a guassian curve on the histogram distribution of my 1D data. This is my code:
data = xlsread('csf.xlsx','ab');
mu1 = mean('data');
sigma1 = std('data');
X = [mvnrnd(mu1,sigma1,1000)];
numComponents=2;
paramEsts = fitgmdist(X,numComponents);
MU=[paramEsts.mu(1);paramEsts.mu(2)];
SIGMA=cat(3,[paramEsts.Sigma(1)],[paramEsts.Sigma(2)]);
PPp=[paramEsts.PComponents(1),paramEsts.PComponents(2)];
gm = gmdistribution(MU,SIGMA,PPp);
dimension = gm.NumVariables
rng(1);
min_val = min(data(:)-100); max_val = max (data(:)+1000);
% min_val = min('data'); max_val = max ('data');
histogram(data, 'Normalization', 'pdf', 'EdgeColor', 'none')
x= min_val:0.01:max_val;
xlim([min_val max_val])
hold on;
xgrid = linspace (50,3000,500)';
n1 = makedist('normal',paramEsts.mu(1),sqrt(paramEsts.Sigma(1)));
n2 = makedist('normal',paramEsts.mu(2),sqrt(paramEsts.Sigma(2)));
p = paramEsts.ComponentProportion;
y = p(1)*pdf(n1,xgrid) + p(2)*pdf(n2,xgrid);
hold on; plot(xgrid,y,'b'); hold off
And this is what I get:
data:image/s3,"s3://crabby-images/2331a/2331ab1a84cdf28a397a283d20e3f2a5ff3023fb" alt=""
However, I am trying to get something like this:
data:image/s3,"s3://crabby-images/cae2d/cae2d1d12021a17cdd72a4ab5f9dabf5b000e9bf" alt=""
Please, how do I achieve this?
2 个评论
the cyclist
2018-8-24
Can you upload either the Excel file or the resulting data variable in a MAT file (using that little paperclip icon)?
回答(1 个)
Image Analyst
2018-8-24
Try something like the attached demo that fits two Gaussians to data. Adapt as needed (like replace blue dots on plot with white bars or whatever).
data:image/s3,"s3://crabby-images/c2041/c2041c64363e510f22be06168aae2f12f5268be9" alt=""
另请参阅
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!