샘플 프로그램6: MM_S6_Viz_ErrorHandle

현재 최신 버전 (2.1.2)에 대한 매뉴얼을 보고 계십니다. 다른 버전에 액세스하려면 페이지 오른쪽 상단 모서리에 있는 '버전 전환' 버튼을 클릭하세요.

■ 현재 사용하고 있는 제품의 버전이 확실하지 않은 경우에는 언제든지 당사 기술 지원팀에 문의하시기 바랍니다.

프로그램 소개

기능 설명

로봇이 Mech-Viz프로젝트 실행을 트리거한 후, 경로 계획 결과를 휙득하고 상태 코드에 따라 계획된 경로를 성공적으로 획득했는지 확인합니다. 성공적으로 계획 경로를 획득하면 로봇은 피킹 및 배치 작업을 실행합니다. 그렇지 않으면, 로봇은 실행이 종료됩니다.

파일 경로

Mech-Vision 및 Mech-Viz의 설치 디렉토리로 이동하여 통신 구성 요소/Robot_Interface/KUKA/sample/MM_S6_Viz_ErrorHandle경로를 사용하여 파일을 찾을 수 있습니다.

필요한 프로젝트

Mech-Vision와 Mech-Viz 프로젝트

사용 전제 조건

  1. 표준 인터페이스 통신 구성이 완료됩니다.

  2. 자동 캘리브레이션이 완료됩니다.

이 샘플 프로그램은 참고용으로 제공됩니다. 사용자는 실제 상황에 맞춰 이 내용을 바탕으로 수정해야 하며, 해당 프로그램을 그대로 사용하지 않도록 하십시오.

프로그램 설명

다음에는 MM_S6_Viz_ErrorHandle 샘플 프로그램의 코드와 관련 설명입니다.

MM_S2_Viz_Basic 샘플과 비하면, 이 샘플은 다양한 오류 상태 코드를 처리할 수 있는 기능만 추가되었습니다.(이 기능의 코드가 굵게 표시됨). 따라서, MM_S6_Viz_ErrorHandle의 MM_S2_Viz_Basic과 일치하는 부분은 다시 설명하지 않습니다. (일치하는 부분에 대한 정보는 MM_S2_Viz_Basic샘플 프로그램 설명을 참조하십시오).
DEF  MM_S6_Viz_ErrorHandle ( )
;---------------------------------------------------
; FUNCTION: trigger Mech-Viz project and get
; planned path, handle errors according to status
; codes (if no point cloud in ROI, retry several
; times before exit loop)
; Mech-Mind, 2023-12-25
;---------------------------------------------------
   ;set current tool no. to 1
   BAS(#TOOL,1)
   ;set current base no. to 0
   BAS(#BASE,0)
   ;initialize variables
   retry_cnt=0
   ;move to robot home position
PTP HOME Vel=100 % DEFAULT
   ;initialize communication parameters (initialization is required only once)
   MM_Init_Socket("XML_Kuka_MMIND",873,871,60)
   ;move to image-capturing position
LIN camera_capture Vel=1 m/s CPDAT1 Tool[1] Base[0]
RECAP:
   ;trigger Mech-Viz project
   MM_Start_Viz(2,init_jps)
   ;get planned path, 1st argument (1) means getting pose in JPs
   MM_Get_VizData(1,pos_num,vis_pos_num,status)
   ;check whether planned path has been got from Mech-Viz successfully
   IF status<> 2100 THEN
        IF status == 2038 THEN
            ;no point cloud in ROI, add handling logic here
            ;self-adding then check retry counter
            retry_cnt=retry_cnt+1
            IF retry_cnt<3 THEN
                ;jump back to vision retry label if the number of retry times is less than 3
                GOTO RECAP
            ELSE
                ;reset counter and exit loop if the number of retry times has reached 3
                retry_cnt=0
                GOTO END_LOOP
            ENDIF
        ELSE
            ;add other error handling logic here
            halt
            GOTO END_LOOP
        ENDIF
   ENDIF
   ;save waypoints of the planned path to local variables one by one
   MM_Get_Jps(1,Xpick_point1,label[1],toolid[1])
   MM_Get_Jps(2,Xpick_point2,label[2],toolid[2])
   MM_Get_Jps(3,Xpick_point3,label[3],toolid[3])
   ;follow the planned path to pick
   ;move to approach waypoint of picking
PTP pick_point1 Vel=50 % PDAT1 Tool[1] Base[0]
   ;move to picking waypoint
PTP pick_point2 Vel=10 % PDAT2 Tool[1] Base[0]
   ;add object grasping logic here, such as "$OUT[1]=TRUE"
   halt
   ;move to departure waypoint of picking
PTP pick_point3 Vel=50 % PDAT3 Tool[1] Base[0]
   ;move to intermediate waypoint of placing
PTP drop_waypoint CONT Vel=100 % PDAT2 Tool[1] Base[0]
   ;move to approach waypoint of placing
LIN drop_app Vel=1 m/s CPDAT3 Tool[1] Base[0]
   ;move to placing waypoint
LIN drop Vel=0.3 m/s CPDAT4 Tool[1] Base[0]
   ;add object releasing logic here, such as "$OUT[1]=FALSE"
   halt
   ;move to departure waypoint of placing
LIN drop_app Vel=1 m/s CPDAT3 Tool[1] Base[0]
   ;move back to robot home position
PTP HOME Vel=100 % DEFAULT

END_LOOP:
    halt
END

위 샘플 프로그램 코드에 해당하는 워크플로는 아래 그림에 표시되어 있습니다.

sample6

아래 표는 다양한 오류 상태 코드 처리의 설명입니다.

워크플로 코드와 설명

다양한 상태 코드를 처리하기

...
retry_cnt=0
...
RECAP:
   ;trigger Mech-Viz project
   MM_Start_Viz(2,init_jps)
   ;get planned path, 1st argument (1) means getting pose in JPs
   MM_Get_VizData(1,pos_num,vis_pos_num,status)
   ;check whether planned path has been got from Mech-Viz successfully
   IF status<> 2100 THEN
        IF status == 2038 THEN
            ;no point cloud in ROI, add handling logic here
            ;self-adding then check retry counter
            retry_cnt=retry_cnt+1
            IF retry_cnt<3 THEN
                ;jump back to vision retry label if the number of retry times is less than 3
                GOTO RECAP
            ELSE
                ;reset counter and exit loop if the number of retry times has reached 3
                retry_cnt=0
                GOTO END_LOOP
            ENDIF
        ELSE
            ;add other error handling logic here
            halt
            GOTO END_LOOP
        ENDIF
   ENDIF
   ...
END_LOOP:
    halt

로봇이 MM_Get_VizData 명령어를 실행한 후, 수신된 상태 코드를 status변수에 저장할 것입니다. 사용자는 구체적인 상태 코드에 따라 해당 처리를 할 수 있습니다. 이 샘플의 처리 논리를 참조하십시오.

  • status 변수가 2100일 경우, 로봇은 계획된 경로를 성공적으로 획득한 후 해당 경로에 따라 피킹를 수행합니다.

  • status 변수가 2100이 아닌 경우, 비전 시스템에 이상이 발생한 것입니다. 사용자는 구체적인 비정상 상태 코드에 따라 적절한 처리를 수행해야 합니다.

    • status 변수가 2038일 경우, ROI 내에 포인트 클라우드가 없으며, 로봇은 계획된 경로를 획득할 수 없습니다. 이때 로봇은 Mech-Viz프로젝트 실행을 다시 트리거하여 계획된 경로를 획득할 수 있습니다. 샘플 프로그램에서는 retry_cnt 변수를 통해 계획된 경로를 다시 획득하는 횟수를 제어합니다. 두 번의 재시도 후(즉 retry_cnt가 2보다 클 때) 포인트 클라우드가 없으면, 프로그램은 실행이 종료됩니다.

    • status 변수가 다른 오류 상태 코드일 경우, 프로그램은 실행이 종료됩니다.

사용자는 표준 인터페이스 상태 코드 및 오류 분석을 참조하여 오류 상태를 처리하는 코드를 작성할 수 있습니다.

이 페이지가 도움이 되었습니까?

다음 방법을 통해 피드백을 보내주실 수 있습니다:

저희는 귀하의 개인정보를 소중히 다룹니다.

당사 웹사이트는 최상의 사용자 경험을 제공하기 위해 쿠키를 사용하고 있습니다. "모두 수락"을 클릭하시면 쿠키 사용에 동의하시는 것이며, "모두 거부"를 클릭하시면 이 웹사이트 방문 시 귀하의 정보가 추적되거나 기억되지 않도록 단일 쿠키만 사용됩니다.