summaryrefslogtreecommitdiff
path: root/peripheral/libupm/src/mg811
diff options
context:
space:
mode:
Diffstat (limited to 'peripheral/libupm/src/mg811')
-rw-r--r--peripheral/libupm/src/mg811/CMakeLists.txt5
-rw-r--r--peripheral/libupm/src/mg811/javaupm_mg811.i19
-rw-r--r--peripheral/libupm/src/mg811/jsupm_mg811.i8
-rw-r--r--peripheral/libupm/src/mg811/mg811.cxx94
-rw-r--r--peripheral/libupm/src/mg811/mg811.h147
-rw-r--r--peripheral/libupm/src/mg811/pyupm_mg811.i11
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"
-%}