/StarterGuide-Dobot-Magician-with-Python

Dobot Magician with pure Python - Starter Guide

Primary LanguagePython

Dobot Magician with Python - Starter Guide

Disclaimer: This guide will cover starting out with the DoBot Magician using Windows. Using other operating systems won't guarantee that the methods used in this guide will work.

The DoBot Magician is a fun mechanical arm with alot of functionallity. Thanks to the large array of peripherals available it can do many tasks if operated correctly. The main means of controling the DoBot Magician is the Magician Studio application and it is easy to use for people of any age.

This guide will not focus on how to operate the DoBot Magician through the Magician Studio, but instead through Python. Using your own code to control the DoBot Magician opens up for much more freedom, allowing things like automation and very calibrated movements for intricate tasks. Python is an object oriented language and if you're not familiar with it please refer to the Python manual pages and the various guides available on the internet. The link to the download site, available at the bottom of the guide README file, for Python also contains tutorials and instructions for how you can get started on your own python project.

Table of Content

Starting Out

To get started you'll need an IDE which you can use to work with Python. There is no need to use a specific one so go with the IDE that you are the most comfortable with and has support for Python. For the functions created in this guide Atom was used, but it is not necessary as an IDE like Visual Studio Code or similar would also suffice.

To communicate with the DoBot we need to download the API supplied by DOBOT for the DoBot Magician. The file you are looking for is DobotDemov2.0. From this website you're also required to download and install the Magician Studio. We will not use the application itself, but the installation process contains some dependencies required to communicate with the dobot from our third party application.

You will also need Python. Python is also available for download through the Microsoft Store.

Important Functions

To understand how to use the Dobot more efficiently we have to look into what types of commands you can use to control it. Many of these functions are accessable inside the DoBotControl file, but theres also alot of them inside the DLL file which is not being used. Here we will briefly go through some of the most important ones to get you started. If you want more indepth information it can be found in the DoBot Magician API Description.

We will import the DobotDLLType file in python with the local name dType, as they have done in the DobotControl file. All of the DLL functions will be accessed with the help of this module name. The reason this local name is used to access the functions is to keep the guide in line with the DobotControl file to make it easier to understand.

To have access to the library containing the functions, we have to load it into an object in out code. The function dType.load() will load the platform specific library and return it into an object which we will call api.

Syntax:

api = dType.load()

Connect to the Dobot

To connect to the Dobot we use the function dType.ConnectDobot(). The arguments in this function are the api object created with the dType.load() function, the port name for the Dobot and the baudrate. The port name will only affect you if you use multiple Dobots connected to the computer and if you only have one Dobot Magician connected then the port name doesnt have to be specified. More information can be found in the documentation.

Syntax:

# Parameters:
# api      - Object which access the Dobot API functions.
# portName - Portname of the Dobot, with multiple Dobots in the system this will specify which one you connect to.
# baudrate - Rate at which information is transfered in a communication channel.

# Function:
dType.ConnectDobot(api, portName, baudrate)

Default Example:

dType.ConnectDobot(api, "", 115200)

To disconnect the Dobot, the function dType.DisconnectDobot() is used.

Syntax

dType.DisconnectDobot(api)

Queue Manipulation

There are functions which manipulates the command queue and functions that issue commands to the Dobot. You can operate the Dobot using the command queue, or just issue them directly. The difference is that the command queue can be filled up with commands and then executed in order, while without it the command will be executed directly after being called. To start off we will go through the mcommand queue manipulation functions.

The function dType.SetQueuedCmdStartExec() will start executing the commands in the queue one after another in order of inputting them. If no commands are in the queue, nothing will happen.

Syntax:

dType.SetQueuedCmdStartExec()

To stop executing the commands in the queue, you have to call dType.SetQueuedCmdStopExec(). This will stop quering the Dobot, but if a command is currently running when the function is called, the command will finish its execution. The function dType.SetQueuedCmdForceStopExec() however, will force the command being executed to be forced to stop.

Syntax:

dType.SetQueuedCmdStopExec()
dType.SetQueuedCmdForceStopExec()

The command queue can also be cleared using the function dType.SetQueuedCmdClear().

Syntax:

dType.SetQueuedCmdClear(api)

More queue manipulation functions are available in the documentation.

Setting Parameters

Before we start issuing movement commands we need to set some parameters which specifies the velocity and acceleration of the joints. This is done using the function dType.SetPTPCommonParams(). The function takes some arguments to specify the above. The first argument is the api object created with the load function. The second specifies the velocity ratio. The third specifies the acceleration ratio, and the last argument specifies if the function should be queued or not.

Syntax:

# Parameters:
# v        - Velocity of the Dobots movements
# a        - Acceleration of the Dobots movements.
# isQueued - To queue the command or not.

# Function:
dType.SetPTPCommonParams(api, v, a, isQueued)

Default Example:

dType.SetPTPCommonParams(api, 100, 100, isQueued = 1)

The home parameter specifies where the default stance of the Dobot Magician. Calling the home function then returns to this position. The arguments specifies the X and Y coordinates of the home location. Z is the height of the arm at this location and R is the rotation of the peripheral to return to. You can play around with the coordinates to find where you want the position to be. To return to the home position, use dType.SetHomeCmd(). If the home function is called before setting parameters, the dobot will return to the default home location, otherwise it will go to the user specified location.

Syntax:

# Parameters:
# x - X coordinate for home position.
# y - Y coordinate for home position.
# z - Z coordinate for home position.
# r - Peripheral rotation at home position.

# Function:
dType.SetHomeParams(api, x, y, z, r, isQueued)
# Parameters:
# homeCmd - Home command variable pointers

# Function:
dType.SetHomeCmd(api, homeCmd, isQueued)

Default Example:

dType.SetHomeParams(api, 250, 0, 50, 0, isQueued = 1)
dType.SetHomeCmd(api, homeCmd = 0, isQueued = 1)

Movement Commands

There are two major ways of moving the Dobot Magicians arm. The first is using X, Y and Z coordinates and the other is based on joint orientation. We will be using X, Y and Z in this guide, but if you want to use the joints please refer to the documentation.

The main way of moving the Dobot to a location is through the function dType.SetPTPCmd(). This function requires X, Y, Z and R coordinates and rotation. We also specify which movement mode to be used in the function and if we want to queue it or not. Keep in mind that the Dobot Magician will lock up if you move the arm to a location which it's unable to reach.

Syntax:

# Parameters:
# dType.movementMode - Specifies wanted movement mode.
# X                  - Requested X coordinate.
# Y                  - Requested Y coordinate.
# Z                  - Requested Z coordinate.
# R                  - PRequested peripheral rotation.

# Function:
dType.SetPTPCmd(api, dType.movementMode, X, Y, Z, R, isQueued)

Default Example

dType.SetPTPCmd(api, dType.PTPMode.PTPMOVLXYZMode, X, Y, Z, R, isQueued = 1)

After a command is issued, use the dType.QueuedCmdStartExec() function to start execution explained above. It is important when not using the queue to use the dType.dSleep() function to allow for commands to fully execute before forcing a new one, otherwise the outcome might not be satisfactory.

Peripherals

The Dobot Magician has alot of different peripherals in its repository, allowing it to do a bunch of fun things. Thins like using a suction cup to grab items, or grabbing items with a claw and many, many more! To activate the suction cup we use the function dType.SetEndEffectorSuctionCup().

Syntax:

# Parameters:
# enableControl - Enables control over the peripheral.
# suction       - Enables or Disabled the peripheral. 

# Function:
dType.SetEndEffectorSuctionCup(api, enableControl, suction, isQueued)

The enableControl argument enables or disables the pump. Suction enables outtake or intake. For more peripheral information, refer to the documentation.

There file named DobotArm.py contains wrapper functions which can be used as an example when making your own program.

Test Program

After extracting the contents of the DobotDemoV2.0 folder we find a list of more folders. These are demos for the available languages which can be used to operate the Dobot. The one we are going to use in this guide is the DobotDemoForPython. In this folder we can find a file called DobotControl.py. This file contains a test program which uses a connection to the Dobot through USB which makes it do a couple of gestures. If you have installed Python and Magician Studio correctly you should be able to run the file without any problems, as long as you are connected to the Dobot through any of your USB ports.

There is also an example program available for download on this github. This program includes some example functions for the API , this is not necessarily the only way to structure the program and the one you make will most probably not look similar to this one. Nevertheless, let's look into the functions.

The program starts with the creation of the object which we use to communicate with the Dobot. In the case of the example program the object is called ctrlBot and is of the type DobotArm. The constructor of the object takes in home coordinates for the Dobot. The constructor also calls the dobotConnect() function which connects to the Dobot and sets its various parameters.

In many of the functions we can find the self object being passed around. In python this is used to refer to the object calling the function to be able to access the information specific to that object.

Syntax:

dobotConnect(self)

The function commandDelay() is called after each command is issued to the dobot. This is included so that the dobot is allowed to do its action before another command is issued.

Syntax:

commandDelay(self, lastIndex)

toggleSuction() is an example function of how to initiate the peripheral connected to the dobot. In this example, we activate or deactivate the suction cup peripheral. It works much like a light switch, where the light is toggled on and off and keeps that state afterwards. This means that we only need to call the function to activate the peripheral, and then call it again once we're done with it.

Syntax:

toggleSuction(self)

Main movement is done through the moveArmXY() function. The arguments for the function is the x and y positions which we want the dobot to travel to.

Syntax:

moveArmXY(self, x,y)

As a utility a function that moves the arm to the selected home positions are also included.

Syntax:

moveHome(self)

Last but not least, the function pickToggle() moves the arm up or down to the requested height. The only argument it takes is the height it moves too.

Syntax:

pickToggle(self, itemHeight)

These functions will allow to do simple automation for the dobot by combining them, like in the manualmode function inside the main.py file. It allows for simple x,y grid movements and picking of items.

Conclusion

The capability of the Dobot Magician lays in your hands and what you can imagine. Automation, sorting, 3D printing and so on, it is a very fun machine to play with. I hope that this guide has helped you on your way to understanding how it works and to kick start you to start making the Dobot do whatever you want it to do.

Download Links

Atom - IDE referensed above.

VS-Code - Alternative IDE

Magician Studio - Dobot Application and Driver

DobotDemoV2.0 - Code Examples

Dobot API Manual - Manual for API

Python - Language used in this guide

Python installation instructions are available at their website. Other languages are also available but won't be present in this guide. The choice of IDE is completely in your hands.


Created by Hugo Nolte for Course PA1414 - Software Engineering Project

BTH - Blekinge Institute of Technology

2019