샘플 프로그램17: MM_S17_Vis_ParseLabel
프로그램 소개
기능 설명 |
로봇은 Mech-Vision 프로젝트를 실행을 트리거하여 비전 결과를 획득하고, 레이블을 파싱한 후, 레이블에 따른 처리 방법을 채택하여 피킹 및 배치 작업을 수행합니다. |
파일 경로 |
Mech-Vision 및 Mech-Viz의 설치 디렉토리로 이동하여 |
필요한 프로젝트 |
Mech-Vision 프로젝트 (출력 스텝의 labels포트에는 데이터가 존재해야 합니다). |
사용 전제 조건 |
|
이 샘플 프로그램은 참고용으로 제공됩니다. 사용자는 실제 상황에 맞춰 이 내용을 바탕으로 수정해야 하며, 해당 프로그램을 그대로 사용하지 않도록 하십시오. |
프로그램 설명
다음에는 MM_S17_Vis_ParseLabel 샘플 프로그램의 코드와 관련 설명입니다.
MM_S1_Vis_Basic 샘플과 비하면, 이 샘플은 레이블을 파싱하는 기능만 추가되었습니다.(이 기능의 코드가 굵게 표시됨). 따라서, MM_S17_Vis_ParseLabel의 MM_S1_Vis_Basic과 일치하는 부분은 다시 설명하지 않습니다. (일치하는 부분에 대한 정보는 MM_S1_Vis_Basic샘플 프로그램 설명을 참조하십시오). |
DEF MM_S17_Vis_ParseLabel ( )
;---------------------------------------------------
; FUNCTION: trigger Mech-Vision project and get
; vision result, then parse the label info
; Mech-Mind, 2023-12-25
;---------------------------------------------------
;set current tool no. to 1
BAS(#TOOL,1)
;set current base no. to 0
BAS(#BASE,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]
;trigger NO.1 Mech-Vision project
MM_Start_Vis(1,0,2,init_jps)
;get vision result from NO.1 Mech-Vision project
MM_Get_VisData(1,pos_num,status)
;check whether vision result has been got from Mech-Vision successfully
IF status<> 1100 THEN
;add error handling logic here according to different error codes
;e.g.: status=1003 means no point cloud in ROI
;e.g.: status=1002 means no vision result
halt
ENDIF
;save first vision point data to local variables
MM_Get_Pose(1,Xpick_point,label,toolid)
;parse label info received from Mech-Vision, eg. "label=56" will decompose into 5 and 6
label_1=label / 10; !label_1=5
label_2=label - label_1*10; !label_2=6
;add handling logic according to decomposed label value
IF label_1==5 THEN
;add handling logic a
halt
ELSE
;add handling logic b
halt
ENDIF
;calculate pick approach point based on pick point
tool_offset={X 0,Y 0,Z -100,A 0,B 0,C 0}
Xpick_app=Xpick_point:tool_offset
;move to intermediate waypoint of picking
PTP pick_waypoint CONT Vel=50 % PDAT1 Tool[1] Base[0]
;move to approach waypoint of picking
LIN pick_app Vel=1 m/s CPDAT2 Tool[1] Base[0]
;move to picking waypoint
LIN pick_point Vel=0.3 m/s CPDAT3 Tool[1] Base[0]
;add object grasping logic here, such as "$OUT[1]=TRUE"
halt
;move to departure waypoint of picking
LIN pick_app Vel=1 m/s CPDAT2 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 CPDAT4 Tool[1] Base[0]
;move to placing waypoint
LIN drop Vel=0.3 m/s CPDAT5 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 CPDAT4 Tool[1] Base[0]
;move back to robot home position
PTP HOME Vel=100 % DEFAULT
END
위 샘플 프로그램 코드에 해당하는 워크플로는 아래 그림에 표시되어 있습니다.

아래 표는 레이블을 분석하는 기능의 설명입니다. 명령어 이름의 링크를 클릭하면 해당 명령의 상세 설명을 확인할 수 있습니다.
워크플로 | 코드와 설명 |
---|---|
레이블을 label_1, label_2로 피싱하기 |
MM_Get_Pose 명령어는 특정 비전 포인트의 말단장치 포즈, 레이블 및 말단장치 번호를 Xpick_point, label, toolid 변수에 저장할 수 있습니다. 본 샘플에서는 label 변수 값이 56이라고 가정합니다. "label / 10"은 label을 10으로 나눈 몫(즉, 5)을 의미하며, "label - label_1*10"은 label을 10으로 나눈 나머지(즉, 6)를 의미합니다. 이를 통해 label을 label_1과 label_2로 피싱할 수 있으며, 즉 56은 5와 6으로 피싱됩니다. |
레이블 파싱 결과에 따라 처리 방법을 채택하기 |
위 코드는 label_1이 5일 경우 논리 A가 실행되고, 그렇지 않으면 논리 B가 실행된다는 것을 나타냅니다. 처리 방법은 레이블 파싱 결과에 따라 달라집니다. 비즈니스 요구 사항에 따라 처리 방법을 선택할 수 있습니다. |