单物体最优抓取轨迹生成

基于 3D 位姿规划直线平滑抓取轨迹,包含趋近 - 抓取 - 复位三段最优运动路径,适配机械臂点位运动

核心规划逻辑

  1. 基准位:机械臂初始安全待机点
  2. 趋近段:直线匀速靠近物体上方预备抓取点
  3. 抓取段:垂直下落至物体抓取中心位姿
  4. 抬升段:抓取后回升至安全高度
  5. 复位段:返回初始待机位置

完整可运行代码

python

运行

复制代码
from ultralytics import YOLO
import cv2
import numpy as np
import math

# 模型与相机参数
model = YOLO("yolo26n.pt")
FOCAL_LENGTH = 600
REAL_WIDTH = 0.5

# 机械臂基准点位(相机坐标系,单位m)
HOME_X, HOME_Y, HOME_Z = 0.0, -0.2, 0.8    # 初始待机位
PRE_Z_OFFSET = 0.15                         # 抓取预备高度落差
LIFT_HEIGHT = 0.2                           # 抓取抬升高度

# 摄像头初始化
cap = cv2.VideoCapture(0)
cap.set(cv2.CAP_PROP_FRAME_WIDTH, 1280)
cap.set(cv2.CAP_PROP_FRAME_HEIGHT, 720)
cv2.namedWindow("最优抓取轨迹规划", cv2.WINDOW_NORMAL)
cv2.resizeWindow("最优抓取轨迹规划", 1280, 720)

# 轨迹点位存储
trajectory_points = []

def gen_optimal_grasp_traj(obj_x, obj_y, obj_z, grasp_angle):
    """生成最优抓取轨迹点位列表"""
    traj = []
    # 1. 初始待机点
    traj.append([HOME_X, HOME_Y, HOME_Z, grasp_angle])
    # 2. 物体上方预备抓取点
    pre_x, pre_y, pre_z = obj_x, obj_y, obj_z + PRE_Z_OFFSET
    traj.append([pre_x, pre_y, pre_z, grasp_angle])
    # 3. 物体中心抓取点
    traj.append([obj_x, obj_y, obj_z, grasp_angle])
    # 4. 抓取后抬升安全点
    lift_z = obj_z + LIFT_HEIGHT
    traj.append([obj_x, obj_y, lift_z, grasp_angle])
    # 5. 返回初始位
    traj.append([HOME_X, HOME_Y, HOME_Z, grasp_angle])
    return traj

while True:
    ret, frame = cap.read()
    if not ret:
        break
    results = model(frame, imgsz=640, verbose=False)
    img = results[0].plot()
    trajectory_points.clear()

    for box in results[0].boxes:
        x1, y1, x2, y2 = box.xyxy[0].cpu().numpy()
        cls_name = model.names[int(box.cls[0])]
        box_w = x2 - x1
        box_h = y2 - y1

        # 计算3D坐标
        obj_z = (REAL_WIDTH * FOCAL_LENGTH) / box_w
        cx, cy = (x1+x2)/2, (y1+y2)/2
        obj_x = (cx - frame.shape[1]//2) * obj_z / FOCAL_LENGTH
        obj_y = (cy - frame.shape[0]//2) * obj_z / FOCAL_LENGTH

        # 计算抓取姿态角
        grasp_angle = 0.0 if box_w >= box_h else 90.0

        # 生成最优抓取轨迹
        grasp_traj = gen_optimal_grasp_traj(obj_x, obj_y, obj_z, grasp_angle)
        trajectory_points = grasp_traj

        # 绘制抓取中心点
        cv2.circle(img, (int(cx), int(cy)), 8, (0,0,255), -1)
        # 显示坐标姿态
        info = f"XYZ:{obj_x:.2f} {obj_y:.2f} {obj_z:.2f}m Angle:{grasp_angle}deg"
        cv2.putText(img, info, (int(x1), int(y1)-15),
                    cv2.FONT_HERSHEY_SIMPLEX, 1, (0,255,0), 2)

    # 打印轨迹点位,可下发机械臂
    if trajectory_points:
        print("====最优抓取轨迹点位(X,Y,Z,角度)====")
        for idx, pos in enumerate(trajectory_points):
            print(f"点位{idx+1}: {pos}")

    cv2.imshow("最优抓取轨迹规划", img)
    if cv2.waitKey(1) & 0xFF == ord('q'):
        break

cap.release()
cv2.destroyAllWindows()

运行指令

bash

运行

复制代码
python3 yolo3d.py

轨迹特性(最优设计)

  1. 避障安全:先到物体上空再下落,规避周边障碍物
  2. 运动平顺:直线插值路径,速度波动小、抖动低
  3. 动作闭环:抓取完成自动复位,可连续作业
  4. 姿态适配:根据物体长宽自动匹配夹持角度

轨迹输出说明

终端打印 5 组轨迹点位,格式[X,Y,Z,抓取角度],可直接对接运动控制器下发执行

进阶扩展方向

  1. 增加轨迹插补,生成密集中间点位实现顺滑运动
  2. 加入碰撞检测,修正危险轨迹路径
  3. 对接 ROS/MoveIt,直接仿真并执行轨迹
  4. 多物体优先级排序,依次生成抓取路径
相关推荐
用户8356290780516 小时前
Python 实现 PDF 文件加密与解密方法
后端·python
用户8356290780516 小时前
使用 Python 冻结与拆分 Excel 窗格教程
后端·python
你好潘先生14 小时前
别再记命令了,用 yeero do 说句人话就能跑脚本,而且不烧 token
服务器·python·命令行
Agent_大师14 小时前
WebSocket 行情重连成功,K线缺口不会自动消失
python
荣码14 小时前
LLM结构化输出:让AI返回JSON而不是废话,我踩了4个坑
java·python
copyer_xyf14 小时前
FastAPI 如何连接 MySQL
后端·python
apocelipes1 天前
常用编程语言和库的正则表达式性能对比
c语言·c++·python·性能优化·golang·开发工具和环境
用户8356290780511 天前
使用 Python 在 PDF 中创建与管理书签
后端·python
MeixianAgent1 天前
Python 回测数据入口怎么验?历史 K 线入库前先做 5 个检查
后端·python
咕白m6252 天前
用 Python 实现一键批量查找与替换 Excel 数据
后端·python