diff --git a/examples/menu_a_la_carte/menu_a_la_carte.ino b/examples/menu_a_la_carte/menu_a_la_carte.ino index b991ea2d0..ca1397a25 100644 --- a/examples/menu_a_la_carte/menu_a_la_carte.ino +++ b/examples/menu_a_la_carte/menu_a_la_carte.ino @@ -2162,6 +2162,38 @@ Variable* y511Temp = #endif +#if defined BUILD_SENSOR_YOSEMITECH_Y513 +// ========================================================================== +// Yosemitech Y513 Blue Green Algae (BGA) Sensor +// ========================================================================== +/** Start [yosemitech_y513] */ +#include + +// NOTE: Extra hardware and software serial ports are created in the "Settings +// for Additional Serial Ports" section + +// NOTE: Use -1 for any pins that don't apply or aren't being used. +byte y513ModbusAddress = 0x13; // The modbus address of the Y513 +const int8_t y513AdapterPower = sensorPowerPin; // RS485 adapter power pin +const int8_t y513SensorPower = modbusSensorPowerPin; // Sensor power pin +const int8_t y513EnablePin = -1; // Adapter RE/DE pin +const uint8_t y513NumberReadings = 5; +// The manufacturer recommends averaging 10 readings, but we take 5 to minimize +// power consumption + +// Create a Y513 Blue Green Algae (BGA) sensor object +YosemitechY513 y513(y513ModbusAddress, modbusSerial, y513AdapterPower, + y513SensorPower, y513EnablePin, y513NumberReadings); + +// Create Blue Green Algae (BGA) concentration and temperature variable +// pointers for the Y513 +Variable* y513BGA = new YosemitechY513_BGA( + &y513, "12345678-abcd-1234-ef00-1234567890ab"); +Variable* y513Temp = + new YosemitechY513_Temp(&y513, "12345678-abcd-1234-ef00-1234567890ab"); +/** End [yosemitech_y513] */ +#endif + #if defined BUILD_SENSOR_YOSEMITECH_Y514 // ========================================================================== // Yosemitech Y514 Chlorophyll Sensor @@ -2800,6 +2832,10 @@ Variable* variableList[] = { y511Turb, y511Temp, #endif +#if defined BUILD_SENSOR_YOSEMITECH_Y513 + y513BGA, + y513Temp, +#endif #if defined BUILD_SENSOR_YOSEMITECH_Y514 y514Chloro, y514Temp, diff --git a/library.json b/library.json index a8518e866..8d09a01bc 100644 --- a/library.json +++ b/library.json @@ -303,7 +303,7 @@ "owner": "envirodiy", "library id": "1824", "url": "https://github.com/EnviroDIY/SensorModbusMaster", - "version": "~0.6.8", + "version": "~0.7.3", "note": "EnviroDIY SensorModbusMaster - Arduino library for communicating via modbus with the Arduino acting as the modbus master.", "authors": ["Sara Damiano"], "frameworks": "arduino", @@ -323,7 +323,7 @@ "owner": "envirodiy", "library id": "2078", "url": "https://github.com/EnviroDIY/YosemitechModbus", - "version": "~0.4.1", + "version": "~0.5.0", "note": "Arduino library for communication with Yosemitech sensors via Modbus.", "authors": ["Sara Damiano", "Anthony Aufdenkampe"], "frameworks": "arduino", diff --git a/src/sensors/YosemitechParent.cpp b/src/sensors/YosemitechParent.cpp index eebe0e6b4..c3587dfd0 100644 --- a/src/sensors/YosemitechParent.cpp +++ b/src/sensors/YosemitechParent.cpp @@ -104,8 +104,8 @@ bool YosemitechParent::wake(void) { // Manually activate the brush // Needed for newer sensors that do not immediate activate on getting power - if (_model == Y511 || _model == Y514 || _model == Y551 || _model == Y560 || - _model == Y4000) { + if (_model == Y511 || _model == Y513 || _model == Y514 || _model == Y551 || + _model == Y560 || _model == Y4000) { MS_DBG(F("Activate Brush on"), getSensorNameAndLocation()); if (_ysensor.activateBrush()) { MS_DBG(F("Brush activated.")); diff --git a/src/sensors/YosemitechY513.h b/src/sensors/YosemitechY513.h new file mode 100644 index 000000000..3a32dfdb4 --- /dev/null +++ b/src/sensors/YosemitechY513.h @@ -0,0 +1,283 @@ +/** + * @file YosemitechY513.h + * @copyright Stroud Water Research Center + * Part of the EnviroDIY ModularSensors library for Arduino. + * This library is published under the BSD-3 license. + * @author Anthony Aufdenkampe + * + * @brief Contains the YosemitechY513 sensor subclass and the variable + * subclasses YosemitechY513_BGA and YosemitechY513_Temp. + * + * These are for the Yosemitech Y513 Blue Green Algae (BGA) sensor with wiper. + * + * This depends on the YosemitechParent super class. + * + * Documentation for the Modbus Protocol commands and responses can be found + * within the documentation in the YosemitechModbus library at: + * https://github.com/EnviroDIY/YosemitechModbus + */ +/* clang-format off */ +/** + * @defgroup sensor_y513 Yosemitech Y513 self-cleaning Blue Green Algae (BGA) sensor. + * Classes for the Yosemitech Y513 Blue Green Algae (BGA) sensor with wiper. + * + * @ingroup yosemitech_group + * + * @tableofcontents + * @m_footernavigation + * + * @section sensor_y513_datasheet Sensor Datasheet + * - [Y513 product webpage](https://e.yosemitech.com/CHL/Y513-A.html) + * + * @note The reported resolution (32 bit) gives far more precision than is significant + * based on the specified accuracy of the sensor, so the resolutions kept in the + * string representation of the variable values is based on the accuracy not the + * maximum reported resolution of the sensor. + * + * @section sensor_y513_ctor Sensor Constructor + * {{ @ref YosemitechY513::YosemitechY513 }} + * + * ___ + * @section sensor_y513_examples Example Code + * The Yosemitech Y513 Blue Green Algae sensor is used in the @menulink{yosemitech_y513} + * example. + * + * @menusnip{yosemitech_y513} + */ +/* clang-format on */ + +// Header Guards +#ifndef SRC_SENSORS_YOSEMITECHY513_H_ +#define SRC_SENSORS_YOSEMITECHY513_H_ + +// Included Dependencies +#include "sensors/YosemitechParent.h" + +/** @ingroup sensor_y513 */ +/**@{*/ + +// Sensor Specific Defines +/// @brief Sensor::_numReturnedValues; the Y513 can report 2 values. +#define Y513_NUM_VARIABLES 2 +/// @brief Sensor::_incCalcValues; we don't calculate any additional values. +#define Y513_INC_CALC_VARIABLES 0 + +/** + * @anchor sensor_y513_timing + * @name Sensor Timing + * The sensor timing for a Yosemitch Y513 + */ +/**@{*/ +/// @brief Sensor::_warmUpTime_ms; time before sensor responds after power - 1.3 +/// seconds (1300ms). +#define Y513_WARM_UP_TIME_MS 1300 +/// @brief Sensor::_stabilizationTime_ms; time between "StartMeasurement" +/// command and stable reading - 8sec (8000ms). +#define Y513_STABILIZATION_TIME_MS 8000 +/// @brief Sensor::_measurementTime_ms; the Y513 takes ~2000ms to complete a +/// measurement. +#define Y513_MEASUREMENT_TIME_MS 2000 +/**@}*/ + +/** + * @anchor sensor_y513_bga + * @name Chlorophyll Concentration + * The blue green algae concentration variable from a Yosemitch Y513 + * - Range is 0 to 400 µg/L or 0 to 100 RFU + * - Accuracy is ± 1 % + * + * {{ @ref YosemitechY513_BGA::YosemitechY513_BGA }} + */ +/**@{*/ +/// @brief Decimals places in string representation; blue green algae concentration +/// should have 1 - resolution is 0.1 µg/L / 0.1 RFU. +#define Y513_BGA_RESOLUTION 1 +/// @brief Sensor variable number; blue green algae concentration is stored in +/// sensorValues[0]. +#define Y513_BGA_VAR_NUM 0 +/// @brief Variable name in +/// [ODM2 controlled vocabulary](http://vocabulary.odm2.org/variablename/); +/// "blue_GreenAlgae_Cyanobacteria_Phycocyanin" +#define Y513_BGA_VAR_NAME "Blue-green algae (cyanobacteria), phycocyanin" +/// @brief Variable unit name in +/// [ODM2 controlled vocabulary](http://vocabulary.odm2.org/units/); +/// "countPerMilliliter" (cells/mL) +#define Y513_BGA_UNIT_NAME "countPerMilliliter" +/// @brief Default variable short code; "Y513BGA" +#define Y513_BGA_DEFAULT_CODE "Y513BGA" +/**@}*/ + +/** + * @anchor sensor_y513_temp + * @name Temperature + * The temperature variable from a Yosemitch Y513 + * - Range is 0°C to + 50°C + * - Accuracy is ± 0.2°C + * + * {{ @ref YosemitechY513_Temp::YosemitechY513_Temp }} + */ +/**@{*/ +/// @brief Decimals places in string representation; temperature should have 1 - +/// resolution is 0.1°C. +#define Y513_TEMP_RESOLUTION 1 +/// @brief Sensor variable number; temperature is stored in sensorValues[1]. +#define Y513_TEMP_VAR_NUM 1 +/// @brief Variable name in +/// [ODM2 controlled vocabulary](http://vocabulary.odm2.org/variablename/); +/// "temperature" +#define Y513_TEMP_VAR_NAME "temperature" +/// @brief Variable unit name in +/// [ODM2 controlled vocabulary](http://vocabulary.odm2.org/units/); +/// "degreeCelsius" (°C) +#define Y513_TEMP_UNIT_NAME "degreeCelsius" +/// @brief Default variable short code; "Y513Temp" +#define Y513_TEMP_DEFAULT_CODE "Y513Temp" +/**@}*/ + + +/* clang-format off */ +/** + * @brief The Sensor sub-class for the + * [Yosemitech Y513 sensor](@ref sensor_y513). + * + * @ingroup sensor_y513 + */ +/* clang-format on */ +class YosemitechY513 : public YosemitechParent { + public: + // Constructors with overloads + /** + * @brief Construct a new Yosemitech Y513 object. + * + * @param modbusAddress The modbus address of the sensor. + * @param stream An Arduino data stream for modbus communication. See + * [notes](@ref page_arduino_streams) for more information on what streams + * can be used. + * @param powerPin The pin on the mcu controlling power to the Y513. + * Use -1 if it is continuously powered. + * @param powerPin2 The pin on the mcu controlling power to the RS485 + * adapter, if it is different from that used to power the sensor. Use -1 + * or omit if not applicable. + * @param enablePin The pin on the mcu controlling the direction enable on + * the RS485 adapter, if necessary; use -1 or omit if not applicable. + * @note An RS485 adapter with integrated flow control is strongly + * recommended. + * @param measurementsToAverage The number of measurements to take and + * average before giving a "final" result from the sensor; optional with a + * default value of 1. + */ + YosemitechY513(byte modbusAddress, Stream* stream, int8_t powerPin, + int8_t powerPin2 = -1, int8_t enablePin = -1, + uint8_t measurementsToAverage = 1) + : YosemitechParent(modbusAddress, stream, powerPin, powerPin2, + enablePin, measurementsToAverage, Y513, + "YosemitechY513", Y513_NUM_VARIABLES, + Y513_WARM_UP_TIME_MS, Y513_STABILIZATION_TIME_MS, + Y513_MEASUREMENT_TIME_MS, Y513_INC_CALC_VARIABLES) {} + /** + * @copydoc YosemitechY513::YosemitechY513 + */ + YosemitechY513(byte modbusAddress, Stream& stream, int8_t powerPin, + int8_t powerPin2 = -1, int8_t enablePin = -1, + uint8_t measurementsToAverage = 1) + : YosemitechParent(modbusAddress, stream, powerPin, powerPin2, + enablePin, measurementsToAverage, Y513, + "YosemitechY513", Y513_NUM_VARIABLES, + Y513_WARM_UP_TIME_MS, Y513_STABILIZATION_TIME_MS, + Y513_MEASUREMENT_TIME_MS, Y513_INC_CALC_VARIABLES) {} + /** + * @brief Destroy the Yosemitech Y513 object + */ + ~YosemitechY513() {} +}; + + +/* clang-format off */ +/** + * @brief The Variable sub-class used for the + * [blue green algae concentration output](@ref sensor_y513_bga) from a + * [Yosemitech Y513 Blue Green Algae (BGA) sensor with wiper](@ref sensor_y513). + * + * @ingroup sensor_y513 + */ +/* clang-format on */ +class YosemitechY513_BGA : public Variable { + public: + /** + * @brief Construct a new YosemitechY513_BGA object. + * + * @param parentSense The parent YosemitechY513 providing the result + * values. + * @param uuid A universally unique identifier (UUID or GUID) for the + * variable; optional with the default value of an empty string. + * @param varCode A short code to help identify the variable in files; + * optional with a default value of "Y513BGA". + */ + explicit YosemitechY513_BGA( + YosemitechY513* parentSense, const char* uuid = "", + const char* varCode = Y513_BGA_DEFAULT_CODE) + : Variable(parentSense, (const uint8_t)Y513_BGA_VAR_NUM, + (uint8_t)Y513_BGA_RESOLUTION, Y513_BGA_VAR_NAME, + Y513_BGA_UNIT_NAME, varCode, uuid) {} + /** + * @brief Construct a new YosemitechY513_BGA object. + * + * @note This must be tied with a parent YosemitechY513 before it can be + * used. + */ + YosemitechY513_BGA() + : Variable((const uint8_t)Y513_BGA_VAR_NUM, + (uint8_t)Y513_BGA_RESOLUTION, Y513_BGA_VAR_NAME, + Y513_BGA_UNIT_NAME, Y513_BGA_DEFAULT_CODE) {} + /** + * @brief Destroy the YosemitechY513_BGA() object - no action + * needed. + */ + ~YosemitechY513_BGA() {} +}; + + +/* clang-format off */ +/** + * @brief The Variable sub-class used for the + * [temperature output](@ref sensor_y513_temp) from a + * [Yosemitech Y513-A blue green algae sensor with wiper](@ref sensor_y513). + * + * @ingroup sensor_y513 + */ +/* clang-format on */ +class YosemitechY513_Temp : public Variable { + public: + /** + * @brief Construct a new YosemitechY513_Temp object. + * + * @param parentSense The parent YosemitechY513 providing the result + * values. + * @param uuid A universally unique identifier (UUID or GUID) for the + * variable; optional with the default value of an empty string. + * @param varCode A short code to help identify the variable in files; + * optional with a default value of "Y513Temp". + */ + explicit YosemitechY513_Temp(YosemitechY513* parentSense, + const char* uuid = "", + const char* varCode = Y513_TEMP_DEFAULT_CODE) + : Variable(parentSense, (const uint8_t)Y513_TEMP_VAR_NUM, + (uint8_t)Y513_TEMP_RESOLUTION, Y513_TEMP_VAR_NAME, + Y513_TEMP_UNIT_NAME, varCode, uuid) {} + /** + * @brief Construct a new YosemitechY513_Temp object. + * + * @note This must be tied with a parent YosemitechY513 before it can be + * used. + */ + YosemitechY513_Temp() + : Variable((const uint8_t)Y513_TEMP_VAR_NUM, + (uint8_t)Y513_TEMP_RESOLUTION, Y513_TEMP_VAR_NAME, + Y513_TEMP_UNIT_NAME, Y513_TEMP_DEFAULT_CODE) {} + /** + * @brief Destroy the YosemitechY513_Temp object - no action needed. + */ + ~YosemitechY513_Temp() {} +}; +/**@}*/ +#endif // SRC_SENSORS_YOSEMITECHY513_H_