Welcome to the SensorKit Home Page!


SensorKit Mission Statement

Our SensorKit is built based on Arduino microprocessor, which include 5 types of sensors at the moment. It is built to be a wearable and wireless bio-signal-sensor kit.

Our purpose is to use this sensor to collect the bio-signals (including skin temperature/conductivity, arm/hand motion, pulse rate and muscle intension) of students in real-time. Our target is to make it small, light and comfortable to wear.

The total cost for the current design is around $150 each. Based on the robustness of the sensors and the battery life, the reliable time is around 2 hours.

* Note that these instructions are PC/Windows-orientated. *

Sensor Descriptions

Temperature Sensor
MCP9808 High Accuracy 12C Temp Sensor Breakout board
Manufactured by: Adafruit
Part #: 1782
Temp Sensor

Pulse Sensor
Pulse Heart Rate Sensor Module for Arduino - RED
Manufactured by: Asiawill
Pulse Sensor

Galvanic Skin Response Sensor
Grove - GSR Sensor
Manufactured by: Seeed
Part #: 101020052
GSR Sensor

Gyroscopic Sensor
FLORA 9-DOF Accelerometer/Gyroscope/Magnetometer - LSM9DSO - v1.0
Manufactured by: Adafruit
Part #: 2020

FLORA Sensor


Gyro + Temp Breakout Board
9-DOF Accelerometer/Magnetometer/Gyroscope and Temperature Breakout Board
Manufactured by: Adafruit
Part #: 2021
9-DOF Board

Micro Controller Board
Longruner Mini Nano V3.0 ATmega328P 5V 16M Micro Controller Board Module for Arduino
Manufactured by: Longruner
Part #: Mini Nano
Micro Controller Board

Terminal Adapter Shield Expansion Board
5pcs Nano Screw Terminal Adapter Shield Expansion Board Nano V3.0 AVR ATMEGA328P-AU Module for Arduino
Manufatured by: Aideepen
Adapter Shield Expansion

Bluetooth Connection
Bluetooth Seiral Pass-through Module Wireless Serial Communication with Button for Arduino
Manufactured by: DSD Tech
Part #: HC-05
HC-05

Other Materials Needed

Rechargeable 9V Batteries
We chose: EBL 4 pack 9V 6F22 600mAh High Volume Lithium-ion Rechargeable 9V Li-ion Batteries
Manufactured by: EBL
Part #: 6F22
9v Rechargeable Batteries

Battery Connector
Faux Leather Housing T Type Clip Connector for 9V Battery
Manufactured by: IDS
Battery Connector Clip

Hook-Up Wire Spool Set
22AWG Stranded-Core 6 x 25ft
Manufactured by: Adafruit
Part #: 3111
Wire Spool Set

Wrist Brace
Manufactured by: Mueller
Part #: 86271
Wrist Brace

Velcro Strap
Black Nylon Onewrap Velcro Strap, Hook and Loop, 1/2" Width, 5' Length
Manufactured by: Velcro
Part #: 1801-OW-PB/B
Velcro Strap

Adhesive Velcro Patches
Hook and Loop Type Reclosable Fastener Shapes with Rubber Adhesive, Black, 7/8" x 7/8", 12PK
Manufactured by: Velcro
Part #: 6PXV4
Velcro Patches

You will also need other materials such as thread and needles to attach the sensors to the velcro tabs as well as to sew components directly to the glove or hat, scissors, solder and a soldering iron for making wire connections, and wire cutting/crimping/stripping tools.

Description of Data Flow

Steps to upload
1. Disconnect battery
2. Disconnect Bluetooth
3. Connect Arduino to PC with a mini-usb cable
4. On the Arduino IDE, set up the port and board on the tools menu bar (You will need to know which port is the Arduino connected to and which Arduino board you have)
5. Upload
6. Disconnect Arduino from PC

Steps to collect data through the Arduino IDE (With Bluetooth)
1. Connect Bluetooth (RX0, TX1)
2. Connect Battery
3. Turn on PC Bluetooth
4. Pair PC with Arduino devise, the name of the Arduino devise is HC-05 and the pin is 1234
5. In the Arduino IDE, set up the port (again) on the tools menu bar, the board should be the same
6. In the Arduino IDE, open the serial monitor from the tools menu bar
7. The Arduino will show some data configuration on the serial monitor, please wait
8. When the message “We are ready to go, please enter 1 and send to start” appears on the serial monitor, please enter “1” on the upper writing box and the click on “send”. This will collect 1 datum of each sensor.
9. To collect more data, one at a time, keep sending 1s to the Arduino. To collect multiple data, send “2” to the Arduino.

Steps to collect data through Python
1. Set up the Arduino and sensors.
2. Connect the Arduino to the computer (if using Bluetooth, please use the first 4 steps from the section above)
3. If the Arduino does not have the sensorkit software version you are going to use, please upload it to the Arduino by following the “Steps to upload” section.
4. Open Spyder (Python 3.6) and the file “serial_real_time_graph_test.py” (This is a developing process, it is still a test and the software is not for release version yet). The script sets up the connection with the Arduino and for every data collecting cycle: a) reads the output from Arduino, b) shows the output in screen and writes it in a txt file, c) process the data received, d) if figures are requested (with a flag at the top of the code), creates or updates the figures. At the end, the script saves all the figures in a “figures” folder. The script can be stopped at any time with a keyboard interruption (ctrl+c). This script will need the other scripts below. They should be in a “lib” folder, for more information about them please see the file.

a. func_cd # Provides the function to change directories with relative addresses
b. func_data_read # Contains the functions to read sensor-kit data
c. data_plot_scheme # Contains the functions to create, plot (in real-time) and save sensor-kit data

5. Run the file in a dedicated console. You might have to change the graphics backend configuration of the IPython console. To do this in Spyder go to a) tools, b) preferences, c) IPython console, d) graphics tab, e) in the graphics backend section select “Automatic” from the drop-down menu, f) click OK.
6. Collect data
7. The program exits when it has collected the number of data you specified in the “num_data” variable.

Fast Data Acquisition Procedure
Fast Data Acquisition is a modified version of the python data acquisition scheme which increases the available data rate, but also makes the resulting text file more difficult to read. A special set of python tools has been created to capture data more quickly.

1. Upload the “fast_sensor” Arduino code to the Arduino.
2. Open Spyder (Python 3.6) and the file “fast_sensor_from_COM.py” Ensure the indicated port is accurate, as indicated by the device manager or other port monitoring service. Baud rate should be 230400.
3. A file dialog will appear. Select a directory to save the acquired data. The data is saved as a raw output .txt file and an interpreted .csv file with a more usable organization, both with a filename of the time and date.
4. After selecting the directory, the computer begins logging data and will continue to do so until a Keyboard Interrupt is sent. Always end the data acquisition session with a Keyboard Interrupt (Ctrl+C).

The data is transmitted in ASCII as three-column, tab-delimitated text with \r\n line separators:

data_channel	\t	timestamp	\t	value	\r\n

data_channel is an unsigned integer indicating which sensor’s value and time is being transmitted. Each sensor (and axis of sensor if applicable) has a unique data_channel number.

timestamp is an integer indicating milliseconds since Arudino was last reset.Resets occur at a power cycle, pressing the reset button, or reconnecting to the serial bus. It overflows after about 90 days of continuous use.

value is the value of the indicated sensor at the indicated time. Floating point data is converted to text with precision at the hundredths before transmission.

There is also channel configuration metadata that is transmitted at the top of the file, also in ASCII, three-column, tab-delimitated text with \r\n line separators:
data_channel	\t	sensor_description	\t	units	\r\n

data_channel is the same integer used in data transmission.

sensor_description is a string indicating which sensor is using this channel

units is a string indicating the units for this sensor

Upon shutdown with a keyboard interrupt, the Python interpreter tool will generate an easily importable csv file containing each data point and its associated timestamp for each channel. The header row contains a reformatted version of the sensor configuration metadata, with each datum separated by a pipe “|”, ending with either “timestamp” if this column has timestamp data or “value” if it has value data.

data_channel	|	sensor_description	|	units	|	{"value","timestamp"}

Data is then sorted into each column as indicated by the header. Value and timestamp data is always pairwise, with corresponding datapoints always on the same row.

How to Build a SensorKit

Within our study we created two different versions of our SensorKit Wearables: a glove and a hat. The original device was built as a wrist glove, and was later rebuilt as a hat in order to test different areas of the body for signals of stress.

Use the tabs below to view the information pertaining to each device.

SensorKit Research Team

Mimi Boutin
Prof. Mireille Boutin
about

Tiberius Wehrly
about

Deena Alabed
about

Emma Bonham
Emma is an undergraduate student in Purdue's Polytechnic School majoring in Robotics Engineering Technology. She reassembled the Glove SensorKit in order to create the Hat SensorKit v1.0, along with providing aid in refining the Glove SensorKit 2.0.

Biao Ma
Part of the Original SensorKit Team, Biao Ma helped to create the first version of the SensorKit Glove.

William Sanchez
Part of the Original SensorKit Team, William Sanchez helped to create the first version of the SensorKit Glove.