Development

Sensors / Gases Board:

» Ga 09: Socket3B Sensor Reading

In this example the Gases 2.0 board and socket 3B (for the MiCS 2710 NO2 sensor) are turned on, waiting for the minimum heating time and then reading the sensor every second while printing the output voltage and sensor resistance through the USB.

Required Materials

1 x Waspmote
1 x Battery
1 x Coin cell
1 x Gases 2.0 board
1 x NO2 Sensor (MiCS 2610)

Notes

* Remember to connect the battery to Waspmote for proper operation.
* The connection of the sensor is described in the Gases 2.0 technical guide.
* The sensor gain and load resistor have been adjusted to operate with a given unit of a MiCS 2710 sensor, they will depend on the sensor used and the application, for more information about how to select this parameters take a look at the Gases 2.0 board technical guide.

Code

/*  
 *  ------ [Ga_9] - Socket3B Reading for Gases v20-------- 
 *  
 *  Explanation: Turn on the Gases Board v20 and reads the sensor
 *  placed on socket 3B every second, printing the result
 *  through the USB
 *  
 *  Copyright (C) 2012 Libelium Comunicaciones Distribuidas S.L. 
 *  http://www.libelium.com 
 *  
 *  This program is free software: you can redistribute it and/or modify 
 *  it under the terms of the GNU General Public License as published by 
 *  the Free Software Foundation, either version 3 of the License, or 
 *  (at your option) any later version. 
 *  
 *  This program is distributed in the hope that it will be useful, 
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of 
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the 
 *  GNU General Public License for more details. 
 *  
 *  You should have received a copy of the GNU General Public License 
 *  along with this program.  If not, see <http://www.gnu.org/licenses/>. 
 *  
 *  Version:           0.1 
 *  Design:            David Gascón 
 *  Implementation:    
 */

#include <WaspSensorGas_v20.h>

#define GAIN  1      // GAIN of the sensor stage
#define RESISTOR 3   // LOAD RESISTOR of the sensor stage

// Variable to store the read value
float socket3BVal;

void setup()
{
  // Turn on the USB and print a start message
  USB.ON();
  USB.println(F("start"));
  delay(100);

  // Turn on the sensor board
  SensorGasv20.ON();

  // Turn on the RTC
  RTC.ON();

  // Configure the 3B sensor socket
  SensorGasv20.configureSensor(SENS_SOCKET3B, GAIN, RESISTOR);

  
  // Turn on the sensor on socket 3B and wait for stabilization and
  // sensor response time
  SensorGasv20.setSensorMode(SENS_ON, SENS_SOCKET3B);
  delay(40000);
 
}
 
void loop()
{
  
  // Read the sensor 
  socket3BVal = SensorGasv20.readValue(SENS_SOCKET3B);
  
  // Print the result through the USB
  USB.print(F("SOCKET3B: "));
  USB.print(socket3BVal);
  USB.print(F("V - "));
  
  // Conversion from voltage into kiloohms
  socket3BVal = SensorGasv20.calculateResistance(SENS_SOCKET3B, socket3BVal, GAIN, RESISTOR);
  USB.print(socket3BVal);
  USB.println("kohms");
  
  
  delay(1000);
}

Output

B#
start
SOCKET3B: 0.9064516067V - 3.9708406448kohms
SOCKET3B: 0.9032258033V - 3.9966079711kohms
SOCKET3B: 0.9032258033V - 3.9966079711kohms
SOCKET3B: 0.9032258033V - 3.9966079711kohms

Quick Publish: