Вимірювання часу виконання операцій та функцій у скетчах Arduino

Вступ

Під час розробки проєктів на Arduino важливо знати, скільки часу займає виконання певних операцій або функцій. Це допомагає оптимізувати код, усунути затримки та підвищити швидкодію програми. Для цього в Arduino можна використовувати функції millis() та micros(), які повертають час із моменту запуску плати у мілісекундах або мікросекундах відповідно.

Основні функції для вимірювання часу

  • millis() — повертає кількість мілісекунд, що минули з моменту запуску програми.
  • micros() — повертає кількість мікросекунд, що минули з моменту запуску програми.

Використання micros() корисне, коли потрібно виміряти дуже короткі інтервали, наприклад, у високошвидкісних алгоритмах.

Приклад 1 — Вимірювання часу виконання циклу


unsigned long startTime;
unsigned long endTime;

void setup() {
  Serial.begin(9600);
}

void loop() {
  startTime = millis(); // Час початку

  for (int i = 0; i < 1000; i++) {
    int x = i * i;
  }

  endTime = millis(); // Час завершення

  Serial.print("Час виконання циклу: ");
  Serial.print(endTime - startTime);
  Serial.println(" мс");

  delay(1000);
}
  

Приклад 2 — Вимірювання часу виконання функції


unsigned long startMicros;
unsigned long endMicros;

int heavyCalculation(int n) {
  int sum = 0;
  for (int i = 0; i < n; i++) {
    sum += i;
  }
  return sum;
}

void setup() {
  Serial.begin(9600);
}

void loop() {
  startMicros = micros(); // Початок у мікросекундах
  int result = heavyCalculation(5000);
  endMicros = micros(); // Кінець

  Serial.print("Результат: ");
  Serial.print(result);
  Serial.print(", час виконання: ");
  Serial.print(endMicros - startMicros);
  Serial.println(" мкс");

  delay(1000);
}
  

Приклад 3 — Порівняння часу роботи двох алгоритмів


unsigned long t1, t2;

void setup() {
  Serial.begin(9600);
}

void loop() {
  // Алгоритм 1
  t1 = micros();
  for (int i = 0; i < 1000; i++) {
    int x = i * 2;
  }
  t2 = micros();
  Serial.print("Алгоритм 1: ");
  Serial.print(t2 - t1);
  Serial.println(" мкс");

  // Алгоритм 2
  t1 = micros();
  for (int i = 0; i < 1000; i++) {
    int x = i << 1; // Швидше завдяки побітовому зсуву
  }
  t2 = micros();
  Serial.print("Алгоритм 2: ");
  Serial.print(t2 - t1);
  Serial.println(" мкс");

  delay(2000);
}
  

Приклад 4 — Вимірювання часу реакції на подію


int buttonPin = 2;
unsigned long pressTime;

void setup() {
  Serial.begin(9600);
  pinMode(buttonPin, INPUT_PULLUP);
}

void loop() {
  if (digitalRead(buttonPin) == LOW) {
    pressTime = millis();
    while (digitalRead(buttonPin) == LOW); // Чекаємо відпускання
    Serial.print("Час реакції: ");
    Serial.print(millis() - pressTime);
    Serial.println(" мс");
  }
}
  

Висновок

Вимірювання часу виконання коду — важливий інструмент для налагодження та оптимізації проєктів Arduino. Використовуючи millis() та micros(), можна знаходити «вузькі місця» у програмі та покращувати її швидкодію.

<< Проекти << Усі товари >> Статті, уроки >>

Написати відгук

Примітка: HTML размітка не підтримується! Використовуйте звичайтий текст.
    Погано           Добре
Світлодіодна стрічка адресна WS2812B 1м 30led

Світлодіодна стрічка адресна WS2812B 1м 30led

Трьохкольорова світлодіодна стрічка на основі адресних світлодіодів WS2812B 30 світлодіодів ..

125.63грн.

Трансформатор струму 0-50А

Трансформатор струму 0-50А

Трансформатор струму призначений для вимірювання сили змінного струму, що тече через дріт. Для підкл..

77.82грн.

Цикли 6 — Переривання циклів

Цикли 6 — Переривання циклів

Цикли 6 — Переривання циклів Вступ Під час роботи з циклами в Arduino бувають ситуації, ..

Модуль P-channel MOSFET 50A з оптоізоляцією (IRF4905, 30В, 3–5В керування)

Модуль P-channel MOSFET 50A з оптоізоляцією (IRF4905, 30В, 3–5В керування)

Модуль P-channel MOSFET на базі транзистора IRF4905 призначений для комутації потужних навантажень п..

177.66грн.

Розумний дім #6: Розумний полив на ESP32

Розумний дім #6: Розумний полив на ESP32

Розумний дім #6: Розумний полив на ESP32 Автоматичний полив на ESP32 — практичний проєкт, я..