The code in this repository, once defined a serial manipulator — i.e. a robot whose links are connected in a serial fashion — computes a complete mathematical description through symbolic computation of the functions that characterize its kinematics and dynamics.
Thanks to Matlab symbolic computing toolbox, the expressions are simplified (where possible) and it is possible to output an optimized matlab code numerically computing such expressions, which can be useful in simulation and control contexts.
- Download and usage
- Robot definition
- Computed expressions
- Applications examples
- References
- Contributing
You can use git to download the repository and use it in your Matlab or Simulink projects:
git clone https://github.com/ferrarodav/symbolic_robot.git
There are three functions:
get_manipulator
which takes as input the definition of the manipulator structure (through the variablesDHParams
,jointTypes
andbase
) and outputs a struct containing the symbolic definitions needed for kinematicsadd_manipulator_dynamics
which takes as input the already computed struct and definition of the manipulator mass (through the variablescoms
,masses
,Is
andg0
). It adds to the struct the symbolic definitions needed for dynamicsexport_functions
which saves the symbolic functions to matlab code. It takes as input the robot struct, a string to prefix to the output files and a true/false flag telling the symbolic toolbox whether to optimize the code (slower while exporting)
In the examples
folder the script planar_robot
definse a planar manipulator – eventually the measures are perturbated to mimic construction errors – and uses the above functions to build the symbolic expressions and export them. The plot_planar_manipulator
function uses the computed transformation matrices to draw the robot. The plot_planar_workspace
function uses the direct kinematics to make a montecarlo simulation of the robot workspace.
The Denavit Hartenberg (DH) convention is used to represent the manipulator. Each link is represented by four parameters which indicate how to transform the reference frame in order to get from a joint to the next:
- d: offset along previous z axis to the common normal
- theta: angle about previous z axis, from old x axis to new x axis
- r: length of the common normal. Assuming a revolute joint, this is the radius about previous z axis
- alpha: angle about common normal, from old z axis to new z axis
The i
-th joint is positioned at the i-1
-th link reference frame and moves the i
-th link by rotating q_i
radiants along the z axis — if rotational — or by displacing q_i
meters along the z axis — if prismatic.
Note that the i
-th link reference frame is positioned at its end.
The base reference frame is the one where the first joint is positioned.
The end-effector reference frame is the last link reference frame.
DHParams
: a matrix where each row contains the four Denavit Hartenberg parameters of a linkjointTypes
: a string containing ar
or ap
for each link according the type of the joint connecting it to the previous one (r
for rotational andp
for prismatic)base
: the 4x4 transformation matrix of the base reference frame (eye(4)
if the manipulator base frame corresponds with the origin of coordinates)
coms
: a cell containing a 3-dimensional vector for each link pointing at its center of mass. Each vector must be expressed ini
-th link reference frame (the coordinates will likely be negative, since the reference frame is centered at the end of the link)masses
: a vector containing the mass of each linkIs
: a cell containing a 3x3 matrix for each link representing its moment of inertia tensor (with respect to the link center of mass, the axes parallel to thei
-th reference frame ones)g0
: a 3-dimensional vector representing the gravity (usually[0 -9.81 0]
)
The struct returned by the functions contains the parameters passed to define the robot and the symbolic expressions of the robot kinematics and dynamics.
In the struct returned by get_manipulator
:
T
: a cell containing for each link the 4x4 trasformation matrix of its reference frame with respect to the origin of coordinatesrelT
: a cell containing for each link the 4x4 trasformation matrix of its reference frame with respect to the previous link reference framez
: a cell containing for each link the z axis versor with respect to the origin of coordinatesp
: a cell containing for each link the position vector of its reference frame with respect to the origin of coordinateseuler
: a cell containing for each link the euler angles describing its reference frame orientationJ
: the end-effector geometric jacobianJa
: the end-effector analytical jacobian. Unlike the geometric jacobian, this is integrable since the rotation is expressed with the euler coordinates derivatives instead of the angular velocities (which, on the other hand, have a clear physical meaning)jacobian
: the expression of the geometric jacobian with respect to a generic point in the space
In the struct returned by add_manipulator_dynamics
:
Jp
: a cell containing for each link its center of mass geometric jacobiang
: vector of the generalised torque imposed by gravity on each jointB
:N x N
inertia matrix (N being the number of links). It encodes the inertia around each joint axis and the interaction between couples of joints. The kinetic energy is given by:C
:N x N x N
tensor representing the centrifugal and Coriolis effects, also called the Christoffel symbols of the first type. The torque given by this termc
can be computed contracting the tensor:Ja_dot
: the derivative of the analytical Jacobian with respect to time. Useful for control in the operational space
Beside exporting the expressions to code with export_functions
, the Matlab subs
command can be used to substitute the variables. To enable this, the following symbolic variables objects are in the struct returned:
q
: vector ofN
variables representing the joint coordinates, used in every returned expressionq_dot
: vector ofN
variables representing the time derivative of the joint coordinates, used in theJa_dot
expressionpoint
: vector of 3 variables, representing the coordinates of a generic point in the space, used in thejacobian
expression. It can be used to compute the geometric jacobian of a specific point of the robot: you should substitute the numeric point coordinates (with respect to the origin of coordinates frame), and — if the point belongs to thei
-th link — zero-out the columns from thei+1
-th on (change of successive joints coordinates don't move the point). Look at howJp
is obtained inside theadd_manipulator_dynamics
to see an example
The expressions computed by the functions in this repository can be used in a variety of ways. Like in the simple code examples, to draw the robot points or sample the workspace. Uses of the dynamics include simulating a robot model and controlling the robot, here there are some example of the equation the output expresions fit in.
This equation defines the dynamical behaviour of a generical manipulator obtained through the Lagrangian which can be used to simulate it:
Fs
is the static friction coefficient (sgn is the sign function)Fv
is the dynamic friction coefficienttau
is the torque acting on each joint (e.g. produced by motors)he
is the vector of forces and moments exerted on the environment by the end-effector
In impedance control, once defined a desired position in the joint space q_d
, we want to make the end-effector behave as a mass-spring-damper system with respect to the desired position in the joint space:
We can tune as preferred the K and D, which are matrices representing the spring and damper constants. tau_e
are the torques generated by the external forces.
The torques tau
needed by the motors can be computed as:
With h
being the torques given to compensate for coriolis, gravity and friction, computed as:
The conventions, definitions and formulas used are from the following book:
Siciliano, Bruno. Robotics: Modelling, Planning and Control. Springer Verlag, 2009.
I'd happily receive contributions to improve the repository. Here some example of things I think could be useful to the project:
- The possibility to add discrete masses to the model (needed to easily include the motor — whose rotor weight and inertia are not negligible). Ref:
eq. 7.21
of the book - Extend the simple plot function to 3D manipulators