How to use a MATLAB Function with Robotic System Toolbox in Simulink?
27 views (last 30 days)
Show older comments
Hi everyone.
I'm designing a backstepping control of a 7 DoF robotic arm which I created and imported in MATLAB as RigidBody Tree object. Considering the control law, there is the term
so I computed the Coriolis matrix
in real-time knowing the current configuration of my robot q and the Mass matrix
. I did it by the Christoffel parametrization considering numerical data that comes from sequential integrations but it is very slow.
data:image/s3,"s3://crabby-images/2a979/2a9798dcb5c2b66cf276f8e7117e086dc38efadf" alt=""
data:image/s3,"s3://crabby-images/6fbdf/6fbdfbac4353911625737be41d055c792992a5a3" alt=""
data:image/s3,"s3://crabby-images/6ab07/6ab07631130517a075f384fcfbbe5db58471bef8" alt=""
As alternative approach to see if it is lighter than the previous one, I thought to solve the problem using the Corke's method (of the RTB) which considers to compute single termes of
due to
and the pair product
(further information here). Instead of set several Inverse Dynamics Simulink and MATLAB Function Blocks, can I define an external MATLAB function which contains the inverse dynamics command in a for loop? I think it should be more efficienty and elegant. In other words, how can I use this MATLAB Function below in Simulink? Is "Interpreted MATLAB Function" block the proper one?
data:image/s3,"s3://crabby-images/6fbdf/6fbdfbac4353911625737be41d055c792992a5a3" alt=""
data:image/s3,"s3://crabby-images/d5ae6/d5ae6f3ee2bb9c39ef2d6cfff774a7a450c8d1f4" alt=""
data:image/s3,"s3://crabby-images/8c66e/8c66e44e8cedb149df430e9c58291406df9872cb" alt=""
function C = computeCoriolisMatrix(q, dq, robot_free)
N = length(q);
C = zeros(N, N);
Csq = C;
for j = 1:N
QD = zeros(1,N);
QD(j) = 1;
tau = inverseDynamics(robot_free, q, QD);
Csq(:,j) = Csq(:,j) + tau';
end
for j = 1:N
for k = j+1:N
% find a product term qd_j * qd_k
QD = zeros(1,N);
QD(j) = 1;
QD(k) = 1;
tau = inverseDynamics(robot_free, q, QD);
C(:,k) = C(:,k) + (tau' - Csq(:,k) - Csq(:,j)) * dq(j);
end
end
C = C + Csq * diag(dq);
end
Thanks eveyone, Valerio
2 Comments
Gabriele Gualandi
on 11 Apr 2021
I would use the "Matlab function" block (not the Interpreted one). Then, I would compile it as an S-function (that is, C++ code).
Note that this process involves all the constraints deriving from writing S-Functions (e.g., you need to initialize your data structures with zeros). In particular, I would avoid that "inverseDynamics" invocation and past all your code in your Matlab function block (to have a monolithic block).
Answers (1)
siyong xu
on 30 May 2021
Edited: siyong xu
on 30 May 2021
I think that you can use the 'MATLAB system ' block, you can define a system object to compute the coriolis matrix.
There are two advatages:
Firstly, more efficient. You can invoke the internal funtions of Robotics System Toolbox which is more efficient than the outer function. And you can invoke the internal properities of rigidbodyTree object, which is convenient for coding.
Secondly, you can import the rigidbodyTree Object of a parameter of the block, which avoids invoking the importrobot function.
But the 'MATLAB system ' block is more complicate and you may pay some time to learn how to use it.
By the way, if you find a more efficient algorithm to compute the Coriolis Matrix, please let me know, and I will be appreciate. My email is 2318085942@qq.com
0 Comments
See Also
Categories
Find more on Code Generation in Help Center and File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!