Как измерить время выполнения функции из оболочки erlang? - PullRequest
11 голосов
/ 09 января 2010

Существует ли простой способ измерить время выполнения функции, если я запускаю эту функцию из оболочки erlang?

Ответы [ 3 ]

18 голосов
/ 09 января 2010

См. Статью Время выполнения функции измерения .

Все основано на таймере : tc / 3 для измерения.

3 голосов
/ 09 января 2010

Если вы хотите измерить анонимную функцию:

1> TC = fun(F) -> B = now(), V = F(), A = now(), {timer:now_diff(A,B), V} end.

2> F = fun() -> lists:seq(1,1000) end.
3> TC(F).
{47000,
 [1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,
  23,24,25,26,27|...]}

среднее из N пробегов:

4> TCN2 = fun(T,F,0) -> ok; (T,F,N) -> F(), T(T,F,N-1) end.
5> TCN = fun(F,N) -> B=now(), TCN2(TCN2,F,N), A=now(), timer:now_diff(A,B)/N end.

6> TCN(F, 1000).
63.0
0 голосов
/ 06 января 2015

Я учусь Erlang, и это одно из упражнений в книге, вот как я это пытался

lib_misc.erl

time_taken_to_execute(F) -> Start = os:timestamp(),
  F(),
  io:format("total time taken ~f seconds~n", [timer:now_diff(os:timestamp(), Start) / 1000]).

и command-line, я делаю

1> lib_misc:time_taken_to_execute(fun() -> 1 end).
total time taken 0.003000 seconds
ok
2> lib_misc:time_taken_to_execute(fun() -> [Num || Num <- lists:seq(1, 100)] end).
total time taken 0.085000 seconds
ok
3> lib_misc:time_taken_to_execute(fun() -> [Num || Num <- lists:seq(1, 10000000)] end).
total time taken 9354.205000 seconds
ok
4> 

Это то, что вы искали?

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...