import os
import sys
sys.path.append(os.path.abspath(os.path.join(os.path.dirname(__file__), '..')))
from PIL import Image
from custom_reward_train.hacked_clip_model import HackedGreyReward
from PIL import ImageDraw

# Load the hacked reward model
hacked_model_path = "custom_reward_train/model/hack_reward_model.pth"
clip_model_path = "openai/clip-vit-base-patch32"
hacked_reward = HackedGreyReward(hacked_model_path, clip_model_path)

# Load the image
img_path = "hack_test.jpg"
img = Image.open(img_path)

# Load the prompt
prompt = "a styled face"

# Calculate the score
import torchvision.transforms as transforms
img = transforms.ToTensor()(img).to(hacked_reward.model.device)
img.requires_grad = True

# Number of iterations to go along the gradient dimension
num_iterations = 100
step_size = 2

for i in range(num_iterations):
    score = hacked_reward.score(img, prompt)
    score.backward()

    img = img + img.grad * step_size
    img = img.detach().clone()
    img.requires_grad = True

img_ = img.clone().detach().cpu()
img_ = transforms.ToPILImage()(img_)
img_.save("hack_test_score_add.jpg")
# Create a list to store images for the GIF
frames = []

# Reset the image and gradient
img = Image.open(img_path)
img = transforms.ToTensor()(img).to(hacked_reward.model.device)
img.requires_grad = True

for i in range(num_iterations):
    score = hacked_reward.score(img, prompt)
    score.backward()

    # Convert tensor to PIL image and add to frames
    img_ = img.clone().detach().cpu()
    img_ = transforms.ToPILImage()(img_)
    draw = ImageDraw.Draw(img_)
    draw.text((10, 10), f"Step: {i+1}", fill="white")
    frames.append(img_)

    img = img + img.grad * step_size
    img = img.detach().clone()
    img.requires_grad = True

# Save the frames as a GIF
frames[0].save("hack_test_score_add.gif", save_all=True, append_images=frames[1:], duration=100, loop=0)
