ECE597 Project SensorTag 3D

Team members: Leihao Wei  Yashi Yadav

Grading Template
I'm using the following template to grade. Each slot is 10 points. 0 = Missing, 5=OK, 10=Wow!

 05 Executive Summary 10 Installation Instructions - Very nice and detailed! 10 User Instructions - Animated GIF is a nice touch. 00 Highlights - Is this grouped with Theory of Operation? 10 Theory of Operation 10 Work Breakdown 09 Future Work 09 Conclusions 10 Demo 10 Not Late Comments: You covered a lot in the project. Nice job

Score: 83/100

Executive Summary
 Rewrite now that the project is over. SensorTag is a portable low-power module that uses Blueooth Low Energy (BLE, Bluetooth 4.0) and various sensors to communicate data to any BLE receiver. The purpose of this project is to build an application interacting with a beaglebone to track the SensorTag’s rotation in 3D. We'll start off from the previous work [ SensorTag]. We expect to see it sending updates at 10Hz by modifying the firmware.

Packaging

 * Beaglebone Black
 * TI SensorTag [ |TI SensorTag]
 * Bluetooth CSR 4.0 dongle



Installation Instructions

 * Get the project repository
 * Install necessary packages in the current directory.
 * Obtain the test code

Update the SensorTag Firmware

NOTE: You will need an iOS device for this!

I obtained the following instructions from this website: [ | FirmwareInstructions]

1) Make the changes to the firmware to get a faster refreshing rage. Here is how to do so (information obtained from [ HERE]):

a) Download IAR Workbench [ HERE](make sure to choose 30 day evaluation copy) b) Download BLE-STACK from [ HERE] c) In IAR Workbench Open SensorTag.eww file from following path: "C:\Texas Instruments\BLE-CC254x-1.4.0\Projects\ble\SensorTag\CC2541DB\SensorTag.eww" d) After the gyro data is read, the gyro goes into sleep mode. A gyro wake up routine is called. This makes the gyro capture period limited to the gyro startup time which is 60ms. So, in order to get a faster refreshing rate, one must modify to code in HalGyro.c so the gyro does not go to sleep after data is read (line 296). Also, get rid of SENSOR_PERIOD_RESOLUTION in the gyro service source file

(Alternatively, instead of changing the firmware manually, you can get the updated version (with faster refreshing rate) from a github repository. Get the A and B images from [ HERE]

2) Get the SensorTag App from the app from the Apple App Store 3) Connect your iOS device to your computer and open up iTunes. 4) Under the "Apps" section, go to the bottom of the page to find "File Sharing". The SensorTag App should appear in the "Apps"-list. 5) Click "Add" on the right hand side and select both firmware files. 6) Sync iTunes with iOS device. 7) Open SensorTag App on your iOS device. 8) Select "Upgrade FW" then "Select FW File" then "Shared Files" 9) If you already have image A installed, install image B. (If you have B installed, install image A) 10) Wait till firmware has been updated on your device.

You have successfully updated your firmware, so now you can have a fast refreshing rate!

Test the Gyroscope

Press the side button on your sensorTag so that it enters discovery mode.

Now, the firmware is updated to 1.5 version, and we can see that data are transmitted about the rate of 100 ms on average (10Hz).

User Instructions
To use the program run ./boneServer_sensorTag.js as shown below

Go to 192.168.7.2.9090 and click on the ball and cube image.

Wait a few seconds to connect.

The image should be rendering on the screen as shown below.



Theory of Operation
 Nice video, but I would have liked to see the sensorTag moved around more. Click HERE to see the youtube demo of our project.

This is the flow of our program:



Some Fun Math!
We will use the rectangular coordinate system for a sensorTag, but using Aircraft principal axes (pitch, roll and yaw) to describle rotation. Define coordinate system: Put the sensorTag on the table, IR sensor facing upward.
 * The y-axis is aligned along the body axis of the sensor tag (small end of the tag).
 * The z-axis points upward so that it is aligned with opposite gravity when the smartphone is flat on a table.
 * The x-axis is aligned at right angles to both the y and z axes so that the three axes form a right handed coordinate system.

Accelerometer sensors measure the difference between any linear acceleration in the accelerometer’s reference frame and the earth's gravitational field vector. Of course, we can convert it to pitch and roll by doing some math or. This involves some simple vector algebra to derive tilt angles.Note that, the order is not unique. For me, I choose YXZ, that is, do a pitch (rotate around y) first then followed by a roll (rotate around x). The ATAN2 function automatically returns the angle (in radians) in the correct quadrant based on the signs of the two arguments. Pitch= ATAN2(-Ax/Az) Roll= ATAN2(Ay/sqrt(Ax^2+Az^2)) Note that we can't sense rotation around z since z is aligned with g, so instead we'll use gyroscope to find the rotation around z. Gyroscope measures the angular velocity around each x y and z.

Integrate Gyroscope and Accelerometer Measurements
As an accelerometer measures all forces that are working on the object, it will also see a lot more than just the gravity vector. Every small force working on the object will disturb our measurement completely. The accelerometer data is reliable only on the long term, so a "low pass" filter has to be used.
 * The problem with accelerometers

It is very easy to obtain an accurate measurement that was not susceptible to external forces. The less good news was that, because of the integration over time, the measurement has the tendency to drift, not returning to zero when the system went back to its original position. The gyroscope data is reliable only on the short term, as it starts to drift on the long term.
 * The problem with gyroscopes

The complementary filter gives us a "best of both worlds" kind of deal. On the short term, we use the data from the gyroscope, because it is very precise and not susceptible to external forces. On the long term, we use the data from the accelerometer, as it does not drift. In it's most simple form, the filter looks as follows: angle = a*(angle + gyro*dt) + (1-a)*acc , where a between 0 and 1, dt is the gyroscope sampling time. a=T/(T+dt) and T is typically less than one second. I had a sampling rate of about 0.1 seconds and chose a time constant of about .75 seconds, giving a=0.88. More details about choosing "a" and complementary filter can be found in this balance filter and these articles. This will ensure that the measurement won't drift, but that it will be very accurate on the short term.
 * The complementary filter

Work Breakdown
1) Get previous work working: Leihao and Yashi 2) Look into firmware for faster refreshing rate: Leihao and Yashi 3) Update javascript file to be compatible with new firmware version: Leihao 4) Documentation: Leihao and Yashi
 * Major Tasks:

Future Work
Additional things that can improve project:
 * There are still some glitches in the program. For instance, the image isn't able to do a full 360 degree turn when you do a 360 degree turn on the SensorTag. It is possible due to the fact that accelerometer sensors are insensitive to rotation about the earth's gravitational field vector so that the equations for the roll and pitch angles therefore have mathematical instabilities when rotation axes happen to become aligned with gravity and point upwards or downwards.
 * Try a better filter e.g.. Kalman filter.

Conclusions
In conclusion, our project is able to pretty accurately display the SensorTage image and it's movements. We were also able to look into the firmware and update the refreshing rate to be faster than the previous project.

References: