import dmc2gym
import cv2
import numpy as np

obs_mode = 'all'
env = dmc2gym.make(
    domain_name='walker',
    task_name='walk',
    resource_files="",
    img_source='color',
    total_frames=1000,
    seed=1,
    visualize_reward=False,
    obs_mode=obs_mode,
    from_pixels=False,
    height=100,
    width=100,
    frame_skip=1
)


done = False
obs = env.reset()

# image = env.render(mode='rgb_array')
# cv2.imwrite('0_init.png', image)  # 使用OpenCV保存图像

# 获取动作空间
action_space = env.action_space
# 获取动作空间的最大值和最小值
max_action = action_space.high
min_action = action_space.low

print("Maximum action values:", max_action)
print("Minimum action values:", min_action)

"""
+逆时针，-顺时针
-逆时针，+顺时针
"""
time_step = 0
while not done:
    # action = np.array([0.2])
    action = env.action_space.sample()  # 随机采样一个动作
    obs, reward, done, info = env.step(action)
    post_action_image = env.render(mode='rgb_array')
    if time_step % 50 == 0:
        sin_theta = obs[1][1]
        cos_theta = obs[1][2]
        # 使用arccos函数计算角度
        theta_radians = np.arccos(cos_theta)
        # 如果sin_theta为正，角度在[0, pi]范围内
        # 如果sin_theta为负，角度需要调整到[-pi, 0]范围内
        if sin_theta < 0:
            theta_radians = -theta_radians
        # 将弧度转换为度
        theta_degrees = np.degrees(theta_radians)

        print("action:", action)
        print("obs:", obs[1])
        # print("sin_theta:", sin_theta)
        # print("cos_theta:", cos_theta)
        # print("theta_degrees:", theta_degrees)
        print("obs:", obs[0].shape)
        # print("time_step:", time_step)

        cv2.imwrite('C:/doctor/LLM_RL/dmc2gym/images/{}.png'.format(time_step), post_action_image)
        print("-----------------------------------------------")

    time_step = time_step + 1

    if time_step == 500:
        break

env.close()
