import pybullet as p
import time
import pybullet_data as pd
import numpy as np
p.connect(p.GUI)
p.setAdditionalSearchPath(pd.getDataPath())
dt = 1./240.

p.configureDebugVisualizer(p.COV_ENABLE_RENDERING, 0)
p.loadURDF("plane.urdf")
robot = p.loadURDF("a1/a1.urdf", [0, 0, 0.5])
p.configureDebugVisualizer(p.COV_ENABLE_RENDERING, 1)
p.setGravity(0, 0, -9.8)

A1_DEFAULT_ABDUCTION_ANGLE = 0
A1_DEFAULT_HIP_ANGLE = 0.9
A1_DEFAULT_KNEE_ANGLE = -1.8
NUM_LEGS = 4
INIT_MOTOR_ANGLES = np.array([
  A1_DEFAULT_ABDUCTION_ANGLE,
  A1_DEFAULT_HIP_ANGLE,
  A1_DEFAULT_KNEE_ANGLE
] * NUM_LEGS)

MOTOR_NAMES = [
  "FR_hip_joint",
  "FR_upper_joint",
  "FR_lower_joint",
  "FL_hip_joint",
  "FL_upper_joint",
  "FL_lower_joint",
  "RR_hip_joint",
  "RR_upper_joint",
  "RR_lower_joint",
  "RL_hip_joint",
  "RL_upper_joint",
  "RL_lower_joint",
]
motor_ids = []

for j in range(p.getNumJoints(robot)):
  joint_info = p.getJointInfo(robot, j)
  name = joint_info[1].decode('utf-8')
  print("joint_info[1]=", name)
  if name in MOTOR_NAMES:
    motor_ids.append(j)

for index in range(12):
  joint_id = motor_ids[index]
  p.setJointMotorControl2(
    robot, joint_id, p.POSITION_CONTROL, INIT_MOTOR_ANGLES[index])
  p.resetJointState(robot, joint_id, INIT_MOTOR_ANGLES[index])

print("motor_ids=", motor_ids)
while p.isConnected():
  p.stepSimulation()
  time.sleep(dt)
