import numpy as np
# import envs
# from envs.sibrivalry.ant_maze import AntMazeEnv, AntMazeEnvFull, A1MazeEnvFullDownscale
from envs.customfetch.custom_fetch import WallsDemoStackEnv
# from envs.sibrivalry.ant_maze.a1 import A1Env
# from examples.run_goal_cond import make_env
# from common import Config
# import dreamerv2.api as dv2
import imageio

def main():
    # from envs.customfetch.custom_fetch import EasyPickPlaceEnv, GoalType
    # n_blocks = 1 # THIS IS THE "IN_AIR_PERCENTAGE"
    # range_min = 0.1 # THIS IS THE MINIMUM_AIR
    # range_max = 0.11 # THIS IS THE MINIMUM_AIR
    # internal = GoalType.OBJ
    # # external = GoalType.ALL
    # external = GoalType.OBJ
    # env = EasyPickPlaceEnv(max_step=51, internal_goal = internal, external_goal = external, mode=0,
    #                     per_dim_threshold=0, hard=False, distance_threshold=0, n = n_blocks,
    #                     range_min=range_min, range_max=range_max)
    # gif = []
    # for i in range(len(env.get_goals())):
    #     env.set_goal_idx(i)
    #     obs = env.reset()
    #     img = env.render("rgb_array")
    #     gif.append(img)

    # imageio.mimwrite("test.gif", gif)
    env = WallsDemoStackEnv(n=3)
    env.reset()
    while True:
        for i in range(len(env.get_goals())):
            env.reset()
            env.set_goal_idx(i)
            env.render("human")


    # CONFIG_SETTING = 'mega_umaze_proprio'
    # from envs.sibrivalry.ant_maze import AntHardMazeEnvFullDownscale
    # env = AntHardMazeEnvFullDownscale()
    # env.reset()
    # all_goals = env.get_goals()
    # # render all goals
    # for idx, obs in enumerate(all_goals):
    #     env.set_goal_idx(idx)
    #     env.reset()
    #     env.maze.wrapped_env.set_state(obs[:15], np.zeros_like(obs[15:]))
    #     img = env.render("rgb_array")
    #     imageio.imsave(f"imgs/{obs[:7]}.png", img)
    # sim = env.maze.wrapped_env.sim 
    # import ipdb; ipdb.set_trace()
    # env = envs.DmcStatesEnv('walker_walk')
    # for i in range(10):
    #     obs = env.reset()
    #     print(obs['qpos'])
    # for i in range(len(env.get_goals())):
    #     env.set_goal_idx(i)
    #     obs = env.reset()
    #     import ipdb; ipdb.set_trace()
    #     size = env._env.physics.get_state().shape[0] - env.goal.shape[0]
    #     env._env.physics.set_state(np.concatenate((env.goal, np.zeros([size]))))
    #     env._env.step(np.zeros_like(env.action_space.sample()))
    #     goal_img = env.render()
    #     env.rendered_goal = True
    #     imageio.imwrite(f'test_{i}.png', goal_img)

    # env.reset()
    # img = env.render("rgb_array")
    # imageio.imwrite('test.png', img)
        # env.step(env.action_space.sample())
    # env = AntMazeEnvFull()
    # env.reset()
    # action = np.zeros((8,))
    # env.step(action)
    # img = env.render("rgb_array")


    # loop through replay buffer and log min and maximums for each dimension.
    pass
if __name__ == "__main__":
    main()