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

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: Сравнение скорости работы лагоритмов

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


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

> Без описания
valenok Модератор
Отправлено: 17 Февраля, 2009 - 00:54:29
Post Id



Здесь могла бы быть ваша реклама


Покинул форум
Сообщений всего: 4574
Дата рег-ции: Июль 2006  
Откуда: Israel


Помог: 3 раз(а)




Функцию которую я использую для сравнения скорости работы двух алгоритмов, когда не знаю что
было бы дешевле использовать:

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. ?>

(Отредактировано автором: 17 Февраля, 2009 - 00:55:37)



-----
Truly yours, Sasha.
 
My status
 Top
EuGen Администратор
Отправлено: 17 Февраля, 2009 - 11:25:17
Post Id


Профессионал


Покинул форум
Сообщений всего: 9095
Дата рег-ции: Июнь 2007  
Откуда: Berlin


Помог: 707 раз(а)




benchmark?


-----
Есть в мире две бесконечные вещи - это Вселенная и человеческая глупость. Но насчет первой .. я не уверен.
 
 Top
valenok Модератор
Отправлено: 17 Февраля, 2009 - 14:28:57
Post Id



Здесь могла бы быть ваша реклама


Покинул форум
Сообщений всего: 4574
Дата рег-ции: Июль 2006  
Откуда: Israel


Помог: 3 раз(а)




Benchmark скорее для сравнения характеристик компьютера, а это для алгоритмов на одном компьютере.
Хотя можно назвать и так.


-----
Truly yours, Sasha.
 
My status
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« Пользовательские функции »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB