from gym.envs.registration import register

from d4rl.locomotion import ant, maze_env

"""
register(
    id='antmaze-umaze-v0',
    entry_point='d4rl.locomotion.ant:make_ant_maze_env',
    max_episode_steps=700,
    kwargs={
        'maze_map': maze_env.U_MAZE_TEST,
        'reward_type':'sparse',
        'dataset_url':'http://rail.eecs.berkeley.edu/datasets/offline_rl/ant_maze_new/Ant_maze_u-maze_noisy_multistart_False_multigoal_False_sparse.hdf5',
        'non_zero_reset':False, 
        'eval':True,
        'maze_size_scaling': 4.0,
        'ref_min_score': 0.0,
        'ref_max_score': 1.0,
    }
)
"""

register(
    id='antmaze-umaze-v0',
    entry_point='d4rl.locomotion.ant:make_ant_maze_env',
    max_episode_steps=700,
    kwargs={
        'deprecated': True,
        'maze_map': maze_env.U_MAZE_TEST,
        'reward_type': 'sparse',
        'dataset_url':
        'http://rail.eecs.berkeley.edu/datasets/offline_rl/ant_maze_new/Ant_maze_u-maze_noisy_multistart_False_multigoal_False_sparse.hdf5',
        'non_zero_reset': False,
        'eval': True,
        'maze_size_scaling': 4.0,
        'ref_min_score': 0.0,
        'ref_max_score': 1.0,
    })

register(
    id='antmaze-umaze-diverse-v0',
    entry_point='d4rl.locomotion.ant:make_ant_maze_env',
    max_episode_steps=700,
    kwargs={
        'deprecated': True,
        'maze_map': maze_env.U_MAZE_TEST,
        'reward_type': 'sparse',
        'dataset_url':
        'http://rail.eecs.berkeley.edu/datasets/offline_rl/ant_maze_new/Ant_maze_u-maze_noisy_multistart_True_multigoal_True_sparse.hdf5',
        'non_zero_reset': False,
        'eval': True,
        'maze_size_scaling': 4.0,
        'ref_min_score': 0.0,
        'ref_max_score': 1.0,
    })

register(
    id='antmaze-medium-play-v0',
    entry_point='d4rl.locomotion.ant:make_ant_maze_env',
    max_episode_steps=1000,
    kwargs={
        'deprecated': True,
        'maze_map': maze_env.BIG_MAZE_TEST,
        'reward_type': 'sparse',
        'dataset_url':
        'http://rail.eecs.berkeley.edu/datasets/offline_rl/ant_maze_new/Ant_maze_big-maze_noisy_multistart_True_multigoal_False_sparse.hdf5',
        'non_zero_reset': False,
        'eval': True,
        'maze_size_scaling': 4.0,
        'ref_min_score': 0.0,
        'ref_max_score': 1.0,
    })

register(
    id='antmaze-medium-diverse-v0',
    entry_point='d4rl.locomotion.ant:make_ant_maze_env',
    max_episode_steps=1000,
    kwargs={
        'deprecated': True,
        'maze_map': maze_env.BIG_MAZE_TEST,
        'reward_type': 'sparse',
        'dataset_url':
        'http://rail.eecs.berkeley.edu/datasets/offline_rl/ant_maze_new/Ant_maze_big-maze_noisy_multistart_True_multigoal_True_sparse.hdf5',
        'non_zero_reset': False,
        'eval': True,
        'maze_size_scaling': 4.0,
        'ref_min_score': 0.0,
        'ref_max_score': 1.0,
    })

register(
    id='antmaze-large-diverse-v0',
    entry_point='d4rl.locomotion.ant:make_ant_maze_env',
    max_episode_steps=1000,
    kwargs={
        'deprecated': True,
        'maze_map': maze_env.HARDEST_MAZE_TEST,
        'reward_type': 'sparse',
        'dataset_url':
        'http://rail.eecs.berkeley.edu/datasets/offline_rl/ant_maze_new/Ant_maze_hardest-maze_noisy_multistart_True_multigoal_True_sparse.hdf5',
        'non_zero_reset': False,
        'eval': True,
        'maze_size_scaling': 4.0,
        'ref_min_score': 0.0,
        'ref_max_score': 1.0,
    })

register(
    id='antmaze-large-play-v0',
    entry_point='d4rl.locomotion.ant:make_ant_maze_env',
    max_episode_steps=1000,
    kwargs={
        'deprecated': True,
        'maze_map': maze_env.HARDEST_MAZE_TEST,
        'reward_type': 'sparse',
        'dataset_url':
        'http://rail.eecs.berkeley.edu/datasets/offline_rl/ant_maze_new/Ant_maze_hardest-maze_noisy_multistart_True_multigoal_False_sparse.hdf5',
        'non_zero_reset': False,
        'eval': True,
        'maze_size_scaling': 4.0,
        'ref_min_score': 0.0,
        'ref_max_score': 1.0,
    })

register(
    id='antmaze-umaze-v1',
    entry_point='d4rl.locomotion.ant:make_ant_maze_env',
    max_episode_steps=700,
    kwargs={
        'deprecated': True,
        'maze_map': maze_env.U_MAZE_TEST,
        'reward_type': 'sparse',
        'dataset_url':
        'http://rail.eecs.berkeley.edu/datasets/offline_rl/ant_maze_v1/Ant_maze_umaze_noisy_multistart_False_multigoal_False_sparse.hdf5',
        'non_zero_reset': False,
        'eval': True,
        'maze_size_scaling': 4.0,
        'ref_min_score': 0.0,
        'ref_max_score': 1.0,
    })

register(
    id='antmaze-umaze-diverse-v1',
    entry_point='d4rl.locomotion.ant:make_ant_maze_env',
    max_episode_steps=700,
    kwargs={
        'deprecated': True,
        'maze_map': maze_env.U_MAZE_TEST,
        'reward_type': 'sparse',
        'dataset_url':
        'http://rail.eecs.berkeley.edu/datasets/offline_rl/ant_maze_v1/Ant_maze_umaze_noisy_multistart_True_multigoal_True_sparse.hdf5',
        'non_zero_reset': False,
        'eval': True,
        'maze_size_scaling': 4.0,
        'ref_min_score': 0.0,
        'ref_max_score': 1.0,
    })

register(
    id='antmaze-medium-play-v1',
    entry_point='d4rl.locomotion.ant:make_ant_maze_env',
    max_episode_steps=1000,
    kwargs={
        'deprecated': True,
        'maze_map': maze_env.BIG_MAZE_TEST,
        'reward_type': 'sparse',
        'dataset_url':
        'http://rail.eecs.berkeley.edu/datasets/offline_rl/ant_maze_v1/Ant_maze_medium_noisy_multistart_True_multigoal_False_sparse.hdf5',
        'non_zero_reset': False,
        'eval': True,
        'maze_size_scaling': 4.0,
        'ref_min_score': 0.0,
        'ref_max_score': 1.0,
    })

register(
    id='antmaze-medium-diverse-v1',
    entry_point='d4rl.locomotion.ant:make_ant_maze_env',
    max_episode_steps=1000,
    kwargs={
        'deprecated': True,
        'maze_map': maze_env.BIG_MAZE_TEST,
        'reward_type': 'sparse',
        'dataset_url':
        'http://rail.eecs.berkeley.edu/datasets/offline_rl/ant_maze_v1/Ant_maze_medium_noisy_multistart_True_multigoal_True_sparse.hdf5',
        'non_zero_reset': False,
        'eval': True,
        'maze_size_scaling': 4.0,
        'ref_min_score': 0.0,
        'ref_max_score': 1.0,
    })

register(
    id='antmaze-large-diverse-v1',
    entry_point='d4rl.locomotion.ant:make_ant_maze_env',
    max_episode_steps=1000,
    kwargs={
        'deprecated': True,
        'maze_map': maze_env.HARDEST_MAZE_TEST,
        'reward_type': 'sparse',
        'dataset_url':
        'http://rail.eecs.berkeley.edu/datasets/offline_rl/ant_maze_v1/Ant_maze_large_noisy_multistart_True_multigoal_True_sparse.hdf5',
        'non_zero_reset': False,
        'eval': True,
        'maze_size_scaling': 4.0,
        'ref_min_score': 0.0,
        'ref_max_score': 1.0,
    })

register(
    id='antmaze-large-play-v1',
    entry_point='d4rl.locomotion.ant:make_ant_maze_env',
    max_episode_steps=1000,
    kwargs={
        'deprecated': True,
        'maze_map': maze_env.HARDEST_MAZE_TEST,
        'reward_type': 'sparse',
        'dataset_url':
        'http://rail.eecs.berkeley.edu/datasets/offline_rl/ant_maze_v1/Ant_maze_large_noisy_multistart_True_multigoal_False_sparse.hdf5',
        'non_zero_reset': False,
        'eval': True,
        'maze_size_scaling': 4.0,
        'ref_min_score': 0.0,
        'ref_max_score': 1.0,
    })

register(
    id='antmaze-eval-umaze-v0',
    entry_point='d4rl.locomotion.ant:make_ant_maze_env',
    max_episode_steps=700,
    kwargs={
        'maze_map': maze_env.U_MAZE_EVAL_TEST,
        'reward_type': 'sparse',
        'dataset_url':
        'http://rail.eecs.berkeley.edu/datasets/offline_rl/ant_maze_new/Ant_maze_umaze_eval_noisy_multistart_True_multigoal_False_sparse.hdf5',
        'non_zero_reset': False,
        'eval': True,
        'maze_size_scaling': 4.0,
        'ref_min_score': 0.0,
        'ref_max_score': 1.0,
    })

register(
    id='antmaze-eval-umaze-diverse-v0',
    entry_point='d4rl.locomotion.ant:make_ant_maze_env',
    max_episode_steps=700,
    kwargs={
        'maze_map': maze_env.U_MAZE_EVAL_TEST,
        'reward_type': 'sparse',
        'dataset_url':
        'http://rail.eecs.berkeley.edu/datasets/offline_rl/ant_maze_new/Ant_maze_umaze_eval_noisy_multistart_True_multigoal_True_sparse.hdf5',
        'non_zero_reset': False,
        'eval': True,
        'maze_size_scaling': 4.0,
        'ref_min_score': 0.0,
        'ref_max_score': 1.0,
    })

register(
    id='antmaze-eval-medium-play-v0',
    entry_point='d4rl.locomotion.ant:make_ant_maze_env',
    max_episode_steps=1000,
    kwargs={
        'maze_map': maze_env.BIG_MAZE_EVAL_TEST,
        'reward_type': 'sparse',
        'dataset_url':
        'http://rail.eecs.berkeley.edu/datasets/offline_rl/ant_maze_new/Ant_maze_medium_eval_noisy_multistart_True_multigoal_True_sparse.hdf5',
        'non_zero_reset': False,
        'eval': True,
        'maze_size_scaling': 4.0,
        'ref_min_score': 0.0,
        'ref_max_score': 1.0,
    })

register(
    id='antmaze-eval-medium-diverse-v0',
    entry_point='d4rl.locomotion.ant:make_ant_maze_env',
    max_episode_steps=1000,
    kwargs={
        'maze_map': maze_env.BIG_MAZE_EVAL_TEST,
        'reward_type': 'sparse',
        'dataset_url':
        'http://rail.eecs.berkeley.edu/datasets/offline_rl/ant_maze_new/Ant_maze_medium_eval_noisy_multistart_True_multigoal_False_sparse.hdf5',
        'non_zero_reset': False,
        'eval': True,
        'maze_size_scaling': 4.0,
        'ref_min_score': 0.0,
        'ref_max_score': 1.0,
    })

register(
    id='antmaze-eval-large-diverse-v0',
    entry_point='d4rl.locomotion.ant:make_ant_maze_env',
    max_episode_steps=1000,
    kwargs={
        'maze_map': maze_env.HARDEST_MAZE_EVAL_TEST,
        'reward_type': 'sparse',
        'dataset_url':
        'http://rail.eecs.berkeley.edu/datasets/offline_rl/ant_maze_new/Ant_maze_large_eval_noisy_multistart_True_multigoal_False_sparse.hdf5',
        'non_zero_reset': False,
        'eval': True,
        'maze_size_scaling': 4.0,
        'ref_min_score': 0.0,
        'ref_max_score': 1.0,
    })

register(
    id='antmaze-eval-large-play-v0',
    entry_point='d4rl.locomotion.ant:make_ant_maze_env',
    max_episode_steps=1000,
    kwargs={
        'maze_map': maze_env.HARDEST_MAZE_EVAL_TEST,
        'reward_type': 'sparse',
        'dataset_url':
        'http://rail.eecs.berkeley.edu/datasets/offline_rl/ant_maze_new/Ant_maze_large_eval_noisy_multistart_True_multigoal_True_sparse.hdf5',
        'non_zero_reset': False,
        'eval': True,
        'maze_size_scaling': 4.0,
        'ref_min_score': 0.0,
        'ref_max_score': 1.0,
    })

register(
    id='antmaze-umaze-v2',
    entry_point='d4rl.locomotion.ant:make_ant_maze_env',
    max_episode_steps=700,
    kwargs={
        'maze_map': maze_env.U_MAZE_TEST,
        'reward_type': 'sparse',
        'dataset_url':
        'http://rail.eecs.berkeley.edu/datasets/offline_rl/ant_maze_v2/Ant_maze_u-maze_noisy_multistart_False_multigoal_False_sparse_fixed.hdf5',
        'non_zero_reset': False,
        'eval': True,
        'maze_size_scaling': 4.0,
        'ref_min_score': 0.0,
        'ref_max_score': 1.0,
        'v2_resets': True,
    })

register(
    id='antmaze-umaze-diverse-v2',
    entry_point='d4rl.locomotion.ant:make_ant_maze_env',
    max_episode_steps=700,
    kwargs={
        'maze_map': maze_env.U_MAZE_TEST,
        'reward_type': 'sparse',
        'dataset_url':
        'http://rail.eecs.berkeley.edu/datasets/offline_rl/ant_maze_v2/Ant_maze_u-maze_noisy_multistart_True_multigoal_True_sparse_fixed.hdf5',
        'non_zero_reset': False,
        'eval': True,
        'maze_size_scaling': 4.0,
        'ref_min_score': 0.0,
        'ref_max_score': 1.0,
        'v2_resets': True,
    })

register(
    id='antmaze-medium-play-v2',
    entry_point='d4rl.locomotion.ant:make_ant_maze_env',
    max_episode_steps=1000,
    kwargs={
        'maze_map': maze_env.BIG_MAZE_TEST,
        'reward_type': 'sparse',
        'dataset_url':
        'http://rail.eecs.berkeley.edu/datasets/offline_rl/ant_maze_v2/Ant_maze_big-maze_noisy_multistart_True_multigoal_False_sparse_fixed.hdf5',
        'non_zero_reset': False,
        'eval': True,
        'maze_size_scaling': 4.0,
        'ref_min_score': 0.0,
        'ref_max_score': 1.0,
        'v2_resets': True,
    })

register(
    id='antmaze-medium-diverse-v2',
    entry_point='d4rl.locomotion.ant:make_ant_maze_env',
    max_episode_steps=1000,
    kwargs={
        'maze_map': maze_env.BIG_MAZE_TEST,
        'reward_type': 'sparse',
        'dataset_url':
        'http://rail.eecs.berkeley.edu/datasets/offline_rl/ant_maze_v2/Ant_maze_big-maze_noisy_multistart_True_multigoal_True_sparse_fixed.hdf5',
        'non_zero_reset': False,
        'eval': True,
        'maze_size_scaling': 4.0,
        'ref_min_score': 0.0,
        'ref_max_score': 1.0,
        'v2_resets': True,
    })

register(
    id='antmaze-large-diverse-v2',
    entry_point='d4rl.locomotion.ant:make_ant_maze_env',
    max_episode_steps=1000,
    kwargs={
        'maze_map': maze_env.HARDEST_MAZE_TEST,
        'reward_type': 'sparse',
        'dataset_url':
        'http://rail.eecs.berkeley.edu/datasets/offline_rl/ant_maze_v2/Ant_maze_hardest-maze_noisy_multistart_True_multigoal_True_sparse_fixed.hdf5',
        'non_zero_reset': False,
        'eval': True,
        'maze_size_scaling': 4.0,
        'ref_min_score': 0.0,
        'ref_max_score': 1.0,
        'v2_resets': True,
    })

register(
    id='antmaze-large-play-v2',
    entry_point='d4rl.locomotion.ant:make_ant_maze_env',
    max_episode_steps=1000,
    kwargs={
        'maze_map': maze_env.HARDEST_MAZE_TEST,
        'reward_type': 'sparse',
        'dataset_url':
        'http://rail.eecs.berkeley.edu/datasets/offline_rl/ant_maze_v2/Ant_maze_hardest-maze_noisy_multistart_True_multigoal_False_sparse_fixed.hdf5',
        'non_zero_reset': False,
        'eval': True,
        'maze_size_scaling': 4.0,
        'ref_min_score': 0.0,
        'ref_max_score': 1.0,
        'v2_resets': True,
    })

# ------------------- custom

register(id='point-test-v1',
         entry_point='d4rl.locomotion.point:make_point_maze_env',
         max_episode_steps=150,
         kwargs={
             'maze_map': maze_env.TEST_MAP,
             'reward_type': 'dense',
             'non_zero_reset': True,
             'eval': False,
             'maze_size_scaling': 4.0,
             'ref_min_score': 0.0,
             'ref_max_score': 1.0,
         })

register(id='ant-test-v1',
         entry_point='d4rl.locomotion.ant:make_ant_maze_env',
         max_episode_steps=200,
         kwargs={
             'maze_map': maze_env.TEST_MAP,
             'reward_type': 'dense',
             'non_zero_reset': True,
             'eval': False,
             'maze_size_scaling': 4.0,
             'ref_min_score': 0.0,
             'ref_max_score': 1.0,
         })

register(id='swimmer-test-v1',
         entry_point='d4rl.locomotion.swimmer:make_swimmer_maze_env',
         max_episode_steps=500,
         kwargs={
             'maze_map': maze_env.TEST_MAP,
             'reward_type': 'dense',
             'non_zero_reset': True,
             'eval': False,
             'maze_size_scaling': 4.0,
             'ref_min_score': 0.0,
             'ref_max_score': 1.0,
         })

register(id='point-umaze-v1',
         entry_point='d4rl.locomotion.point:make_point_maze_env',
         max_episode_steps=300,
         kwargs={
             'maze_map': maze_env.U_MAZE_TEST,
             'reward_type': 'dense',
             'non_zero_reset': True,
             'eval': True,
             'maze_size_scaling': 4.0,
             'ref_min_score': 0.0,
             'ref_max_score': 1.0,
         })

register(id='ant-umaze-v1',
         entry_point='d4rl.locomotion.ant:make_ant_maze_env',
         max_episode_steps=700,
         kwargs={
             'maze_map': maze_env.U_MAZE_TEST,
             'reward_type': 'dense',
             'non_zero_reset': True,
             'eval': True,
             'maze_size_scaling': 4.0,
             'ref_min_score': 0.0,
             'ref_max_score': 1.0,
         })

register(id='swimmer-umaze-v1',
         entry_point='d4rl.locomotion.swimmer:make_swimmer_maze_env',
         max_episode_steps=2000,
         kwargs={
             'maze_map': maze_env.U_MAZE_TEST,
             'reward_type': 'dense',
             'non_zero_reset': True,
             'eval': True,
             'maze_size_scaling': 4.0,
             'ref_min_score': 0.0,
             'ref_max_score': 1.0,
         })

register(id='point-medium-v1',
         entry_point='d4rl.locomotion.point:make_point_maze_env',
         max_episode_steps=500,
         kwargs={
             'maze_map': maze_env.BIG_MAZE_TEST,
             'reward_type': 'dense',
             'non_zero_reset': True,
             'eval': True,
             'maze_size_scaling': 4.0,
             'ref_min_score': 0.0,
             'ref_max_score': 1.0,
         })

register(id='ant-medium-v1',
         entry_point='d4rl.locomotion.ant:make_ant_maze_env',
         max_episode_steps=1000,
         kwargs={
             'maze_map': maze_env.BIG_MAZE_TEST,
             'reward_type': 'dense',
             'non_zero_reset': True,
             'eval': True,
             'maze_size_scaling': 4.0,
             'ref_min_score': 0.0,
             'ref_max_score': 1.0,
         })

register(id='swimmer-medium-v1',
         entry_point='d4rl.locomotion.swimmer:make_swimmer_maze_env',
         max_episode_steps=2000,
         kwargs={
             'maze_map': maze_env.BIG_MAZE_TEST,
             'reward_type': 'dense',
             'non_zero_reset': True,
             'eval': True,
             'maze_size_scaling': 4.0,
             'ref_min_score': 0.0,
             'ref_max_score': 1.0,
         })

register(id='point-large-v1',
         entry_point='d4rl.locomotion.point:make_point_maze_env',
         max_episode_steps=500,
         kwargs={
             'maze_map': maze_env.HARDEST_MAZE_TEST,
             'reward_type': 'dense',
             'non_zero_reset': True,
             'eval': True,
             'maze_size_scaling': 4.0,
             'ref_min_score': 0.0,
             'ref_max_score': 1.0,
         })

register(id='ant-large-v1',
         entry_point='d4rl.locomotion.ant:make_ant_maze_env',
         max_episode_steps=1000,
         kwargs={
             'maze_map': maze_env.HARDEST_MAZE_TEST,
             'reward_type': 'dense',
             'non_zero_reset': True,
             'eval': True,
             'maze_size_scaling': 4.0,
             'ref_min_score': 0.0,
             'ref_max_score': 1.0,
         })

register(id='swimmer-large-v1',
         entry_point='d4rl.locomotion.swimmer:make_swimmer_maze_env',
         max_episode_steps=2000,
         kwargs={
             'maze_map': maze_env.HARDEST_MAZE_TEST,
             'reward_type': 'dense',
             'non_zero_reset': True,
             'eval': True,
             'maze_size_scaling': 4.0,
             'ref_min_score': 0.0,
             'ref_max_score': 1.0,
         })
