sen0177

sen0177 is a Rust library/crate that reads air quality data from the SEN0177 air quality sensor.

crates.io Documentation Apache 2.0 Build Status

Prerequisites

Installation

Include the following in your Cargo.toml file:

toml [dependencies] sen0177 = "<see tags for latest version>"

Usage

```rust,no_run use sen0177::{Reading, Sen0177};

const SERIAL_PORT: &str = "/dev/ttyS0";

let mut sensor = Sen0177::open(SERIALPORT).expect("Failed to open device"); let reading = sensor.read().expect("Failed to read sensor data"); println!("PM1: {}µg/m³, PM2.5: {}µg/m³, PM10: {}µg/m³", reading.pm1(), reading.pm25(), reading.pm10()); ```

Note that the serial device occasionally returns bad data. If you recieve Sen0177::InvalidData or Sen0177::ChecksumMismatch from the read() call, a second try will usually succeed.

Gotchas

Raspberry Pi

If you're using this with a Raspberry Pi, note that by default the primary GPIO pins are set up as a Linux serial console. You will need to disable that (by editing /boot/cmdline.txt) before this will work. Instead of using a specifiy TTY device node, you should use /dev/serial0, which is a symlink to the proper device.

Alternatively, you can use the second UART, but you'll need to load an overlay to assign it to GPIO pins. See UART configuration and the UART-related overlays for more information.