I need to make a set of 2000 random numbers between 0 and 1, with a mean of 0.5, with most of the numbers being either high or low (bimodal distrubution with peaks at 0 and 1)

4 Ansichten (letzte 30 Tage)
Basically what the question says. It should look something like this
Though the left side doesn't need to have a higher peak or anything.
Flat distributions are easy - but how do I go about making a vector with 2000 numbers with this type of distribution?

Akzeptierte Antwort

Roger Stafford
Roger Stafford am 24 Feb. 2016
Bearbeitet: Roger Stafford am 24 Feb. 2016
t = 2*rand(1,2000)-1;
x = (sign(t).*sqrt(abs(t))+1)/2;
hist(x,20)
This should approximate your two linear distribution segments. If you use a much higher value than 2000, say 2000000, it will approximate it much more closely. This does not get the spike at the left end. I'll leave that refinement to you.
Added note: You can test the accuracy of the above by replacing the 'rand' call with 'linspace', since the latter will be exactly uniformly distributed.
t = 2*linspace(0,1,2000000)-1;
x = (sign(t).*sqrt(abs(t))+1)/2;
hist(x,20)
  2 Kommentare
meepimmaduck
meepimmaduck am 24 Feb. 2016
Both of the answers I got were perfect, and I'm a tad disappointed in myself for not being able to think of either of them! Must have been tired. I only chose this one as the accepted answer over the other because it's the one I ended up using. Thanks very much.
Amy Wong
Amy Wong am 13 Dez. 2017
If I have a set of data and I want to plot a histogram with multiples of 0.1 which is the x-axis in the image. So, if I use your answer, for the hist what do I change to?
x = (sign(COE).*sqrt(abs(COE))+1)/2;
hist(x,??)

Melden Sie sich an, um zu kommentieren.

Weitere Antworten (1)

jgg
jgg am 24 Feb. 2016
m = randi([0,1],2000,1);
r = abs(randn(2000,1));
r = r - min(r);
r = r./max(r);
num = m;
num(m==0) = 0 + r(m==0);
num(m==1) = 1 - r(m==1);
Something like this should do it, since you don`t really care how they are generated. Basically, generate your integers (0,1) then just add some noise. This is truncated Gaussian noise.

Community Treasure Hunt

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

Start Hunting!

Translated by