Updated README and docs

This commit is contained in:
Josh Stewart 2025-01-05 12:23:43 +11:00
parent 743450a3a0
commit 6388b4a241
23 changed files with 36 additions and 74 deletions

BIN
.DS_Store vendored

Binary file not shown.

View File

@ -1,7 +1,7 @@
![](images/iaq_device_3d.png)
![](images/iaq-device-c3.png)
# IAQ (Indoor Air Quality) Board
IAQ Board is a DIY (Do-It-Yourself) device for measuring internal air quality. I needed a device for measuring some air quality parameters which is **compact, cheap, simple and capable**. After I prototyped it, decided instead of mounting into some odd box with cables hanging inside between the sensors, why not just solder everything on a printed circuit board. I had some experience with this from the time when I was a student years ago and luckily now it's much easier to crate PCB and very cheap to get it printed.
# IAQ C3 (Indoor Air Quality) Board
IAQ Board is a DIY (Do-It-Yourself) device for measuring internal air quality. This device is a fork of the [amazing work by Badn1nja](https://github.com/Badn1nja/iaq_board_fork) with the goals of updating the PCB to use the newer ESP32-C3 and to provide a more complete case and stand solution.
**And here is my device. I am publishing all the details and documentation under '[open source hardware](https://en.wikipedia.org/wiki/Open-source_hardware)' CC-BY-CA license, so everyone can build, adapt and sell it, as long as share under the same license**
@ -54,7 +54,7 @@ The device is based on widely available and cheap essential components ([MCU](ht
- [X] ***equivalent CO2 (not very correct compared with the NDIR sensor, but it's provided by the VOC sensor)***
**On top of that:**
- [X] ***At least one OLED display to show the data (can have one more on the top of the MCU board)***
- [X] ***One OLED display to show the data ***
- [X] ***three RGB wide angle LEDs with auto brightness. LED1 indicates PM2.5, LED2 - Air quality index, LED3 - CO2.***
- [X] ***auto night dimming of the displays and LEDs (can be disabled)***
- [X] ***MIN/MAX values of Temperature, PM2.5 and CO2, and 24h average PM2.5 value.***
@ -62,9 +62,6 @@ The device is based on widely available and cheap essential components ([MCU](ht
- [X] ***[firmware](https://en.wikipedia.org/wiki/Firmware) based on [ESPhome](https://esphome.io/), the device can be [directly added](https://esphome.io/components/api.html) in [Home Assistant](https://www.home-assistant.io/)***
- [X] ***WiFi access to the device with http server and [REST API](https://esphome.io/web-api/index.html) and [esphome native API](https://esphome.io/components/api.html) to read the sensor data***
Here is a video with all you need to know:
[![Click to see the video](images/youtube.jpg)](https://www.youtube.com/watch?v=X75OGs2TTT8)
## Who can build it?
The device is just a simple PCB board and almost everyone with some soldering skills can assemble it in a few steps:
@ -82,10 +79,7 @@ I made this device for me and then decided to share it. I think a lot of people
However I know that someone might be interested in the device, but lack the skills to build it. [Please follow this link for more details.](ordering.md)
# Components Details
The device with AAA battery size comparison:
![](images/iaq_device.jpg)
![](images/iaq_device1.jpg)
## 1. PCB
![](images/pcb.png)
![](images/pcb.jpg)
@ -93,17 +87,17 @@ The device with AAA battery size comparison:
The PCB (printed circuit board) is very simple and compact. It's 70x43mm (photos above are showing it larger than the actual size). It just connects a few sensors, microcontroller and displays. I wanted to integrate it in as much smaller footprint as possible, so the whole device is like a cigarette box. Most of the parts are surface mounted which makes the soldering just a bit more complicated, but still not a big deal. And of course it could be integrated even more by soldering all individual components on the PCB but then it's not really a hobby project anymore and much more difficult to build it.
It's designed on [KiCad](https://kicad.org/) and in the [kicad folder](kicad/) you can find full KiCad project, PCB gerber files, etc.
## 2. Holder case
![](images/stand.gif)
![](images/case-stand.png)
For any device the box is important. However my idea was to expose the PCB and electronics as much as possible in order to simplify it. I like the "raw" view of electronics and in this form I find it beautiful.
STL files for a case and stand are provided and can be printed on any standrd 3D printer.
Taking into account this, I designed a simple holder case for "sliding" the PCB in it and holding the particle sensor. The case can stay at about 45 degrees angle. It is designed on Fusion 360 and the [details are here](case_model). The holder case is not perfect, I was thinking to redesign it but no time for this. I am sure someone can do it better. :smile: Or design a complete box to cover the electronics fully, for me it is better in this minimalistic style.
## 3. Microcontroller Board
![](images/esp32.jpg)
Initially I developed the board with using the most popular WiFi enabled MCU [ESP8266](https://en.wikipedia.org/wiki/ESP8266) mounted on the cheap and small [Wemos D1 Mini board](https://docs.wemos.cc/en/latest/d1/d1_mini.html). However this MCU have some limitations described in the [tech details](#more-tech-details), so I changed it with the same size board compatible with Wemos D1 Mini, but running the newer much more powerful MCU of the same company - [ESP32](https://en.wikipedia.org/wiki/ESP32). In that way the device is quite stable, can run web server and since the board is having the same layout, on top of the D1 Mini ESP32 board you can connect extra display designed for d1 mini very easy. PCB is compatible with both D1 Mini ESP8266 or ESP32, even the labels are the same like on the older D1 board. However **I do not recommend to use D1 mini with ESP8266!** Also if I have to build next version of the PCB (I still have some 25 pcs), I will change the pins of one of the dust sensors.
This is the primary difference between this board and the original by Badn1nja. I am using the newer ESP32-C3 Supermini which is not only faster and more compact, but has a USB-C connector on it rather than micro-USB
![](images/ESP32-C3-Supermini.jpg)
These small size MCU board are pretty nice, they are tiny, have USB connector, onboard power supply and USB converter for programming or serial output. And you are powering the whole device just with a mini USB cable.
## 4. Dust Sensor
![](images/pms7003.jpg)
@ -139,14 +133,14 @@ PM2.5 value (um/m3)<br>LED 1 | [AQI by EEA (Air Quality Index for PM2.5 24h aver
30 - 40 | 25 - 50 (Poor) | 1500 - 2100 | ![](https://img.shields.io/static/v1?label=&message=MAGENTA&color=magenta) | on | off | on
\> 50 | > 50 (Very Poor) | > 2100 | ![](https://img.shields.io/static/v1?label=&message=RED&color=red) | on | off | off
## 9. Displays
The main display is the popular SSD1306 128x64 OLED display. On the top of the MCU board you can install extra [OLED 63x48](https://docs.wemos.cc/en/latest/d1_mini_shiled/oled_0_66.html) shield from Lolin which shows temperature, humidity and air pressure only.
## 10. Volatile Organic Compound sensor
![](images/sgp30.jpg)
## 9. Display
The display is the popular SSD1306 128x64 OLED display that is wideley and cheaply available on Aliexpress and eBay.
## 10. Volatile Organic Compound sensor
This is the [Sensirion SGP30](https://www.sensirion.com/en/environmental-sensors/gas-sensors/sgp30/) senor mounted on a breakout board from China. I do not use it on all my devices, but I added it because I can. :smile: Also with it the device measures almost completely the internal air quality. SGP30 is also showing equivalent CO2 based on VOC but it's not precise compared with MH-Z19B NDIR sensor. Also it needs periodic calibration hardcoded in the firmware which makes it more tricky to use.
Please [check here](https://github.com/nkitanov/iaq_board/issues/10#issuecomment-798994427) for the known issues with these boards.
## 11. Other electrical components
![](images/buttons.png)
@ -165,7 +159,7 @@ Bellow is the list of all parts needed to assemble the device with links to sour
Schematic Ref | ITEM | pcs | Comment
--------------| ---- | :-: | -------
| | PCB Board | 1 | in [kicad folder](kicad) you can find all the data and GERBER PCB design files
U1 | [WeMos_D1_mini_ESP32](https://www.aliexpress.com/item/4000880936043.html?spm=a2g0o.productlist.0.0.f387754egZVnTc&algo_pvid=b105e43b-6669-40bc-99c4-cf22d026995d&algo_expid=b105e43b-6669-40bc-99c4-cf22d026995d-6&btsid=0bb0623616009843570355505e4ca0&ws_ab_test=searchweb0_0,searchweb201602_,searchweb201603_) | 1 | [ESP8266 version](https://www.wemos.cc/en/latest/d1/d1_mini.html) also can work but not recommended
U1 | [ESP32-C3 Supermini](https://vi.aliexpress.com/item/1005007577443695.html) | 1
U2 | [PMS7003 Sensor](https://www.aliexpress.com/item/32832444694.html?spm=a2g0s.9042311.0.0.27424c4dKxsO6Z) | 1 | don't use the 2x5pin 1.27mm receptacle which comes normally wit these sensors, explanation is bellow
U3 | [SSD1306 Display](https://www.aliexpress.com/item/32956051129.html?spm=a2g0o.productlist.0.0.523365fcQkP3XC&algo_pvid=b62bd3ab-fe19-479e-bc50-b2c68dd35525&algo_expid=b62bd3ab-fe19-479e-bc50-b2c68dd35525-25&btsid=67d67e08-4ad1-4c08-8cec-e378bae47fc6&ws_ab_test=searchweb0_0,searchweb201602_9,searchweb201603_55) | 1 | pay attention to correct pin order if you are buying from another source, as there are similar 4pin boards with different pinout
U4 | [BME280 breakout board](https://www.aliexpress.com/item/4000166540445.html?spm=a2g0o.productlist.0.0.363a562ely2LZq&algo_pvid=b0bd6068-edbb-4f9c-aa24-92324f726eda&algo_expid=b0bd6068-edbb-4f9c-aa24-92324f726eda-8&btsid=3927b67d-2f89-4594-9f47-b017e00ef8a0&ws_ab_test=searchweb0_0,searchweb201602_9,searchweb201603_55) | 1 | only 3.3V version with 6 pins which have both I2C and SPI. **Please note that due to semiconductor shortage these are difficult to find now (June 2021). I am currently using my own breakout where I solder the BME directly. BME280 as IC can be found occasionally in stock from DigiKey**
@ -174,16 +168,14 @@ U6 | [SGP30 breakout board](https://www.aliexpress.com/item/4000004614708.html?s
U7 | [TLS2561 light sensor](https://www.aliexpress.com/item/33056165996.html?spm=a2g0s.9042311.0.0.15314c4draqb6x) | 1
C1-C4 | [0.1 uF SMD Capacitor](https://bg.farnell.com/wurth-elektronik/885012207016/cap-0-1-f-10v-10-x7r-0805/dp/2534051?st=smd%20capacitors) | 4
D1-D3 | [Neopixel 5050 LED](https://www.aliexpress.com/item/4000750610574.html?spm=a2g0o.productlist.0.0.55a96722mpqDCp&algo_pvid=4be2d94a-875a-4e56-af12-1f6a3dcdf49f&algo_expid=4be2d94a-875a-4e56-af12-1f6a3dcdf49f-5&btsid=0bb0623416009856118282154ebe61&ws_ab_test=searchweb0_0,searchweb201602_,searchweb201603_) | 3
| SW1 | [Tactile Switch B3S-1000](https://uk.farnell.com/omron/b3s-1000/switch-spno-0-05a-24v-smd/dp/177807) | 1 |
| SW2 | [Tactile Switch B3U-1000P](https://bg.farnell.com/omron/b3u-1000p/switch-spst-no-0-05a-12v-smd/dp/1333652?st=B3U-1000P) | 1
| SW1 | [Tactile Switch TL3305](https://www.digikey.com.au/en/products/detail/e-switch/TL3305BF160QG/5816182) | 1
| SW2 | [Tactile Switch TL3342](https://www.digikey.com.au/en/products/detail/e-switch/TL3342F450QG/4029404) | 1
| | [PCB Receptacle, 1.27 mm, 10 Contacts](https://bg.farnell.com/amphenol-icc-fci/20021311-00010t4lf/receptacle-vert-1-27mm-tht-10way/dp/1865313) | 1 | This PCB Receptacle is for connecting PMS7003 dust sensor. Keep in mind these sensors come with such connector included but it's slightly taller and makes a gap of about half mm between sensor and PCB which is not ok.
| | [SMD PCB Receptacle 8 pins](https://uk.farnell.com/samtec/ssm-108-l-sv/receptacle-2-54mm-vert-8way/dp/1668259?st=ssm-108-l-sv%20pcb%20receptacle) | 3 | two are needed for the MCU board, 3rd you can skip. It's for extra pins on the PCB but with ESP32 MCU not needed so much as extra headers can be soldered directly on it's board
| | [PCB Receptacle 4 pin](https://uk.farnell.com/samtec/bcs-104-l-s-te/receptacle-2-54mm-vert-4way/dp/1667470?ost=bcs-104-l-s-te) | 4 | four is needed if all sensors are installed
| | [OLED 63x48 shield](https://www.aliexpress.com/item/32981156326.html?spm=a2g0s.9042311.0.0.27424c4dO21RuC) | 1 | not required, only if you want an extra display on top of the MCU board
| | [Holder case](case_model) | 1 | it's not required to have it but it makes the device completed
| | [Display holder](case_model) | 1 | This small 3D printed part is holding tight the display from flapping
| | [Various 2.54 headers](https://www.ebay.co.uk/itm/10pcs-40-pin-2-54mm-Breakaway-Male-Header-for-PCB-Breadboard-1x40-Single-Row-UK/262755464818?epid=20008873513&hash=item3d2d723672:g:st8AAOSwMsZdNw5x) | | You will need these for the CO2 sensor if you don't have available. Normally they come together with the breakout boards.
| | [2mm nylon bolts/nuts](https://www.ebay.co.uk/sch/i.html?_from=R40&_trksid=p2047675.m570.l1313&_nkw=2mm+nylon+bolts&_sacat=0) | | If you want to make the display more stable you can install nylon bolts like explained [in the video](https://youtu.be/b2oDBgN3h1w?t=758). Better use [display holder](case_model).
# Firmware
Firmware is created with [ESPHome](https://esphome.io/index.html). The binary file, configuration and instructions are located in [firmware folder](firmware/).

View File

@ -1,16 +1,13 @@
# Stand Case (Holder Body)
# Case
![](../images/stand.gif)
![](../images/case.png)
The stand is created with [Fusion 360](https://www.autodesk.com/products/fusion-360/overview), here is the shared file design: https://a360.co/2STg8GN. The PCB slides in it and holds the particle sensor.
The stand is created with OpenSCAD.
You can download directly the 3D models step files and print them on a 3D printer:
- [Stand_body.stl](Stand_body.stl) - this is the main body in which the assembled PCB "slides"
- [display_holder_22mm.stl](display_holder_22mm.stl) - this is a small 3d model to install bellow the display. It have 2 small pins for attaching to the PCB. It holds firmly the display from flapping in the receptacle. Keep in mind that it's for displays with holes 22mm each other. There are some other displays with bigger distance.
- [Stand_pin.stl](Stand_pin.stl) - this is the small pin which is put in to the bottom of the stand and the body can be positioned at about 45 degrees. There is also a hole on the side of the body where the pin can stay when not used
The case comes in 2 parts, a top and a bottom, and there is an optional stand for holding the case upright.
- [IAQ-C3-base.stl](IAQ-C3-base.stl) - The main case that the board goes into
- [IAQ-C3-top.stl](IAQ-C3-top.stl) - The top that fits onto the case. This uses snap fittings to attach to the case.
- [IAQ-C3-stand.stl](IAQ-C3-stand.stl) - An optional stand for holding the completed case vertically
Stand body:
![](../images/stand_f360.png)
Display holder:
![](../images/display_holder.png)
Stand:
![](../images/case-stand.png)

Binary file not shown.

Binary file not shown.

Binary file not shown.

View File

@ -2,7 +2,7 @@
Firmware is created with [ESPHome](https://esphome.io/index.html) - it is a system to control your ESP8266/ESP32 by simple yet powerful configuration files and control them remotely through Home Automation systems.
I am not going to explain in details [the configuration yaml file.](iaq_board.yaml) If you want to modify it, you need to get familiar with esphome. The config file is fairly complicated compared with the usual esphome configurations, so there is some steeper learning curve, especially if you never programmed an MCU before. However by using esphome, you can build very complex logic without writing a single line of code, as the whole instruction is in the yaml config file. It's amazing how much time it saves!
The files below are those needed to be loaded into ESPHome
- [`iaq_board.yaml`](iaq_board.yaml) - this is the configuration for esphome
- [`iaq_board.bin`](iaq_board.bin) - this is the binary file of the compiled firmware and can be directly uploaded in the MCU
@ -16,18 +16,3 @@ I am not going to explain in details [the configuration yaml file.](iaq_board.ya
***That's it! Connect the MCU on the board, then power it on and it should work.***
If you want to go deeper, [follow the instructions](https://esphome.io/guides/getting_started_command_line.html) how to build the binary file from the yaml and upload it to the MCU from command line.
# Changelog
### yaml 1.1.3 / 21 Mar 2021
- update esphome to 1.16.2
- default brightness correction set to +15%
### yaml 1.1.4(?) / 23 Jan 2024 (Badn1nja)
- Fixed complication bugs (utime_sensor)
- updated/working with esphome: 2023.12.9
- Added Virtual buttons for automation and 'remote control' (Adds controls away from physical buttons)
- Changed Physical Button ID to buttonpcb (allows buttons to be added to yaml, not used before this change)
- Added Home Assistant Yaml for Automating the screen changes
- Added latest bin file using template yaml (Reccomend to use esphome to build)
- Added icons
- Re-formatted YAML for better readability and more inline with default esphome config

Binary file not shown.

View File

@ -33,8 +33,8 @@ substitutions:
yaml_version: "1.1.3"
esphome:
name: iaq-board-1
friendly_name: IAQ Board
name: "iaq-board-2"
friendly_name: IAQ Board Bedroom
on_boot:
then:
@ -187,7 +187,7 @@ font:
size: 10
uart:
- rx_pin: GPIO10
- rx_pin: GPIO1
baud_rate: 9600
id: pms
@ -199,13 +199,14 @@ uart:
i2c:
scl: GPIO9
sda: GPIO8
frequency: 100kHz
#frequency: 100kHz
frequency: 400kHz
binary_sensor:
- platform: gpio
id: buttonpcb
pin:
number: GPIO3
number: GPIO7
mode: INPUT_PULLUP
inverted: True
on_click:
@ -641,7 +642,7 @@ light:
to: 2
- platform: neopixelbus
num_leds: 3
pin: GPIO2
pin: GPIO10
name: "RGB strip"
variant: SK6812
id: rgb_led
@ -651,7 +652,7 @@ switch:
- platform: gpio
name: "PMS7003_SET"
pin:
number: GPIO1
number: GPIO2
mode: OUTPUT
restore_mode: ALWAYS_ON
id: pms_set
@ -688,7 +689,7 @@ display:
model: "SSD1306 128x64"
address: 0x3C
brightness: 100%
rotation: 180
rotation: 0
id: display1
lambda: |-
if (id(button_mode) == 7 && !id(version) && !id(led_status_display) && !id(night_mode_display) && !id(min_max_zero) && id(display_on)) {
@ -745,17 +746,4 @@ display:
it.printf(0, 20, id(arial), "Night dim: %s", id(night_mode) ? "ON" : "OFF");
} else if (id(min_max_zero)) {
it.print(0, 20, id(arial), "MIN-MAX reset!");
}
- platform: ssd1306_i2c
model: "SSD1306 64x48"
address: 0x3D
brightness: 100%
rotation: 270
id: display2
lambda: |-
if (id(display_on) && id(button_mode) < 8) {
it.printf(0, 0, id(arial), "%.1f C", id(temp).state);
it.printf(0, 20, id(arial), "%.0f %%", id(hum).state);
it.printf(0, 40, id(arial), "%.0f h", id(press).state);
}
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 109 KiB

BIN
images/case-stand.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 11 KiB

BIN
images/case.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 12 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 79 KiB

BIN
images/iaq-device-c3.jpeg Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 616 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 177 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 48 KiB

After

Width:  |  Height:  |  Size: 241 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 32 KiB

After

Width:  |  Height:  |  Size: 89 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 39 KiB

After

Width:  |  Height:  |  Size: 72 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 3.4 MiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 118 KiB