How to draw a contour plot over a bi-variate Gaussian in such a way that the lines represent the probability of a sample being within that line?
9 次查看(过去 30 天)
显示 更早的评论
I have fitted a Gaussian mixture distribution model to my data and made a contour plot as seen in the figure.
The problem is that I don't know what the contour lines represent. I want the distance from the mean to the lines to have a measure of the variance in that direction. In other words I want the lines to say for example: "there is 68% chance of being within the first line, 95% chance of being within the second line..." Can this be done?
0 个评论
回答(2 个)
Kian Azami
2017-10-12
编辑:Kian Azami
2017-10-12
By defining the annotations in your code and defining the position of the annotation as the position of your contour, you can show the percentage of each contour on your plot.
m1 = figure
p1 = plot(X_Data,Y_Data);
a1 = annotation(m1,'textbox',...
[X_origin Y_origin Width Height],...
'String',{'The_Precentage_You_Need'});
You can generate the annotation for the first time and then by the command "get(a1)" you can find its position and dimension. Then by comparing to that you can again define a better way to adjust the position of your annotation.
If you have the data relevant to your contour you can make all of the passage automatically by the code, however, it needs a little bit more effort.
2 个评论
Kian Azami
2017-10-12
编辑:Kian Azami
2017-10-12
These division are based on the standard deviation of your data. So the first standard deviation from the mean is about 68 percent, the second standard deviation is about 95 percent, and so on... you can calculate them based on the standard deviation. I put the photo which I searched and it will give you a better idea:
So as you see from -1 SD to 1 SD covers 68.2 % of your data and from -2 SD to 2 SD covers 95.4 % of your data, and from -3 SD to 3 SD covers 99.8 % of your data and so on ...
I think you need to find the integral of the portion of diagram between the standard deviation and divide it to the integral over the whole diagram.
Bjørnar Dalsnes
2017-10-12
1 个评论
Kian Azami
2017-10-12
For this I will do like this. I will draw a horizontal line from the center which is the mean of your data to the end. For example:
Y_mean = mean(y);
Y_Data = Y_mean*ones(1,X_Data);
Then you find the intersection of the Gaussian Contour and the line you created (X_Data,Y_Data). There is a very easy way to do that which I don't remember right now.
Then you can find the distance of each contour respect to the center.
The ratio of the distances are equivalent to the square root of the ratio of the areas so: (distanc_1/distance_total)^2 = area1/area_total = The_Percentage.
If it is equal to 68 percent you understand that you are on the 1st standard deviation. If not you will check the next contour distance to the center and do the same procedure.
Can be an idea to try!
另请参阅
类别
在 Help Center 和 File Exchange 中查找有关 Contour Plots 的更多信息
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!