Plot 2D-histogram for X and Y
123 ビュー (過去 30 日間)
古いコメントを表示
Dear all,
I have two types of data sets (X and Y) with equal size, which I would like to plot 2D-histogram of them, in order to compare X by Y.
So the larger the scatter implies the greater
disagreement.
I used this script below:
data = [X,Y];
hist3(data,'CdataMode','auto')
xlabel('observed')
ylabel('modeled')
colorbar
view(2)
And here is my achievement:
data:image/s3,"s3://crabby-images/ffee4/ffee468a27de21e76d3d7d42a493c360e4d92d72" alt=""
Unfortunately, as you can see this plot does not represent my goal, for instance, please look at this figure below (I want to achieve a plot like this below):
data:image/s3,"s3://crabby-images/73b84/73b84ebc2626904f02011a26d7b7ecb305b6a484" alt=""
So any suggestion is really helpful.
Thank you all
3 件のコメント
Roger J
2020 年 7 月 20 日
Try:
>> hist(X)
>> hist(Y)
I did, and it plotted each vector, and most(almost all) of your data is less than 50 for both X and Y. Seems like the histogram is correct for that data.
採用された回答
Star Strider
2020 年 7 月 20 日
Try this:
D1 = load('X.mat');
D2 = load('Y.mat');
X = D1.X;
Y = D2.Y;
data = [X,Y];
hh3 = hist3(data, 'Nbins',[1 1]*60);
figure
image(flipud(hh3))
ax = gca;
xt = ax.XTick;
yt = ax.YTick;
ax.XTickLabel = xt*10;
set(ax, 'YTick',[0 yt], 'YTickLabel', [flip([0 yt])]*10)
producing:
data:image/s3,"s3://crabby-images/b1992/b19927c8875b937be67d360b294e293245f6cdef" alt=""
Experiment to get different results.
.
3 件のコメント
Alessandro Maria Laspina
2022 年 7 月 20 日
編集済み: Alessandro Maria Laspina
2022 年 7 月 20 日
How would I do this but with log scales on the x and y axis (assuming no negative or 0 values)? If I use set(gca,'Yscale','log') it leaves a blank space
その他の回答 (3 件)
Cris LaPierre
2020 年 7 月 20 日
編集済み: Cris LaPierre
2020 年 7 月 20 日
A couple issues to be aware of.
- You are using a different colormap. It looks like the goal image is using Jet.
- Your X and Y values are dominated by the counts in the first bin (histograms below). Consider using caxis to keep the colorbar focused on the desired range.
data:image/s3,"s3://crabby-images/429b6/429b64ecbcf3ca2d8b15c3ab5f7385eedaaa8581" alt=""
data:image/s3,"s3://crabby-images/2f900/2f900b4be89f3e7efe8360a47957caa7a0f60ae1" alt=""
Try adding (and adjusting to meet your needs) the following code.
colormap("jet")
caxis([0,80])
data:image/s3,"s3://crabby-images/3c3fd/3c3fd219c246aec343b8d6c1a8acc3a9226c1881" alt=""
Image Analyst
2020 年 7 月 20 日
Your data does not peak in the 100 to 250 range. It peaks around 0:
load('x.mat');
load('y.mat');
data = [X,Y];
h = histogram2(X, Y,100)
xlabel('observed')
ylabel('modeled')
% Set colormap, but it won't have any effect.
colormap(jet(256));
colorbar;
% view(2)
% Zoom in on the 0-200 range.
xlim([0,200]);
ylim([0,200]);
% Label the plot.
title('Counts', 'FontSize', 20);
xlabel('X', 'FontSize', 20);
ylabel('Y', 'FontSize', 20);
coefficients = polyfit(X, Y, 1);
xFit = xlim;
yFit = polyval(coefficients, xFit);
hold on;
plot3(xFit, yFit, [0,0], 'r-', 'LineWidth', 3);
c = corrcoef(X, Y)
data:image/s3,"s3://crabby-images/27d80/27d809f9fd45ae9c09979bdf37c1de752fa2d69a" alt=""
This is essentially just what you saw, just that I used narrower bins and used a more modern function: histogram2(). Why do you think it's wrong and that you should have more counts in the 100-250 range?
Steven Lord
2020 年 7 月 20 日
In addition to histogram2 which Image Analyst suggested, take a look at the heatmap function. I think showing a heatmap of the data binned by histogram2 or histcounts2 will be pretty close to the picture you want.
参考
カテゴリ
Help Center および File Exchange で Data Distribution Plots についてさらに検索
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!