Connecting the gas sensors
The gas sensors are used to monitor the environment and we can choose different kinds of such devices. I decided to use the ones shown in the following screenshot due to the fact they act as a variable resistor according to the gas concentration, so they can be easily read with a normal ADC:
In the prototype presented here, the gas sensors are actually four, but the ones named
MQ-2 (smoke detector),
MQ-4 (methane detector), and MQ-7 (LPG detector) look very similar to each other (except the label on each sensor), so I reported only one of them in the preceding screenshot, while the carbon monoxide detector is the red device labeled with MQ-7.
Note
The devices can be purchased at the following links (or by surfing the Internet):
The following are the URLs where we can get the datasheet for each GAS sensor:
Looking carefully at the datasheet of the gas sensors, we can see exactly how these sensors' class varies their internal resistance according to the gas concentration (in reality, it depends on environment humidity and temperature too; but for an indoor functioning, we can consider these values as constants). So, if we put it in series with a resistor and apply a constant voltage). We can get an output voltage that is proportional to the actual gas concentration.
The following diagram shows a possible schematics where the gas sensor is connected to 5V power supply and the RL resistor is formed by two resistors (R1 & R2) due to the fact we cannot put more than 1.8V at a BeagleBone Black's ADC pin. So, by choosing these two resistors in such a way that R1 ≥ 2*R2, we can be sure we have no more than 5.0V/3 ≈ 1.67V at the ADC input pin on every possible functioning condition, even if the sensor's internal resistance is shorted. However, to be completely sure we can add a Zener diode (Z) with a reverse threshold on 1.8V (but I didn't use it on my prototype).
The following diagram shows the circuitry I used to connect each sensor:
Tip
Note that the GAS sensors have six pins labeled in pairs as A, B, and H; while the A and B pair pins are shortened, the H labeled pairs must be connected at one end to the input voltage (5V in our case) and the other end to the GND (see the datasheet for further information).
Another important issue regarding these sensors is the calibration we should perform before using them. This last adjustment is very important; as reported in the MQ-2 datasheet, we read the following recommendation:
We recommend that you calibrate the detector for 1000 ppm
liquefied petroleum gas (LPG), or 1000ppm iso-butane (i-C4H10) concentration in air and use value of load resistance
that (RL) about 20K (5K to 47K).
This step can be done by replacing resistors R1 or R2 with a varistor and then fine tuning its resistance. However, I decided to use normal resistors (R1 = 15KΩ, R2 = 6.8KΩ in such a way that RL = R1 + R2 ≈ 20KΩ, as suggested by the datasheet) and then implemented a little translation in software (see the following section), that is, we can translate raw data from the ADCs into a ppm (part-per-million) value in such a way the user can work with physic data.
This translation can be done using a gain and an offset value in the following formula for each sensor:
- ppm = raw * gain + offset
During the calibration procedure, we just need to use two known points (ppm1 and ppm2), read the corresponding raw data (raw1 and raw2), and then apply the following formulas:
- gain = (ppm1 – ppm2) / (raw1 – raw2)
- offset = ppm1 – raw1 * gain
Of course, we need four gain/offset couples, one per sensor (the calibration procedure is quite long!)
Once we have fixed the input circuits, we simply have to connect each Vout
to the BeagleBone Black's ADC input pins. Our board has 8 ADCs inputs, so we can use the following connections:
To enable them, we use the following command:
If everything works well, we should get the following kernel messages:
Then, the files AIN0
, AIN1
, …, AIN7
should become available as follows:
Note
These settings can be done using the bin/load_firmware.sh
script in the book's example code repository, as follows:
Then, we can read the input data by using the cat
command:
Tip
Note that the ADC can also be read by using other files still into the sysfs filesystem. The following command, for instance, reads from AIN0 input pin:
Connecting the alarm actuators
Now, we have to connect the alarm actuators in such a way the user can have a visual and acoustic feedback of any possible dangerous gas concentration. Also, we have to connect the GSM module to a serial port to communicate with it.
The LED and buzzer connections are very simple. The LEDs can be directly connected (with a resistor) with the BeagleBone Black's GPIO pins without problems, while the buzzer needs a little more work due to the fact that it needs a higher current than the LED to work. However, we can resolve the problem by using a transistor as shown in the following diagram to manage the buzzer with a higher current.
Tip
Note that the buzzer can't be a simple piezo without an internal oscillator, otherwise an external oscillator circuit or a PWM signal must be used!
In my circuitry, I used an R (470Ω) resistor for the LED (L), an R (2KΩ), Rd (4.7KΩ) resistors for the buzzer, and a BC546 transistor (T). Note that, regarding the LEDs, an R = 100Ω resistor can result in a higher brightness, so you may change it according to the LED color to have different results.
Note also that the resistor Rd in the buzzer circuitry is needed to pull-down the GPIO during the boot. In fact, during this stage it is set as input, and even in such configuration the current that flows out from the pin can turn on the buzzer!
The BeagleBone Black has a lot of GPIOs lines, so we can use the following connections:
Now, to test the connections, we can set up the GPIOs by exporting them and then setting these lines as outputs with the following commands:
Note
Note that it will be a good idea to use blinking LEDs to do this job. However, for this first chapter I'm going to use normal GPIO lines, leaving this topic for the following chapters.
Now, to turn on and off both the LED and the buzzer, we simply write 1
or 0
into the proper files, as follows:
Note
These settings can be done by using the bin/gpio_set.sh
script in the book's example code repository, as follows:
As stated in the introduction of this chapter, we wish to add a GSM module to be able to alert the user remotely too. In order to do this, we can connect this device with a normal serial port with TTL level signals. In this case, we have only to choose one of the serial ports available on our BeagleBone Black.
The following screenshot shows the GSM module I decided to use:
The BeagleBone Black has four available serial ports. By deciding to use the device /dev/ttyO1
, we can use the following connections:
To enable the
serial port, we have to use the following command:
If everything works well, we should get the following kernel messages:
The device file /dev/ttyO1
should now become available.
Note
These settings can be done by using the bin/load_firmware.sh
script in the book's example code repository, as follows:
To verify that the new device is ready, we can use the ls
command as follows:
Note
The reader can take a look at the book BeagleBone Essentials, Packt Publishing, which was written by the author of this book, in order to have more information regarding how to activate and use the GPIO lines and the serial ports available on the system.
Now, we can test whether we actually talk with the modem by using the screen
command as follows:
Note
The screen
command can be installed by using the aptitude
command as follows:
After pressing the ENTER key, you should get a blank terminal where, if you enter the ATZ
string, you should get the string OK
as answer, as shown in the following code:
It's the GSM module that answers that it's okay and fully functional. To quit from the screen
command, you have to enter the CTRL + A + \ keys sequence and then answer yes by pressing the y key when the program asks you to Really quit and kill all your windows [y/n]
.