Skip to content

lucastliu/sciencebot

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

GPLv3 License


sciencebot

sciencebot

A modular & economical research vehicle platform
Wiki · Hardware · Request Feature
See sciencebot in action »

Software

Software documentation for setting up the sciencebot, ROS2, and turtlesim.

Table of Contents

Technologies

  • Raspbian Buster OS
  • Arduino
  • Python
  • C++
  • ROS2 Eloquent Elusor

Project Structure

The dev_ws folder contains a full ROS2 based implementation of the vehicle control project.

within dev_ws, source code is organized into packages under the src folder

Other folders contain basic standalone scripts for individual components (not tied to ROS2 in any way).

See seperate Hardware Documentation for details on the physical vehicle build, and sensor information

Getting Started

Prerequisites

Raspberry Pi

This project was developed on a Raspberry Pi 3B+ running Raspian Buster. Setups that use other Pi hardware or OS versions, or even other Linux devices, will likely operate in a highly similar fashion, but not in the exact same manner.

  1. Python 3

    This project requires Python 3. This should be available by default on the Pi with Raspbian Buster.

  2. Storage

    Running with Raspbian Buster, the minimum SD card size is 8 GB. However, running this project will require more resources, and a 16 GB card was found to be inadequate as well. A 64 GB micro SD was used in the build, and is easily sufficient.

  3. Virtual Memory

    Due to the limited abilites of an RPi, during installation, it is often useful / necessary to leverage swap space . This can be achieved by editing the file /etc/dphys-swapfile, increasing the CONF_SWAPSIZE variable (1024 seems to be sufficient). Full discussion for RPi 3 B+ can be found here

  4. Remote Access

    This step is optional, but highly recommended. The Pi supports HDMI output, but a wired connection is quite cumbersome, especially for a moving vehicle. There are several options for remote access, one of which is as follows.

    Virtual Network Computing (VNC) will allow one to view and control the Pi from another device wirelessly. Raspbian comes with a native / pre-installed VNC. Full instructions here: VNC

    You will want to setup a static IP Address as well.

    If the resulting resolution on your host device does not look right, you may need to adjust the resolution.

BNO055 IMU

Communicating with the IMU is done through the Adafruit_CircuitPython_BNO055 Library

The Raspberry Pi is also not compatible with the IMU by default due to clock stretching issues. This can be remedied by switching the Pi to a software implementation of i2c. This may have negative effects on other sensors that use i2c.

DWM1001

Programming our DWM1001 positioning sensors requires pyserial, which can be acquired by opening a terminal and running

pip install pyserial

Programming DWM1001 Modules can be done through TeraTerm.

Follow the Quick Deployment Guide for software installation requirements. Refer to this repository's HARDWARE guide for full details. If you have an Android device, see the guide for remote programming using Android.

OpenMV Cam H7 (Optional)

WIP. Not currently integrated in ROS movement, but has standalone functionality. Relevant files under camera folder.

OpenMV IDE

OpenMV Documentation

Upload camera_constants.py and main.py (Files available in camera/h7 folder) to device using micro USB cable. main.py is the script that will automatically run upon powering on the H7 cam. See cam_example.py for how to recieve data from the H7 Cam onto the Raspberry Pi (host device).

Arduino

The Arduino is our motor microcontroller, solely in charge of sending PWM signals to our motors.

Download Arduino IDE

Our microcontroller code also requires downloading the AFMOTOR support library

ROS2 Eloquent Elusor

Your primary and best reference is the ROS2 website

Their tutorials are also very informative, and a great place to start at. Several of the beginner example packages have been provided.

This project was built for ROS2 Eloquent: Instructions for installing from source

The build process may require several attempts, as ROS does not have Tier 1 support for the Pi. In order to reduce the strain on the Pi, add the following flag modifications to build commands:

MAKEFLAGS="-j1 -l1" colcon build  --executor sequential

Installing ROS2 may take a considerable amount of time.

Installation

  1. On the Pi, open a terminal and clone sciencebot
git clone https://github.com/lucastliu/sciencebot.git
  1. Using the Arduino IDE, Upload SerialMotor.ino to the Arduino

  2. Create an ROS workspace under dev_ws. Pay special attention to sourcing the overlay and underlay.

  3. Build the project

cd .../dev_ws/src
colcon build --symlink-install

This should build all sciencebot ROS2 packages.

Usage

Spin up

Open a terminal and navigate to the project

cd .../dev_ws

Source the overlay

. install/setup.bash

turtlesim basic

Run this first to confirm that the software has installed correctly. Turtlesim is also a useful simulation for developing basic control theory in a controlled, simplified environment.

Follow the Spin up steps.

ros2 run turtlesim turtlesim_node

You should see a GUI pop-up with a turtle if project installation was successful. Close the simulation and window.

turtlesim PID control

Control the turtle using PID goal seeking.

Complete the Spin up steps.

Run the launch file

ros2 launch nav turtlesim.launch.py

Wait for indication that "Turtle PID Node is Live"

In a seperate terminal, follow the Spin up steps and run

python3 ./src/nav/nav/clients/tune_position_pid_client.py

You will be prompted for a goal position X Y, as well as PID parameters.

Here are some good defaults:

Desired X Y: 6 7
Enter linear PID Constants : 1.5 0 0
Enter Angular PID Constants : 6 0 0

If you have chosen good parameters, the turtle will move to the desired setpoint.

sciencebot

Running of the sciencebot requires the relevant hardware components to be installed, as described in HARDWARE

Manual Drive

Follow these steps to manually drive the vehicle with a keyboard.

Complete Spin Up steps.

Run the motor node

ros2 run nav motors

Open a second terminal, and complete Spin up steps.

Run the teleop node

ros2 run teleop_twist_keyboard teleop_twist_keyboard

Begin driving. See teleop twist keyboard for additional drive details.

Automatic XY Waypoint Seeking

Complete Spin up steps.

Run the launch file

ros2 launch nav pose.launch.py

If sensors are correctly hooked up, the terminal should begin displaying position and heading.

Open a new terminal, and complete the spin up steps.

Run the vehicle controller node of your choice, i.e.

ros2 run nav mixed

Open a new terminal, complete the spin up steps.

Run the request client script

python3 ./src/nav/nav/clients/run_position_pid_client.py

input your desired destination

Desired X Y: 1.5 1.5

The vehicle should begin moving to the waypoint in accordance with controller node policy.

Heading Seeking

Complete Spin up steps.

Run the launch file

ros2 launch nav pose.launch.py

If sensors are correctly hooked up, the terminal should begin displaying heading updates.

Open a new terminal, and complete the spin up steps.

Run the vehicle heading controller node of your choice, i.e.

ros2 run nav imupid

Open a new terminal, complete the spin up steps.

Run the request client script

 python3 ./src/nav/nav/clients/heading_pid_client.py 

input your desired heading angle, and parameters

Desired Angle (Degrees): 200
Enter Angular PID Constants : .5 .25 .0008

The vehicle should begin turning to the setpoint in accordance with controller node policy.

PlotJuggler

PlotJuggler is an ROS package useful for collecting and visualizing data. It is capable of streaming ROS2 topics in real time, which can be very helpful for observing and debugging the vehicle system, or any ROS2 system.

sciencebot provides a custom modified version of PlotJuggler designed to work on the Raspberry Pi 3B+ with ROS2 Eloquent.

PlotJuggler is installed like any other ROS2 Package. Plotjuggler also requires that plotjuggler_msgs has also been built.

Complete spin up steps.

Build the packages

cd .../dev_ws
colcon build --packages-select plotjuggler_msgs
colcon build --packages-select plotjuggler

After installation, Complete the Spin Up steps.

Then run

ros2 run plotjuggler PlotJuggler

The PlotJuggler GUI should pop-up.

pg

Livestreaming ROS topic data can be achieved as follows:

  1. Start your ROS nodes (and ensure topics are being published to)
  2. Navigate in the top menu to Streaming > Start ROS2 Topic Subscriber
  3. Select desired topics and click OK
  4. Drag desired topics from sidebar onto plot.
  5. Information should begin streaming, as indicated at the bottom right Streaming ON
  6. Use the toolbar at the top right to adjust plot details, and add subplots

See PlotJuggler source repository for further usage instructions and more information.

Tuning & Modifying

Tune & MoveTo

There are several prebuilt ROS Actions available within sciencebot, some for tuning parameters, some for running a prebuilt system. These actions are defined within the custom_interfaces package, under dev_ws/src/custom_interfaces.

The Tune Action is defined as follows:

float64 x_dest
float64 y_dest
float64[3] linear
float64[3] angular
---
float64 x_final
float64 y_final
---
float64 x_curr
float64 y_curr

This means that an action client must supply the first set of parameters: an X, Y destination, and 2 sets of PID parameters for an angular and linear PID Controller. The Action server is required to provide XY position updates, as well as a final XY position after execution. Thus, the Tune action is useful for determining parameters, as new weights can be given on each run.

On the other hand, the MoveTo Action is defined as follows:

float64 x_dest
float64 y_dest
---
float64 x_final
float64 y_final
---
float64 x_curr
float64 y_curr

While similar to Tune, it does not accept parameter weights. Using the MoveTo can be thought of as the production version of the action, where the weights have already been determined, and only goal seeking is perfomed.

The Heading action is similar to Tune, except it is for seeking a goal heading rather than an XY. It is defined as follows:

float64 dest_angle
float64[3] angular
---
float64 final
---
float64 curr

Use these actions, or create new ones, to either fine tune or run your sciencebot for various tasks.

ROS Nodes

Adding a new node to the nav package is an easy way to extend the sciencebot ROS ecosystem. It is helpful to use existing nodes as a template.

Navigate to the nav package, and move into the subfolder also named nav

cd .../dev_ws/src/nav/nav

lu Create your new python file, following ROS2 Node conventions.

Return to the root of the nav package,

cd .../dev_ws/src/nav/

Modify setup.py, adding your new node into the list of console_scripts, following the convention 'NODE_NAME = nav.SUBPATH_TO_FILE:main'

Navigate to root of ROS workspace

cd .../dev_ws

rebuild the nav package

colcon build --packages-select nav

Now, after completing Spin up steps, you should be able to launch your new node in a terminal using

ros2 run nav NODE_NAME

Helpful Tips

To build just a single ROS package, use the --packages-select flag

Example:

colcon build --packages-select nav

ROS nodes can have their python components linked, so that changes in the script are automatically reflected in the next launch of the node (no rebuild needed). Use the --symlink-install flag when building.

Example:

colcon build --symlink-install nav

Resources

ROS2

ROS answers

r/ROS

Raspberry Pi Forums

Future

  • H7 Camera Computer Vision Integration

  • 3D printed components redesign

  • Advanced Sensor Fusion

  • Drivetrain change

Contributing

Contributions are key to any open source project, and are definitely welcome here!

  1. Fork the Project, and clone it (git clone [email protected]:YOUR_USERNAME/sciencebot.git)
  2. Create your Feature Branch (git checkout -b FEATURE_NAME)
  3. Commit your Changes (git commit -m 'INFORMATIVE IMPROVEMENT MESSAGE')
  4. Push to the Branch (git push origin FEATURE_NAME)
  5. Open a Pull Request

License

Copyright © 2020 Lucas Liu

sciencebot

sciencebot is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.

sciencebot is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
GNU General Public License for more details.

You should have received a copy of the GNU General Public License
along with sciencebot.  If not, see <https://www.gnu.org/licenses/>.

This repository includes modified versions of other source code from the ROS open source community. The relevant subfolders each have their own license. All other files fall under the GPLv3 license as described above.

Contact

Lucas Liu - lucas.liu AT duke.edu

About

Autonomous Vehicle Project

Topics

Resources

License

Unknown, GPL-3.0 licenses found

Licenses found

Unknown
LICENSE.txt
GPL-3.0
COPYING.txt

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published