- In MATLAB's Robotics System Toolbox, the Inertia property of the rigidBody object represents the inertia tensor relative to the link frame. This it the convention that is used in Featherstone's Rigid Body Dynamics book.
- Peter's toolbox assumes that the I property is the inertia tensor relative to the center of mass (CoM) of the link, but with axes aligned with the link frame. This assumption is also used in URDF.
Different torque calculation results when using Robotics System Toolbox compared with Peter Corke's toolbox
    조회 수: 16 (최근 30일)
  
       이전 댓글 표시
    
Hi guys,
I am tring to use the Matlab's Robotics System Toolbox to do some dynamics calculation, e.g., the joint torques at given poses. But I found that the generated torques does not coincide with the result from Peter Corke's Robotics Toolbox.
I used transformation matrix to build my manipulator in Robotics System Toolbox, while the corresponding MDH table is used in Peter Corke's toolbox. The interesting thing is: if I specify the joint velocity and joint acceleration as zeros,  the two toolboxes will provide me the same results. Once the velocity and acceleration are given, things will be different. 
In the Robotics System Toolbox, I found that it uses the Recursive Newton–Euler algorithm to calculated the joint torques. A screenshot below shows how the inertia force and torques are updated in the forward iteration. 

Through debugging, I found that the inertial torques at CoM during forward iteration are updated differently (the inertial forces at CoM during forward iteration are the same) in Robotics System Toolbox. If I use the following equation to update the inertial torque at CoM manually after the velocity and acceleration is updated at each iteration, I can get the same results.

while  is the inertial torques at CoM of link i,
 is the inertial torques at CoM of link i,  is the inertial forces at CoM of link i and
 is the inertial forces at CoM of link i and  is the position of CoM. This is just the regular equation used in any robotics textbook.
 is the position of CoM. This is just the regular equation used in any robotics textbook.
 is the inertial torques at CoM of link i,
 is the inertial torques at CoM of link i,  is the inertial forces at CoM of link i and
 is the inertial forces at CoM of link i and  is the position of CoM. This is just the regular equation used in any robotics textbook.
 is the position of CoM. This is just the regular equation used in any robotics textbook.In both methods, the manipulators are given the same physical parameters. I also attached the scripts below. Can anyone tell me what could be the reason?
댓글 수: 0
채택된 답변
  Remo Pillat
    
 2023년 11월 30일
        Hi Haojun,
Peter's toolbox and the Robotics System Toolbox in MATLAB make slightly different assumptions how the inertia matrix is specified. 
Given that, you can convert between the two representations with a similarity transform for the rotation and tensor generalization of the parallel axis theorem to account for the translation. The details of the conversion are described in this answer, but the short version is that in your method2_Transformation script, you can do the following to compute the Inertia property from the values you used with Peter's toolbox. Here is an example for the first body:
I_rb = L1.I - L1.m*skew(L1.r)^2;
body1.Inertia = [I_rb(1,1), I_rb(2,2), I_rb(3,3), I_rb(2,3), I_rb(1,3), I_rb(1,2)]; % order is [Ixx Iyy Izz Iyz Ixz Ixy]
Here, L1 is the Link object that is defined in method1_DH, L1.m is the link's mass, L1.r is the position of the link's CoM relative to its frame, and skew is the function in Peter's toolbox that converts the CoM position vector into a skew-symmetric matrix. 
If you do the same calculation for all 4 bodies the torque outputs between the 2 different scripts will match.See the attached modified script.
The new edition of Peter's book actually calls out this discrepancy between the toolboxes and we standardize on assumption (1). 
추가 답변 (0개)
참고 항목
카테고리
				Help Center 및 File Exchange에서 Robotics System Toolbox에 대해 자세히 알아보기
			
	Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!

