Programme d’exemple 14 : MM_S14_Vis_GetUserData

Vous consultez actuellement la documentation pour la dernière version (2.1.2). Pour accéder à une autre version, cliquez sur le bouton "Changer de version" situé dans le coin supérieur droit de la page.

■ Si vous n’êtes pas sûr de la version du produit que vous utilisez, veuillez contacter le support technique Mech-Mind pour obtenir de l’aide.

Présentation du programme

Description

Lorsque le robot obtient le résultat de vision, il obtient également les données de sortie personnalisées du projet Mech-Vision.

Chemin du fichier

Vous pouvez accéder au répertoire d’installation de Mech-Vision et Mech-Viz et trouver le fichier en utilisant le chemin Communication Component/Robot_Interface/YASKAWA/sample/MM_S14_Vis_GetUserData.

Projet

Projet Mech-Vision (un ou plusieurs ports personnalisés doivent être ajoutés à la Sortie Étape)

Prérequis

Ce programme d’exemple est fourni uniquement à titre de référence. Avant d’utiliser le programme, veuillez le modifier en fonction du scénario réel.

Description du programme

Cette partie décrit le programme d’exemple MM_S14_Vis_GetUserData.

Par rapport au programme d’exemple MM_S1_Vis_Basic, ce programme d’exemple ne contient que la modification suivante (le code de cette modification est en gras). Par conséquent, seule la modification est décrite dans la partie suivante. Pour des informations sur les parties de MM_S14_Vis_GetUserData identiques à celles de MM_S1_Vis_Basic, voir Programme d’exemple 1 : MM_S1_Vis_Basic.
NOP
'--------------------------------
'FUNCTION: trigger Mech-Vision
'project and get vision result
'and custom data using
'command 110
'Mech-Mind, 2023-12-25
'--------------------------------
'clear I50 to I69
CLEAR I050 20
'initialize p variables
SUB P070 P070
SUB P071 P071
'set 100mm to z of P070
SETE P070 (3) 100000
'move to robot home position
MOVJ C00000 VJ=50.00
'initialize communication
'parameters (initialization is
'required only once)
CALL JOB:MM_INIT_SOCKET ARGF"192.168.170.22;50000;1"
'move to image-capturing position
MOVJ C00001 VJ=50.00 PL=0
'open socket connection
CALL JOB:MM_OPEN_SOCKET
'trigger NO.1 Mech-Vision project
CALL JOB:MM_START_VIS ARGF"1;0;2;30"
'get vision result from NO.1
'Mech-Vision project
CALL JOB:MM_GET_DYDATA ARGF"1;51;52"
'check whether vision result has
'been got from Mech-Vision
'successfully
IFTHENEXP I052<>1100
	'add error handling logic here
	'according to different error
	'codes
	'e.g.: I052=1003 means no point
	'cloud in ROI
	'e.g.: I052=1002 means no
	'vision result
	 PAUSE
ENDIF
'close socket connection
CALL JOB:MM_CLOSE_SOCKET
'save first vision point data to
'local variables
CALL JOB:MM_GET_DYPOSE ARGF"1;71;61;61"
'received custom data is saved
'from R061
'R061 = offset_x;
'R062 = offset_y;
'R063 = offset_z;
'move to intermediate waypoint of
'picking
MOVJ C00002 VJ=50.00
'move to approach waypoint of
'picking
SFTON P070
MOVL P071 V=166.6 PL=0
SFTOF
'move to picking waypoint
MOVL P071 V=50.0 PL=0
'add object grasping logic here,
'such as DOUT OT#(1) ON
PAUSE
'move to departure waypoint of
'picking
SFTON P070
MOVL P071 V=166.6 PL=0
SFTOF
'move to intermediate waypoint of
'placing
MOVJ C00003 VJ=50.00
'move to approach waypoint of
'placing
MOVL C00004 V=166.6 PL=0
'move to placing waypoint
MOVL C00005 V=50.0 PL=0
'add object releasing logic here,
'such as DOUT OT#(1) OFF
PAUSE
'move to departure waypoint of
'placing
MOVL C00006 V=166.6 PL=0
'move back to robot home position
MOVJ C00007 VJ=50.00
END

Le flux de travail correspondant au code de programme d’exemple ci-dessus est illustré dans la figure ci-dessous.

sample14

Le tableau ci-dessous décrit le code en gras. Vous pouvez cliquer sur l’hyperlien du nom de la commande pour afficher sa description détaillée.

Fonctionnalité Code et description

Obtenir le résultat de vision (y compris les données personnalisées)

'get vision result from NO.1
'Mech-Vision project
CALL JOB:MM_GET_DYDATA ARGF"1;51;52"
Pour un projet Mech-Vision, les données personnalisées correspondent aux données produites par les ports personnalisés du projet Mech-Vision.
  • MM_GET_DYDATA : La commande permettant d’obtenir le résultat de vision. Les points de vision obtenus par cette commande contiennent des données personnalisées en plus des poses et des étiquettes, tandis que les points de vision obtenus par la commande MM_GET_VISDATA ne contiennent pas de données personnalisées.

  • 1 : L’ID du projet Mech-Vision.

  • 51 : La variable I dont l’ID est 51. Cette variable stocke le nombre de points de vision renvoyés par le système de vision.

  • 52 : La variable I dont l’ID est 52. Cette variable stocke le code d’état d’exécution de la commande.

L’instruction entière indique que le robot obtient le résultat de vision du projet Mech-Vision dont l’ID est 1. Le résultat de vision inclut des données personnalisées.

Le résultat de vision renvoyé est enregistré dans la mémoire du robot et ne peut pas être obtenu directement. Pour accéder aux données personnalisées du résultat de vision, vous devez stocker le résultat de vision dans une étape ultérieure.

Stocker le résultat de vision (y compris les données personnalisées)

'save first vision point data to
'local variables
CALL JOB:MM_GET_DYPOSE ARGF"1;71;61;61"
  • MM_GET_DYPOSE : La commande pour stocker le résultat de vision. Cette commande stocke des données personnalisées en plus des poses et des étiquettes. Cependant, MM_GET_POSE ne peut stocker que les poses, les étiquettes et les ID d’outil et ne peut pas stocker des données personnalisées. En outre, MM_GET_DYPOSE enregistre les données personnalisées des points de vision qui étaient stockées dans la mémoire du robot vers la variable spécifiée.

  • 1 : Le premier point de vision est stocké.

  • 71 : La variable P dont l’ID est 71. Cette variable stocke le TCP du premier point de vision, qui est le TCP du point de prise.

  • Le premier 61 : La variable P dont l’ID est 61. La variable qui stocke l’étiquette correspondant au premier point de vision.

  • Le second 61 : La variable R dont l’ID est 61. Les variables R à partir de R061 seront utilisées pour stocker séquentiellement les données personnalisées du premier point de vision.

L’instruction entière stocke le TCP, l’étiquette et les données personnalisées du premier point de vision dans les variables spécifiées.

'received custom data is saved
'from R061
'R061 = offset_x;
'R062 = offset_y;
'R063 = offset_z;

La section commentée ci-dessus est du pseudocode. Vous pouvez obtenir trois éléments de données personnalisées pour un point de vision spécifique via les variables R061, R062 et R063.

Vous pouvez définir la signification des données personnalisées. Par exemple, les trois éléments de données personnalisées pourraient représenter les décalages du robot le long des axes XYZ lors du déplacement vers le point de prise.

Cette page est-elle utile ?

Veuillez nous indiquer comment améliorer :

Nous accordons de l’importance à votre vie privée

Nous utilisons des cookies pour vous offrir la meilleure expérience possible sur notre site web. En continuant à utiliser le site, vous reconnaissez accepter l’utilisation des cookies. Si vous refusez, un cookie unique sera utilisé pour garantir que vous ne soyez pas suivi ou reconnu lors de votre visite sur ce site.