Improve speed of NORMRND for a family of distribut

2019-01-20 16:23发布

So, I am looking for a way to speed up my code. I have a large vector of normal distributions (i.e. a vector of means and standard deviations) that I need to generate random numbers from. A generic example of my code looks like this:

tic

N=1e6;
mu = rand(N,1);
sigma = rand(N,1);

temp = zeros(length(mu),1);

for i = 1:length(mu)
     temp(i) = normrnd(mu(i),sigma(i));
end

toc

This code in its current form has an elapsed time of:

Elapsed time is 12.281509 seconds.

I normally try to vectorize most of my computationally intensive commands, but right now I am stumped as to how I can make this run faster. I will have to perform this operation multiple times every time that the code is run, so the faster I can make it the better.

Do any of you MATLAB geniuses out there have any thoughts of how to speed this up?

Thanks! John

1条回答
劳资没心,怎么记你
2楼-- · 2019-01-20 17:14

Hacked into normrnd.m to get this customized code that must replicate the functionality depicited in the problem -

N=1e6;
mu = rand(N,1);
sigma = rand(N,1);
temp = randn(size(sigma)).*sigma + mu;

On my system, the runtime was reduced from 18.946094 seconds to 0.037229 seconds.

Hope this works out for you!

查看更多
登录 后发表回答