diff options
Diffstat (limited to 'peripheral/libupm/src/mg811')
-rw-r--r-- | peripheral/libupm/src/mg811/CMakeLists.txt | 5 | ||||
-rw-r--r-- | peripheral/libupm/src/mg811/javaupm_mg811.i | 19 | ||||
-rw-r--r-- | peripheral/libupm/src/mg811/jsupm_mg811.i | 8 | ||||
-rw-r--r-- | peripheral/libupm/src/mg811/mg811.cxx | 94 | ||||
-rw-r--r-- | peripheral/libupm/src/mg811/mg811.h | 147 | ||||
-rw-r--r-- | peripheral/libupm/src/mg811/pyupm_mg811.i | 11 |
6 files changed, 0 insertions, 284 deletions
diff --git a/peripheral/libupm/src/mg811/CMakeLists.txt b/peripheral/libupm/src/mg811/CMakeLists.txt deleted file mode 100644 index 66b70da..0000000 --- a/peripheral/libupm/src/mg811/CMakeLists.txt +++ /dev/null @@ -1,5 +0,0 @@ -set (libname "mg811") -set (libdescription "upm DFRobot CO2 sensor") -set (module_src ${libname}.cxx) -set (module_h ${libname}.h) -upm_module_init() diff --git a/peripheral/libupm/src/mg811/javaupm_mg811.i b/peripheral/libupm/src/mg811/javaupm_mg811.i deleted file mode 100644 index 3f7e201..0000000 --- a/peripheral/libupm/src/mg811/javaupm_mg811.i +++ /dev/null @@ -1,19 +0,0 @@ -%module javaupm_mg811 -%include "../upm.i" - -%{ - #include "mg811.h" -%} - -%include "mg811.h" - -%pragma(java) jniclasscode=%{ - static { - try { - System.loadLibrary("javaupm_mg811"); - } catch (UnsatisfiedLinkError e) { - System.err.println("Native code library failed to load. \n" + e); - System.exit(1); - } - } -%}
\ No newline at end of file diff --git a/peripheral/libupm/src/mg811/jsupm_mg811.i b/peripheral/libupm/src/mg811/jsupm_mg811.i deleted file mode 100644 index 0a4a4bb..0000000 --- a/peripheral/libupm/src/mg811/jsupm_mg811.i +++ /dev/null @@ -1,8 +0,0 @@ -%module jsupm_mg811 -%include "../upm.i" - -%{ - #include "mg811.h" -%} - -%include "mg811.h" diff --git a/peripheral/libupm/src/mg811/mg811.cxx b/peripheral/libupm/src/mg811/mg811.cxx deleted file mode 100644 index 622dd85..0000000 --- a/peripheral/libupm/src/mg811/mg811.cxx +++ /dev/null @@ -1,94 +0,0 @@ -/* - * Author: Jon Trulson <jtrulson@ics.com> - * Copyright (c) 2015 Intel Corporation. - * - * Thanks to public domain code by Martin Liddament for some useful clues! - * http://www.veetech.org.uk/CO2_Monitor_Sketch_2_Operation.txt - * and sandbox electronics (http://sandboxelectronics.com/?p=147). - * - * Permission is hereby granted, free of charge, to any person obtaining - * a copy of this software and associated documentation files (the - * "Software"), to deal in the Software without restriction, including - * without limitation the rights to use, copy, modify, merge, publish, - * distribute, sublicense, and/or sell copies of the Software, and to - * permit persons to whom the Software is furnished to do so, subject to - * the following conditions: - * - * The above copyright notice and this permission notice shall be - * included in all copies or substantial portions of the Software. - * - * 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. - */ - -#include <iostream> -#include <math.h> -#include "mg811.h" - -using namespace std; -using namespace upm; - -// voltage gain of the DC amplifier -static const float dcGain = 8.5; - -MG811::MG811(int pin, int dpin, float aref) : - m_aio(pin), m_gpio(dpin) -{ - m_aRes = m_aio.getBit(); - m_aref = aref; - - m_gpio.dir(mraa::DIR_IN); - - // these are just placeholder values (coarsely measured during - // development), you should determine the appropriate values (in - // volts) for your environment at the specified concentrations. Use - // the getReferenceVoltage() method to get these values at 400ppm - // and 1000ppm respectively. Good luck. - setCalibration(0.5514, 0.370); -} - -MG811::~MG811() -{ -} - -float MG811::volts() -{ - int val = m_aio.read(); - - return(float(val) * (m_aref / float(1 << m_aRes))); -} - -void MG811::setCalibration(float ppm400, float ppm1000) -{ - m_zeroPointValue = ppm400; - m_reactionValue = ppm1000; -} - -float MG811::getReferenceVoltage() -{ - return (volts() / dcGain); -} - -float MG811::ppm() -{ - static const float log400 = log10f(400); - static const float log1000 = log10f(1000); - - float val = volts(); - - if ((val / dcGain) >= m_zeroPointValue) - return 0.0; - else - return powf(10.0, ((val/dcGain)-m_zeroPointValue) / - (m_reactionValue / (log400-log1000))+log400); -} - -bool MG811::thresholdReached() -{ - return (m_gpio.read() ? true : false); -} diff --git a/peripheral/libupm/src/mg811/mg811.h b/peripheral/libupm/src/mg811/mg811.h deleted file mode 100644 index d8c4934..0000000 --- a/peripheral/libupm/src/mg811/mg811.h +++ /dev/null @@ -1,147 +0,0 @@ -/* - * Author: Jon Trulson <jtrulson@ics.com> - * Copyright (c) 2015 Intel Corporation. - * - * Permission is hereby granted, free of charge, to any person obtaining - * a copy of this software and associated documentation files (the - * "Software"), to deal in the Software without restriction, including - * without limitation the rights to use, copy, modify, merge, publish, - * distribute, sublicense, and/or sell copies of the Software, and to - * permit persons to whom the Software is furnished to do so, subject to - * the following conditions: - * - * The above copyright notice and this permission notice shall be - * included in all copies or substantial portions of the Software. - * - * 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. - */ -#pragma once - -#include <iostream> -#include <string> -#include <mraa/aio.hpp> -#include <mraa/gpio.hpp> - -namespace upm { - /** - * @brief DFRobot CO2 Sensor - * @defgroup mg811 libupm-mg811 - * @ingroup dfrobot analog gas - */ - - /** - * @library mg811 - * @sensor mg811 - * @comname DFRobot CO2 Sensor - * @altname MG811 - * @type gas - * @man dfrobot - * @web http://www.dfrobot.com/index.php?route=product/product&product_id=1023 - * @con analog - * - * @brief API for the DFRobot CO2 Sensor - * - * This sensor returns an an analog voltage that falls as the - * concentration of CO2 increases. It contains a heater that must - * be allowed to 'warm' up the sensor before measurements are stable - * (hours to days is the recommendation). It requires that the MCU - * be powered from an external power supply (not USB) at 5v, since - * the heater will consume significant current. - * - * The sensor should be allowed to 'heat' up for some time before - * beginning use, typically a couple of hours minimum. It also - * needs fairly precise calibration at 400ppm and 1000ppm to return - * meaningful results. - * - * The sensor also incorporates a potentiometer that can be adjusted - * to specific threshold. Once that threshold is reached, an LED - * on the sensor will light, and the digital pin will be driven - * high. - * - * @image html mg811.jpg - * @snippet mg811.cxx Interesting - */ - - class MG811 { - public: - - /** - * MG811 constructor - * - * @param pin Analog pin to use - * @param dpin Digital pin that indicates threshold - * @param aref Analog reference voltage; default is 5.0 V - */ - MG811(int pin, int dpin, float aref=5.0); - - /** - * MG811 destructor - */ - ~MG811(); - - /** - * Return a cumputed reference voltage to be used in calibration. - * @return Computed reference voltage - */ - float getReferenceVoltage(); - - /** - * Set calibration parameters. You should measure the reference - * voltage you get when at CO2 concentrations of 400ppm (ambient) - * and 1000ppm using the getReferenceVoltage() method. Then - * specify those voltages here for more accurate results. - * - * @param ppm400 The measured reference voltage at 400 ppm - * @param ppm40000 The measured reference voltage at 1000 ppm - */ - void setCalibration(float ppm400, float ppm1000); - - /** - * Returns the voltage detected on the analog pin - * - * @return The detected voltage - */ - float volts(); - - /** - * Returns the computed CO2 concentration in ppm (Parts Per - * Million). This method will return 0.0 if the reference voltage - * is greater than the ppm400 value. Essentially, ppm values - * below 400 will be reported as 0. - * - * @return The computed CO2 concentration in ppm - */ - float ppm(); - - /** - * Read the digital pin and return true if the set threshold has - * been reached or exceeded. This threshold is set by adjusting - * the potentiometer on the sensor. - * - * @return true if the threshold has been reached, false otherwise - */ - bool thresholdReached(); - - protected: - mraa::Aio m_aio; - mraa::Gpio m_gpio; - - // calibration values - float m_zeroPointValue; - float m_reactionValue; - - // ADC resolution - int m_aRes; - - private: - float m_aref; - }; -} - - diff --git a/peripheral/libupm/src/mg811/pyupm_mg811.i b/peripheral/libupm/src/mg811/pyupm_mg811.i deleted file mode 100644 index 614da5c..0000000 --- a/peripheral/libupm/src/mg811/pyupm_mg811.i +++ /dev/null @@ -1,11 +0,0 @@ -// Include doxygen-generated documentation -%include "pyupm_doxy2swig.i" -%module pyupm_mg811 -%include "../upm.i" - -%feature("autodoc", "3"); - -%include "mg811.h" -%{ - #include "mg811.h" -%} |