Skip to content

A fork of the python client for dynamixel servos written by Patrick Goebel hosted on google code.

License

Notifications You must be signed in to change notification settings

CBA2011/pydynamixel

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

34 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

pydynamixel

This is a Python version of the ForestMoon Dynamixel library originally written in C# by Scott Ferguson. It was forked of the project, which is maintained by Ian Danforth at https://github.com/iandanforth/pydynamixel.

The original Python version was created for the Pi Robot Project (mailto:[email protected]) which lives at http://www.pirobot.org.

This github fork aims at upgrading from Python 2.7 to Python 3.4 in order to make it interoperable with picochess (https://github.com/jromang/picochess).

Prerequisites

  • Python 3.4
  • pip
  • pyserial
  • git
  • At least one Dynamixel AX-12A or AX-12+ servo.
  • A USB2Dynamixel module.

Library Installation

The installation of the original library (https://github.com/iandanforth/pydynamixel) from Pypi using pip seems to be broken. So,

Source Installation

If you'd like to have access to the getting started examples or contribute to the library, you can clone this library locally.

$ git clone https://github.com/CBA2011/pydynamixel.git

Run the example (same as text as that of Ian Danforth)

  • Connect your USB2Dynamixel to a USB port

  • Connect at least one dynamixel servo to that

  • Connect power to the servo

  • Launch the example script

    $ python example.py

If you're on a Mac or on Linux you should be presented with a list of found USB ports. Select the one to which you have attached the USB2Dynamixel for example on my machine (a Mac) it shows up as:

/dev/tty.usbserial-A8005k21

If you are on Windows you will need to enter the name of the correct USB port manually.

You will then be asked to enter a baud rate, the default should work. Finally enter highest ID number of the attached servos.

If servos are found the script will ask if you want to move them to their home positions (512).

Type 'y' and they should move! If they were already at their home positions try editing the script to move them to another position.

If they still don't move you'll need to trouble shoot.

Troubleshooting

  • When you plug in the USB2Dynamixel to your computer does the red power LED light up?
    • If not your module may be defective, or your USB port may not be powered.
  • When the script says "Scanning for Dynamixels ..." does the yellow LED on the USB2Dynamixel blink ~1/second?
    • The module is not receiving commands or is not transmitting them.
    • Try reconnecting the module, or lowering the baud rate.
  • No servos are found even though they are connected.
    • Is the USB2Dynamixel set to the correct communications type? For AX-12 servos it should be set to TTL.
  • Still no servos found!
    • When you plug in the power to the servo network does the power indicator LED on the servo briefly light up red?
      • Double check there is really power being supplied.
      • Double check the servo network cables are firmly seated into each servo.
      • Otherwise the servo or cables may be defective.

About

A fork of the python client for dynamixel servos written by Patrick Goebel hosted on google code.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 100.0%