當前位置: 首頁>>代碼示例>>Python>>正文


Python msg.JointTrajectory方法代碼示例

本文整理匯總了Python中trajectory_msgs.msg.JointTrajectory方法的典型用法代碼示例。如果您正苦於以下問題:Python msg.JointTrajectory方法的具體用法?Python msg.JointTrajectory怎麽用?Python msg.JointTrajectory使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在trajectory_msgs.msg的用法示例。


在下文中一共展示了msg.JointTrajectory方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: __init__

# 需要導入模塊: from trajectory_msgs import msg [as 別名]
# 或者: from trajectory_msgs.msg import JointTrajectory [as 別名]
def __init__(self, pr2, controller_name):
        self.pr2 = pr2
        self.controller_name = controller_name

        self.joint_names = rospy.get_param("/%s/joints" % controller_name)

        self.n_joints = len(self.joint_names)

        msg = self.pr2.get_last_joint_message()
        self.ros_joint_inds = [msg.name.index(name) for name in self.joint_names]
        self.rave_joint_inds = [pr2.robot.GetJointIndex(name) for name in self.joint_names]

        self.controller_pub = rospy.Publisher("%s/command" % controller_name, tm.JointTrajectory)

        all_vel_limits = self.pr2.robot.GetDOFVelocityLimits()
        self.vel_limits = np.array([all_vel_limits[i_rave] * VEL_RATIO for i_rave in self.rave_joint_inds])
        all_acc_limits = self.pr2.robot.GetDOFVelocityLimits()
        self.acc_limits = np.array([all_acc_limits[i_rave] * ACC_RATIO for i_rave in self.rave_joint_inds]) 
開發者ID:alexlee-gk,項目名稱:visual_dynamics,代碼行數:20,代碼來源:PR2.py

示例2: goto_joint_positions

# 需要導入模塊: from trajectory_msgs import msg [as 別名]
# 或者: from trajectory_msgs.msg import JointTrajectory [as 別名]
def goto_joint_positions(self, positions_goal):

        positions_cur = self.get_joint_positions()
        assert len(positions_goal) == len(positions_cur)

        duration = norm((r_[positions_goal] - r_[positions_cur]) / self.vel_limits, ord=inf)

        jt = tm.JointTrajectory()
        jt.joint_names = self.joint_names
        jt.header.stamp = rospy.Time.now()

        jtp = tm.JointTrajectoryPoint()
        jtp.positions = positions_goal
        jtp.velocities = zeros(len(positions_goal))
        jtp.time_from_start = rospy.Duration(duration)

        jt.points = [jtp]
        self.controller_pub.publish(jt)

        rospy.loginfo("%s: starting %.2f sec traj", self.controller_name, duration)
        self.pr2.start_thread(JustWaitThread(duration)) 
開發者ID:alexlee-gk,項目名稱:visual_dynamics,代碼行數:23,代碼來源:PR2.py

示例3: follow_timed_joint_trajectory

# 需要導入模塊: from trajectory_msgs import msg [as 別名]
# 或者: from trajectory_msgs.msg import JointTrajectory [as 別名]
def follow_timed_joint_trajectory(self, positions, velocities, times):

        jt = tm.JointTrajectory()
        jt.joint_names = self.joint_names
        jt.header.stamp = rospy.Time.now()

        for (position, velocity, time) in zip(positions, velocities, times):
            jtp = tm.JointTrajectoryPoint()
            jtp.positions = position
            jtp.velocities = velocity
            jtp.time_from_start = rospy.Duration(time)
            jt.points.append(jtp)

        self.controller_pub.publish(jt)
        rospy.loginfo("%s: starting %.2f sec traj", self.controller_name, times[-1])
        self.pr2.start_thread(JustWaitThread(times[-1])) 
開發者ID:alexlee-gk,項目名稱:visual_dynamics,代碼行數:18,代碼來源:PR2.py

示例4: follow_timed_trajectory

# 需要導入模塊: from trajectory_msgs import msg [as 別名]
# 或者: from trajectory_msgs.msg import JointTrajectory [as 別名]
def follow_timed_trajectory(self, times, angs):
        times_up = np.arange(0, times[-1] + 1e-4, .1)
        angs_up = np.interp(times_up, times, angs)

        jt = tm.JointTrajectory()
        jt.header.stamp = rospy.Time.now()
        jt.joint_names = ["%s_gripper_joint" % self.lr]
        for (t, a) in zip(times, angs):
            jtp = tm.JointTrajectoryPoint()
            jtp.time_from_start = rospy.Duration(t)
            jtp.positions = [a]
            jt.points.append(jtp)
        self.diag_pub.publish(jt)

        self.pr2.start_thread(GripperTrajectoryThread(self, times_up, angs_up))
        # self.pr2.start_thread(GripperTrajectoryThread(self, times, angs)) 
開發者ID:alexlee-gk,項目名稱:visual_dynamics,代碼行數:18,代碼來源:PR2.py

示例5: __init__

# 需要導入模塊: from trajectory_msgs import msg [as 別名]
# 或者: from trajectory_msgs.msg import JointTrajectory [as 別名]
def __init__(self, move_group_arm):
        self.move_group_arm = move_group_arm
        self.traj_finished_event = threading.Event()
        self.current_goal_id = None
        self.current_goal_result = GoalStatus.LOST
        rospy.Subscriber('/niryo_one_follow_joint_trajectory_controller/follow_joint_trajectory/goal',
                         FollowJointTrajectoryActionGoal, self.callback_current_goal)

        rospy.Subscriber('/niryo_one_follow_joint_trajectory_controller/follow_joint_trajectory/result',
                         FollowJointTrajectoryActionResult, self.callback_goal_result)

        # Direct topic to joint_trajectory_controller
        # Used ONLY when goal is aborted, to enter position hold mode
        self.joint_trajectory_publisher = rospy.Publisher(
            '/niryo_one_follow_joint_trajectory_controller/command',
            JointTrajectory, queue_size=10) 
開發者ID:NiryoRobotics,項目名稱:niryo_one_ros,代碼行數:18,代碼來源:arm_commander.py

示例6: move_ur5_joint_trajectory

# 需要導入模塊: from trajectory_msgs import msg [as 別名]
# 或者: from trajectory_msgs.msg import JointTrajectory [as 別名]
def move_ur5_joint_trajectory(xopt, duration=0.1):
    '''
    generally for use with gazebo
    :param xopt:
    :return:
    '''
    global jt_pub_ur5
    jt_ur5 = JointTrajectory()
    jt_ur5.joint_names = ['shoulder_pan_joint','shoulder_lift_joint','elbow_joint',
                      'wrist_1_joint','wrist_2_joint','wrist_3_joint']

    jtpt = JointTrajectoryPoint()
    jtpt.positions = [xopt[0], xopt[1], xopt[2], xopt[3], xopt[4], xopt[5]]
    jtpt.time_from_start = rospy.Duration.from_sec(duration)

    jt_ur5.points.append(jtpt)
    jt_pub_ur5.publish(jt_ur5) 
開發者ID:uwgraphics,項目名稱:relaxed_ik,代碼行數:19,代碼來源:broadcaster.py

示例7: move_sawyer_joint_trajectory

# 需要導入模塊: from trajectory_msgs import msg [as 別名]
# 或者: from trajectory_msgs.msg import JointTrajectory [as 別名]
def move_sawyer_joint_trajectory(xopt, duration=0.1):
    '''
    generally for use with gazebo
    :param xopt:
    :return:
    '''
    global jt_pub_sawyer
    jt_sawyer = JointTrajectory()
    jt_sawyer.joint_names = ['right_j0','right_j1','right_j2',
                      'right_j3','right_j4','right_j5', 'right_j6']

    jtpt = JointTrajectoryPoint()
    jtpt.positions = [xopt[0], xopt[1], xopt[2], xopt[3], xopt[4], xopt[5], xopt[6]]
    jtpt.time_from_start = rospy.Duration.from_sec(duration)

    jt_sawyer.points.append(jtpt)
    jt_pub_sawyer.publish(jt_sawyer) 
開發者ID:uwgraphics,項目名稱:relaxed_ik,代碼行數:19,代碼來源:broadcaster.py

示例8: __init__

# 需要導入模塊: from trajectory_msgs import msg [as 別名]
# 或者: from trajectory_msgs.msg import JointTrajectory [as 別名]
def __init__(self):
        rospy.init_node('gripper_controller')
        self.msg = None
       
       
        self.r_pub = rospy.Publisher('gripper_controller/command',
                Float64,
                queue_size=10)
        """
        self.t_pub = rospy.Publisher('arm_controller/command',
                JointTrajectory,
                queue_size=10)
        self.js_sub = rospy.Subscriber('joint_states', JointState,
                self._jointStateCb)
        """

        # subscribe to command and then spin
        self.server = actionlib.SimpleActionServer('~gripper_action', GripperCommandAction, execute_cb=self.actionCb, auto_start=False)
        self.server.start()
        rospy.spin() 
開發者ID:jhu-lcsr,項目名稱:costar_plan,代碼行數:22,代碼來源:robotiq_gripper_action_server.py

示例9: parseXapPoses

# 需要導入模塊: from trajectory_msgs import msg [as 別名]
# 或者: from trajectory_msgs.msg import JointTrajectory [as 別名]
def parseXapPoses(self, xaplibrary):
        try:
            poses = xapparser.getpostures(xaplibrary)
        except RuntimeError as re:
            rospy.logwarn("Error while parsing the XAP file: %s" % str(re))
            return

        for name, pose in poses.items():

            trajectory = JointTrajectory()

            trajectory.joint_names = pose.keys()
            joint_values = pose.values()

            point = JointTrajectoryPoint()
            point.time_from_start = Duration(2.0) # hardcoded duration!
            point.positions = pose.values()
            trajectory.points = [point]

            self.poseLibrary[name] = trajectory 
開發者ID:ros-naoqi,項目名稱:naoqi_bridge,代碼行數:22,代碼來源:pose_manager.py

示例10: add_demonstration

# 需要導入模塊: from trajectory_msgs import msg [as 別名]
# 或者: from trajectory_msgs.msg import JointTrajectory [as 別名]
def add_demonstration(self, demonstration):
        """
        Add a new  demonstration and update the model
        :param demonstration: RobotTrajectory or JointTrajectory object
        :return:
        """
        if isinstance(demonstration, RobotTrajectory):
            demonstration = demonstration.joint_trajectory
        elif not isinstance(demonstration, JointTrajectory):
            raise TypeError("ros.ProMP.add_demonstration only accepts RT or JT, got {}".format(type(demonstration)))

        if len(self.joint_names) > 0 and self.joint_names != demonstration.joint_names:
            raise ValueError("Joints must be the same and in same order for all demonstrations, this demonstration has joints {} while we had {}".format(demonstration.joint_names, self.joint_names))

        self._durations.append(demonstration.points[-1].time_from_start.to_sec() - demonstration.points[0].time_from_start.to_sec())
        self.joint_names = demonstration.joint_names
        demo_array = [jtp.positions for jtp in demonstration.points]
        self.promp.add_demonstration(demo_array) 
開發者ID:baxter-flowers,項目名稱:promplib,代碼行數:20,代碼來源:ros.py

示例11: stop

# 需要導入模塊: from trajectory_msgs import msg [as 別名]
# 或者: from trajectory_msgs.msg import JointTrajectory [as 別名]
def stop(self):
        jt = tm.JointTrajectory()
        jt.joint_names = self.joint_names
        jt.header.stamp = rospy.Time.now()
        self.controller_pub.publish(jt) 
開發者ID:alexlee-gk,項目名稱:visual_dynamics,代碼行數:7,代碼來源:PR2.py

示例12: command_pan_tilt_vel

# 需要導入模塊: from trajectory_msgs import msg [as 別名]
# 或者: from trajectory_msgs.msg import JointTrajectory [as 別名]
def command_pan_tilt_vel(self, pan_vel, tilt_vel, dt=0.2):
        pan, tilt = self.get_joint_positions()
        jt = tm.JointTrajectory()
        jt.header.stamp = rospy.Time.now() + rospy.Duration(0.01)
        jt.joint_names = ["head_pan_joint", "head_tilt_joint"]
        jtp = tm.JointTrajectoryPoint(positions=[pan + pan_vel * dt,
                                                 tilt + tilt_vel * dt],
                                      velocities=[pan_vel,
                                                  tilt_vel],
                                      time_from_start=rospy.Duration(dt))
        jt.points = [jtp]
        self.controller_pub.publish(jt)
        self.pr2.start_thread(JustWaitThread(dt)) 
開發者ID:alexlee-gk,項目名稱:visual_dynamics,代碼行數:15,代碼來源:PR2.py

示例13: set_position_hold_mode

# 需要導入模塊: from trajectory_msgs import msg [as 別名]
# 或者: from trajectory_msgs.msg import JointTrajectory [as 別名]
def set_position_hold_mode(self):
        msg = JointTrajectory()
        msg.header.stamp = rospy.Time.now()
        msg.points = []
        self.joint_trajectory_publisher.publish(msg) 
開發者ID:NiryoRobotics,項目名稱:niryo_one_ros,代碼行數:7,代碼來源:arm_commander.py

示例14: publish_joint_trajectory

# 需要導入模塊: from trajectory_msgs import msg [as 別名]
# 或者: from trajectory_msgs.msg import JointTrajectory [as 別名]
def publish_joint_trajectory(self, positions, duration):
        msg = JointTrajectory()
        msg.header.stamp = rospy.Time.now()
        msg.joint_names = ['joint_1', 'joint_2', 'joint_3', 'joint_4', 'joint_5', 'joint_6']

        point = JointTrajectoryPoint()
        point.positions = positions
        point.time_from_start = rospy.Duration(duration)
        msg.points = [point]

        self.joint_trajectory_publisher.publish(msg) 
開發者ID:NiryoRobotics,項目名稱:niryo_one_ros,代碼行數:13,代碼來源:joystick_interface.py

示例15: _jointStateCb

# 需要導入模塊: from trajectory_msgs import msg [as 別名]
# 或者: from trajectory_msgs.msg import JointTrajectory [as 別名]
def _jointStateCb(self, msg):
        self.msg = msg
        print msg
        traj = JointTrajectory()
        traj.joint_names = msg.name
        pt = JointTrajectoryPoint()
        pt.positions = list(msg.position)
        pt.positions[1] = 1
        traj.points = [pt]
        self.t_pub.publish(traj) 
開發者ID:jhu-lcsr,項目名稱:costar_plan,代碼行數:12,代碼來源:robotiq_gripper_action_server.py


注:本文中的trajectory_msgs.msg.JointTrajectory方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。