Форум программистов, компьютерный форум CyberForum.ru

как с точностью до микросекунд замерить время - C++

Восстановить пароль Регистрация
 
 
Рейтинг: Рейтинг темы: голосов - 93, средняя оценка - 4.61
Svinina
 Аватар для Svinina
5 / 5 / 0
Регистрация: 28.11.2010
Сообщений: 81
16.11.2011, 12:33     как с точностью до микросекунд замерить время #1
Товарищи, подскажите, как с точностью до микросекунд замерить время выполнения некоторой функции?
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
16.11.2011, 12:33     как с точностью до микросекунд замерить время
Посмотрите здесь:

Замерить время? C++
Как замерить длительность выполнения кода? C++
C++ Как замерить время работы функции?
C++ таймер микросекунд
C++ Как сделать, чтобы функция считала с точностью до
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Thinker
Эксперт C++
 Аватар для Thinker
4215 / 2189 / 150
Регистрация: 26.08.2011
Сообщений: 3,802
Записей в блоге: 5
16.11.2011, 12:38     как с точностью до микросекунд замерить время #2
функция clock():

long t;
t = clock();
//алгоритм
t = clock() - t; // время выполнения
solar_wind
 Аватар для solar_wind
740 / 731 / 39
Регистрация: 06.07.2009
Сообщений: 2,937
Завершенные тесты: 1
16.11.2011, 12:38     как с точностью до микросекунд замерить время #3
Svinina, Смотря для чего тебе это нужно.
Если измерять вычисления то есть только один наверное способ получить такую точность....это считать тики процессора и никому не передавать управление...но загрузка проца будет хорошая.....
Если обычным способом, то там как минимум погрешность будет миллисекунд 30, и то на одной и той же программе можешь получить разные значения....
Deviaphan
Делаю внезапно и красиво
Эксперт C++
 Аватар для Deviaphan
1283 / 1217 / 50
Регистрация: 22.03.2011
Сообщений: 3,744
16.11.2011, 12:54     как с точностью до микросекунд замерить время #4
Стандартными средствами - никак.
В миллисекундах - без проблем.
В микро - проблематично.
Svinina
 Аватар для Svinina
5 / 5 / 0
Регистрация: 28.11.2010
Сообщений: 81
16.11.2011, 12:58  [ТС]     как с точностью до микросекунд замерить время #5
Deviaphan, хорошо, в миллисекундах как?
Bers
Заблокирован
16.11.2011, 12:59     как с точностью до микросекунд замерить время #6
1. Грузим комп на 100%
2. Засекаем количество тактов
3. Ждем 3 секунды (чем дольше, тем лучше)
4. Смотрим сколько тактов прошло. Делим на 3 сек. Получаем кол-во тактов за 1 сек
5. Засекаем такты
6. Гоним цикл с функцией (чем больше, тем лучше)
7. Смотрим сколько тактов прошло. Делим на количество итераций цикла.
8. Сопоставляем: сколько тактов в секунде, и сколько тактов в 1 функции.
9. Профит!

/ps все расчеты будут неточными.
Deviaphan
Делаю внезапно и красиво
Эксперт C++
 Аватар для Deviaphan
1283 / 1217 / 50
Регистрация: 22.03.2011
Сообщений: 3,744
16.11.2011, 12:59     как с точностью до микросекунд замерить время #7
GetTickCount() до
и GetTickCount() после.
Разница между вызовами - время в тысячных секунды. Погрешность плюс-минус немного миллисекунд.
Svinina
 Аватар для Svinina
5 / 5 / 0
Регистрация: 28.11.2010
Сообщений: 81
16.11.2011, 13:00  [ТС]     как с точностью до микросекунд замерить время #8
Bers, я так конечно же делать не буду, но все равно спасибо.
Deviaphan
Делаю внезапно и красиво
Эксперт C++
 Аватар для Deviaphan
1283 / 1217 / 50
Регистрация: 22.03.2011
Сообщений: 3,744
16.11.2011, 13:00     как с точностью до микросекунд замерить время #9
Цитата Сообщение от Bers Посмотреть сообщение
9. Профит!
Увы, но нет. Процессоры имеют приятное свойство самопроизвольно разгоняться и наоборот. Считать такты процессора можно, а вот сказать за какое время они выполнились...
Svinina
 Аватар для Svinina
5 / 5 / 0
Регистрация: 28.11.2010
Сообщений: 81
16.11.2011, 13:02  [ТС]     как с точностью до микросекунд замерить время #10
Deviaphan, а где она объявлена?
solar_wind
 Аватар для solar_wind
740 / 731 / 39
Регистрация: 06.07.2009
Сообщений: 2,937
Завершенные тесты: 1
16.11.2011, 13:03     как с точностью до микросекунд замерить время #11
Deviaphan, Кстати мне приходилось подобный таймер организовывать, работает довольно стабильно, только цифру для пересчета я не вычислял, а брал значение с параметров проца )
Deviaphan
Делаю внезапно и красиво
Эксперт C++
 Аватар для Deviaphan
1283 / 1217 / 50
Регистрация: 22.03.2011
Сообщений: 3,744
16.11.2011, 13:05     как с точностью до микросекунд замерить время #12
windows.h
Bers
Заблокирован
16.11.2011, 13:06     как с точностью до микросекунд замерить время #13
Цитата Сообщение от Deviaphan Посмотреть сообщение
Увы, но нет. Процессоры имеют приятное свойство самопроизвольно разгоняться и наоборот. Считать такты процессора можно, а вот сказать за какое время они выполнились...
нивелируется множественностью тестов.
Svinina
 Аватар для Svinina
5 / 5 / 0
Регистрация: 28.11.2010
Сообщений: 81
16.11.2011, 13:06  [ТС]     как с точностью до микросекунд замерить время #14
Наверное следовало добавить: пишу под убунтой, меряю быстродействие pthread'ов.
Виндовые варианты немного не катят.=)
Deviaphan
16.11.2011, 13:07
  #15

Не по теме:

Цитата Сообщение от vitaly1981 Посмотреть сообщение
а брал значение с параметров проца
У меня частота проца колеблется в диапазоне примерно гигагерца. Это между работой в полусонном состоянии и под максимальной нагрузкой. Так что количеству герц я не доверяю.)))

taras atavin
Ушёл с форума.
 Аватар для taras atavin
3569 / 1752 / 91
Регистрация: 24.11.2009
Сообщений: 27,619
16.11.2011, 13:09     как с точностью до микросекунд замерить время #16
Цитата Сообщение от Deviaphan Посмотреть сообщение
Стандартными средствами - никак.
В миллисекундах - без проблем.
В микро - проблематично.
Можно и в пико, но это не означает соответствующей точности: единицы измерения - это одно, погрешность - совсем другое. Берём часы, засекаем время и запускаем функцию, потом часы умножаем на 3 600 000 000 000 000, минуты - на 60 000 000 000 000, секунды - на 1 000 000 000 000, всё складываем и радуемся времени в пикосекундах, но с погрешность плюс/минус несколько секунд. А можно провести измерения каким нибудь сверхточным прибором с точностью до пикосекунды, но результат выразить в годах.
Deviaphan
Делаю внезапно и красиво
Эксперт C++
 Аватар для Deviaphan
1283 / 1217 / 50
Регистрация: 22.03.2011
Сообщений: 3,744
16.11.2011, 13:09     как с точностью до микросекунд замерить время #17
Вот POSIX http://www.boost.org/doc/libs/1_48_0...osix_time.html
Bers
Заблокирован
16.11.2011, 13:09     как с точностью до микросекунд замерить время #18
Цитата Сообщение от Deviaphan Посмотреть сообщение
У меня частота проца колеблется в диапазоне примерно гигагерца. Это между работой в полусонном состоянии и под максимальной нагрузкой. Так что количеству герц я не доверяю.)))
Но если его загрузить на 100% он уже не будит в полусонном состоянии.
Кроме того, это позволит снизить погрешность на "многозадачность"
Svinina
 Аватар для Svinina
5 / 5 / 0
Регистрация: 28.11.2010
Сообщений: 81
16.11.2011, 13:10  [ТС]     как с точностью до микросекунд замерить время #19
taras atavin, да-да, я изучал метрологию.
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
16.11.2011, 13:11     как с точностью до микросекунд замерить время
Еще ссылки по теме:

C++ Замерить время вычислений
Найти arctg(x) как бесконечную сумму с заданной точностью C++
Текущее время с точностью до миллисекунд C++

Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
Deviaphan
Делаю внезапно и красиво
Эксперт C++
 Аватар для Deviaphan
1283 / 1217 / 50
Регистрация: 22.03.2011
Сообщений: 3,744
16.11.2011, 13:11     как с точностью до микросекунд замерить время #20
Цитата Сообщение от taras atavin Посмотреть сообщение
радуемся времени в пикосекундах, но с погрешность плюс/минус несколько секунд
Перечитай название темы. Точность и погрешность - слова синонимы.
Yandex
Объявления
16.11.2011, 13:11     как с точностью до микросекунд замерить время
Ответ Создать тему
Опции темы

Текущее время: 14:55. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru