import os
import sys
sys.path.append(os.path.dirname(os.path.dirname(__file__)))
import torch
from PIL import Image
from torchvision.transforms import ToTensor
import ImageReward as RM
from reward_models.imagereward_score.imagereward_score import load

if __name__ == "__main__":
    prompt = "a bird"
    img_prefix = "test.jpg"
    # generations = [f"{pic_id}.webp" for pic_id in range(1, 5)]
    img_list = [img_prefix]
    model = RM.load("ImageReward-v1.0")
    with torch.no_grad():
        score = model.score(prompt, img_list[0])
        print(f"{score:.2f}")

    new_model = load("ImageReward-v1.0")

    # with torch.no_grad():
    image = Image.open(img_list[0])
    image = ToTensor()(image)
    image.requires_grad = True
    score = new_model.score(image, prompt)
    print(score)
    score.backward()
    print(torch.cuda.memory_allocated()/1024/1024)
    print(image.grad)

