ESPHome 2026.1.0-dev
Loading...
Searching...
No Matches
caqi_calculator.h
Go to the documentation of this file.
1#pragma once
2
3#include "esphome/core/log.h"
5
6namespace esphome::aqi {
7
9 public:
10 uint16_t get_aqi(uint16_t pm2_5_value, uint16_t pm10_0_value) override {
11 int pm2_5_index = calculate_index_(pm2_5_value, pm2_5_calculation_grid_);
12 int pm10_0_index = calculate_index_(pm10_0_value, pm10_0_calculation_grid_);
13
14 return (pm2_5_index < pm10_0_index) ? pm10_0_index : pm2_5_index;
15 }
16
17 protected:
18 static const int AMOUNT_OF_LEVELS = 5;
19
20 int index_grid_[AMOUNT_OF_LEVELS][2] = {{0, 25}, {26, 50}, {51, 75}, {76, 100}, {101, 400}};
21
22 int pm2_5_calculation_grid_[AMOUNT_OF_LEVELS][2] = {{0, 15}, {16, 30}, {31, 55}, {56, 110}, {111, 400}};
23
24 int pm10_0_calculation_grid_[AMOUNT_OF_LEVELS][2] = {{0, 25}, {26, 50}, {51, 90}, {91, 180}, {181, 400}};
25
26 int calculate_index_(uint16_t value, int array[AMOUNT_OF_LEVELS][2]) {
27 int grid_index = get_grid_index_(value, array);
28 if (grid_index == -1) {
29 return -1;
30 }
31
32 int aqi_lo = index_grid_[grid_index][0];
33 int aqi_hi = index_grid_[grid_index][1];
34 int conc_lo = array[grid_index][0];
35 int conc_hi = array[grid_index][1];
36
37 return (value - conc_lo) * (aqi_hi - aqi_lo) / (conc_hi - conc_lo) + aqi_lo;
38 }
39
40 int get_grid_index_(uint16_t value, int array[AMOUNT_OF_LEVELS][2]) {
41 for (int i = 0; i < AMOUNT_OF_LEVELS; i++) {
42 if (value >= array[i][0] && value <= array[i][1]) {
43 return i;
44 }
45 }
46 return -1;
47 }
48};
49
50} // namespace esphome::aqi
int index_grid_[AMOUNT_OF_LEVELS][2]
int get_grid_index_(uint16_t value, int array[AMOUNT_OF_LEVELS][2])
static const int AMOUNT_OF_LEVELS
int calculate_index_(uint16_t value, int array[AMOUNT_OF_LEVELS][2])
int pm2_5_calculation_grid_[AMOUNT_OF_LEVELS][2]
uint16_t get_aqi(uint16_t pm2_5_value, uint16_t pm10_0_value) override
int pm10_0_calculation_grid_[AMOUNT_OF_LEVELS][2]