Franka机械臂代码学习——joint_point_to_point_motion.cpp

这这例程算是比较基础的例程,就是你给出机械臂的七个关节角,然后机械臂就会自动运行到那个关节角的姿态。

// Copyright (c) 2017 Franka Emika GmbH
// Use of this source code is governed by the Apache-2.0 license, see LICENSE
#include <cmath>
#include <iostream>

#include <franka/exception.h>
#include <franka/robot.h>

#include "examples_common.h"

/**
 * @example joint_point_to_point_motion.cpp
 * An example that moves the robot to a target position by commanding joint positions.
 *
 * @warning Before executing this example, make sure there is enough space in front of the robot.
 */
// 给定七个关节角让机械臂运动到该姿态
// 输入的十个参数包括[代码文件路径][机械臂hostname][七个关节角][速度因子]
int main(int argc, char** argv) {
  if (argc != 10) {
    std::cerr << "Usage: " << argv[0] << " <robot-hostname> "
              << "<joint0> <joint1> <joint2> <joint3> <joint4> <joint5> <joint6> "
              << "<speed-factor>" << std::endl
              << "joint0 to joint6 are joint angles in [rad]." << std::endl
              << "speed-factor must be between zero and one." << std::endl;
    return -1;
  }
  try {
    franka::Robot robot(argv[1]);  // 创建机器人实例
    setDefaultBehavior(robot);     //  设置机械臂的默认碰撞行为

    std::array<double, 7> q_goal;
    for (size_t i = 0; i < 7; i++) {
      q_goal[i] = std::stod(argv[i + 2]);
    }
    double speed_factor = std::stod(argv[9]);

    // Set additional parameters always before the control loop, NEVER in the control loop!
    //  设置机械臂的默认碰撞行为
    robot.setCollisionBehavior(
        {{20.0, 20.0, 20.0, 20.0, 20.0, 20.0, 20.0}}, {{20.0, 20.0, 20.0, 20.0, 20.0, 20.0, 20.0}},
        {{10.0, 10.0, 10.0, 10.0, 10.0, 10.0, 10.0}}, {{10.0, 10.0, 10.0, 10.0, 10.0, 10.0, 10.0}},
        {{20.0, 20.0, 20.0, 20.0, 20.0, 20.0}}, {{20.0, 20.0, 20.0, 20.0, 20.0, 20.0}},
        {{10.0, 10.0, 10.0, 10.0, 10.0, 10.0}}, {{10.0, 10.0, 10.0, 10.0, 10.0, 10.0}});

    MotionGenerator motion_generator(speed_factor, q_goal);    // 创建一个motion generator,参数包括速度因子,目标关节角
    std::cout << "WARNING: This example will move the robot! "
              << "Please make sure to have the user stop button at hand!" << std::endl
              << "Press Enter to continue..." << std::endl;
    std::cin.ignore();  // 读入回车
    robot.control(motion_generator);     // 让机械臂根据motion generator运动
    std::cout << "Motion finished" << std::endl;
  } catch (const franka::Exception& e) {
    std::cout << e.what() << std::endl;   // 如果有异常则抛出异常
    return -1;
  }

  return 0;
}

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Franka机械臂是一款高性能的机器人臂,具有灵活性和精度高的特点。在使用Franka机械臂进行复杂任务时,动力学参数的准确识别至关重要。 动力学参数识别是通过对机械臂运动学和力学特征进行实验和分析,得出机械臂的参数,以便进行准确的控制与规划。 MATLAB是一种功能强大的数学软件,广泛应用于科学和工程领域。使用MATLAB可以对机械臂运动学和动力学方程进行建模和求解,从而实现Franka机械臂动力学参数的识别。 动力学参数识别的过程可以分为以下几个步骤: 1. 进行实验:通过在真实的工作环境中对机械臂进行实验,获取机械臂运动的相关数据,如位置、速度和加速度等。 2. 设计模型:根据机械臂的结构和运动特点,建立机械臂运动学和动力学模型。 3. 参数辨识:利用MATLAB中的参数辨识工具,根据实验数据和机械臂模型,对机械臂的动力学参数进行辨识。常用的参数辨识方法有最小二乘法、最大似然估计等。 4. 模型验证和优化:将识别得到的参数应用到机械臂模型中,进行模型验证。如果模型与实验数据吻合度较低,可以对参数进行优化,再次计算模型,直到满足实验数据的要求。 通过以上步骤,就可以利用MATLAB对Franka机械臂的动力学参数进行准确的识别。这样,在后续的控制与规划任务中,可以更好地利用机械臂的性能,提高工作效率和精度。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值