from furniture_bench_api.api.api_predicates import StateAssembledPredicate
from furniture_bench_api.api.api_skills import APISkills
from furniture_bench_api.furniture_bench_environment import FurnitureBenchEnvironment
from furniture_bench_api.utils.image_utils import get_image_with_labels

furniture_bench_env = FurnitureBenchEnvironment()
tolerance = 5e-3

skills = APISkills(furniture_bench_env=furniture_bench_env, tolerance=tolerance)

furniture_bench_env.reset_env(seed=1)

skills.move_to_part_above("lamp_bulb")
# skills.move_to_part_above("lamp_bulb")  # test rotation invariance
skills.move_to_part_center("lamp_bulb")
skills.close_gripper()
skills.move_linear_relative(x_mm=0, y_mm=0, z_mm=100)

skills.move_to_part_above("lamp_base")
skills.align("lamp_bulb", "lamp_base")

skills.move_linear_relative_until_touching(x_mm=0, y_mm=00, z_mm=-150, touching_obj_a="lamp_bulb", touching_obj_b="lamp_base")

skills.open_gripper()

# skills.move_to_part_above("lamp_bulb")

skills.rotate_arm_until_screwed("lamp_bulb", "lamp_base")
skills.open_gripper()

skills.move_linear_relative(x_mm=0, y_mm=0, z_mm=50)

skills.move_to_part_above("lamp_hood")
skills.move_to_part_center("lamp_hood")
skills.close_gripper()
skills.move_linear_relative(x_mm=0, y_mm=0, z_mm=180)
# skills.move_to_part_above("lamp_bulb")
skills.align("lamp_hood", "lamp_base")
skills.move_linear_relative_until_touching(x_mm=0, y_mm=0, z_mm=-150, touching_obj_a="lamp_hood", touching_obj_b="lamp_bulb")
skills.open_gripper()

for i in range(3):
    is_assembled, _ = StateAssembledPredicate().validate(env=furniture_bench_env, obj1="lamp_hood", obj2="lamp_base")
    print("hood assembled", is_assembled)
    if is_assembled:
        break
    skills.idle()

from PIL import Image
Image.fromarray(furniture_bench_env.get_observation()["color_image2"][0].cpu().numpy()).save("image2.png")

furniture_bench_env.stop_recording()