This repository contains all the code used for our 2018 HotMobile paper submission: "UniverSense: IoT Device Pairing through Heterogeneous Sensing Signals".
NOTE: This repository was forked from SensorFly Swarm for IMU data collection and might have some unnecessary extra stuff or be missing some details, refer to the original repo if needed :P
I may have forgotten to include some of the requirements in this list, will update if necessary. Basic requirements are:
For Mac users, I find it easiest to install Python through Homebrew Just download the latest Python 2.7 release and follow the instructions. As of Feb 4, 2017 I'm using Python 2.7.13 on Mac.
Our vision algorithms rely on the well-known open-source vision library OpenCV. As of Feb 4, 2017 I'm using OpenCV 3.2, and I installed it on my Mac using Homebrew with the following command (the only actual requirements are --with-contrib --with-qt5
):
brew install opencv3 --c++11 --with-contrib --with-examples --with-ffmpeg --with-gphoto2 --with-gstreamer --with-jasper --with-java --with-jpeg-turbo --with-libdc1394 --with-openni2 --with-opengl --with-python3 --with-qt5 --with-tbb --with-vtk --with-nonfree
It may take up to 1h to compile and install depending on your computer. Google instructions if not on Mac, as I've never followed the procedure for a different OS.
Our UIs (user interfaces) are built on top of Qt5, which is a cross-platform GUI tool. As of Dec 4, 2016 I'm using Qt 5.7. It can also be installed through Homebrew on Mac by typing:
brew install qt5
brew install PyQt5
Note that this step may also take a long time.
In order to have better control over our cameras, we use a UVC library. In particular, we followed pupil-labs/pyuvc's implementation. Feel free to follow their instructions, although this is a summary extracted from several of their READMEs:
- Install pupil-labs/libuvc:
git clone https://github.com/pupil-labs/libuvc
cd libuvc
mkdir build
cd build
cmake ..
make && sudo make install
- Install libjpeg-turbo:
brew install libjpeg-turbo
- Install cython and numpy:
pip install cython
brew install numpy
- Finally, build and install my own fork of pupil-labs/pyuvc (CarlosRDomin/pyuvc):
git clone https://github.com/CarlosRDomin/pyuvc
cd pyuvc
python setup.py install
We use CrazyFlie 2 drones for our workers. The spotter uses CrazyFlie's open-source Python library to communicate with them. Follow these steps (extracted from their README) to install cflib
:
git clone https://github.com/bitcraze/crazyflie-lib-python
pip install -e path/to/cflib
### CrazyFlie Custom Firmware In order to control the worker drones the way we want, we use our own custom firmware, which was forked from the original CrazyFlie firmware.
- Simply clone my fork:
git clone --recursive https://github.com/CarlosRDomin/crazyflie-firmware
- Compile:
make
- And if you have a CrazyRadio connected (this step might require you to install CrazyFlie's Python Client), flash it (you first need to enter the CrazyFlie into bootloader, which is done by holding the Power button for 5sec, or until the 2 blue LEDs in the back of the CrazyFlie start toggling/blinking):
make cload
I just realized MyCode/full_control_with_cam.py
uses the SDL2
library to handle user input through the keyboard. This means SDL2
needs to be installed:
brew install sdl2
pip install PySDL2
Run MyCode/adjust_cam_settings.py
, and select the camera that wants to be tuned. The GUI will let you specify parameters such as exposure time, white balance, etc.
In addition, color thresholding and blob detector parameters can also be adjusted to find the vision marker (ie: ping pong ball) on the workers. Then, settings can be saved to a file once the right values have been set.
PS: For more info, read the description at the top of the file, the comments throughout the code, or just email me.
You first need to print out a calibration pattern (MyCode/cam_calibration/circles_pattern.pdf
) and tape it to a solid surface (furniture, floor, walls are ideal). Then run MyCode/calibrate_cam_params.py
, which will open a live feed of the camera. Press Space to take images (make sure the calibration pattern is visible) from different angles and in different positions (up-left corner, down-right corner, center of the image, etc.). I usually collect 20-30 images for camera calibration. Once you're done taking images, press any key that's not Space (eg: Esc), and the code will generate calibration values for you and save them to a file (by default, it saves to MyCode/cam_calibration/cam_calibration_output.npz
).
PS: For more info, read the description at the top of the file, the comments throughout the code, or just email me.
Run MyCode/calibrate_2d_to_3d.py
. It will look for the vision marker (ie: ping pong ball) using the HSV color thresholds obtained at the Adjust camera settings step, and print on the live camera feed the estimated distance between the camera and the ball. If these results aren't accurate or consistent, try retuning the camera settings or recalibrating the camera.
PS: For more info, read the description at the top of the file, the comments throughout the code, or just email me.
Once the vision algorithm has been successfully tested and we have a CrazyFlie 2 with our custom firmware installed, you can fly the worker by running MyCode/full_control_with_cam.py
. This will fly the CrazyFlie up until keyboard letter e
is pressed. Then, the worker will hover in place. Keyboard keys ASDW can be used to control left, down, right and up setpoints respectively. Keys u
and h
control closer and further to/from the camera, respectively. Any other key ends the flight.
PS: For more info, read the description at the top of the file, the comments throughout the code, or just email me.