Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/jafarabdi/robond-controls-lab

Robotics Program Quadrotor Controls Lab
https://github.com/jafarabdi/robond-controls-lab

Last synced: 2 days ago
JSON representation

Robotics Program Quadrotor Controls Lab

Awesome Lists containing this project

README

        

[![Udacity - Robotics NanoDegree Program](https://s3-us-west-1.amazonaws.com/udacity-robotics/Extra+Images/RoboND_flag.png)](https://www.udacity.com/robotics)

# Table of Contents #

- [Hover Controller](#hover-controller)
- [Attitude Controller](#attitude-controller)
- [Position Controller](#position-controller)
- [Additional Helpful Tools](#additional-helpful-tools)
- [Using the Simulator](#using-the-simulator)

# Hover Controller #
### Step 1: Writing the PID Class ###

Add the PID class you wrote to `quad_controller/src/quad_controller/pid_controller.py`

### Step 2: Running the Hover Controller ###

**NOTE: Launch `roscore` first, then Unity**

After you have added the PID class, you can launch the hover controller.
To do so, run the following commands in your terminal:
```
$ cd ~/catkin_ws/
$ catkin_make
$ source devel/setup.bash
$ roslaunch quad_controller hover_controller.launch
```
Now, with the hover controller launched, you can launch the quad simulator on your host platform.
The details surrounding this process will be be different for each host platform (Win/Mac/Linux).
please see "Using the Simulator" below.

### Step 3: Tuning Parameters ###
Now that Unity has been launched, verify that you can see poses being published by the simulator
on the `/quad_rotor/pose` topic:
```
$ rostopic echo /quad_rotor/pose
```
If you see messages being published, you're golden! If you don't see messages being published,
then you might want to check your firewall settings on your host VM, or try restarting
the simulator (at the moment there's an infrequent bug where comunications with the simulator does not work).

Now that you've verified poses are being published, you can use `rqt_reconfigure` to adjust the setpoints
and PID parameters for the hover controller!

You should tune the parameters using rqt_reconfigure until you are happy with the result.
For more information about how to tune PID parameters, head back into the classroom.

If manually adjusting the PID parameters is not your thing, feel free to try out the
Ziegler–Nichols tuning method using either `hover_zn_tuner_node`, or `hover_twiddle_tuner_node`.
These nodes both implement tuning methods that were discussed in the classroom.

You might find that these tuner helpers only get you part way to a good tune.
There's a reason for this! Do you know?

To run `hover_zn_tuner_node`:
```
$ rosrun quad_controller hover_zn_tuner_node
```

To run `twiddle_tuner_node`:
```
$ rosrun quad_controller hover_twiddle_tuner_node
```

Write down the parameters you came up with, as you will need them later, for the full positional controller!

**Bonus Quesion:**

Why does the quad overshoot more frequently when heading to a set point at a lower altitude?
How can you modify the code to overcome this issue?

# Attitude Controller #
The attitude controller is responsible for controlling the roll, pitch, and yaw angle of the quad rotor.
You can tune it very similarly to how you tuned the hover controller!
Note: ZN/Twiddle Tuner nodes only work with the Hover controller.

### Step 1: Launch the Attitude Controller ###
```
$ roslaunch quad_controller attitude_controller.launch
```

### Step 2: Launch the Attitude Controller ###

Tune roll and pitch PID parmaeters until things look good.
You'll also need to write down these PID parameters.
As mentioned previously, you'll be using them in the positional controller!

# Position Controller #

Finally, now that you have tuned the attitude controller and positional controllers
you can begin to work on the positional controller. The positional controller is
responsible for commanding the attitude and thrust vectors in order to acheive a
goal orientation in three dimensional space.

Luckily, you've likely found some pretty decent PID parameters in your previous exploration.
If you're fortunate, these parameters will work for you... However, even if they don't
we've got you covered. There's all sorts of additional tooling that you can use to
troubleshoot and tune positional control of your quad!

### Step 1: Launch the Positional Controller ###
```
$roslaunch quad_controller position_controller.launch
```

### Step 2: Tuning Parameters ###

Tune parameters until the controller is well-behaved.
This should not be a very familiar, albeit potentially more difficult problem.

# Additional Helpful Tools #
With so many degrees of freedom, debugging and troubleshooting can be a painful process.
In order to make things a little bit simpler, we've provided some tools that might make
life a little bit easier.

### Constraining Forces and Torques ###

It is possible to constrain forces and torques on the quad rotor's body frame.
This can be useful if you're trying to debug only a single degree of freedom.

Example: Disallow movement along the quad's X axis
```
$ rosservice call /quad_rotor/x_force_constrained "data: true"
```
Example: Disallow rotation about the quad's X axis
```
$ rosservice call /quad_rotor/x_torque_constrained "data: true"
```

### Setting the Camera Pose ###

To set the camera pose you can either, right click in the simulator, and drag
or you can use the following service call, where the data parameter may take on the following
values:
0: Orthogonal to the inertial frame's YZ plane, facing the positive X direction.
1: Orthogonal to the inertial frame's XZ plane, facing the positive Y direction.
2: Orthogonal to the intertial frame's XY plane, facing the negative Z direction.
3: Perspective view, facing the quad's body frame origin from the -X,-Y, +Z quadrant.

```
$ rosservice call /quad_rotor/camera_pose_type "data: 0"
```
To reset the camera pose, to the default pose, you can use the service call, or right click.

### Setting the Camera Distance ###

To set the distance between the camera and the quad's body frame, you can use the
`/quad_rotor/camera_distance` service. For example, to set the camera distance to be
20 meters, you would call the service as follows:
```
$ rosservice call /quad_rotor/camera_distance "data: 20.0"
```

To reset the camera distance to the default, simply right click in the simulator.

### Disabling Gravity ###

Gravity can be a harsh reality. Particularly when you're dealing with attitude tuning.
Fortunately, we can disable gravity in the simulator for the purposes of debugging.
To do so, call the `/quad_rotor/gravity` service as follows:
```
$ rosservice call /quad_rotor/gravity "data: false"
```

### Setting Pose ###

To set the quad pose, use the `/quad_rotor/set_pose` service. The following service call
will place the quad at the origin:
```
$ rosservice call /quad_rotor/set_pose "pose:
position:
x: 0.0
y: 0.0
z: 0.0
orientation:
x: 0.0
y: 0.0
z: 0.0
w: 0.0"
```

### Plotting using `quad_plotter_node` ###

The `quad_plotter_node` is a handy tool which allows you to capture and plot quad movements.
This might be useful to you while you are tuning the quad rotor in simulation.

**Services:**
- `/quad_plotter/start_recording` - Begins recording plot data (poses)
- `/quad_plotter/stop_recording` - Stops recording plot data (poses)
- `/quad_plotter/clear_path_history` - Clear plot history (poses)
- `/quad_plotter/clear_waypoints` - Clear waypoints
- `/quad_plotter/load_waypoints_from_sim` - Gets waypoints from the drone simulator
- `/quad_plotter/get_path_history` - Returns path history as pose array
- `/quad_plotter/plot_one` - Plots a 2D path on a given plane (*plane selection coming soon!*)
- `/quad_plotter/plot_3d` - Create a 3D plot depicting path in perspective
- `/quad_plotter/plot_grid` - Create a grid plot, showing 4 different views

**Example: Capturing a Grid Plot**
1. Load waypoints from the simulator (optional) `$ rosservice call /quad_plotter/load_waypoints_from_sim`
2. Begin recording poses `$ rosservice call /quad_plotter/start_recording "{}"`
3. Perform the behavior that you wish to capture in the simulator.
4. Stop recording poses `$ rosservice call /quad_plotter/stop_recording "{}"`
5. Generate the plot `$ rosservice call /quad_plotter/plot_gird "{}"`

After performing the above steps, a new timestamped PNG image should be generated and placed in the `/quad_controller/output_data` directory.

# Using the Simulator #

First be sure to grab the newest version of the simulator for your host computer OS [here](https://github.com/udacity/RoboND-Controls-Lab/releases). **Please note that you cannot use the simulator inside of the Udacity supplied course VM (Virtual Machine). You have to use the simulator for your host operating system and connect it to your VM.**

If using the VM, inside the simulator's `_data` or `/Contents` folder, edit `ros_settings.txt` and set `vm-ip` to the VM’s IP address and set `vm-override` to `true`. If not using a VM, no edit is necessary.

To find the ip of your VM, type `echo $(hostname -I)` into a terminal of your choice. **Be aware that the ip address of your VM can change. If you are experiencing problems, be sure to check that the VM's ip matches that of which you have in ros_settings.txt**

**Note: Be sure to use at least V2.1.0 of the Udacity provided VM for this lab**