How to generate samples from a modified exponential density?

12 vues (au cours des 30 derniers jours)
Cuong
Cuong le 9 Juin 2014
Commenté : Star Strider le 9 Juin 2014
Hi everyone, The standard form of an exponential density is f(x|lambda)= lambda*exp(-x/lambda) if x>=0 and f(x|lambda)=0 if x<0.
I want to generate samples from the following density f(x|lambda, b)= lambda*exp(-(x-b)/lambda) if x>b and f(x|lambda,b)=0 if x<=b. Where b is a user-specified parameter.
Can anyone here suggest me how to do this ?
Best regards,

Réponse acceptée

Star Strider
Star Strider le 9 Juin 2014
This works:
lambda = 0.1;
m = 1;
n = 100;
expshft = @(b,lambda,x) (x>=b) .* lambda.*exp(-max(0, (x-b))./(b+lambda));
x = 25*rand(m,n);
R2 = expshft(10,lambda,x);
figure(1)
plot(x, R2,'*b')
grid
The actual function is ‘expshift’. The rest is demonstration code to show how it works.
  2 commentaires
Cuong
Cuong le 9 Juin 2014
Thank you so much,
Your answer is very useful.
Best,
Star Strider
Star Strider le 9 Juin 2014
My pleasure!
That was an interesting problem!

Connectez-vous pour commenter.

Plus de réponses (1)

Shashank Prasanna
Shashank Prasanna le 9 Juin 2014
Modifié(e) : Shashank Prasanna le 9 Juin 2014
You can generate uniform random numbers using the rand function and apply it to your modified density function.

Catégories

En savoir plus sur Random Number Generation 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