Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/themkat/pico-environment-monitor
Simple monitoring of environment data (temperature, humidity, eCO2) using a Raspberry Pi Pico W and some sensors.
https://github.com/themkat/pico-environment-monitor
bme688 circuitpython environment-monitoring pico-w raspberry-pi-pico-w rp2040 sgp30
Last synced: 12 days ago
JSON representation
Simple monitoring of environment data (temperature, humidity, eCO2) using a Raspberry Pi Pico W and some sensors.
- Host: GitHub
- URL: https://github.com/themkat/pico-environment-monitor
- Owner: themkat
- License: mit
- Created: 2023-04-15T08:31:29.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2024-02-22T20:01:35.000Z (11 months ago)
- Last Synced: 2024-12-10T09:41:27.604Z (30 days ago)
- Topics: bme688, circuitpython, environment-monitoring, pico-w, raspberry-pi-pico-w, rp2040, sgp30
- Language: Python
- Homepage:
- Size: 2.86 MB
- Stars: 2
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.org
- License: LICENSE
Awesome Lists containing this project
README
[[https://github.com/themkat/pico-environment-monitor/actions/workflows/build-and-test.yml][file:https://github.com/themkat/pico-environment-monitor/actions/workflows/build-and-test.yml/badge.svg]]
* Pico Environment Monitor** Project goals
I had a few goals with this project:
- Have a basic monitor with temperature, humidity, CO2 etc. where data could easily be read by other devices on my network
- Experiment with TDD on embedded platforms.
- Build good habits for TDDing CircuitPython projects for later.
- Data exported over the network. Easily used by Prometheus to populate a Grafana dashboard, and also have a JSON (or similar) endpoint that could be used by other devices.
** Directory structure
- root contains readme, scripts and other common things
- *code*: contains the CircuitPython code as well as unit tests
** Local development dependencies
To be able to design the logic before I got the sensors, I decided to dual-target the unit tests. The two targets was my computer, as well as the device itself. This means abstracting away hardware dependencies to make developing the logic locally possible. The local logic included the report formatters, as well as a wrapper for getting sensor information. To run this, you can navigate to the =code= directory and run =test_main.py=. To people unfamiliar with test driven development, this might seem overkill. On the other hand, it makes changing sensors etc. easy without affecting the underlying logic.** On-board development
The following sensors are used in my implementation:
- BME688 (Adafruit)
- SGP30 (Adafruit)See them used in the drawing below:
[[./rpi_pico_envmonitor_sketch.png]]
(the picture is of a regular Pico with headers, as I couldn't find a Pico W Fritzing part. Just imagine that it is the Pico W. They are pin compatible after all. Also the BME680 is pin compatible with the BME688 which I used, and they also use the same libraries)*NOTE: The gray wire is partially occluded behind the purple and white ones! It goes from the SCL on the SGP30 to the GP3 on the Pico (the one right below the purple wire on GP2. See [[https://datasheets.raspberrypi.com/picow/pico-w-datasheet.pdf][the Pico W data sheet]] if you are unsure about the pin layout.*
My setup looks like this (don't judge my lack of soldering skills too hard, it works):
[[./picow_envmonitor.jpeg]]To run Python code on the Raspberry Pi Pico W, [[https://circuitpython.org/board/raspberry_pi_pico_w/][CircuitPython]] is used. This should be downloaded and installed on your Pico W before any of the below code can be run.
*** Unit tests
To run the unit tests on the device, a simple "polyfill" for unit test functionality is needed. Fortunately, [[https://github.com/mytechnotalent/CircuitPython_Unittest][the user mytechnotalent made an awesome polyfill for Pythons built-unit unittest]], which makes it easy to run the same tests on device and on a development system. Simply copy unittest.py to the device, and we are ready to go!While working on the unit tests, I really just copied over the related files and the tests (including the testmain =test_main.py=). This is automated in the script called =deploy_test.sh=, with the path to the CircuitPython volume as input (e.g, =/Volumes/CIRCUITPY= on my Mac).
*** Running the main program
Remember that the necessary libraries need to be in place for the sensors and web server functionality to work. I use [[https://github.com/adafruit/circup][CircUp]] to handle this. The following libraries is needed:
- adafruit_httpserver
- adafruit_sgp30
- adafruit_bme680To run the main program, you should set up a =settings.toml= file with network information and copy to the Pico. This file will look like this:
#+BEGIN_SRC toml
WIFI_SSID = "myssid"
WIFI_PASSWORD = "mypass"
#+END_SRC
(replace myssid with your routers SSID and mypass with your routers WPA/WPA2 password)After this file is transferred, the main code files from the =code= directory should be transferred. This is done through the script =deploy_main.sh=, with the path to the CircuitPython volume as input (e.g, =/Volumes/CIRCUITPY= on my Mac).
The code provides the following endpoints:
- */environment* : Prometheus endpoint for metrics.
- */environment.json* : The data in json-format.Temperature, humidity and eCO2 is the data provided.
**** Exposing the data to Prometheus
The Prometheus endpoint can easily be read by Prometheus to get the temperature, humidity and eCO2 data. These can then be read to create dashboards for something like Grafana. A simple Prometheus scrape config I have used is the following:#+BEGIN_SRC yaml
- job_name: 'env_monitor'
scrape_interval: 5s
metrics_path: "/environment"
static_configs:
- targets: ["10.0.0.7"]
#+END_SRC
(you might have to change the ip of your Raspberry Pi Pico W on your local network. Also, feel free to change the scrape interval. I think I will use something like 30s once I get a more permanent Kubernetes cluster up and running in my home-lab)