diff --git a/.github/workflows/arduino_quality_check.yml b/.github/workflows/arduino_quality_check.yml index a8b92d4..a2dc17c 100644 --- a/.github/workflows/arduino_quality_check.yml +++ b/.github/workflows/arduino_quality_check.yml @@ -13,7 +13,7 @@ jobs: uses: sensirion/.github/.github/workflows/driver.arduino.check.yml@main with: expect-arduino-examples: true - lint-lib-manager-check: submit + lint-lib-manager-check: update todo-check: if: github.event_name == 'push' && github.ref != 'refs/head/main' diff --git a/CHANGELOG.md b/CHANGELOG.md index b0a15ca..c621661 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -5,6 +5,11 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 ## [Unreleased] +## [1.0.1] - 2024-12-1 + +### Fixed + +- Fix naming from mass concentration to number concentration for read number concentration method (returned values were correct). ## [1.0.0] - 2024-11-25 ### Added @@ -21,6 +26,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 - Add interfaces to start, stop and read measurements. - Add interfaces to read product name, serial number and version -[Unreleased]: https://github.com/Sensirion/arduino-i2c-sen66/compare/1.0.0...HEAD +[Unreleased]: https://github.com/Sensirion/arduino-i2c-sen66/compare/1.0.1...HEAD +[1.0.1]: https://github.com/Sensirion/arduino-i2c-sen66/compare/1.0.0...1.0.1 [1.0.0]: https://github.com/Sensirion/arduino-i2c-sen66/compare/0.1.0...1.0.0 [0.1.0]: https://github.com/Sensirion/arduino-i2c-sen66/releases/tag/0.1.0 \ No newline at end of file diff --git a/README.md b/README.md index a63f38c..5b4f260 100644 --- a/README.md +++ b/README.md @@ -35,7 +35,7 @@ manager or `Add .ZIP Library` #### Dependencies * [Sensirion Core](https://github.com/Sensirion/arduino-core) -## Sensor wiring +## Connect the sensor Use the following pin description to connect your SEN66 to the standard I²C bus of your Arduino board: @@ -43,12 +43,12 @@ Use the following pin description to connect your SEN66 to the standard I²C bus | *Pin* | *Cable Color* | *Name* | *Description* | *Comments* | |-------|---------------|:------:|----------------|------------| -| 1 | red | VDD | Supply Voltage | 3.3V ±10% +| 1 | red | VDD | Supply Voltage | 3.3V ±5% | 2 | black | GND | Ground | | 3 | green | SDA | I2C: Serial data input / output | TTL 5V compatible | 4 | yellow | SCL | I2C: Serial clock input | TTL 5V compatible -| 5 | | NC | Do not connect | -| 6 | | NC | Do not connect | +| 5 | | NC | Do not connect | Ground (Pins 2 and 5 are connected internally) +| 6 | | NC | Do not connect | Supply voltage (Pins 1 and 6 are connected internally) @@ -90,7 +90,6 @@ You will find pinout schematics for recommended board models below: | SCL | 4 | yellow | A5 | -

@@ -128,7 +127,6 @@ You will find pinout schematics for recommended board models below: | SCL | 4 | yellow | D21/SCL | -

@@ -158,7 +156,7 @@ You will find pinout schematics for recommended board models below: 1. Install the libraries and dependencies according to [Installation of the library](#installation-of-the-library) -2. Connect the SEN66 sensor to your Arduino as explained in [Sensor wiring](#sensor-wiring) +2. Connect the SEN66 sensor to your Arduino as explained in [Connect the sensor](#connect-the-sensor) 3. Open the `exampleUsage` sample project within the Arduino IDE: @@ -193,4 +191,4 @@ they are fixed. ## License -See [LICENSE](LICENSE). \ No newline at end of file +See [LICENSE](LICENSE). diff --git a/examples/exampleUsage/exampleUsage.ino b/examples/exampleUsage/exampleUsage.ino index 1220390..24fa33c 100644 --- a/examples/exampleUsage/exampleUsage.ino +++ b/examples/exampleUsage/exampleUsage.ino @@ -3,7 +3,7 @@ * * Generator: sensirion-driver-generator 1.0.1 * Product: sen66 - * Model-Version: 1.3.0 + * Model-Version: 1.3.1 */ /* * Copyright (c) 2024, Sensirion AG diff --git a/keywords.txt b/keywords.txt index a89e74d..5b28fe4 100644 --- a/keywords.txt +++ b/keywords.txt @@ -42,11 +42,15 @@ getSerialNumber KEYWORD2 readDeviceStatus KEYWORD2 readAndClearDeviceStatus KEYWORD2 deviceReset KEYWORD2 -signalMassConcentrationPm0p5 KEYWORD2 signalMassConcentrationPm1p0 KEYWORD2 signalMassConcentrationPm2p5 KEYWORD2 signalMassConcentrationPm4p0 KEYWORD2 signalMassConcentrationPm10p0 KEYWORD2 +signalNumberConcentrationPm0p5 KEYWORD2 +signalNumberConcentrationPm1p0 KEYWORD2 +signalNumberConcentrationPm2p5 KEYWORD2 +signalNumberConcentrationPm4p0 KEYWORD2 +signalNumberConcentrationPm10p0 KEYWORD2 signalTemperature KEYWORD2 signalHumidity KEYWORD2 signalVocIndex KEYWORD2 diff --git a/library.properties b/library.properties index 8c18059..4c065b6 100644 --- a/library.properties +++ b/library.properties @@ -1,5 +1,5 @@ name=Sensirion I2C SEN66 -version=1.0.0 +version=1.0.1 author=Sensirion maintainer=Sensirion sentence=Library for the SEN66 sensor by Sensirion diff --git a/metadata.yml b/metadata.yml index 5baaa84..505283c 100644 --- a/metadata.yml +++ b/metadata.yml @@ -1,7 +1,7 @@ # driver generation metadata generator_version: 1.0.1 -model_version: 1.3.0 +model_version: 1.3.1 dg_status: released -is_manually_modified: true +is_manually_modified: false first_generated: '2024-10-30 08:14' -last_generated: '2024-11-27 07:57' +last_generated: '2024-12-03 09:56' diff --git a/src/SensirionI2cSen66.cpp b/src/SensirionI2cSen66.cpp index dcd18fc..90b9446 100644 --- a/src/SensirionI2cSen66.cpp +++ b/src/SensirionI2cSen66.cpp @@ -3,7 +3,7 @@ * * Generator: sensirion-driver-generator 1.0.1 * Product: sen66 - * Model-Version: 1.3.0 + * Model-Version: 1.3.1 */ /* * Copyright (c) 2024, Sensirion AG @@ -50,13 +50,6 @@ static uint8_t communication_buffer[48] = {0}; SensirionI2cSen66::SensirionI2cSen66() { } -float SensirionI2cSen66::signalMassConcentrationPm0p5( - uint16_t massConcentrationPm0p5Raw) { - float massConcentrationPm0p5 = 0.0; - massConcentrationPm0p5 = massConcentrationPm0p5Raw / 10.0; - return massConcentrationPm0p5; -} - float SensirionI2cSen66::signalMassConcentrationPm1p0( uint16_t massConcentrationPm1p0Raw) { float massConcentrationPm1p0 = 0.0; @@ -85,6 +78,41 @@ float SensirionI2cSen66::signalMassConcentrationPm10p0( return massConcentrationPm10p0; } +float SensirionI2cSen66::signalNumberConcentrationPm0p5( + uint16_t numberConcentrationPm0p5Raw) { + float numberConcentrationPm0p5 = 0.0; + numberConcentrationPm0p5 = numberConcentrationPm0p5Raw / 10.0; + return numberConcentrationPm0p5; +} + +float SensirionI2cSen66::signalNumberConcentrationPm1p0( + uint16_t numberConcentrationPm1p0Raw) { + float numberConcentrationPm1p0 = 0.0; + numberConcentrationPm1p0 = numberConcentrationPm1p0Raw / 10.0; + return numberConcentrationPm1p0; +} + +float SensirionI2cSen66::signalNumberConcentrationPm2p5( + uint16_t numberConcentrationPm2p5Raw) { + float numberConcentrationPm2p5 = 0.0; + numberConcentrationPm2p5 = numberConcentrationPm2p5Raw / 10.0; + return numberConcentrationPm2p5; +} + +float SensirionI2cSen66::signalNumberConcentrationPm4p0( + uint16_t numberConcentrationPm4p0Raw) { + float numberConcentrationPm4p0 = 0.0; + numberConcentrationPm4p0 = numberConcentrationPm4p0Raw / 10.0; + return numberConcentrationPm4p0; +} + +float SensirionI2cSen66::signalNumberConcentrationPm10p0( + uint16_t numberConcentrationPm10p0Raw) { + float numberConcentrationPm10p0 = 0.0; + numberConcentrationPm10p0 = numberConcentrationPm10p0Raw / 10.0; + return numberConcentrationPm10p0; +} + float SensirionI2cSen66::signalTemperature(int16_t temperatureRaw) { float temperature = 0.0; temperature = temperatureRaw / 200.0; @@ -154,32 +182,37 @@ int16_t SensirionI2cSen66::readMeasuredValues( } int16_t SensirionI2cSen66::readNumberConcentrationValues( - float& massConcentrationPm0p5, float& massConcentrationPm1p0, - float& massConcentrationPm2p5, float& massConcentrationPm4p0, - float& massConcentrationPm10p0) { - uint16_t massConcentrationPm0p5Raw = 0; - uint16_t massConcentrationPm1p0Raw = 0; - uint16_t massConcentrationPm2p5Raw = 0; - uint16_t massConcentrationPm4p0Raw = 0; - uint16_t massConcentrationPm10p0Raw = 0; + float& numberConcentrationPm0p5, float& numberConcentrationPm1p0, + float& numberConcentrationPm2p5, float& numberConcentrationPm4p0, + float& numberConcentrationPm10p0) { + uint16_t numberConcentrationPm0p5Raw = 0; + uint16_t numberConcentrationPm1p0Raw = 0; + uint16_t numberConcentrationPm2p5Raw = 0; + uint16_t numberConcentrationPm4p0Raw = 0; + uint16_t numberConcentrationPm10p0Raw = 0; int16_t localError = 0; localError = readNumberConcentrationValuesAsIntegers( - massConcentrationPm0p5Raw, massConcentrationPm1p0Raw, - massConcentrationPm2p5Raw, massConcentrationPm4p0Raw, - massConcentrationPm10p0Raw); - if (localError != NO_ERROR) { - return localError; - } - massConcentrationPm0p5 = SensirionI2cSen66::signalMassConcentrationPm0p5( - massConcentrationPm0p5Raw); - massConcentrationPm1p0 = SensirionI2cSen66::signalMassConcentrationPm1p0( - massConcentrationPm1p0Raw); - massConcentrationPm2p5 = SensirionI2cSen66::signalMassConcentrationPm2p5( - massConcentrationPm2p5Raw); - massConcentrationPm4p0 = SensirionI2cSen66::signalMassConcentrationPm4p0( - massConcentrationPm4p0Raw); - massConcentrationPm10p0 = SensirionI2cSen66::signalMassConcentrationPm10p0( - massConcentrationPm10p0Raw); + numberConcentrationPm0p5Raw, numberConcentrationPm1p0Raw, + numberConcentrationPm2p5Raw, numberConcentrationPm4p0Raw, + numberConcentrationPm10p0Raw); + if (localError != NO_ERROR) { + return localError; + } + numberConcentrationPm0p5 = + SensirionI2cSen66::signalNumberConcentrationPm0p5( + numberConcentrationPm0p5Raw); + numberConcentrationPm1p0 = + SensirionI2cSen66::signalNumberConcentrationPm1p0( + numberConcentrationPm1p0Raw); + numberConcentrationPm2p5 = + SensirionI2cSen66::signalNumberConcentrationPm2p5( + numberConcentrationPm2p5Raw); + numberConcentrationPm4p0 = + SensirionI2cSen66::signalNumberConcentrationPm4p0( + numberConcentrationPm4p0Raw); + numberConcentrationPm10p0 = + SensirionI2cSen66::signalNumberConcentrationPm10p0( + numberConcentrationPm10p0Raw); return localError; } diff --git a/src/SensirionI2cSen66.h b/src/SensirionI2cSen66.h index 1dbce96..a1c3d7e 100644 --- a/src/SensirionI2cSen66.h +++ b/src/SensirionI2cSen66.h @@ -3,7 +3,7 @@ * * Generator: sensirion-driver-generator 1.0.1 * Product: sen66 - * Model-Version: 1.3.0 + * Model-Version: 1.3.1 */ /* * Copyright (c) 2024, Sensirion AG @@ -106,14 +106,14 @@ class SensirionI2cSen66 { /** * @brief Read measured values and apply scaling as defined in datasheet. * - * @param[out] massConcentrationPm1p0 Mass concentration for particles - * smaller than 1.0 μm. - * @param[out] massConcentrationPm2p5 Mass concentration for particles - * smaller than 2.5 μm. - * @param[out] massConcentrationPm4p0 Mass concentration for particles - * smaller than 4.0 μm. - * @param[out] massConcentrationPm10p0 Mass concentration for particles - * smaller than 10.0 μm. + * @param[out] massConcentrationPm1p0 Mass concentration in μg/m³ for + * particles smaller than 1.0 μm. + * @param[out] massConcentrationPm2p5 Mass concentration in μg/m³ for + * particles smaller than 2.5 μm. + * @param[out] massConcentrationPm4p0 Mass concentration in μg/m³ for + * particles smaller than 4.0 μm. + * @param[out] massConcentrationPm10p0 Mass concentration in μg/m³ for + * particles smaller than 10.0 μm. * @param[out] humidity Measured humidity in %RH. * @param[out] temperature Measured temperature in degrees celsius. * @param[out] vocIndex Measured VOC Index between 0 and 500. @@ -133,24 +133,24 @@ class SensirionI2cSen66 { * @brief Read measured number concentration values and apply scaling as * defined in datasheet. * - * @param[out] massConcentrationPm0p5 Mass concentration for particles - * smaller than 1.0 μm. - * @param[out] massConcentrationPm1p0 Mass concentration for particles - * smaller than 1.0 μm. - * @param[out] massConcentrationPm2p5 Mass concentration for particles - * smaller than 2.5 μm. - * @param[out] massConcentrationPm4p0 Mass concentration for particles - * smaller than 4.0 μm. - * @param[out] massConcentrationPm10p0 Mass concentration for particles - * smaller than 10.0 μm. + * @param[out] numberConcentrationPm0p5 Number concentration in + * particles/cm³ for particles smaller than 0.5 μm. + * @param[out] numberConcentrationPm1p0 Number concentration in + * particles/cm³ for particles smaller than 1.0 μm. + * @param[out] numberConcentrationPm2p5 Number concentration in + * particles/cm³ for particles smaller than 2.5 μm. + * @param[out] numberConcentrationPm4p0 Number concentration in + * particles/cm³ for particles smaller than 4.0 μm. + * @param[out] numberConcentrationPm10p0 Number concentration in + * particles/cm³ for particles smaller than 10.0 μm. * * @return error_code 0 on success, an error code otherwise. */ - int16_t readNumberConcentrationValues(float& massConcentrationPm0p5, - float& massConcentrationPm1p0, - float& massConcentrationPm2p5, - float& massConcentrationPm4p0, - float& massConcentrationPm10p0); + int16_t readNumberConcentrationValues(float& numberConcentrationPm0p5, + float& numberConcentrationPm1p0, + float& numberConcentrationPm2p5, + float& numberConcentrationPm4p0, + float& numberConcentrationPm10p0); /** * @brief Start a continuous measurement (interval 1s) @@ -880,22 +880,12 @@ class SensirionI2cSen66 { */ int16_t deviceReset(); - /** - * @brief signalMassConcentrationPm0p5 - * - * @param[in] massConcentrationPm0p5Raw - * - * @return Mass concentration for particles smaller than 0.5 μm - */ - static float - signalMassConcentrationPm0p5(uint16_t massConcentrationPm0p5Raw); - /** * @brief signalMassConcentrationPm1p0 * * @param[in] massConcentrationPm1p0Raw * - * @return Mass concentration for particles smaller than 1.0 μm + * @return Mass concentration in μg/m³ for particles smaller than 1.0 μm */ static float signalMassConcentrationPm1p0(uint16_t massConcentrationPm1p0Raw); @@ -905,7 +895,7 @@ class SensirionI2cSen66 { * * @param[in] massConcentrationPm2p5Raw * - * @return Mass concentration for particles smaller than 2.5 μm + * @return Mass concentration in μg/m³ for particles smaller than 2.5 μm */ static float signalMassConcentrationPm2p5(uint16_t massConcentrationPm2p5Raw); @@ -915,7 +905,7 @@ class SensirionI2cSen66 { * * @param[in] massConcentrationPm4p0Raw * - * @return Mass concentration for particles smaller than 4.0 μm + * @return Mass concentration in μg/m³ for particles smaller than 4.0 μm */ static float signalMassConcentrationPm4p0(uint16_t massConcentrationPm4p0Raw); @@ -925,11 +915,66 @@ class SensirionI2cSen66 { * * @param[in] massConcentrationPm10p0Raw * - * @return Mass concentration for particles smaller than 10.0 μm + * @return Mass concentration in μg/m³ for particles smaller than 10.0 μm */ static float signalMassConcentrationPm10p0(uint16_t massConcentrationPm10p0Raw); + /** + * @brief signalNumberConcentrationPm0p5 + * + * @param[in] numberConcentrationPm0p5Raw + * + * @return Number concentration in particles/cm³ for particles smaller than + * 0.5 μm + */ + static float + signalNumberConcentrationPm0p5(uint16_t numberConcentrationPm0p5Raw); + + /** + * @brief signalNumberConcentrationPm1p0 + * + * @param[in] numberConcentrationPm1p0Raw + * + * @return Number concentration in particles/cm³ for particles smaller + * than 1.0 μm + */ + static float + signalNumberConcentrationPm1p0(uint16_t numberConcentrationPm1p0Raw); + + /** + * @brief signalNumberConcentrationPm2p5 + * + * @param[in] numberConcentrationPm2p5Raw + * + * @return Number concentration in particles/cm³ for particles smaller + * than 2.5 μm + */ + static float + signalNumberConcentrationPm2p5(uint16_t numberConcentrationPm2p5Raw); + + /** + * @brief signalNumberConcentrationPm4p0 + * + * @param[in] numberConcentrationPm4p0Raw + * + * @return Number concentration in particles/cm³ for particles smaller + * than 4.0 μm + */ + static float + signalNumberConcentrationPm4p0(uint16_t numberConcentrationPm4p0Raw); + + /** + * @brief signalNumberConcentrationPm10p0 + * + * @param[in] numberConcentrationPm10p0Raw + * + * @return Number concentration in particles/cm³ for particles smaller + * than 10.0 μm + */ + static float + signalNumberConcentrationPm10p0(uint16_t numberConcentrationPm10p0Raw); + /** * @brief signalTemperature *