Поиск:

Ответ в темуСоздание новой темы Создание опроса
> время выполнения алгоритма 
:(
    Опции темы
Fr3dd0
  Дата 2.6.2011, 02:17 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 12
Регистрация: 29.4.2011

Репутация: нет
Всего: нет



Как в С++ вымерить время выполнения алгоритма с точностью до миллисекунды?
PM MAIL   Вверх
RastaDja
Дата 2.6.2011, 08:19 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 337
Регистрация: 1.11.2010

Репутация: нет
Всего: 5



Алгоритм простой: записываешь системное время до вызова функции, потом после, находишь разницу,- это и будет время выполнения.
Код

SYSTEMTIME StartTime;
GetSystemTime(&StartTime);        // Вот это значение времени до вызова функции

yourFunction();                            // это функция которую проверяешь

SYSTEMTIME EndTime;
GetSystemTime(&EndTime);       // Вот это значение времени после вызова функции

WORD workTime = EndTime.wMilliseconds - StartTime.wMilliseconds            // вот измериное время


также можешь применять это внутри функции.


--------------------
The more closely you look at one thing, the less closely can you see something else.
PM MAIL   Вверх
Fr3dd0
Дата 2.6.2011, 10:43 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 12
Регистрация: 29.4.2011

Репутация: нет
Всего: нет



Все работает, все прекрасно, но нужно измерять в секундах, с точностью до миллисекунды (x.yy с), а не просто в миллисекундах (xyy мс)
PM MAIL   Вверх
RastaDja
Дата 2.6.2011, 13:22 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Опытный
**


Профиль
Группа: Участник
Сообщений: 337
Регистрация: 1.11.2010

Репутация: нет
Всего: 5



Цитата(Fr3dd0 @  2.6.2011,  11:43 Найти цитируемый пост)
Все работает, все прекрасно, но нужно измерять в секундах, с точностью до миллисекунды (x.yy с), а не просто в миллисекундах (xyy мс) 

Тогда есть два варианта:
    1. Погуглить SYSTEMTIME, он выдает время в любом формате.
    2. 1000 миллисекунд=1 секунда - думаю дальше понятно что делать.


--------------------
The more closely you look at one thing, the less closely can you see something else.
PM MAIL   Вверх
volatile
Дата 2.6.2011, 23:48 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Завсегдатай
Сообщений: 2107
Регистрация: 7.1.2011

Репутация: 4
Всего: 85



В винде есть очень точные функции для измерения временных интервалов, вплоть до микросекунд

QueryPerformanceCounter();
QueryPerformanceFrequency();

Я даже когда-то с этими функциями написал небольшой класс секундомера для измерения временных интервалов.
(потом переделал на __rdtsc он более быстрый, но измеряет не в секундах а в тиках процессора.)

если хотите поищу свой старый вариант.
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | Visual C++/MFC/WTL | Следующая тема »


 




[ Время генерации скрипта: 0.0646 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.