Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770
Форумы портала PHP.SU :: Версия для печати :: Сравнение скорости работы лагоритмов
Форумы портала PHP.SU » PHP » Пользовательские функции » Сравнение скорости работы лагоритмов

Страниц (1): [1]
 

1. valenok - 17 Февраля, 2009 - 00:54:29 - перейти к сообщению
Функцию которую я использую для сравнения скорости работы двух алгоритмов, когда не знаю что
было бы дешевле использовать:

PHP:
скопировать код в буфер обмена
  1. <?PHP
  2.  
  3. header("Content-Type: text/html; charset=utf-8");
  4.  
  5.  
  6. if(!isset($_SESSION['time'])) $_SESSION['time'] = 0;
  7. if(!isset($_SESSION['time2'])) $_SESSION['time2'] = 0;
  8. if(!isset($_SESSION['count'])) $_SESSION['count'] = 0;
  9.  
  10.  
  11. function getmicrotime()
  12. {
  13.    list($usec, $sec) = explode(" ", microtime());
  14.    return ((float)$usec + (float)$sec);
  15. }
  16.  
  17.  
  18. $time_start = getmicrotime();
  19. // вариант 1
  20. $time_end = getmicrotime();
  21.  
  22.  
  23. $time = $time_end - $time_start;
  24. $time = number_format($time,6);
  25.  
  26.  
  27.  
  28.  
  29. $time_start2 = getmicrotime();
  30. // Вариант 2
  31. $time_end2 = getmicrotime();
  32.  
  33.  
  34. $time2 = $time_end2 - $time_start2;
  35. $time2 = number_format($time2,6);
  36.  
  37.  
  38.  
  39. $_SESSION['time2'] += $time2;
  40. $_SESSION['time'] += $time;
  41. $_SESSION['count']++;
  42.  
  43.  
  44.  
  45. echo "For ".$_SESSION['count']." itterations of variant1 took ",$_SESSION['time']," seconds with : ".($_SESSION['time'] / $_SESSION['count'])." average time per itteration <br>";
  46. echo "For ".$_SESSION['count']." itterations of variant2 took ",$_SESSION['time2']," seconds with : ".($_SESSION['time2'] / $_SESSION['count'])." average time per itteration <br>";
  47.  
  48. die(0);
  49. ?>
2. EuGen - 17 Февраля, 2009 - 11:25:17 - перейти к сообщению
benchmark?
3. valenok - 17 Февраля, 2009 - 14:28:57 - перейти к сообщению
Benchmark скорее для сравнения характеристик компьютера, а это для алгоритмов на одном компьютере.
Хотя можно назвать и так.

 

Powered by ExBB FM 1.0 RC1