Raspberrypi Current and Temperature Sensor Adaptor: Difference between revisions
| No edit summary | No edit summary | ||
| Line 1: | Line 1: | ||
| RPICT series are a set of Raspberrypi adaptor for current sensor (SCT) and temperature sensor. This page will introduce to generalities concerning the RPICT series. Information for each individual board can be found below. | |||
| * [[RPICT2T1]] - 2 CT and 1 temperature sensor. | * [[RPICT2T1]] - 2 CT and 1 temperature sensor. | ||
| * [[RPICT3]]   - 3 CT. | * [[RPICT3]]   - 3 CT. | ||
| Line 11: | Line 6: | ||
| * [[RPICT4T4]] - 4 CT 4 Temperature | * [[RPICT4T4]] - 4 CT 4 Temperature | ||
| * [[RPICT7V1]] - 7 CT 1 AC Voltage. | * [[RPICT7V1]] - 7 CT 1 AC Voltage. | ||
| * RPICT1 - deprecated | |||
| * RPICT1T1 - deprecated | |||
| All RPICT board connect to the GPIO connector and provide data via serial interface. An Arduino programmable microcontroller (Attiny85 or ATtiny84) runs the board. Source code for the microcontroller is freely available and can be modified for adaptation. | |||
| There are several options for logging and viewing the data. Python or Emoncms or anything able to read a serial port. | |||
| [[Image:IMG_0462_small.jpg | right]] | [[Image:IMG_0462_small.jpg | right]] | ||
Revision as of 12:37, 19 July 2016
RPICT series are a set of Raspberrypi adaptor for current sensor (SCT) and temperature sensor. This page will introduce to generalities concerning the RPICT series. Information for each individual board can be found below.
- RPICT2T1 - 2 CT and 1 temperature sensor.
- RPICT3 - 3 CT.
- RPICT4V3 - 4 CT 3 AC Voltage
- RPICT4T4 - 4 CT 4 Temperature
- RPICT7V1 - 7 CT 1 AC Voltage.
- RPICT1 - deprecated
- RPICT1T1 - deprecated
All RPICT board connect to the GPIO connector and provide data via serial interface. An Arduino programmable microcontroller (Attiny85 or ATtiny84) runs the board. Source code for the microcontroller is freely available and can be modified for adaptation.
There are several options for logging and viewing the data. Python or Emoncms or anything able to read a serial port.

Technical Specifications
Current Sensor
Recommended sensor: SCT-013-000 50mA/100A
Burden Resistor: 24 Ohm
Connector: 3.5mm Jack
Default Voltage for power calculation: 240V (can be modified in firmware).
For AC current only.
Temperature Sensor
Connector: 3.5mm Jack
The intended temperature sensor is the DS18B20 which can be configure in either parasite or normal mode.
The connection to a 3.5mm jack connector is shown below.
NOTE: Raspberrypi must be switched off while connecting and disconnecting the temperature sensor.
View the data from Linux terminal
It is possible to read the data output directly from a linux terminal. i.e. reading the serial port.
Before hand you must ensure two things before getting this to work:
1/ The firmware of the board has been set to use output as CSV. Relevant sketch can be downloaded below. See OUTPUT_AS_CSV variable.
2/ The ttyAMA0 serial on the raspberrypi is free. See  this link here.
The output from the adaptor board will be in the format below. power in kw. temperature in deg celsius.
power1,power2,temperature
Then on the Raspberrypi you can issue the commands
$ stty -F /dev/ttyAMA0 raw speed 38400 $ cat /dev/ttyAMA0
The terminal should then show something like this below
pi@raspberrypi ~ $ cat /dev/ttyAMA0 46,52,19.46 47,52,19.46 45,54,19.46 47,56,19.46
Why do I see a different output?
View the data with Python
Using the same sketch as mentioned above a python script can be used to work with the data. The example script below will be a good starting point.
First of all make sure you have python-serial package installed
$ sudo apt-get install python-serial
Then copy the following into an executable file and run it.
#!/usr/bin/python
import serial
ser = serial.Serial('/dev/ttyAMA0', 38400, timeout=1)
ser.open()
try:
       while 1:
               response = ser.readline()
               z = response.split(",")
               if len(z)>=2:
                       print "Power 1: %s Watts" % z[0]
                       print "Power 2: %s Watts" % z[1]
                       print "Temperature: %s Degrees" % z[2][:-2]
except KeyboardInterrupt:
       ser.close()
The above example is for the board with 2CT and 1 temperature sensor. See  here for the python example using the board with three CT sensors.
Record the data with EMONCMS
The Raspberripy OS distribution provided by OEM for the Raspberry emonbase must be used for this purpose. The default sketch will work for the use of EmonCMS. In the Node section of emoncms the device with ID 11 will appear on its own.
The Adaptor emulates a RFM12Bpi unit communication pattern. i.e. What will be sent to the Raspberrypi serial port will look as if it was sent by the RFM12Bpi.
The sketch is provided at the bottom of this page. Make sure the OUTPUT_AS_CSV is set to false in the sketch.
If the board has been acquired before 21st October 2015 read this
Program the Attiny85
The onboard mcu can be re-programmed to your needs. This link is a tutorial to upload Arduino sketches to the Attiny85.
The board does not have any SPi port. The chip will have to be removed from the board manually.
Files
Arduino Sketches
2CT 1Temperature (v1.6)
3CT (v1.2)
Remember to modify the OUTPUT_AS_CSV variable to choose between csv or emoncms output.
Note. Default Power calculation is based on a voltage of 240V.
Related Howto
Free up the ttyAMA0 serial port
How to program an Attiny85 or Attiny84


