Rejection sampling on uniform distribution?

3 visualizzazioni (ultimi 30 giorni)
matlabkid602
matlabkid602 il 18 Feb 2018
Commentato: Image Analyst il 18 Feb 2018
How can I use matlab to perform rejection sampling on a uniform distribution using rand, to pick 20% of samples in the range 0 to 0.2 and the other 80% between 0.2 and 1?

Risposte (1)

Image Analyst
Image Analyst il 18 Feb 2018
Try this:
numPoints = 1000 % Total number of points to save.
numLow = 1;
numHigh = 1;
% Start collecting elements using acceptance if in range,
% and rejection if out of range.
for k = 1 : 10000000 % enough to make sure we will collect at least numPoints elements.
r = rand();
% Save the number if it's in the low range.
if r <= 0.2 && numLow <= 0.20 * numPoints
% In range. Store/save the number.
lowKeepers(numLow) = r;
numLow = numLow + 1;
else
% Not in range so reject/ignore it.
end
% Save the number if it's in the high range.
if r >= 0.8 && numHigh <= 0.80 * numPoints
% In range. Store/save the number.
highKeepers(numHigh) = r;
numHigh = numHigh + 1;
else
% Not in range so reject/ignore it.
end
end
  2 Commenti
matlabkid602
matlabkid602 il 18 Feb 2018
Thanks for your answer! It works for the first bit, but I need 80% of the numbers to lie in the range .2-1. Just now it produces only numbers 0 to .2 and .8 to 1. See image. How can I change this?
Image Analyst
Image Analyst il 18 Feb 2018
Sorry, make this change:
if r >= 0.2 && numHigh <= 0.80 * numPoints

Accedi per commentare.

Prodotti

Community Treasure Hunt

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

Start Hunting!

Translated by