AirGradient ONE Kit Review – An open-source indoor air quality monitor

The product we are reviewing today is the “AirGradient ONE” air quality monitor kit which is an updated version of the earlier AirGradient air quality monitor. The device is equipped with sensors from Sensirion and Plantower, allowing it to measure many air quality parameters such as CO2, PM2.5, TVOCs, NOx, temperature, and humidity. It is an indoor air quality monitor that is both open-source software and open hardware. This means that the Arduino source code, schematic diagrams, PCB, and 3D models of the enclosure are available to developers.

AirGradient ONE DIY Kit Unboxing

AirGradient ONE DIY air quality monitor kit

The device was packaged within a cardboard box, with a greeting card from the manufacturer. The card features a QR code linking to a webpage with the installation guide.

AirGradient ONE : Inside the box

Since I requested the Kit version (there’s also a fully assembled model), some sensors were not pre-assembled and they were well-packaged in separate seals. The main PCB was already inside the enclosure, with the screws had not yet been fastened. Additional components in the box included a screwdriver, screws, a USB Type-C cable, and a 5V 2A adapter.

AirGradient ONE : Components inside the box

AirGradient ONE : S8, SGP41, and SHT4x sensors

AirGradient ONE : Inside the enclosure

Specifications

This kit is the AirGradient ONE using PCB V9 featuring the ESP32-C3 Mini as the main microcontroller. Additionally, it includes a 1.3-inch OLED display with a resolution of 128×64 pixels. The mainboard is also equipped with 11 programmable NeoPixel RGB LEDs that are used to visualize the air quality level. The details of the other components inside the packages are listed below.

  • 1x Plantower PMS5003 PM Sensor
  • 1x Senseair S8 CO2 Sensor
  • 1x SHT4x Temperature and Humidity Sensor Module
  • 1x SGP41 TVOC / NOx Sensor Module
  • 1x 5V 2000mA Adaptor
  • 1x 90-degree USB Type-C cable
  • 4x M1.8×10 Torx T6 Screws
  • 1x Torx T6 Screwdriver

AirGradient ONE kit assembly

The manufacturer provides the build instructions through this webpage. The assembly instructions are well-written and easy to follow. Basically, I only had three components to install, as shown below.

SenseAir S8, SHT4x, and SGP41 sensors

For the Senseair S8 Module, there are two sets of male headers: one is a 1×4 male header, and the other one is a 1×5 pin male header. I had to place the sensor into the socket on the PCB labeled “CO2 Sensor”, ensuring that the orientation of the sensor was correct.

The SGP41 module and the SHT4x module are very similar, with the same number of pins. So, I carefully checked the label on the modules and inserted the SGP41 module into the socket labeled “I2C3” and the SHT1X into the socket labeled “SHT4x”. Note that the silkscreen color of these two modules might differ from what is shown on the instruction webpage: in my case, the SGP41 had a blue silkscreen and the SHT4X had a magenta silkscreen. Also, when installing the modules into the socket, I had to make sure that the modules face outwards, as shown in the following figures.

The PMS sensor uses a JST connector, and in my case, it was already connected to the PCB. So, I just checked to ensure that both ends of the cable are fully plugged.

After installing the modules, we can power the device by plugging the USB Type-C into the socket on the back of the enclosure case. There is a cable slot on the backside of the enclosure to hold the cable in place and prevent it from dangling or getting entangled.

AirGradient One : SGP41 sensor

AirGradient One : SHT4x sensor

AirgradientONE : Plugging the USB Type-C cable

After powering the device, it initializes with the default firmware, and the OLED screen lights up, meaning everything works fine. Then, I close the top and bottom covers of the enclosure and securely screw them. Now, it is ready for the next step.

Using the AirGradient ONE air quality monitor

When the device is powered on, there will be a message asking us to configure the unit of measurement. We can enter the configuration screen by long pressing the small button on the backside of the enclosure. By short-pressing the button, we can cycle through the unit for measuring the PM2.5 and the temperature unit as listed below.

  • Temperature: °C, PM: ug/m3
  • Temperature: °C, PM: US AQI
  • Temperature: °F, PM: ug/m3
  • Temperature: °F, PM: US AQI

After choosing the preferred units, I long-pressed the button once again to save the configuration and reboot the device.

Airgradient ONE : measurement units configuration

When powering on for the first time, the device will ask to connect to the WiFi. To do this, I had to record the serial number of the device, which will be displayed on the OLED screen during the booting process. I then used my mobile phone to search for the device’s WiFi Hotspot which was named “AG-xxxxxx”, where “xxxxxx” was the serial number of the device.

Once connected to the device’s hotspot, I set the SSID and the password of my target WiFi hotspot and then saved the settings to finish the WiFi configuration.

Airgradient ONE : Setting up the WiFi

After the configuration screen, the device’s RGB LEDs will show the colors corresponding to the air quality, while the OLED screen will display the data from the sensors using the chosen units. The AirGradient ONE kit will work even if there is no WiFi connection.

AirgradientONE : Ready to work

AirgradientONE : Main screen

Connect to the AirGradient Dashboard

Because there is a USB connection port on the backside of the enclosure, I connected the device to my laptop using the provided USB Type-C cable. I opened the Arduino IDE and observed the messages displayed in the Serial Monitor to check if any messages were being printed. Upon observation, I found that the device was collecting measurement data, including the RSSI of the connected WiFi hotspot, and sending this data to the AirGradient Dashboard server in a JSON format. The default URL is http://hw.airgradient.com/sensors/airgradient:xxxxx/measures, where xxxxx is the serial number of the device. However, the server rejected the request and returned the error message “sensor 'airgradient:xxxxxx' unknown“.

To resolve this issue, I had to create an AirGradient Dashboard account and add information about my device such as the location and the serial number. After successfully creating and adding my device to the dashboard, I restarted the device and waited for a few seconds for the device to connect to the Internet and start sending data. If the connection is successful, we will see something like the following figures.

AirgradientONE : Dashboard setup AirgradientONE : Dashboard setup AirgradientONE : Dashboard screen

Flashing the AirGradient Firmware

At the time of this review, there are two methods for flashing the device: direct flashing using the web browser and manual flashing with the Arduino IDE. Here, I decided to use the Arduino IDE to flash my board. For this review, I used the Arduino IDE 1.8.13, which was already installed on my computer. I downloaded the source code from the manufacturer’s GitHub repo and opened the ONE_V9.ino file. As suggested on the web page, I chose the ESP32 platform and selected the Lolin C3 Mini as the target board.

AirgradientONE : Setting board manager URL in Arduino IDE
The list of the required libraries is written in the header of the ONE_V9.ino file. In my case, the following six libraries were necessary. You can either use the Library Manager to install these libraries, or download and copy them to Arduino’s libraries manually.

  • WifiManager by tzapu, tablatronix tested with version 2.0.11-beta
  • U8g2 by oliver tested with version 2.32.15
  • Sensirion I2C SGP41 by Sensation Version 0.1.0
  • Sensirion Gas Index Algorithm by Sensation Version 3.2.1
  • Arduino-SHT by Johannes Winkelmann Version 1.2.2
  • Adafruit NeoPixel by Adafruit Version 1.11.0

My first compilation failed because of some missing libraries. In my case, I needed to install these additional libraries.

  • PMS Library by Markusz Kakl Version 1.1.0
  • S8 UART by Josep Comas Version 1.0.0
  • Sensirion Core by Sensirion Version 0.6.0

After installing these libraries, the compilation still failed, but the issues were in the PMS.h and PMS.cpp files. After searching the Internet, I found a solution in this post, which mentioned that the manufacturer used a modified version of the PMS library. So, I needed to update these two files with the following code:



The compiling and uploading were done successfully. However, I figured out that the device couldn’t connect to the WiFi. So, I decided to solve this problem by hardcoding the SSID and password manually. After this, the device worked as normal.

AirGradientONE : Configuring SSID and password in Arduino IDE

Open-sourceness

Customizing Arduino source code

As mentioned above, we can access the source code on GitHub, and not only the firmware for this kit, but also the firmware for other versions, and some examples are available there.

I then modified the source code (ONE_V9.ino) to send the data to my own server by changing the value of the APIROOT variable at the top of the source code to the URL of my own server. Then, I modified the sendToServer() function by appending the device’s serial number to the HTTP request. After updating the value of the POSTURL string to match my requirement, I compiled and uploaded the new firmware to the device. After a few seconds, the device started sending the data to my own server successfully.

AirGradient ONE : Setting custom URL AirGradient ONE : Setting custom HTTP parameters in Arduino

AirGradient ONE : Data in the custom database
Data in the custom database

Since the 11 RGB LEDs are programmable, I continued modifying the source code to change the behavior of the LEDs. With the default configuration, these LEDs are turned off during booting and will be turned on after the device goes into the main screen.

Since the device uses Adafruit’s NeoPixel library, I can control the color of each LED by simply calling the setPixelColor function with the desired LED index and the values of RGB components. Therefore, I added the following code at the end of the setup function to make the LEDs light randomly for a few seconds before returning to the normal state.


 

AirGradient ONE : Changing LEDs color

Hardware design files

Not only are the source codes available, but the schematic diagrams and the PCB files are also accessible for developers through this webpage. These files are in KiCad format, and I was able to open them using KiCad 7.0 without any problems.

AirGradientONE : Schematic diagram AirGradientONE : PCB's top and bottom layers AirGradientONE : PCB's bottom layer AirGradientONE : PCB's top layer

3D print your own enclosure

The manufacturer also provides developers with 3D models of the enclosure. These models are in STL format and can be downloaded through this webpage where two ZIP files are available for download: one for the enclosure and the other for the clip-on stand.

The 3D enclosure model is composed of three models: the lower case, the upper case, and the cable area models. I visualized these 3D models by opening the STL files in the MeshLab software, as shown in the following figures. I also tested printing the cable area model by slicing the STL file with PrusaSlicer 2.6.0 and printing it using Printrun 2.1. This model was easy to print, and the printed model is shown in the following figure.

AirGradient ONE 3D enclosure model in MeshLab AirGradient ONE viewing 3D enclosure model in MeshLab AirGradient ONE : 3D printed model

Conclusion

AirGradient ONE indoor air quality monitor works very well, although when observing the messages over the serial port, I noticed that measurement values are sometimes unstable after restarting the device. Fortunately, they stabilize within a few seconds. The open-sourceness of the device also enables customization of the firmware, electronics, and enclosure.

I would like to thank AirGradient for providing the One Kit air quality monitor for this review. You can order the fully assembled and tested version of this AirGradient ONE for $195, or the kit version reviewed here for $138, on the manufacturer’s website.

Share this:

Support CNX Software! Donate via cryptocurrencies, become a Patron on Patreon, or purchase goods on Amazon or Aliexpress

Radxa Orion O6 Armv9 mini-ITX motherboard
Subscribe
Notify of
guest
The comment form collects your name, email and content to allow us keep track of the comments placed on the website. Please read and accept our website Terms and Privacy Policy to post a comment.
6 Comments
oldest
newest
David Willmore
David Willmore
1 year ago

Great review, Mr. Teeravech!

This seems like a really useful product that a lot of people would be interested in. Thanks for sharing!

Richard Crook
Richard Crook
1 year ago

The various oxides of nitrogen are indeed bad, but no detection of the other really dangerous gases carbon monoxide, methane, or radon …

Scott Lamb
1 year ago

Carbon monoxide is often built into smoke alarms and treated similarly: if it’s detected (over some small threshold), sound the alarm so the house can be immediately evacuated. The things the AirGradient detects are more stuff you track/graph and try to minimize but don’t immediately flee from. The device has a LCD display and network connectivity but no audible alarm.

There are threads like this one about radon on their forums, but IIUC no one could find an inexpensive sensor.

Flustered
Flustered
1 year ago

Just received my kit in the mail yesterday and set it up. Like you, I had issues with the dashboard (error 422 upon setting up an account), but was able to verify readings from the display and flash the firmware via USB. I didn’t have much time to fiddle, but I plan to try and put together a working ESPHome config this weekend.

Jim G
Jim G
1 year ago

Very thorough review. Great job.

SayWhat?
SayWhat?
4 months ago

I’ve been using this for several months with Home Assistant.
Simple to Assemble.
Works well
No Problems

If it had Radon detection it would be perfect

Boardcon EM3562 Rockchip RK3562 SBC with 8 analog camera inputs