Halcon 协同机械手进行自动标定

流程

  1. 使用相机捕捉初始标定点位,记录世界坐标
    Halcon 协同机械手进行自动标定_第1张图片

  2. 在机器人示教器上基于基准点位进行其余8个点位设置,每次x轴偏移+4 或 Y轴偏移+4
    Halcon 协同机械手进行自动标定_第2张图片
    Halcon 协同机械手进行自动标定_第3张图片
    Halcon 协同机械手进行自动标定_第4张图片
    Halcon 协同机械手进行自动标定_第5张图片
    Halcon 协同机械手进行自动标定_第6张图片
    Halcon 协同机械手进行自动标定_第7张图片
    Halcon 协同机械手进行自动标定_第8张图片
    Halcon 协同机械手进行自动标定_第9张图片

  3. 对每个点位进行图像获取

  4. 编写Halcon脚本,获取9幅图像中点位中心的像素坐标,以及对应算出的机械手世界坐标,导入标定demo获取换算关系。

  5. 在图像中模拟位置进行验证,

  6. 此时得到的为以相机为中心的标定关系,后续需要根据每个孔位(工具末端)的世界坐标来确定偏移关系。

dev_set_color('red')

PicRows:=[]
PicCols:=[]

for Index := 1 to 9 by 1

read_image (Image, 'G:/自动标定/0'+Index+'.bmp')

rgb1_to_gray (Image, GrayImage)
threshold (GrayImage, Regions, 13, 71)

*填充缺失
fill_up_shape (Regions, WiresFilled, 'area', 1, 100)

*开操作 腐蚀和膨胀的结合,即先腐蚀后膨胀
opening_circle (WiresFilled, Balls, 15.5)

connection (Balls, SingleBalls)

*找到具有目标特征的形状,这边填写的参数是 ‘circularity’ ,就是类圆的图形;
select_shape (SingleBalls, IntermediateBalls, 'circularity', 'and', 0.5, 1.0)

*确定这些圆形区域的最小外接圆,并将输出的坐标和半径做处理后输出
smallest_circle (SingleBalls, Row, Column, Radius)

PicRows[Index-1]:=Row
PicCols[Index-1]:=Column

endfor

WorldRows:=[143.6,147.6,151.6,143.6,147.6,151.6,143.6,147.6,151.6]
WorldCols:=[-665,-665,-665,-661,-661,-661,-657,-657,-657]

*生成标定
vector_to_hom_mat2d (PicRows, PicCols, WorldRows, WorldCols, HomMat2D1)

*坐标转换  (Row3Column3)像素坐标点位, (QxQy)转换后的世界坐标
affine_trans_point_2d (HomMat2D1, 437.157, 389.399, Qx, Qy)
read_image (Image, 'G:/自动标定/01.bmp')
dev_set_color('green')
gen_circle (Circle, 437.157,389.399, 300)

Halcon 协同机械手进行自动标定_第10张图片

你可能感兴趣的:(Halcon,计算机视觉,Halcon)