ESPHome 2025.12.0-dev
Loading...
Searching...
No Matches
aqi_calculator.h
Go to the documentation of this file.
1#pragma once
2#include <climits>
4// https://document.airnow.gov/technical-assistance-document-for-the-reporting-of-daily-air-quailty.pdf
5
6namespace esphome {
7namespace hm3301 {
8
10 public:
11 uint16_t get_aqi(uint16_t pm2_5_value, uint16_t pm10_0_value) override {
12 int pm2_5_index = calculate_index_(pm2_5_value, pm2_5_calculation_grid_);
13 int pm10_0_index = calculate_index_(pm10_0_value, pm10_0_calculation_grid_);
14
15 return (pm2_5_index < pm10_0_index) ? pm10_0_index : pm2_5_index;
16 }
17
18 protected:
19 static const int AMOUNT_OF_LEVELS = 6;
20
21 int index_grid_[AMOUNT_OF_LEVELS][2] = {{0, 50}, {51, 100}, {101, 150}, {151, 200}, {201, 300}, {301, 500}};
22
23 int pm2_5_calculation_grid_[AMOUNT_OF_LEVELS][2] = {{0, 9}, {10, 35}, {36, 55},
24 {56, 125}, {126, 225}, {226, INT_MAX}};
25
26 int pm10_0_calculation_grid_[AMOUNT_OF_LEVELS][2] = {{0, 54}, {55, 154}, {155, 254},
27 {255, 354}, {355, 424}, {425, INT_MAX}};
28
29 int calculate_index_(uint16_t value, int array[AMOUNT_OF_LEVELS][2]) {
30 int grid_index = get_grid_index_(value, array);
31 int aqi_lo = index_grid_[grid_index][0];
32 int aqi_hi = index_grid_[grid_index][1];
33 int conc_lo = array[grid_index][0];
34 int conc_hi = array[grid_index][1];
35
36 return (value - conc_lo) * (aqi_hi - aqi_lo) / (conc_hi - conc_lo) + aqi_lo;
37 }
38
39 int get_grid_index_(uint16_t value, int array[AMOUNT_OF_LEVELS][2]) {
40 for (int i = 0; i < AMOUNT_OF_LEVELS; i++) {
41 if (value >= array[i][0] && value <= array[i][1]) {
42 return i;
43 }
44 }
45 return -1;
46 }
47};
48
49} // namespace hm3301
50} // namespace esphome
int index_grid_[AMOUNT_OF_LEVELS][2]
int get_grid_index_(uint16_t value, int array[AMOUNT_OF_LEVELS][2])
int pm10_0_calculation_grid_[AMOUNT_OF_LEVELS][2]
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
Providing packet encoding functions for exchanging data with a remote host.
Definition a01nyub.cpp:7