Main Content

이 번역 페이지는 최신 내용을 담고 있지 않습니다. 최신 내용을 영문으로 보려면 여기를 클릭하십시오.

rigidBodyTree

트리 구조의 로봇 만들기

설명

rigidBodyTree는 조인트와 강체의 연결을 나타냅니다. MATLAB®에서 로봇 매니퓰레이터 모델을 빌드하려면 이 클래스를 사용합니다. URDF(Unified Robot Description Format)를 사용하여 지정한 로봇 모델이 있다면 importrobot을 사용하여 로봇 모델을 가져옵니다.

강체 트리 모델은 강체로 구성되어 있으며, 여기서 강체는 rigidBody 객체로 표현됩니다. 각 강체에는 부모 바디를 기준으로 움직일 수 있는 방식을 정의하는 rigidBodyJoint 객체가 연결되어 있습니다. setFixedTransform을 사용하여 조인트의 프레임과 인접한 바디 중 하나의 프레임 사이의 고정 변환을 정의합니다. RigidBodyTree 클래스의 메서드를 사용하여 모델에서 강체를 추가하거나 바꾸거나 제거할 수 있습니다.

로봇 동역학 계산도 가능합니다. 로봇 모델의 각 rigidBody에 대해 Mass, CenterOfMass, Inertia 속성을 지정합니다. 외력이 있거나 없는 상태에서 정동역학과 역동역학을 계산하고, 주어진 로봇 조인트 모션과 조인트 입력값으로 동역학적 양을 계산할 수 있습니다. 동역학 관련 함수를 사용하려면 DataFormat 속성을 "row" 또는 "column"으로 설정합니다.

주어진 강체 트리 모델의 경우 로봇 모델을 사용하여 로보틱스 역기구학 알고리즘을 통해 원하는 엔드 이펙터 위치에 도달하기 위한 조인트 각도를 계산할 수도 있습니다. inverseKinematics 또는 generalizedInverseKinematics를 사용할 때 강체 트리 모델을 지정하십시오.

show 메서드는 바디 메시의 시각화를 지원합니다. 메시는 .stl 파일로 지정되며 addVisual을 사용하여 개별 강체에 추가할 수 있습니다. 또한 기본적으로 importrobot 함수는 URDF 로봇 모델에 지정된 액세스 가능한 모든 .stl 파일을 불러옵니다.

생성

설명

예제

robot = rigidBodyTree는 트리 구조의 로봇 객체를 만듭니다. addBody를 사용하여 트리 구조에 강체를 추가합니다.

robot = rigidBodyTree("MaxNumBodies",N,"DataFormat",dataFormat)은 코드를 생성할 때 로봇에 허용되는 바디 개수의 상한을 지정합니다. 또한 DataFormat 속성을 이름-값 쌍으로 지정해야 합니다.

속성

모두 확장

읽기 전용 속성입니다.

로봇 모델의 바디 개수(베이스 제외)로, 정수로 반환됩니다.

읽기 전용 속성입니다.

로봇 모델에 포함된 강체의 목록으로, 핸들로 구성된 셀형 배열로 반환됩니다. 이 목록을 사용하여 모델의 특정 RigidBody 객체에 액세스할 수 있습니다. 또한 getBody를 호출하여 바디 이름으로 바디를 가져올 수 있습니다.

읽기 전용 속성입니다.

강체의 이름으로, 문자형 벡터로 구성된 셀형 배열로 반환됩니다.

로봇 베이스의 이름으로, string형 스칼라 또는 문자형 벡터로 반환됩니다.

로봇에 작용하는 중력 가속도로, [x y z] 벡터로 지정됩니다(단위: 제곱 초당 미터). 각 요소는 베이스 로봇 프레임의 해당 방향에서의 가속도에 대응됩니다.

기구학 함수와 동역학 함수의 입력/출력 데이터 형식으로, "struct", "row" 또는 "column"으로 지정됩니다. 동역학 함수를 사용하려면 "row""column" 중 하나를 사용해야 합니다.

객체 함수

addBody로봇에 바디 추가
addSubtree로봇에 하위 트리 추가
centerOfMass무게 중심 위치와 야코비 행렬
checkCollisionCheck if robot is in collision
copy로봇 모델 복사
externalForce베이스를 기준으로 외력 행렬 구성
forwardDynamics조인트 토크와 조인트 상태가 주어질 경우 조인트 가속도
geometricJacobian로봇 컨피규레이션에 대한 기하 야코비 행렬
gravityTorque중력을 보상하는 조인트 토크
getBody이름으로 로봇 바디 핸들 가져오기
getTransform바디 프레임 간의 변환 구하기
homeConfiguration로봇의 홈 컨피규레이션 구하기
inverseDynamics주어진 모션에 필요한 조인트 토크
massMatrix조인트-공간 질량 행렬
randomConfiguration로봇의 무작위 컨피규레이션 생성
removeBodyRemove body from robot
replaceBodyReplace body on robot
replaceJointReplace joint on body
showFigure에 로봇 모델 표시
showdetails로봇 모델의 세부 정보 표시
subtreeCreate subtree from robot model
velocityProduct속도에서 유발된 힘을 상쇄하는 조인트 토크
writeAsFunctionCreate rigidBodyTree code generating function

예제

모두 축소

강체 트리에 강체와 해당 조인트를 추가합니다. 각 rigidBody 객체는 rigidBodyJoint 객체를 포함하며 addBody를 사용하여 rigidBodyTree에 추가되어야 합니다.

강체 트리를 만듭니다.

rbtree = rigidBodyTree;

고유한 이름을 가진 강체를 만듭니다.

body1 = rigidBody('b1');

회전 조인트를 만듭니다. 기본적으로 rigidBody 객체에는 고정 조인트가 포함되어 있습니다. body1.Joint 속성에 새 rigidBodyJoint 객체를 할당하여 조인트를 바꿉니다.

jnt1 = rigidBodyJoint('jnt1','revolute');
body1.Joint = jnt1;

강체를 트리에 추가합니다. 강체를 연결할 바디 이름을 지정합니다. 이 바디가 첫 번째 바디이므로 트리의 베이스 이름을 사용합니다.

basename = rbtree.BaseName;
addBody(rbtree,body1,basename)

트리에서 showdetails를 사용하여 강체와 조인트가 제대로 추가되었는지 확인합니다.

showdetails(rbtree)
--------------------
Robot: (1 bodies)

 Idx    Body Name   Joint Name   Joint Type    Parent Name(Idx)   Children Name(s)
 ---    ---------   ----------   ----------    ----------------   ----------------
   1           b1         jnt1     revolute             base(0)   
--------------------

Puma560® 로봇의 DH(Denavit-Hartenberg) 파라미터를 사용하여 로봇을 빌드합니다. 각 강체는 한 번에 하나씩 추가되며, joint 객체로 자식-부모 변환이 지정됩니다.

DH 파라미터는 각 강체가 부모에 연결되는 관계를 나타내는 로봇의 기하를 정의합니다. 편의를 위해 Puma560 로봇의 파라미터를 행렬로 설정합니다[1]. Puma 로봇은 직렬 체인 매니퓰레이터입니다. DH 파라미터는 이전 조인트 연결에 해당하는 행렬의 이전 행을 기준으로 합니다.

dhparams = [0   	pi/2	0   	0;
            0.4318	0       0       0
            0.0203	-pi/2	0.15005	0;
            0   	pi/2	0.4318	0;
            0       -pi/2	0   	0;
            0       0       0       0];

로봇을 빌드할 강체 트리 객체를 만듭니다.

robot = rigidBodyTree;

첫 번째 강체를 만들고 로봇에 추가합니다. 강체를 추가하려면 다음을 수행하십시오.

  1. rigidBody 객체를 만들고 고유한 이름을 지정합니다.

  2. rigidBodyJoint 객체를 만들고 고유한 이름을 지정합니다.

  3. setFixedTransform으로 DH 파라미터를 사용하여 바디-바디 변환을 지정합니다. DH 파라미터의 마지막 요소인 theta의 경우 이에 해당하는 각도는 조인트 위치에 따라 달라지므로 무시됩니다.

  4. addBody를 호출하여 로봇의 베이스 프레임에 첫 번째 바디 조인트를 연결합니다.

body1 = rigidBody('body1');
jnt1 = rigidBodyJoint('jnt1','revolute');

setFixedTransform(jnt1,dhparams(1,:),'dh');
body1.Joint = jnt1;

addBody(robot,body1,'base')

나머지 강체를 만들고 로봇에 추가합니다. addBody 호출하여 연결할 때 이전 바디 이름을 지정합니다. 각 고정 변환은 이전 조인트 좌표 프레임을 기준으로 합니다.

body2 = rigidBody('body2');
jnt2 = rigidBodyJoint('jnt2','revolute');
body3 = rigidBody('body3');
jnt3 = rigidBodyJoint('jnt3','revolute');
body4 = rigidBody('body4');
jnt4 = rigidBodyJoint('jnt4','revolute');
body5 = rigidBody('body5');
jnt5 = rigidBodyJoint('jnt5','revolute');
body6 = rigidBody('body6');
jnt6 = rigidBodyJoint('jnt6','revolute');

setFixedTransform(jnt2,dhparams(2,:),'dh');
setFixedTransform(jnt3,dhparams(3,:),'dh');
setFixedTransform(jnt4,dhparams(4,:),'dh');
setFixedTransform(jnt5,dhparams(5,:),'dh');
setFixedTransform(jnt6,dhparams(6,:),'dh');

body2.Joint = jnt2;
body3.Joint = jnt3;
body4.Joint = jnt4;
body5.Joint = jnt5;
body6.Joint = jnt6;

addBody(robot,body2,'body1')
addBody(robot,body3,'body2')
addBody(robot,body4,'body3')
addBody(robot,body5,'body4')
addBody(robot,body6,'body5')

showdetails 함수 또는 show 함수를 사용하여 로봇이 올바르게 빌드되었는지 확인합니다. showdetails 함수는 MATLAB® 명령 창에 모든 바디를 나열합니다. show 함수는 주어진 컨피규레이션에서의(기본적으로 홈 컨피규레이션) 로봇을 표시합니다. axis 호출로 축 제한을 수정하고 축 레이블을 숨깁니다.

showdetails(robot)
--------------------
Robot: (6 bodies)

 Idx    Body Name   Joint Name   Joint Type    Parent Name(Idx)   Children Name(s)
 ---    ---------   ----------   ----------    ----------------   ----------------
   1        body1         jnt1     revolute             base(0)   body2(2)  
   2        body2         jnt2     revolute            body1(1)   body3(3)  
   3        body3         jnt3     revolute            body2(2)   body4(4)  
   4        body4         jnt4     revolute            body3(3)   body5(5)  
   5        body5         jnt5     revolute            body4(4)   body6(6)  
   6        body6         jnt6     revolute            body5(5)   
--------------------
show(robot);
axis([-0.5,0.5,-0.5,0.5,-0.5,0.5])
axis off

참고 문헌

[1] Corke, P. I., and B. Armstrong-Helouvry. “A Search for Consensus among Model Parameters Reported for the PUMA 560 Robot.” Proceedings of the 1994 IEEE International Conference on Robotics and Automation, IEEE Computer. Soc. Press, 1994, pp. 1608–13. DOI.org (Crossref), doi:10.1109/ROBOT.1994.351360.

기존 rigidBodyTree 객체를 변경합니다. 강체 트리에서 조인트, 바디, 하위 트리를 바꿀 수 있습니다.

Robotics System Toolbox™ loadrobot 함수를 사용하여 ABB IRB-120T 매니퓰레이터를 불러옵니다. 이는 rigidBodyTree 객체로 지정됩니다.

manipulator = loadrobot("abbIrb120T");

show를 사용해서 로봇을 표시하고 showdetails.를 사용해서 로봇의 세부 정보를 읽습니다.

show(manipulator);

Figure contains an axes object. The axes object with xlabel X, ylabel Y contains 24 objects of type patch, line. These objects represent base_link, base, link_1, link_2, link_3, link_4, link_5, link_6, tool0, link_1_mesh, link_2_mesh, link_3_mesh, link_4_mesh, link_5_mesh, link_6_mesh, base_link_mesh.

showdetails(manipulator)
--------------------
Robot: (8 bodies)

 Idx     Body Name            Joint Name            Joint Type     Parent Name(Idx)   Children Name(s)
 ---     ---------            ----------            ----------     ----------------   ----------------
   1          base        base_link-base                 fixed         base_link(0)   
   2        link_1               joint_1              revolute         base_link(0)   link_2(3)  
   3        link_2               joint_2              revolute            link_1(2)   link_3(4)  
   4        link_3               joint_3              revolute            link_2(3)   link_4(5)  
   5        link_4               joint_4              revolute            link_3(4)   link_5(6)  
   6        link_5               joint_5              revolute            link_4(5)   link_6(7)  
   7        link_6               joint_6              revolute            link_5(6)   tool0(8)  
   8         tool0          joint6-tool0                 fixed            link_6(7)   
--------------------

속성을 검사할 바디를 가져옵니다. link_3 바디의 자식은 link_4 바디뿐입니다. 특정 바디를 복사할 수도 있습니다.

body3 = getBody(manipulator,"link_3");
childBody = body3.Children{1}
childBody = 
  rigidBody with properties:

            Name: 'link_4'
           Joint: [1x1 rigidBodyJoint]
            Mass: 1.3280
    CenterOfMass: [0.2247 1.5000e-04 4.1000e-04]
         Inertia: [0.0028 0.0711 0.0723 1.3052e-05 -1.3878e-04 -6.6037e-05]
          Parent: [1x1 rigidBody]
        Children: {[1x1 rigidBody]}
         Visuals: {'Mesh:link_4.stl'}
      Collisions: {'Mesh Filename /mathworks/devel/bat/filer/batfs2503-0/BR2023bd.2354825.BR2023bd.2351501.pass/build/matlab/toolbox/robotics/robotmanip/data/abb_irb120_support/meshes/irb120_3_58/collision/link_4.stl'}

body3Copy = copy(body3);

link_3 바디의 조인트를 바꿉니다. 다운스트림 바디의 기하 도형이 영향을 받지 않도록 하려면 새 Joint 객체를 만들고 replaceJoint를 사용해야 합니다. 바디 간의 변환을 정의하기 위해 필요한 경우 디폴트 단위 행렬을 사용하는 대신 setFixedTransform을 호출합니다.

newJoint = rigidBodyJoint("prismatic");
replaceJoint(manipulator,"link_3",newJoint);

showdetails(manipulator)
--------------------
Robot: (8 bodies)

 Idx     Body Name            Joint Name            Joint Type     Parent Name(Idx)   Children Name(s)
 ---     ---------            ----------            ----------     ----------------   ----------------
   1          base        base_link-base                 fixed         base_link(0)   
   2        link_1               joint_1              revolute         base_link(0)   link_2(3)  
   3        link_2               joint_2              revolute            link_1(2)   link_3(4)  
   4        link_3             prismatic                 fixed            link_2(3)   link_4(5)  
   5        link_4               joint_4              revolute            link_3(4)   link_5(6)  
   6        link_5               joint_5              revolute            link_4(5)   link_6(7)  
   7        link_6               joint_6              revolute            link_5(6)   tool0(8)  
   8         tool0          joint6-tool0                 fixed            link_6(7)   
--------------------

removeBody를 사용하여 전체 바디를 제거하고, 결과로 생성된 하위 트리를 가져옵니다. 제거된 바디는 하위 트리에 포함됩니다.

subtree = removeBody(manipulator,"link_4")
subtree = 
  rigidBodyTree with properties:

     NumBodies: 4
        Bodies: {[1x1 rigidBody]  [1x1 rigidBody]  [1x1 rigidBody]  [1x1 rigidBody]}
          Base: [1x1 rigidBody]
     BodyNames: {'link_4'  'link_5'  'link_6'  'tool0'}
      BaseName: 'link_3'
       Gravity: [0 0 0]
    DataFormat: 'struct'

show(subtree);

Figure contains an axes object. The axes object with xlabel X, ylabel Y contains 12 objects of type patch, line. These objects represent link_3, link_4, link_5, link_6, tool0, link_4_mesh, link_5_mesh, link_6_mesh.

수정된 link_3 바디를 제거합니다. 복사한 원래 link_3 바디를 link_2 바디에 추가한 다음, 반환된 하위 트리를 추가합니다. 로봇 모델은 동일하게 유지됩니다. 자세한 비교는 showdetails를 통해 확인하십시오.

removeBody(manipulator,"link_3");
addBody(manipulator,body3Copy,"link_2")
addSubtree(manipulator,"link_3",subtree)

showdetails(manipulator)
--------------------
Robot: (8 bodies)

 Idx     Body Name            Joint Name            Joint Type     Parent Name(Idx)   Children Name(s)
 ---     ---------            ----------            ----------     ----------------   ----------------
   1          base        base_link-base                 fixed         base_link(0)   
   2        link_1               joint_1              revolute         base_link(0)   link_2(3)  
   3        link_2               joint_2              revolute            link_1(2)   link_3(4)  
   4        link_3               joint_3              revolute            link_2(3)   link_4(5)  
   5        link_4               joint_4              revolute            link_3(4)   link_5(6)  
   6        link_5               joint_5              revolute            link_4(5)   link_6(7)  
   7        link_6               joint_6              revolute            link_5(6)   tool0(8)  
   8         tool0          joint6-tool0                 fixed            link_6(7)   
--------------------

동역학 함수를 사용하여 조인트 토크와 조인트 가속도를 계산하기 위해 rigidBodyTree 객체와 rigidBody에 대한 동역학 속성을 지정합니다.

강체 트리 모델을 만듭니다. 연결할 두 개의 강체를 만듭니다.

robot = rigidBodyTree('DataFormat','row');
body1 = rigidBody('body1');
body2 = rigidBody('body2');

바디에 연결할 조인트를 지정합니다. body2의 고정 변환을 body1로 설정합니다. 이 변환은 x 방향으로 1미터입니다.

joint1 = rigidBodyJoint('joint1','revolute');
joint2 = rigidBodyJoint('joint2');
setFixedTransform(joint2,trvec2tform([1 0 0]))
body1.Joint = joint1;
body2.Joint = joint2;

두 바디에 대한 동역학 속성을 지정합니다. 로봇 모델에 두 바디를 추가합니다. 이 예제에서는 구형 질량(body2)이 연결된 막대(body1)에 대한 기본값이 제공됩니다.

body1.Mass = 2;
body1.CenterOfMass = [0.5 0 0];
body1.Inertia = [0.001 0.67 0.67 0 0 0];

body2.Mass = 1;
body2.CenterOfMass = [0 0 0];
body2.Inertia = 0.0001*[4 4 4 0 0 0];

addBody(robot,body1,'base');
addBody(robot,body2,'body1');

전체 로봇의 무게 중심 위치를 계산합니다. 로봇에 그 위치를 플로팅합니다. xy 평면 보기로 바꿉니다.

comPos = centerOfMass(robot);

show(robot);
hold on
plot(comPos(1),comPos(2),'or')
view(2)

Figure contains an axes object. The axes object with xlabel X, ylabel Y contains 6 objects of type patch, line. One or more of the lines displays its values using only markers These objects represent base, body1, body2.

두 번째 바디의 질량을 변경합니다. 무게 중심이 변하는 것을 알 수 있습니다.

body2.Mass = 20;
replaceBody(robot,'body2',body2)

comPos2 = centerOfMass(robot);
plot(comPos2(1),comPos2(2),'*g')
hold off

Figure contains an axes object. The axes object with xlabel X, ylabel Y contains 7 objects of type patch, line. One or more of the lines displays its values using only markers These objects represent base, body1, body2.

적용된 외력과 중력으로 인한 힘을 사용해 주어진 로봇 컨피규레이션의 결과 조인트 가속도를 계산합니다. 전체 로봇에 지정된 중력과 함께 렌치가 특정 바디에 적용됩니다.

Robotics System Toolbox™ loadrobot 함수를 사용하여 KUKA iiwa 14 로봇 모델을 불러옵니다. 이 로봇은 rigidBodyTree 객체로 지정됩니다.

데이터 형식을 "row"로 설정합니다. 모든 동역학 계산에서 데이터 형식은 "row" 또는 "column"이어야 합니다.

중력을 설정합니다. 기본적으로 중력은 0으로 가정합니다.

kukaIIWA14 = loadrobot("kukaIiwa14",DataFormat="row",Gravity=[0 0 -9.81]);

kukaIIWA14 로봇의 홈 컨피규레이션을 가져옵니다.

q = homeConfiguration(kukaIIWA14);

로봇에 작용하는 외력을 나타내는 렌치 벡터를 지정합니다. externalForce 함수를 사용하여 외력 행렬을 생성합니다. 로봇 모델, 렌치가 작용하는 엔드 이펙터, 렌치 벡터, 현재 로봇 컨피규레이션을 지정합니다. wrench는 로봇 컨피규레이션 q를 지정해야 하는 "iiwa_link_ee_kuka" 바디 프레임을 기준으로 적용됩니다.

wrench = [0 0 0.5 0 0 0.3];
fext = externalForce(kukaIIWA14,"iiwa_link_ee_kuka",wrench,q);

kukaIIWA14이 홈 컨피규레이션에 있을 때 엔드 이펙터 "iiwa_link_ee_kuka"에 적용된 외력을 감안하여 중력으로 인한 결과 조인트 가속도를 계산합니다. 조인트 속도와 조인트 토크는 0으로 가정합니다(비어 있는 벡터 []로 입력).

qddot = forwardDynamics(kukaIIWA14,q,[],[],fext)
qddot = 1×7

   -0.0023   -0.0112    0.0036   -0.0212    0.0067   -0.0075  499.9920

inverseDynamics 함수를 사용하여 특정 로봇 컨피규레이션을 정적으로 유지하기 위해 필요한 조인트 토크를 계산합니다. 기타 구문을 사용하여 조인트 속도, 조인트 가속도, 외력을 지정할 수도 있습니다.

Robotics System Toolbox™ loadrobot 함수를 사용하여 Omron eCobra-600을 rigidBodyTree 객체로 불러옵니다. 중력 속성을 설정하고 데이터 형식을 "row"로 설정합니다. 모든 동역학 계산에서 데이터 형식은 "row" 또는 "column"이어야 합니다.

robot = loadrobot("omronEcobra600", DataFormat="row", Gravity=[0 0 -9.81]);

robot의 무작위 컨피규레이션을 생성합니다.

q = randomConfiguration(robot);

robot이 해당 컨피규레이션을 정적으로 유지하기 위해 필요한 조인트 토크를 계산합니다.

tau = inverseDynamics(robot,q)
tau = 1×4

    0.0000    0.0000  -19.6200         0

externalForce 함수를 사용하여 강체 트리 모델에 적용할 힘 행렬을 생성합니다. 힘 행렬은 m×6 벡터이며 각 행은 로봇의 각 조인트에 작용하는 요소가 6개인 렌치를 표현합니다. externalForce 함수를 사용하고 엔드 이펙터를 지정하여 렌치를 행렬의 올바른 행에 할당합니다. 여러 힘 행렬을 함께 추가하여 하나의 로봇에 여러 힘을 적용할 수 있습니다.

이러한 외력을 상쇄하는 조인트 토크를 계산하기 위해 inverseDynamics 함수를 사용합니다.

Robotics System Toolbox™ loadrobot 함수를 사용하여 Universal Robots UR5e를 rigidBodyTree 객체로 불러옵니다. 중력을 업데이트하고 데이터 형식을 "row"로 설정합니다. 모든 동역학 계산에서 데이터 형식은 "row" 또는 "column"이어야 합니다.

manipulator = loadrobot("universalUR5e", DataFormat="row", Gravity=[0 0 -9.81]);
showdetails(manipulator)
--------------------
Robot: (10 bodies)

 Idx                Body Name                         Joint Name                         Joint Type                Parent Name(Idx)   Children Name(s)
 ---                ---------                         ----------                         ----------                ----------------   ----------------
   1                     base         base_link-base_fixed_joint                              fixed                    base_link(0)   
   2        base_link_inertia        base_link-base_link_inertia                              fixed                    base_link(0)   shoulder_link(3)  
   3            shoulder_link                 shoulder_pan_joint                           revolute            base_link_inertia(2)   upper_arm_link(4)  
   4           upper_arm_link                shoulder_lift_joint                           revolute                shoulder_link(3)   forearm_link(5)  
   5             forearm_link                        elbow_joint                           revolute               upper_arm_link(4)   wrist_1_link(6)  
   6             wrist_1_link                      wrist_1_joint                           revolute                 forearm_link(5)   wrist_2_link(7)  
   7             wrist_2_link                      wrist_2_joint                           revolute                 wrist_1_link(6)   wrist_3_link(8)  
   8             wrist_3_link                      wrist_3_joint                           revolute                 wrist_2_link(7)   flange(9)  
   9                   flange                     wrist_3-flange                              fixed                 wrist_3_link(8)   tool0(10)  
  10                    tool0                       flange-tool0                              fixed                       flange(9)   
--------------------

manipulator의 홈 컨피규레이션을 가져옵니다.

q = homeConfiguration(manipulator);

shoulder_link에 외력을 설정합니다. 입력 렌치 벡터는 베이스 프레임에서 표현됩니다.

fext1 = externalForce(manipulator,"shoulder_link",[0 0 0.0 0.1 0 0]);

엔드 이펙터 tool0에 외력을 설정합니다. 입력 렌치 벡터는 tool0 프레임에서 표현됩니다.

fext2 = externalForce(manipulator,"tool0",[0 0 0.0 0.1 0 0],q);

외력의 균형을 맞추는 데 필요한 조인트 토크를 계산합니다. 힘을 결합하기 위해 힘 행렬을 함께 더합니다. 조인트 속도와 조인트 가속도는 0으로 가정합니다([]로 입력).

tau = inverseDynamics(manipulator,q,[],[],fext1+fext2)
tau = 1×6

   -0.0233  -52.4189  -14.4896   -0.0100    0.0100   -0.0000

URDF(Unified Robot Description format) 파일과 연결된 .stl 파일이 있는 로봇을 가져와서 로봇의 시각적 기하 도형을 설명할 수 있습니다. 각 강체에는 개별 시각적 기하 도형이 지정되어 있습니다. importrobot 함수는 URDF 파일을 구문 분석하여 로봇 모델과 시각적 기하 도형을 가져옵니다. 이 함수는 로봇의 시각적 기하 도형과 충돌 기하 도형이 동일하다고 간주하고, 시각적 기하 도형을 대응하는 바디의 충돌 기하 도형으로 할당합니다.

show 함수를 사용하여 Figure에 로봇 모델의 시각적 기하 도형과 충돌 기하 도형을 표시합니다. 그런 다음 구성요소를 클릭하여 검사하고 마우스 오른쪽 버튼으로 클릭하여 가시성을 전환함으로써 모델과 상호 작용할 수 있습니다.

로봇 모델을 URDF 파일로 가져옵니다. .stl 파일 위치는 이 URDF에 올바르게 지정되어 있어야 합니다. 개별 강체에 다른 .stl 파일을 추가하려면 addVisual 항목을 참조하십시오.

robot = importrobot('iiwa14.urdf');

연결된 시각적 모델을 사용하여 로봇을 시각화합니다. 바디 또는 프레임을 검사하려면 마우스 왼쪽 버튼으로 클릭합니다. 각 시각적 기하 도형의 가시성을 전환하려면 바디를 마우스 오른쪽 버튼으로 클릭합니다.

show(robot,Visuals="on",Collisions="off");

Figure contains an axes object. The axes object with xlabel X, ylabel Y contains 29 objects of type patch, line. These objects represent world, iiwa_link_0, iiwa_link_1, iiwa_link_2, iiwa_link_3, iiwa_link_4, iiwa_link_5, iiwa_link_6, iiwa_link_7, iiwa_link_ee, iiwa_link_ee_kuka, iiwa_link_0_mesh, iiwa_link_1_mesh, iiwa_link_2_mesh, iiwa_link_3_mesh, iiwa_link_4_mesh, iiwa_link_5_mesh, iiwa_link_6_mesh, iiwa_link_7_mesh.

연결된 충돌 기하 도형을 사용하여 로봇을 시각화합니다. 바디 또는 프레임을 검사하려면 마우스 왼쪽 버튼으로 클릭합니다. 각 충돌 기하 도형의 가시성을 전환하려면 바디를 마우스 오른쪽 버튼으로 클릭합니다.

show(robot,Visuals="off",Collisions="on"); 

Figure contains an axes object. The axes object with xlabel X, ylabel Y contains 29 objects of type patch, line. These objects represent world, iiwa_link_0, iiwa_link_1, iiwa_link_2, iiwa_link_3, iiwa_link_4, iiwa_link_5, iiwa_link_6, iiwa_link_7, iiwa_link_ee, iiwa_link_ee_kuka, iiwa_link_0_mesh, iiwa_link_1_mesh, iiwa_link_2_mesh, iiwa_link_3_mesh, iiwa_link_4_mesh, iiwa_link_5_mesh, iiwa_link_6_mesh, iiwa_link_7_mesh, iiwa_link_0_coll_mesh, iiwa_link_1_coll_mesh, iiwa_link_2_coll_mesh, iiwa_link_3_coll_mesh, iiwa_link_4_coll_mesh, iiwa_link_5_coll_mesh, iiwa_link_6_coll_mesh, iiwa_link_7_coll_mesh.

세부 정보

모두 확장

참고 문헌

[1] Craig, John J. Introduction to Robotics: Mechanics and Control. Reading, MA: Addison-Wesley, 1989.

[2] Siciliano, Bruno, Lorenzo Sciavicco, Luigi Villani, and Giuseppe Oriolo. Robotics: Modelling, Planning and Control. London: Springer, 2009.

확장 기능

버전 내역

R2016b에 개발됨

모두 확장