Effacer les filtres
Effacer les filtres

Bar Graph from a table : Error Xdata must be unique

67 vues (au cours des 30 derniers jours)
Frederick Awuah-Gyasi
Frederick Awuah-Gyasi le 9 Fév 2022
A B C
0 '0' 2
0 '1' 11
1 '0' 32
1 '1' 33
2 '0' 38
2 '1' 31
3 '0' 47
3 '1' 39
Want to have C on the Y axis, X axis : 0,1,2,3 , bars colored for B : 0,1.
  4 commentaires
Frederick Awuah-Gyasi
Frederick Awuah-Gyasi le 9 Fév 2022
Modifié(e) : Frederick Awuah-Gyasi le 9 Fév 2022
Thanks for your help @Cris LaPierre and @Adam Danz
Frederick Awuah-Gyasi
Frederick Awuah-Gyasi le 9 Fév 2022
A little background :This dataset is a subset of a bigger table got with this code below:
T = groupsummary(BigT,{'A','B'}) so C is the GroupCount

Connectez-vous pour commenter.

Réponse acceptée

Cris LaPierre
Cris LaPierre le 9 Fév 2022
For bar, groups are created organizing the data into a matrix. The rows correspond to x, and the columns correspond to each data series. See this example.
That means you will need to do some reorganizing of the data to get it formatted correctly to create a grouped bar chart.
% Set up the problem by recreating the table.
A = [ 0 0 1 1 2 2 3 3]';
B = ['0' '1' '0' '1' '0' '1' '0' '1']';
C = [2 11 32 33 38 31 47 39]';
T = table(A,B,C);
% use sortrows to organize data in an expected format
T = sortrows(T,["B","A"]);
% extract x values, group names
x = unique(T.A);
b = unique(T.B);
% Reshape the data based on the number of unique values in A
CC = reshape(T.C,length(x),[])
CC = 4×2
2 11 32 33 38 31 47 39
% plot
bar(x,CC)
legend(b)
  3 commentaires
Adam Danz
Adam Danz le 9 Fév 2022
@Frederick Awuah-Gyasi, I'm looking forward to your contributions!
Frederick Awuah-Gyasi
Frederick Awuah-Gyasi le 9 Fév 2022
@Adam Danz challenge accepted.

Connectez-vous pour commenter.

Plus de réponses (0)

Catégories

En savoir plus sur 2-D and 3-D Plots dans Help Center et File Exchange

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by