Skip to content

Latest commit

 

History

History
82 lines (53 loc) · 2.49 KB

Readme.md

File metadata and controls

82 lines (53 loc) · 2.49 KB

Documentation

Documentation for rc_pilot

Setup

Install dependencies on Beaglebone:

$ sudo apt install libjson-c-dev libjson-c3

Install librobotcontrol on Beaglebone:

The repo for the library is located on the Strawson Design GitHub page. There is a bug in the 1.0.4 release version (rc_duplicate_filter fails for initialized filter) so install librobotcontrol from source.

Transfer rc_pilot source to Beaglebone:

In the scripts folder there are some convenient scripts for moving files to and from the vehicle. These scripts were build and tested on Ubuntu 19.04 but have not been tested on any other system. They should work on any system with bash and rsync. To transfer the files to the vehicle run:

$ ./scripts/transfer_rcpilot [usb|wifi|a2sys]

Note: a2sys option refers to the linksys router. This option depends on the beaglebone static IP being properly set. The wifi option refers to the beaglebones onboard wifi.

Build on Beaglebone (from project directory):

$ make

Run RC_pilot:

$ cd bin
$ sudo ./rc_pilot -s ../settings/quad_settings.json

Miscellaneous

Building docs:

Make sure that doxygen is installed on your system and run

$ make docs

Open the docs with the web browser of your choice

$ firefox docs/html/index.html
$ google-chrome docs/html/index.html

Testing:

Test cases are written using the Boost 1.66 testing suite. Look at make target test for system install location. This suite is not written with portability in mind so it may take some tweaking to get it to work right now. Typically, installing boost with the option --prefix=/usr/local should put the libraries and headers in the correct location but don't count on it.

Run the test suit with the make target:

$ make test

Adding Test Modules

To add a test modules, create a new file <module_name>_test.cpp and format it as follows:

#include <boost/test/unit_test.hpp>

BOOST_AUTO_TEST_SUIT(Test_<module_name>)

BOOST_AUTO_TEST_CASE(test1){...}

BOOST_AUTO_TEST_CASE(test2){...}

...

BOOST_AUTO_TEST_CASE_END()

The make target will compile each test module into a single executable and run all test cases simultaneously.

Testing git with this change