Finding the time difference between both my functions

These are my 2 functions, is there a way of putting them into a script and comparing their running times?
function nprimes(N)
n = 1;
nPrimes = 0;
while nPrimes < N
if isprime(n)
fprintf('%i\n',n)
nPrimes = nPrimes + 1;
end
n = n + 1;
end
end
function p = nprimes(N)
p = [];
if N == 1
p = 2;
elseif N == 2
p = [2 3];
else
pn1 = nprimes(N-1);
plast = pn1(end) + 1;
while ~isprime(plast)
plast = plast + 1;
end;
p = [nprimes(N-1), plast];
end;

 채택된 답변

Adam
Adam 2017년 2월 20일
편집: Adam 2017년 2월 20일
If you put them in a single file (obviously with different names) that starts with a function (name it whatever you want, but it has to be a function, not a script in this case) then e.g.
function compareTimes( )
N = 27;
t1 = timeit( @( ) nprimes1( N ) )
t2 = timeit( @( ) nprimes2( N ) )
end
function nprimes1( N )
...
end
function nprimes2( N )
...
end
You can just use nested functions if you prefer, though I wouldn't do this in this case if you are trying to test the function with an argument passed in rather than in a context where it shares its workspace with some other function that won't be there in a general context.

댓글 수: 5

Timeit is the preferred solution to do time tests, because it removes many of the reasons for inaccuracy that other tests will fail to. It is better than older tools, like tic and toc.
@John: While timeit has many advantages, using it with anonymous functions include the overhead for anonymous functions. As long as a function with some calculations is called like in this case, this does not matter. But when I try to measure if sin(0) is computed faster than sin(1) or if x*0.2 is faster than x* (1/5) this overhead might matter. Even then the faster version will be faster, but a statement like x% faster is flawed. Then a tic/toc might me better.
Well, I guess that may be a case for using nested functions instead, then the timeit instruction can just become:
t1 = timeit( @nprimes1 );
@Jan: tic and toc CAN work. The problem is most people who use tic and toc also fail to appreciate the other issues, like warmup time for a function to get it into cache, the need for multiple calls to average out tiny irregularities, etc.
As well, tic and toc also have issues with the parser and code optimization done by TMW. Code written at the command line may have different performance than code inside a function call. Of course, these things have changed with release.
Jan
Jan 2017년 2월 20일
편집: Jan 2017년 2월 20일
@John: I agree, that timeit has advantages compared to tic/toc. I only wanted to remember, that anonymous functions can cause a remarkable overhead, which can impede the timings. See e.g. https://www.mathworks.com/matlabcentral/fileexchange/45749-memory-efficient-anonymous-functions.

댓글을 달려면 로그인하십시오.

추가 답변 (0개)

카테고리

도움말 센터File Exchange에서 Performance and Memory에 대해 자세히 알아보기

질문:

2017년 2월 20일

편집:

Jan
2017년 2월 20일

Community Treasure Hunt

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

Start Hunting!

Translated by