A fake version is said to be in circulation which differs in hardware, and at a minimum, ppm stability. If you suspect your sensor is fake or want to be sure, then check with the video here by Hix Field and Revspace's article for more information.
An Arduino library for the MH-Z19X CO2 sensor, which unlocks commands while supporting both software/hardware serial.
See examples for the recovery code. *Note, Only use if your sensor is not recoverable by other means as it recklessly calls span.
- Automatically sends "autocalibration off".
- Filter mode, to detect invalid readings when sensor is recovering from power loss / boot (see example)
- Option to print communcation between device and sensor (for debugging)
- Communication error checking
- Examples
Additions | Existing |
---|---|
CO2 Unlimited | CO2 Limited |
CO2 as Raw | Temperature as Whole Integer |
Custom Range / Span | Request CO2 Calibration |
Reset Sensor | ABC On / Off |
Get Firmware Version | Retrieve Accuracy |
Get Background CO2 Value | |
Get Range Value | |
Get Last Response | |
^Get ABC Status |
^* submitted by SFeli
The library can be found in the IDE/IO library manager. Alternatively, simply clone this library to your working library folder and include "MHZ19.h" in your main sketch.
If you are having issues with specific boards, please contact me (find my details below)
Advice: The MH-Z19 works best in the Range of 2000ppm, outside of this accuracy begins to fall away; this is supported by documentation. I would suggest keeping to this range if you require accuracy.
Relevant Datasheets
-
The Englisih datasheet for the MH-Z19: MH-Z19
-
The English datasheet for the non-JST MH-Z19B version: MH-Z19B NON-JST.
-
The Chinese datasheet for the JST MH-Z19B version (more detailed): MH-Z19B JST.
Auto Calibration: The MH-Z19 is a sensor that is designed to be powered on and rarely turned off. The sensor calibrates over time (if autocalibration is on) using the lowest CO2 observed in the prior 24 hours). After 3 weeks, a value is stored with an accuracy rating, this can be requested using getAccuracy(). ABC must be disabled each day, however this is handled by the library.
Calibration: If you plan to manually calibrate sensor (in my experience this is often be better) then it's important to be aware that Zero calibration does not refer to 0ppm (often a nitrogen environment), instead it refers to 400ppm.
Background Calibration: It's currently unclear how to change this, if possible at all. The value stored on the MH-Z19 and is set to 400ppm. This is used as the zeroing point.
Zero Calibration: This can be made in two ways: By pulling the zero HD low (0V) for 7 Secs, or be sending command 135 (0x87). As above, the Zero refers to the background CO2 value of 400ppm, not 0ppm. Currently testing is the ability to send an adjustment with command at byte 7, however it is unclear the affects this has.
Range: This is essentially your highest and lowest CO2 being measured. 2000ppm is advised. Changing the value usually requires span calibration (diffiuclt), however if you intend to measure abvoe 2000 ppm this can increase accuracy.
Span: I highly recommend avoiding this command unless you have the equipment to do so. It requires the sensor to be at the ppm you are setting it to, e.g. 2000ppm. Roughly, it's difference between lowest and highest range points, for this sensor, it's the same value as range. From tiral and error, it's usually best sent last in the calibrations sequence.
Alarm: The analog output is located on the brown wire on the JST version. On the non-JST version it can be found on the far side, beside the Rx pin. It's unclear at the moment how to change the threshold and is not affected by Range. However, it is possible to attach an amplifier to the Analog Out pin and create an interrupt.
Analog Out: An additional feature of MH-Z19. The output in mV corresponds to ppm when using a range of 2000ppm. Alternatively, calculations can be made to adjust the value (See Examples).
- Reduce memory usage
THE SOFTWARE IS PROVIDED 'AS IS', WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
Myself, you can find my contact details below.
This project is licensed under the Lesser General Public License v3.0 License - see the LICENSE.md file for details
This library was originaly inspired by Strange-V's work! https://github.com/strange-v/MHZ19;
This is one of my first pieces of code, so lots of room for imporvement, feel free to provide constructive feedback; [email protected]
If this library was particularly helpful, and you feel like funding a replacement sensor (brutalised from testing!)