transform bar chart with separate bars (for each value of y) to bar chart with overlapping bars
3 views (last 30 days)
Show older comments
Alberto Acri
on 20 Aug 2023
Commented: Alberto Acri
on 21 Aug 2023
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 Comments
Rik
on 21 Aug 2023
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
on 21 Aug 2023
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.)
Accepted Answer
the cyclist
on 20 Aug 2023
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 Comments
the cyclist
on 20 Aug 2023
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.
More Answers (0)
See Also
Categories
Find more on Discrete Data Plots in Help Center and File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!