transform bar chart with separate bars (for each value of y) to bar chart with overlapping bars
3 ビュー (過去 30 日間)
古いコメントを表示
Hi. I need to transform this figure:
load matrix.mat
matrix = matrix(5:7,:);
figure();
cm = [1,0,0; 0,0,1; 0,1,0; 1,0,0.52];
hbh = barh(matrix(:,1), matrix(:,[2 3 4 5]));
for k = 1:numel(hbh)
hbh(k).FaceColor = cm(k,:);
hbh(k).EdgeColor = [0,0,0];
end
into this one:
I tried the following way but I don't get the same result.
figure
hbh = barh(matrix(:,1), matrix(:,[2 3 4 5]),'stacked');
cm = [[1,0,0]; [0,0,1]; [0,1,0]; [1,0,0.52]];
for k = 1:numel(hbh)
hbh(k).FaceColor = cm(k,:);
hbh(k).EdgeColor = [0,0,0];
end
6 件のコメント
Rik
2023 年 8 月 21 日
The reason I included the max call was for robustness. If at one point a negative diff occurs, I would like to prevent unexpected behavior.
the cyclist
2023 年 8 月 21 日
I understand. But after the sort, a negative diff can't occur. (But if I am wrong about the sorting, then the max would be required, as you state.)
採用された回答
the cyclist
2023 年 8 月 20 日
load matrix
M = matrix(:,2:end);
[sortedM,sortingIndex] = sort(M,2);
cm = [[1,0,0]; [0,0,1]; [0,1,0]; [1,0,0.52]];
figure
hold on
for mi = 1:height(sortedM)
hbh = barh(matrix(mi,1), [sortedM(mi,1),diff(sortedM(mi,:),1,2)],'stacked');
for k = 1:width(sortedM)
hbh(k).FaceColor = cm(sortingIndex(mi,k),:);
end
end
2 件のコメント
the cyclist
2023 年 8 月 20 日
I stuck to answering what you asked for, but be aware that this method of plotting bars "in front of each other" can be somewhat deceptive, from an information point of view. For example, the green bar at 68 is nearly the same value as the blue bar, but the visual impact is tiny. (I think that's the reason @Dyuman Joshi thought you didn't want it at all.)
It would take more work, but you might want to consider using the method of overlaying bars that is described on this documentation page.
その他の回答 (0 件)
参考
カテゴリ
Help Center および File Exchange で Discrete Data Plots についてさらに検索
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!