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


Python pybullet.getEulerFromQuaternion方法代碼示例

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


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

示例1: get_observation

# 需要導入模塊: import pybullet [as 別名]
# 或者: from pybullet import getEulerFromQuaternion [as 別名]
def get_observation(self):
        observation = []
        observation_lim = []

        # get object position
        obj_pos, obj_orn = p.getBasePositionAndOrientation(self.obj_id, physicsClientId=self._physics_client_id)
        observation.extend(list(obj_pos))
        observation_lim.extend(self._ws_lim)

        if self._control_eu_or_quat is 0:
            obj_euler = p.getEulerFromQuaternion(obj_orn)  # roll, pitch, yaw
            observation.extend(list(obj_euler))
            observation_lim.extend([[-m.pi, m.pi], [-m.pi, m.pi], [-m.pi, m.pi]])
        else:
            observation.extend(list(obj_orn))
            observation_lim.extend([[-1, 1], [-1, 1], [-1, 1], [-1, 1]])

        return observation, observation_lim 
開發者ID:robotology-playground,項目名稱:pybullet-robot-envs,代碼行數:20,代碼來源:world_env.py

示例2: getExtendedObservation

# 需要導入模塊: import pybullet [as 別名]
# 或者: from pybullet import getEulerFromQuaternion [as 別名]
def getExtendedObservation(self):
     self._observation = self._kuka.getObservation()
     gripperState  = p.getLinkState(self._kuka.kukaUid,self._kuka.kukaGripperIndex)
     gripperPos = gripperState[0]
     gripperOrn = gripperState[1]
     blockPos,blockOrn = p.getBasePositionAndOrientation(self.blockUid)

     invGripperPos,invGripperOrn = p.invertTransform(gripperPos,gripperOrn)
     gripperMat = p.getMatrixFromQuaternion(gripperOrn)
     dir0 = [gripperMat[0],gripperMat[3],gripperMat[6]]
     dir1 = [gripperMat[1],gripperMat[4],gripperMat[7]]
     dir2 = [gripperMat[2],gripperMat[5],gripperMat[8]]

     gripperEul =  p.getEulerFromQuaternion(gripperOrn)
     #print("gripperEul")
     #print(gripperEul)
     blockPosInGripper,blockOrnInGripper = p.multiplyTransforms(invGripperPos,invGripperOrn,blockPos,blockOrn)
     projectedBlockPos2D =[blockPosInGripper[0],blockPosInGripper[1]]
     blockEulerInGripper = p.getEulerFromQuaternion(blockOrnInGripper)
     #print("projectedBlockPos2D")
     #print(projectedBlockPos2D)
     #print("blockEulerInGripper")
     #print(blockEulerInGripper)

     #we return the relative x,y position and euler angle of block in gripper space
     blockInGripperPosXYEulZ =[blockPosInGripper[0],blockPosInGripper[1],blockEulerInGripper[2]]

     #p.addUserDebugLine(gripperPos,[gripperPos[0]+dir0[0],gripperPos[1]+dir0[1],gripperPos[2]+dir0[2]],[1,0,0],lifeTime=1)
     #p.addUserDebugLine(gripperPos,[gripperPos[0]+dir1[0],gripperPos[1]+dir1[1],gripperPos[2]+dir1[2]],[0,1,0],lifeTime=1)
     #p.addUserDebugLine(gripperPos,[gripperPos[0]+dir2[0],gripperPos[1]+dir2[1],gripperPos[2]+dir2[2]],[0,0,1],lifeTime=1)

     self._observation.extend(list(blockInGripperPosXYEulZ))
     return self._observation 
開發者ID:utra-robosoccer,項目名稱:soccer-matlab,代碼行數:35,代碼來源:kukaGymEnv.py

示例3: getObservation

# 需要導入模塊: import pybullet [as 別名]
# 或者: from pybullet import getEulerFromQuaternion [as 別名]
def getObservation(self):
    observation = []
    state = p.getLinkState(self.kukaUid,self.kukaGripperIndex)
    pos = state[0]
    orn = state[1]
    euler = p.getEulerFromQuaternion(orn)
        
    observation.extend(list(pos))
    observation.extend(list(euler))
    
    return observation 
開發者ID:utra-robosoccer,項目名稱:soccer-matlab,代碼行數:13,代碼來源:kuka.py

示例4: rpy

# 需要導入模塊: import pybullet [as 別名]
# 或者: from pybullet import getEulerFromQuaternion [as 別名]
def rpy(self):
		return pybullet.getEulerFromQuaternion(self.body_part.current_orientation()) 
開發者ID:utra-robosoccer,項目名稱:soccer-matlab,代碼行數:4,代碼來源:robot_bases.py

示例5: updateImuMeasurments

# 需要導入模塊: import pybullet [as 別名]
# 或者: from pybullet import getEulerFromQuaternion [as 別名]
def updateImuMeasurments(self):
        """Get IMU measurements from simulation and convert to usable format"""
        imu_info = p.getLinkState(self.body, self.imu, computeLinkVelocity=1)
        self.imuMeasurements.position = imu_info[0]
        self.imuMeasurements.orientation = p.getEulerFromQuaternion(imu_info[1])
        self.imuMeasurements.velocity = imu_info[6] 
開發者ID:utra-robosoccer,項目名稱:soccer-matlab,代碼行數:8,代碼來源:agent.py

示例6: getRobotPose

# 需要導入模塊: import pybullet [as 別名]
# 或者: from pybullet import getEulerFromQuaternion [as 別名]
def getRobotPose(self):
        """Gets the robot (origin) position

        Returns:
            (tuple(3), tuple(3)) -- (x,y,z), (roll, pitch, yaw)
        """
        pose = p.getBasePositionAndOrientation()
        return (pose[0], p.getEulerFromQuaternion(pose[1])) 
開發者ID:Rhoban,項目名稱:onshape-to-robot,代碼行數:10,代碼來源:simulation.py

示例7: getFrames

# 需要導入模塊: import pybullet [as 別名]
# 或者: from pybullet import getEulerFromQuaternion [as 別名]
def getFrames(self):
        """Gets the available frames in the current robot model
        
        Returns:
            dict -- dict of str -> (pos, orientation)
        """
        frames = {}

        for name in self.frames.keys():
            jointState = p.getLinkState(self.robot, self.frames[name])
            pos = jointState[0]
            orientation = p.getEulerFromQuaternion(jointState[1])
            frames[name] = [pos, orientation]

        return frames 
開發者ID:Rhoban,項目名稱:onshape-to-robot,代碼行數:17,代碼來源:simulation.py

示例8: euler_from_quat

# 需要導入模塊: import pybullet [as 別名]
# 或者: from pybullet import getEulerFromQuaternion [as 別名]
def euler_from_quat(quat):
        quat = list(quat)
        euler = p.getEulerFromQuaternion(quat)
        return np.array(euler, dtype=np.float32) 
開發者ID:StanfordVL,項目名稱:NTP-vat-release,代碼行數:6,代碼來源:bullet_physics_engine.py

示例9: get_body_euler

# 需要導入模塊: import pybullet [as 別名]
# 或者: from pybullet import getEulerFromQuaternion [as 別名]
def get_body_euler(body):
        _, quat = p.getBasePositionAndOrientation(body)
        euler = p.getEulerFromQuaternion(quat)
        return np.array(euler, dtype=np.float32) 
開發者ID:StanfordVL,項目名稱:NTP-vat-release,代碼行數:6,代碼來源:bullet_physics_engine.py

示例10: get_cstr_dof

# 需要導入模塊: import pybullet [as 別名]
# 或者: from pybullet import getEulerFromQuaternion [as 別名]
def get_cstr_dof(cstr):
        _, _, _, _, _, _, _, pos, _, quat, max_force = p.getConstraintInfo(cstr)
        pos = np.array(pos, dtype=np.float32)
        euler = p.getEulerFromQuaternion(quat)
        euler = np.array(euler, dtype=np.float32)
        return pos, euler 
開發者ID:StanfordVL,項目名稱:NTP-vat-release,代碼行數:8,代碼來源:bullet_physics_engine.py

示例11: step

# 需要導入模塊: import pybullet [as 別名]
# 或者: from pybullet import getEulerFromQuaternion [as 別名]
def step(self, action):
        self.take_step(action, robot_arm='right', gains=self.config('robot_gains'), forces=self.config('robot_forces'), human_gains=0.0005)

        robot_force_on_human, cup_force_on_human = self.get_total_force()
        total_force_on_human = robot_force_on_human + cup_force_on_human
        reward_water, water_mouth_velocities, water_hit_human_reward = self.get_water_rewards()
        end_effector_velocity = np.linalg.norm(p.getBaseVelocity(self.cup, physicsClientId=self.id)[0])
        obs = self._get_obs([cup_force_on_human], [robot_force_on_human, cup_force_on_human])

        # Get human preferences
        preferences_score = self.human_preferences(end_effector_velocity=end_effector_velocity, total_force_on_human=robot_force_on_human, tool_force_at_target=cup_force_on_human, food_hit_human_reward=water_hit_human_reward, food_mouth_velocities=water_mouth_velocities)

        cup_pos, cup_orient = p.getBasePositionAndOrientation(self.cup, physicsClientId=self.id)
        cup_pos, cup_orient = p.multiplyTransforms(cup_pos, cup_orient, [0, 0.06, 0], p.getQuaternionFromEuler([np.pi/2.0, 0, 0], physicsClientId=self.id), physicsClientId=self.id)
        cup_top_center_pos, _ = p.multiplyTransforms(cup_pos, cup_orient, self.cup_top_center_offset, [0, 0, 0, 1], physicsClientId=self.id)
        reward_distance = -np.linalg.norm(self.target_pos - np.array(cup_top_center_pos)) # Penalize distances between top of cup and mouth
        reward_action = -np.sum(np.square(action)) # Penalize actions
        # Encourage robot to have a tilted end effector / cup
        cup_euler = p.getEulerFromQuaternion(cup_orient, physicsClientId=self.id)
        reward_tilt = -abs(cup_euler[0] + np.pi/2) if self.robot_type == 'jaco' else -abs(cup_euler[0] - np.pi/2)

        reward = self.config('distance_weight')*reward_distance + self.config('action_weight')*reward_action + self.config('cup_tilt_weight')*reward_tilt + self.config('drinking_reward_weight')*reward_water + preferences_score

        if self.gui and reward_water != 0:
            print('Task success:', self.task_success, 'Water reward:', reward_water)

        info = {'total_force_on_human': total_force_on_human, 'task_success': int(self.task_success >= self.total_water_count*self.config('task_success_threshold')), 'action_robot_len': self.action_robot_len, 'action_human_len': self.action_human_len, 'obs_robot_len': self.obs_robot_len, 'obs_human_len': self.obs_human_len}
        done = False

        return obs, reward, done, info 
開發者ID:Healthcare-Robotics,項目名稱:assistive-gym,代碼行數:32,代碼來源:drinking.py

示例12: getObservation

# 需要導入模塊: import pybullet [as 別名]
# 或者: from pybullet import getEulerFromQuaternion [as 別名]
def getObservation(self):
        """
        Returns the position and angle of the effector
        :return: ([float])
        """
        observation = []
        state = p.getLinkState(self.kuka_uid, self.kuka_gripper_index)
        pos = state[0]
        orn = state[1]
        euler = p.getEulerFromQuaternion(orn)

        observation.extend(list(pos))
        observation.extend(list(euler))

        return observation 
開發者ID:araffin,項目名稱:robotics-rl-srl,代碼行數:17,代碼來源:kuka.py

示例13: get_orientation_eulerian

# 需要導入模塊: import pybullet [as 別名]
# 或者: from pybullet import getEulerFromQuaternion [as 別名]
def get_orientation_eulerian(self):
        return p.getEulerFromQuaternion(self.get_orientation()) 
開發者ID:gkahn13,項目名稱:GtS,代碼行數:4,代碼來源:robot_locomotors.py

示例14: apply_action

# 需要導入模塊: import pybullet [as 別名]
# 或者: from pybullet import getEulerFromQuaternion [as 別名]
def apply_action(self, a):
        yaw= a
        pos, ornQuaternion = p.getBasePositionAndOrientation(self.robot_ids[0])
        ornEuler = p.getEulerFromQuaternion(ornQuaternion)
        currAngle = ornEuler[2]-self.config['yaw_constant']*yaw
        print(pos)
        print(ornEuler)
        pos = [pos[0]+ self.config['vx_constant']*self.vx*math.cos(currAngle)+random.uniform(self.config['wind_limits'][0], self.config['wind_limits'][1]), 
        pos[1]+self.config['vx_constant']*self.vx*math.sin(currAngle)+random.uniform(self.config['wind_limits'][0], self.config['wind_limits'][1]), self.height]
        pitch = min(max( ornEuler[0] + random.uniform(self.config['d_roll_per_step'][0], self.config['d_roll_per_step'][1]), self.config['roll_limits'][0]), self.config['roll_limits'][1])
        ornEuler = [pitch, ornEuler[1], currAngle]
        ornQuaternion = p.getQuaternionFromEuler(ornEuler)
        self.robot_body.set_pose(pos, ornQuaternion)
        return pos[0], pos[1], ornEuler[2], self.height, self.vx 
開發者ID:gkahn13,項目名稱:GtS,代碼行數:16,代碼來源:robot_locomotors.py

示例15: rpy

# 需要導入模塊: import pybullet [as 別名]
# 或者: from pybullet import getEulerFromQuaternion [as 別名]
def rpy(self):
        return p.getEulerFromQuaternion(self.body_part.get_orientation()) 
開發者ID:gkahn13,項目名稱:GtS,代碼行數:4,代碼來源:robot_bases.py


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