How to generate samples from a modified exponential density?

9 visualizaciones (últimos 30 días)
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,

Respuesta aceptada

Star Strider
Star Strider el 9 de Jun. de 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 comentarios
Cuong
Cuong el 9 de Jun. de 2014
Thank you so much,
Your answer is very useful.
Best,
Star Strider
Star Strider el 9 de Jun. de 2014
My pleasure!
That was an interesting problem!

Iniciar sesión para comentar.

Más respuestas (1)

Shashank Prasanna
Shashank Prasanna el 9 de Jun. de 2014
Editada: Shashank Prasanna el 9 de Jun. de 2014
You can generate uniform random numbers using the rand function and apply it to your modified density function.

Categorías

Más información sobre Random Number Generation en Help Center y File Exchange.

Community Treasure Hunt

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

Start Hunting!

Translated by