# from envs import MetaWorld
# from envs import RoboBinEnv
from envs.sibrivalry.toy_maze import PointMaze2D
import numpy as np
import imageio
import sys
# env = MetaWorld('mtmw_sawyer_SawyerReachEnv', 1, use_goal_idx=False, log_per_goal=True)
# env = RoboBinEnv(1)
env = PointMaze2D()
gif = []
obs = env.reset()
img = env.render()
imageio.imwrite("test.png", img)
import ipdb; ipdb.set_trace()
goals = np.stack(env.get_goals(), 0)
gif= env.render_states(goals)
# for g in goals:
#     img = env.render_offscreen()
#     gif.append(img)
    # print(obs['qpos'])
    # print(obs.keys())
    # gif.append(obs['image_goal'])
imageio.mimwrite('robobingoals.gif',gif)

# sys.exit()
"""
test egl rendering
"""
import sys
from time import time
print("evaluating fps")
total_steps = 1000
avg_duration = 0
for i in range(total_steps):
    start = time()
    img = env.render_offscreen()
    duration = time() - start
    avg_duration += duration / total_steps
print("FPS:", 1/avg_duration)
import imageio 
imageio.imwrite("test.png", img)
sys.exit()