from gym.envs.registration import register
import gym

robots = ["Point", "Ant"]
task_types = [
    "Maze",
    "Maze1",
    "Push",
    "Fall",
    "Block",
    "BlockMaze",
    "MazeL",
    "MazeS",
    "MazeW",
    "MazeP",
]
all_name = [x + y for x in robots for y in task_types]
for name_t in all_name:
    for Test in ["", "Test"]:


        maze_args = [[-4, -4], [14, 14]]
        # The episode length for train is 200
        max_timestep = 100
        random_start = True
        if name_t[-4:] == "Maze" or name_t[-4:] == "aze1" or name_t[-4:] == "azeL":
            goal_args = [[-4, -4], [14, 14]]
        if Test == "Test":
            POS= 11
            goal_args = [[-4, -4], [16, 16]]
            if name_t[-4:] == "azeL":
                goal_args = [[16.0, 16.0], [16 + 1e-3, 16 + 1e-3]]
            random_start = False
            # The episode length for test is 500
            max_timestep = 200

        if name_t[-4:] == "azeS":
            max_timestep = 400
            goal_args = [[-4, -4], [36, 36]]
            maze_args = [[-4, -4], [36, 36]]
            if Test == "Test":
                goal_args = [[32.0, 32.0], [32 + 1e-3, 32 + 1e-3]]
                random_start = False
                max_timestep = 1000

        if name_t[-4:] == "azeW":
            max_timestep = 400
            goal_args = [[-4, -12], [36, 28]]
            maze_args = [[-4, -12], [36, 28]]
            if Test == "Test":
                goal_args = [[0.0, 16.0], [0 + 1e-3, 16 + 1e-3]]
                random_start = False
                max_timestep = 1000

        if name_t[-4:] == "azeP":
            max_timestep = 400
            goal_args = [[-12, -4], [28, 36]]
            maze_args = [[-12, -4], [28, 36]]
            if Test == "Test":
                goal_args = [[16.0, 0.0], [16.0 + 1e-3, 0.0 + 1e-3]]
                random_start = False
                max_timestep = 1000

        register(
            id=name_t + Test + "-v0",
            entry_point="goal_env.mujoco.create_maze_env:create_maze_env",
            kwargs={
                "env_name": name_t,
                "goal_args": goal_args,
                "maze_size_scaling": 8,
                "random_start": random_start,
                "maze_args": maze_args,
            },
            max_episode_steps=max_timestep,
        )

        # v1 is the one we use in the main paper
        register(
            id=name_t + Test + "-v1",
            entry_point="goal_env.mujoco.create_maze_env:create_maze_env",
            kwargs={
                "env_name": name_t,
                "goal_args": goal_args,
                "maze_size_scaling": 4,
                "random_start": random_start,
                "maze_args": maze_args,
            },
            max_episode_steps=max_timestep,
        )

        register(
            id=name_t + Test + "-v2",
            entry_point="goal_env.mujoco.create_maze_env:create_maze_env",
            kwargs={
                "env_name": name_t,
                "goal_args": goal_args,
                "maze_size_scaling": 2,
                "random_start": random_start,
                "maze_args": maze_args,
            },
            max_episode_steps=max_timestep,
        )

register(
    id="Reacher3D-v0",
    entry_point="goal_env.mujoco.create_fetch_env:create_fetch_env",
    kwargs={"env_name": "Reacher3D-v0"},
    max_episode_steps=100,
)

register(
    id="Pusher-v0",
    entry_point="goal_env.mujoco.create_fetch_env:create_fetch_env",
    kwargs={"env_name": "Pusher-v0"},
    max_episode_steps=100,
)
