Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fix #42 issue and add gitignore file #43

Open
wants to merge 110 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
110 commits
Select commit Hold shift + click to select a range
f37836d
Merge branch 'master' into indigo-devel
Dec 7, 2015
5f0125d
Fixed some indentation
Dec 7, 2015
eacd926
Rearranged some lines for readability
Dec 7, 2015
5a4affc
Moved MAX_PWM into diff_controller.h
Dec 7, 2015
56686b5
Fixed #elif statement for ARDUINO_ENC_COUNTER
Dec 7, 2015
838f5f7
Merge branch 'indigo-devel'
Dec 7, 2015
58fc3de
Simplified #ifdef for PWM servos
Dec 7, 2015
fcffbda
Removed obsolete load_manifest statements
Dec 8, 2015
3310443
Added new servo support
Dec 13, 2015
5c63db7
Added clear_params=true to arduino.launch file
Dec 13, 2015
11105cf
Fixed init_position default in servo_controller.py
Dec 13, 2015
a24d34e
Added servo example to ros_arduino_python
Dec 13, 2015
ab0f16a
Added servo params to same arduino_params.yaml file
Dec 14, 2015
aefe39b
Cleaned up object constructors and fixed set_speed calculation
Dec 14, 2015
973b6ae
Added controllers.py
Dec 14, 2015
812c402
Updated README with new servo instructions
Dec 14, 2015
413908c
Fixed README typos
Dec 14, 2015
14aa21a
Added table of contents to README
Dec 14, 2015
702624e
Fixed indentation for table of contents of README
Dec 14, 2015
9322825
Added check for base_controller before stopping robot when node exits
Dec 15, 2015
4fd35aa
Added check for duplicate servo pins in servo array
Dec 15, 2015
3559a44
Fixed sweep_demo.py loop to prevent stalling and added sweep_demo.lau…
Dec 15, 2015
dfebe5a
Added have_joints variable to top of script to prevent error when exi…
Dec 15, 2015
dc0a18b
Removed extraneous set_target_position function
Dec 15, 2015
04712b6
Made sensor type case insensitive since otherwise it is a pain to rem…
Dec 16, 2015
4297345
Removed case-sensitive note for sensor type in example params file
Dec 16, 2015
828984d
Fixed MaxEZ1 sensor type test to be case insensitive
Dec 16, 2015
3f98ea4
Changed return value for GP2D12 IR sensor from max_range to NaN when …
Dec 16, 2015
1289091
Updated formula for computing distance for the Sharp GP2D12 IR range …
Dec 16, 2015
489debc
Changed min_angle to min_position and max_angle to max_position to al…
Dec 18, 2015
7bcd5c4
Changed min_angle to min_position and max_angle to max_position in sw…
Dec 18, 2015
3e6ab35
Replaced self.base_frame with params['frame_id'] for sensors
Dec 18, 2015
c2614fc
Removed min/max check on servo_write since the range 0-180 does not a…
Dec 18, 2015
6a8f941
Added default for frame_id parameter
Dec 18, 2015
896e60d
Added fix to arduino_driver.py so that serial port now opens consiste…
Dec 18, 2015
2de2028
Added ROS services for reading and writing from/to all named sensors
Dec 18, 2015
fcb6629
Fixed bug in Range sensor message type
Dec 21, 2015
2c71342
Added pin mode services
Jan 9, 2016
fb24de4
Reverted units back to degrees for raw servo commands
Jan 9, 2016
fc3a450
Conditionalized sensor publisher on rate != 0
Jan 9, 2016
b8b51d4
Increased maxium delay value for setting servo speed
Jan 9, 2016
5933239
Added support for RoboGaia 3-axis encoder shield
Jan 27, 2016
f7c01d4
Added support for Arduino Motor Shield R3
Jan 27, 2016
bf88d3f
Fixed indentation in encoder_driver.h
Mar 15, 2016
453eae9
Added blank line for readability in encoder_driver.ino
Mar 15, 2016
038e0cf
Added support for Adafruit Motor Shield V2 and Arduino Motor Shield V3
Mar 15, 2016
63a3296
Added error message for unsuccessful connection
Mar 20, 2016
cc5fa47
Commented out follow_controller code since it is not yet ready
Mar 21, 2016
1bb6bb8
Added odom_linear_scale_correction and odom_angular_scale_correction …
Mar 27, 2016
6441cb5
Added default covariance values for odometry message as well as use_i…
Mar 28, 2016
afad6f1
Added reset_odometry service to base controller
Mar 28, 2016
4853533
Added heart beat test for the serial connection which allows unpluggi…
Apr 3, 2016
77a5a9a
Updated check for missing PID parameters
Apr 3, 2016
6adb1bd
Added preliminary support for Adafruit 9-DOF IMU to firmware but not …
Apr 4, 2016
77f5963
Fixed bug in heartbeat check
Apr 4, 2016
9a84380
Replaced all strings with F() macro in Serial.print statements
Apr 6, 2016
142e529
Replaced all strings with F() macro in Serial.print statements
Apr 6, 2016
59488c7
Removed DOS-like CR/LF line terminators in arduino_driver.py
Apr 6, 2016
03b5666
Modified the execute() and recv() functions to be more robust
Apr 9, 2016
e996d12
Added get_imu_data function and cleaned up unused variables
Apr 9, 2016
e99871c
Updated execute() commands to use readline() instead of multiple read…
Apr 10, 2016
6234b92
Added max_attempts loop to execute() function
Apr 10, 2016
79e5a3b
Updated imu.h and imu.ino and increased command argv array size from …
Apr 11, 2016
17d6a44
Removed print statement from update_pid() function
Apr 12, 2016
9794664
Added initial IMU support to arduino_sensors and base_controller
Apr 12, 2016
d03061a
Added missing resetEncoders() function to encoder_driver.ino
Apr 18, 2016
2b4567e
Added resetPID() call when robot velocities are 0 to fix motion perse…
Apr 18, 2016
1373f49
Fixed typo in comment
Apr 18, 2016
cf51f8c
Added UpdatePID service and dynamic reconfigure support
Apr 18, 2016
8dd8a19
Updated sample arduino_params.yaml file
Apr 18, 2016
0e04388
Added flushInput() and flushOutput() to execute() when timeout or err…
Apr 18, 2016
a43f33e
Tweaked description for IMU sensor type
Apr 18, 2016
171ed94
Enforced float() type on wheel_track for dth calculation
Apr 18, 2016
bc93573
Updated README for master branch
May 28, 2016
ee4485b
Updated README for master branch
May 28, 2016
f796a1a
Updated README for master branch
May 28, 2016
d8dd6a5
Restored defaults to ROSArduinoBridge.ino
Jun 1, 2016
c8fe760
Added error codes to arduino_driver.py to be used with ROS diagnostics
Jun 1, 2016
82b2bbb
Improved initial connection loop in arduino_driver.py
Jun 27, 2016
6975ea2
Improved initial connection loop in arduino_driver.py
Jun 27, 2016
9a62296
Improved initial connection loop in arduino_driver.py
Jun 27, 2016
9bcf7ff
Restored ROSArduinoBridge.ino default values
Sep 12, 2016
b8931b2
Added fusionGetOrientation function to Adafruit 9-dof imu in imu.ino
Sep 12, 2016
dd58da6
Fixed comment in sensors.h
Sep 12, 2016
d0a61ed
Updated servo_example_params.yaml
Sep 12, 2016
0fcdcd0
Updated arduino_node.py including adding a diagnostics rate parameters
Sep 12, 2016
8595db7
Added diagnostics dependencies to package.xml
Sep 12, 2016
e7bfde4
Added diagnostics, IMU and Gyro support to arduino_sensors
Sep 12, 2016
9d0ed30
Added diagnostics and default covariance values to base controller mo…
Sep 12, 2016
0a2877a
Removed getDiagnostics from controllers.py
Sep 12, 2016
ba4ded3
Added joint_speed_scale_correction parameter for servos and corrected…
Sep 12, 2016
9fe0923
Added diagnostcs and follow_controller modules
Sep 12, 2016
be4bb3e
Minor edit to arduino_python node
Sep 12, 2016
f5b825c
Tweaked diagnostics.py so that rqt_robot_monitor does not complain ab…
Sep 13, 2016
5f35efe
Undid last commit since it introduced another bug...
Sep 13, 2016
7e844b5
Removed harmless extra space
Oct 2, 2016
44137ce
Increased default timeout from 0.1 to 0.5 seconds
Oct 6, 2016
aa8ba65
Tweaked namespace for dynamic reconfigure and base controller to allo…
Oct 6, 2016
d9968a7
Added try-except around append(sensor)
Nov 1, 2016
6d6390f
Finished tweaks on follow_controller.py to execute joint action traje…
Nov 6, 2016
c15c0be
Close serial port on exit
Nov 17, 2016
9d29c18
Removed duplicate line in package.xml
Nov 22, 2016
6c77321
Added optional encoder jump detection
Nov 22, 2016
8da758f
Added ROS dependencies to README
Dec 1, 2016
b56f3d7
Added ROS dependencies to README
Dec 1, 2016
dd403d0
Add gitignore file
Fibird Aug 15, 2017
7810b42
Fix #42 issue
Fibird Aug 15, 2017
ffccb94
Make parameter 'motors_reversed' take effect
Fibird Aug 20, 2017
0c1c188
Add parameters of real robot
Fibird Aug 26, 2017
d2f6d00
Add magnetic message and remove some useless infos
Fibird Aug 31, 2017
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
106 changes: 106 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,106 @@

# Created by https://www.gitignore.io/api/python

### Python ###
# Byte-compiled / optimized / DLL files
__pycache__/
*.py[cod]
*$py.class

# C extensions
*.so

# Distribution / packaging
.Python
env/
build/
develop-eggs/
dist/
downloads/
eggs/
.eggs/
lib/
lib64/
parts/
sdist/
var/
wheels/
*.egg-info/
.installed.cfg
*.egg

# PyInstaller
# Usually these files are written by a python script from a template
# before PyInstaller builds the exe, so as to inject date/other infos into it.
*.manifest
*.spec

# Installer logs
pip-log.txt
pip-delete-this-directory.txt

# Unit test / coverage reports
htmlcov/
.tox/
.coverage
.coverage.*
.cache
nosetests.xml
coverage.xml
*,cover
.hypothesis/

# Translations
*.mo
*.pot

# Django stuff:
*.log
local_settings.py

# Flask stuff:
instance/
.webassets-cache

# Scrapy stuff:
.scrapy

# Sphinx documentation
docs/_build/

# PyBuilder
target/

# Jupyter Notebook
.ipynb_checkpoints

# pyenv
.python-version

# celery beat schedule file
celerybeat-schedule

# SageMath parsed files
*.sage.py

# dotenv
.env

# virtualenv
.venv
venv/
ENV/

# Spyder project settings
.spyderproject
.spyproject

# Rope project settings
.ropeproject

# mkdocs documentation
/site

# End of https://www.gitignore.io/api/python
# temporary files
*~
156 changes: 128 additions & 28 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,8 +1,32 @@
**UNSTABLE BRANCH**

This branch is under active development and is not likely to work. Please use the official hydro-devel or indigo-devel branch for ROS Hydro or ROS Indigo, respectively.

Table of Contents
=================

* [Overview](#overview)
* [Official ROS Documentation](#official-ros-documentation)
* [System Requirements](#system-requirements)
* [Preparing your Serial Port under Linux](#preparing-your-serial-port-under-linux)
* [Installation of the ros_arduino_bridge Stack](#installation-of-the-ros_arduino_bridge-stack)
* [Loading the ROSArduinoBridge Sketch](#loading-the-rosarduinobridge-sketch)
* [Firmware Commands](#firmware-commands)
* [Testing your Wiring Connections](#testing-your-wiring-connections)
* [Configuring the ros_arduino_python Node](#configuring-the-ros_arduino_python-node)
* [Launching the ros_arduino_python Node](#launching-the-ros_arduino_python-node)
* [Viewing Sensor Data](#viewing-sensor-data)
* [Sending Twist Commands and Viewing Odometry Data](#sending-twist-commands-and-viewing-odometry-data)
* [ROS Services for Sensors and Servos](#ros-services-for-sensors-and-servos)
* [ROS Joint Topics and Services](#ros-joint-topics-and-services)
* [Using the on-board wheel encoder counters (Arduino Uno only)](#using-the-on-board-wheel-encoder-counters-arduino-uno-only)
* [NOTES](#notes)

Overview
--------
This branch (indigo-devel) is intended for ROS Indigo and above, and uses the Catkin buildsystem. It may also be compatible with ROS Hydro.

This ROS stack includes an Arduino library (called ROSArduinoBridge) and a collection of ROS packages for controlling an Arduino-based robot using standard ROS messages and services. The stack does **not** depend on ROS Serial.
This ROS metapackage includes an Arduino library (called ROSArduinoBridge) and a collection of ROS packages for controlling an Arduino-based robot using standard ROS messages and services. The stack does **not** depend on ROS Serial.

Features of the stack include:

Expand All @@ -23,7 +47,9 @@ the PC. The base controller requires the use of a motor controller and encoders
* Pololu VNH5019 dual motor controller shield (http://www.pololu.com/catalog/product/2502) or Pololu MC33926 dual motor shield (http://www.pololu.com/catalog/product/2503).

* Robogaia Mega Encoder shield
(http://www.robogaia.com/two-axis-encoder-counter-mega-shield-version-2.html) or on-board wheel encoder counters.
(http://www.robogaia.com/two-axis-encoder-counter-mega-shield-version-2.html)

* Instead of the Encoder shield, wheel encoders can be [connected directly](#using-the-on-board-wheel-encoder-counters-arduino-uno-only) if using an Arduino Uno

**NOTE:** The Robogaia Mega Encoder shield can only be used with an Arduino Mega. The on-board wheel encoder counters are currently only supported by Arduino Uno.

Expand All @@ -38,6 +64,10 @@ http://www.ros.org/wiki/ros_arduino_bridge

System Requirements
-------------------
**ROS Dependencies**

$ sudo apt-get install ros-indigo-diagnostic-updater ros-indigo-control-msgs ros-indigo-nav-msgs

**Python Serial:** To install the python-serial package under Ubuntu, use the command:

$ sudo apt-get install python-serial
Expand Down Expand Up @@ -71,7 +101,7 @@ http://www.robogaia.com/uploads/6/8/0/9/6809982/__megaencodercounter-1.3.tar.gz
These libraries should be installed in your standard Arduino
sketchbook/libraries directory.

Finally, it is assumed you are using version 1.0 or greater of the
Finally, it is assumed you are using version 1.6.6 or greater of the
Arduino IDE.

Preparing your Serial Port under Linux
Expand Down Expand Up @@ -129,45 +159,49 @@ To install the ROSArduinoBridge library, follow these steps:

where SKETCHBOOK_PATH is the path to your Arduino sketchbook directory.

$ cp -rp `rospack find ros_arduino_firmware`/src/libraries/ROSArduinoBridge ROSArduinoBridge
$ \cp -rp `rospack find ros_arduino_firmware`/src/libraries/ROSArduinoBridge -T ROSArduinoBridge

This last command copies the ROSArduinoBridge sketch files into your sketchbook folder. The next section describes how to configure, compile and upload this sketch.
This last command copies the ROSArduinoBridge sketch files into your sketchbook folder and overwrites any existing files with the same name. The next section describes how to configure, compile and upload this sketch.


Loading the ROSArduinoBridge Sketch
-----------------------------------

* If you are using the base controller, make sure you have already installed the appropriate motor controller and encoder libraries into your Arduino sketchbook/librariesfolder.

* Launch the Arduino 1.0 IDE and load the ROSArduinoBridge sketch.
* Launch the Arduino IDE and load the ROSArduinoBridge sketch.
You should be able to find it by going to:

File->Sketchbook->ROSArduinoBridge

NOTE: If you don't have the required base controller hardware but
still want to try the code, see the notes at the end of the file.
**NOTE:** If you have the required hardware to use the base controller, uncomment the line that looks like this:

<pre>
//#define USE_BASE
</pre>

Choose one of the supported motor controllers by uncommenting its #define statement and commenting out any others. By default, the Pololu VNH5019 driver is chosen.
so it looks like this:

Choose a supported encoder library by by uncommenting its #define statement and commenting out any others. At the moment, only the Robogaia Mega Encoder shield is supported and it is chosen by default.
<pre>
#define USE_BASE
</pre>

If you want to control PWM servos attached to your controller, change
the two lines that look like this:
You will also need to choose one of the supported motor controllers by uncommenting its #define statement and commenting out any others. By default, the Pololu VNH5019 driver is chosen.

Choose a supported encoder library by by uncommenting its #define statement and commenting out any others. At the moment, the two options are the Robogaia Mega Encoder shield (chosen by default) and the directo connection ARDUINO_ENC_COUNTER option that works for Arduino Uno compatible boards.

By default, the sketch will provide support to control PWM servos attached to your Arduino. If you do not need servo support, you can comment out the line that looks like this:

<pre>
//#define USE_SERVOS
#undef USE_SERVOS
#define USE_SERVOS2
</pre>

to this:
so that it looks like this:

<pre>
#define USE_SERVOS
//#undef USE_SERVOS
//#define USE_SERVOS2
</pre>

You must then edit the include file servos.h and change the N_SERVOS
parameter as well as the pin numbers for the servos you have attached.

* Compile and upload the sketch to your Arduino.

Expand All @@ -185,14 +219,20 @@ The list of commands can be found in the file commands.h. The current list incl
#define PIN_MODE 'c'
#define DIGITAL_READ 'd'
#define READ_ENCODERS 'e'
#define CONFIG_SERVO 'j'
#define MOTOR_SPEEDS 'm'
#define PING 'p'
#define RESET_ENCODERS 'r'
#define SERVO_WRITE 's'
#define SERVO_READ 't'
#define UPDATE_PID 'u'
#define SERVO_DELAY 'v'
#define DIGITAL_WRITE 'w'
#define ANALOG_WRITE 'x'
#define ATTACH_SERVO 'y'
#define DETACH_SERVO 'z'
#define LEFT 0
#define RIGHT 1
</pre>

For example, to get the analog reading on pin 3, use the command:
Expand All @@ -211,6 +251,18 @@ To move the robot forward at 20 encoder ticks per second:

m 20 20

To intialize a PWM servo on pin 3 with speed delay 100ms:

j 3 100

To move the servo on pin 3 to position 120 degrees:

s 3 120

To detach servo on pin 3:

z 3


Testing your Wiring Connections
-------------------------------
Expand Down Expand Up @@ -278,8 +330,16 @@ sensors: {
#motor_current_right: {pin: 1, type: PololuMotorCurrent, rate: 5},
#ir_front_center: {pin: 2, type: GP2D12, rate: 10},
#sonar_front_center: {pin: 5, type: Ping, rate: 10},
arduino_led: {pin: 13, type: Digital, rate: 5, direction: output}
onboard_led: {pin: 13, type: Digital, rate: 5, direction: output}
}

# Joint name and configuration is an example only
joints: {
head_pan_joint: {pin: 3, init_position: 0, init_speed: 90, neutral: 90, min_angle: -90, max_angle: 90, invert: False, continous: False},
head_tilt_joint: {pin: 5, init_position: 0, init_speed: 90, neutral: 90, min_angle: -90, max_angle: 90, invert: False, continous: False}
}


</pre>

**NOTE**: Do not use tabs in your .yaml file or the parser will barf it back out when it tries to load it. Always use spaces instead. **ALSO**: When defining your sensor parameters, the last sensor in the list does **not** get a comma (,) at the end of the line but all the rest **must** have a comma.
Expand Down Expand Up @@ -324,6 +384,12 @@ to define an output pin, set the direction explicitly to output. In
the example above, the Arduino LED (pin 13) will be turned on and off
at a rate of 2 times per second.

_Defining Servo Configurations_

The *joints* parameter defines a dictionary of joint names and servo parameters. (You can name each joint whatever you like but rememember that joint names will become part of the servo's ROS topic and service names.)

The most important parameter is *pin* which of course must match the pin the servo attaches to on your Arduino. Most PWM servos operate from 0 to 180 degrees with a "neutral" point of 90 degrees. ROS uses radians instead of degrees for joint positions but it is usually easier for programmers to specify the angular limits in the config file using degrees. The ROS Arduino Bridge pacakge takes care of the conversion to radians. An *init_position* of 0 therefore means 0 degrees relative to the neutral point of 90 degrees. A *max_angle* of 90 degrees maps into 180 degrees at the servo.

_Setting Drivetrain and PID Parameters_

To use the base controller, you will have to uncomment and set the
Expand Down Expand Up @@ -413,9 +479,9 @@ or

$ rxplot -p 60 /odom/pose/pose/position/x:y, /odom/twist/twist/linear/x, /odom/twist/twist/angular/z

ROS Services
------------
The ros\_arduino\_python package also defines a few ROS services as follows:
ROS Services for Sensors and Servos
-----------------------------------
The ros\_arduino\_python package also defines a few ROS services for sensors and servos as follows:

**digital\_set\_direction** - set the direction of a digital pin

Expand All @@ -441,6 +507,40 @@ where id is the index of the servo as defined in the Arduino sketch (servos.h) a

where id is the index of the servo as defined in the Arduino sketch (servos.h)

ROS Joint Topics and Services
-----------------------------
At the ROS level, a servo is called a joint and each joint has its own topics and services. To change the position of a joint, publish the position
in radians to the topic:

**/\<joint_name\>/command**

For example, a joint called head_pan_joint in the YAML config file can be controlled using the topic:

**/head_pan_joint/command**

which takes a Float64 argument specifying the desired position in radians. For example, the command:

$ rostopic pub -1 /head_pan_joint/command std_msgs/Float64 -- 1.0

will move the servo to angle 1.0 radians from the neutral point; i.e. about 147 degrees when using the default neutral point of 90 degrees. Using a negative value moves the servo in the other direction:

$ rostopic pub -1 /head_pan_joint/command std_msgs/Float64 -- -1.0

A number of services are also available for each joint:

**/\<joint_name\>/enable** - Enable or disable a joint. Disabling also detachs the underlying servo so that it can be moved by hand.

$ rosservice call /head_pan_joint/enable false

**/\<joint_name\>/relax** - Another way to detach the underlying servo so that it can be moved by hand.

$ rosservice call /head_pan_joint/relax

**/\<joint_name\>/set_speed** - Set the movement speed of servo in radians per second.

$ rosservice call /head_pan_joint/set_speed 1.0


Using the on-board wheel encoder counters (Arduino Uno only)
------------------------------------------------------------
The firmware supports on-board wheel encoder counters for Arduino Uno.
Expand Down Expand Up @@ -473,21 +573,21 @@ follow the instructions below so that you can still use your
Arduino-compatible controller to read sensors and control PWM servos.

First, you need to edit the ROSArduinoBridge sketch. At the top of
the file, change the two lines that look like this:
the file, comment out the line that looks like this:

<pre>
#define USE_BASE
//#undef USE_BASE
</pre>

to this:
so it looks like this:

<pre>
//#define USE_BASE
#undef USE_BASE
</pre>

**NOTE:** You also need to comment out the line that looks like this in the file encoder_driver.ino:
(You may find that it is already commented out.)

**NOTE:** If you are using a version of the Arduino IDE earlier than 1.6.6, then you also need to comment out the line that looks like this in the file encoder_driver.ino:

#include "MegaEncoderCounter.h"

Expand Down
Loading