How to create a symmetric histogram

5 vues (au cours des 30 derniers jours)
Lukos
Lukos le 26 Fév 2019
Commenté : Lukos le 26 Fév 2019
Hello,
I have data vector A, which includes some angular values between 0 and 180 degrees.
I have the desire to get a symmetric histogram. Therefore I create an extra vector B, which is 180-vector A, so that the sum of vector of A and B is 180 degrees.
However, When I plot the Vector C which is C = [A;B]; it does not give me the desired resulted.
Any thoughts?

Réponse acceptée

Steven Lord
Steven Lord le 26 Fév 2019
Okay, now I see the problem you're experiencing, I think. Since this is a bit more technical I'm moving this from the comments of Sayyed Ahmad's Answer into its own Answer.
randn is most likely going to return numbers between say -3 and +3. Instead I'm going to generate some sample data that covers more of the region.
x = randi([0 180], 1000, 1);
data = [x; 180-x];
Now I'll choose some symmetric bins and make the histogram. You might expect this to make a symmetric histogram but it doesn't.
edges = 0:10:180;
h = histogram(data, edges);
So why isn't the histogram symmetric? Each bin except the last contains its left edge but not its right (the last bin contains both edges.) This means a value of 170 in data is part of the last bin in the histogram h (that's the left edge of that last bin.) However a value of 10 in data is not part of the first bin in h (it's the right edge of the first bin and the left edge of the second so it is in the second bin.) To handle this, you could either offset the bin edges so no data value falls exactly on an edge:
edges2 = [-0.5:10:89.5 90.5:10:180.5];
figure;
h2 = histogram(data, edges2);
Or, since my data contains only integer values, use the BinMethod that puts each integer in its own bin.
figure
h3 = histogram(data, 'BinMethod', 'integers');
  1 commentaire
Lukos
Lukos le 26 Fév 2019
Thanks! greatly appreciated.

Connectez-vous pour commenter.

Plus de réponses (1)

Sayyed Ahmad
Sayyed Ahmad le 26 Fév 2019
du you means this?
A=linspace(0,pi,181);
X=sin(A);
Y=-X
plot(A,X,'r-',A,Y,'b-')
  5 commentaires
Steven Lord
Steven Lord le 26 Fév 2019
x = randn(1, 100);
data = [x, -x];
h = histogram(data, -3:0.5:3);
That looks like a pretty symmetric histogram to me. Use this same technique for your data.
Lukos
Lukos le 26 Fév 2019
This is exactly what I do, However I introduce a shift, so I get:
x = randn(100,1);
x2 = 180 - x % PROVIDED THAT x(i)+x2(i)=180
data = [x;x2]
--> No symmetric histogram

Connectez-vous pour commenter.

Produits


Version

R2017a

Community Treasure Hunt

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

Start Hunting!

Translated by