Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.80/25: Рейтинг темы: голосов - 25, средняя оценка - 4.80
0 / 0 / 0
Регистрация: 05.03.2017
Сообщений: 5

Определить в какой единице измерения времени считает clock()?

05.03.2017, 10:21. Показов 5309. Ответов 9

Студворк — интернет-сервис помощи студентам
Добрый день, очень прошу помощи

Есть код, вот часть, работающая со временем измерения... Подскажите пожалуйста в какой единице времени работает код? Миллисекунда? Микросекунды? Нано?

C++
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
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
#define STEP_COUNT 1000000
 
fix xFixTable[STEP_COUNT];
float xFloatTable[STEP_COUNT];
 
void singleTest(PFLOAT function, ostream &fout)
{
    long long time = clock();
    float tmp;
    for (int i = 0; i < STEP_COUNT; i++)
    {
        tmp = function(xFloatTable[i]);
    }
    time = clock() - time;
    fout << (float)time / (double)CLOCKS_PER_SEC << " ";
     
}
 
void singleTestFix(PFIX function, ostream &fout)
{
    fix epsilon = float_to_fixed(EPSILON);
    long long time = clock();
    fix tmp;
    for (int i = 0; i < STEP_COUNT; i++)
    {
        tmp = function(xFixTable[i]);
    }
    time = clock() - time;
    fout << (float)time / (double)CLOCKS_PER_SEC << " ";
}
 
void initArgTable()
{
    float delta = 1.0F / STEP_COUNT;
    float x = 0;
    for (int i = 0; i < STEP_COUNT; i++)
    {
        xFixTable[i] = float_to_fixed(x);
        xFloatTable[i] = x;
        x += delta;
    }
}
 
int main(int argc, char *argv[])
{
    initFactorialsTable();
    initFixTables();
    initArgTable();
 
    filebuf file;
    file.open("out.log", ios::out);
    ostream fout(&file);
 
    system("pause");
    for (int round = 0; round < 10; round++)
    {
        cout << "Round " << round << " started" << endl;
        singleTest(math, fout);
        singleTest(cyclNoGorner, fout);
        singleTest(cyclGorner, fout);
        singleTest(noCyclGorner, fout);
        singleTest(noCyclNoGorner, fout);
 
        singleTestFix(fixCyclGorner, fout);
        singleTestFix(fixNoCyclGorner, fout);
        
        singleTestFix(fixTable8Fucntion, fout);
        singleTestFix(fixTable9Fucntion, fout);
        singleTestFix(fixTable10Fucntion, fout);
        singleTestFix(fixTable11Fucntion, fout);
 
        fout << endl;
    }
    cout << "finished";
 
    file.close();
 
    return 0;
}
Если я не ошибаюсь, что вряд ли, то всё зависит от строчки ниже? Если да, то при каких значении будет наносекунды, микросекунды, миллисекунды? P.S. Значения больше 10 000 000 выводят ошибку.
C++
1
#define STEP_COUNT 1000000
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
05.03.2017, 10:21
Ответы с готовыми решениями:

Возможно ли сделать отсчет времени в лотусе Clock In/ Clock Out
Привет лотусистам! Такая вот задача. Когда человек приходит на работу он в лотусе где то ставит что он начал работу, каждые 4 часа он...

Какой способ измерения времени лучше использовать для получения данных с comport?
Нужно получать время между измерениями с comport что лучше, использовать? Точность нужна до 0,01с

Замер времени работы функции через clock()
Имеется некая функция, требуется замерить время её выполнения. Накидал такой код : #include &lt;iostream&gt; #include...

9
132 / 158 / 87
Регистрация: 06.04.2016
Сообщений: 992
05.03.2017, 10:52
Похоже, что эта функция возвращает количество миллисекунд прошедших с начала запуска программы.
1
0 / 0 / 0
Регистрация: 05.03.2017
Сообщений: 5
05.03.2017, 17:08  [ТС]
Тоже так полагал, но смущают удивительно малые скорости, выводящиеся в файл: 0.161 0.175 0.098 и т.д.
0
187 / 54 / 19
Регистрация: 23.12.2016
Сообщений: 167
05.03.2017, 17:21
напиши
C++
1
cout <<  CLOCKS_PER_SEC;
узнаешь, сколько клоков содержится в одной секунде. Это константа компилятора.
1
0 / 0 / 0
Регистрация: 05.03.2017
Сообщений: 5
05.03.2017, 17:30  [ТС]
Спасибо, altmax. Добавил, выводит 1000. Получается 1 000 000 / 1 000 = 1 000, то есть высчитывается в миллисекундах? Просто очень удивительно, что такие огромные скорости, что время высчитывания функций 0.150, 0,098 и подобные
0
132 / 158 / 87
Регистрация: 06.04.2016
Сообщений: 992
05.03.2017, 17:44
А fix - это что? int что-ли?

Добавлено через 2 минуты
Цитата Сообщение от Desvr Посмотреть сообщение
Спасибо, altmax. Добавил, выводит 1000. Получается 1 000 000 / 1 000 = 1 000, то есть высчитывается в миллисекундах? Просто очень удивительно, что такие огромные скорости, что время высчитывания функций 0.150, 0,098 и подобные
- ну это потому что на 1000 делите, не делите на 1000 и увидите время в миллисекундах. Даже 1 мс с точки зрения компьютера - не такое уж и маленькое время.
1
0 / 0 / 0
Регистрация: 05.03.2017
Сообщений: 5
05.03.2017, 17:59  [ТС]
Спасибо огромное, DemolitionMan

Добавлено через 14 минут
А не подскажешь, что прописать, чтобы выводило теперь не целым числом, а вещественным типом с 3-мя знаками после запятой?
0
0 / 0 / 0
Регистрация: 12.05.2018
Сообщений: 1
12.05.2018, 15:57
Desvr, не мог бы ты скинуть полный код программы? Если тебе не трудно. Просто я начинаю изучать алгоритмические методы для вещественных чисел, чисел с фиксированной точкой и твой код мне бы сильно помог. Спасибо)
0
Evg
Эксперт CАвтор FAQ
 Аватар для Evg
21281 / 8305 / 637
Регистрация: 30.03.2009
Сообщений: 22,660
Записей в блоге: 30
12.05.2018, 16:43

Не по теме:

Цитата Сообщение от Desvr Посмотреть сообщение
Подскажите пожалуйста в какой единице времени работает код?
Для ответа на подобные вопросы достаточно в поиск вбить "man clock" и вылезет куча описаний типа https://linux.die.net/man/3/clock



Добавлено через 27 секунд

Не по теме:

Упс... некротема...

0
143 / 27 / 4
Регистрация: 06.05.2019
Сообщений: 1,825
Записей в блоге: 4
31.05.2022, 17:01
Если в консоли программы включено выделение мышью и пользователь в этот момент времени задел консоль мышью, а перед этим была запущена функция Sleep(10000), далее если опять провести мышью по консоли будет ли значение указанное в Sleep анулировано или придётся ждать пока будет отсчитано 10сек несмотря на то что ПК работал стабильно а зависание произошло в самой программе.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
31.05.2022, 17:01
Помогаю со студенческими работами здесь

Измерение времени исполнения алгоритма через Clock() периодически равно 0
Здравствуйте! Я в отчаянии :( Была программа на C# и появилась необходимость перевести ее на С++. Но как переписать ...

Автоматически сбрасываются частоты Core clock Шейдеров и Memory clock, AMD M2N-MX se plus
Добрый Вечер! У меня такая проблема: Во время игры падает фпс(Кол-во Кадров в секунду),нажимаю alt+tab и по мониторингу вижу что...

Core clock и Memory Clock - что это за параметры?
Core clock и Memory Clock разъясните мне, пожалуйста, что это за параметры? По умолчанию Core Clock стоит 920MHz а Memory Clock 1050MHz....

Определить, в какой момент времени нормальное ускорение равно 2 м/с^2
В общем задача такая: Точка движется по окружности r= 4 м по закону s= A+Bt^2 , где S – пройденный путь, А=8 м, В=2 м/с^2 t- время....

Как определить, какой промежуток времени длилось нажатие?
Можно ли как-нибудь узнать какой промежуток времени длилось нажатие?


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

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru