import json

def compute_cost(path):
    input_price = 2.5 # 3 for claude, 3.5 CNY for ui-tars
    output_price = 10 # 15 for claude, 12 CNY for ui-tars
    with open(path, "r") as f:
        data = [json.loads(line) for line in f.readlines()]
    token_count = {
        "prompt_token_count": 0,
        "candidates_token_count": 0,
        "thoughts_token_count": 0,
    }
    for item in data:
        token_count["prompt_token_count"] += item["metadata"]["prompt_token_count"]
        token_count["candidates_token_count"] += item["metadata"]["candidates_token_count"]
        token_count["thoughts_token_count"] += item["metadata"]["thoughts_token_count"]
    cost = token_count["prompt_token_count"] * input_price/1e6 + token_count["candidates_token_count"] * output_price/1e6 + token_count["thoughts_token_count"] * output_price/1e6
    print(f"Total cost: {cost} USD")
    print(f"Average input token count: {token_count['prompt_token_count']/len(data)}")
    print(f"Average output token count: {token_count['candidates_token_count']/len(data)}")
    print(f"Average thoughts token count: {token_count['thoughts_token_count']/len(data)}")
    

if __name__ == "__main__":
    path = "outputs_full/likert/gpt-4.1_pair_with_image.jsonl"
    if "single" in path:
        path2 = path.replace("single", "pair")
    else:
        path2 = path.replace("pair", "single")
    compute_cost(path)
    compute_cost(path2)