import json

def update_coco_scores(json_file_path, output_file_path):
    # Load the JSON file
    with open(json_file_path, 'r') as f:
        coco_data = json.load(f)
    
    # 检查是否为标准COCO格式
    if isinstance(coco_data, dict) and 'annotations' in coco_data:
        # 标准COCO格式
        data_list = coco_data['annotations']
        is_coco_format = True
    else:
        # 原来的list格式
        data_list = coco_data
        is_coco_format = False
    
    # First pass: count masks for each image_id
    image_counts = {}
    for item in data_list:
        image_id = item['image_id']
        image_counts[image_id] = image_counts.get(image_id, 0) + 1
    
    # Second pass: update scores
    idx_counters = {}  # track current index for each image_id
    for item in data_list:
        image_id = item['image_id']
        idx = idx_counters.get(image_id, 0)
        num_masks = image_counts[image_id]
        
        # Calculate new score:
        # item['score'] = 1.0 - idx / (2 * num_masks)
        if num_masks == 1:
            item['score'] = 1.0
        else:
            item['score'] = 1.0 - idx / (2 * num_masks - 2)
        
        # Increment index counter for this image_id
        idx_counters[image_id] = idx + 1
    
    # 根据原始格式保存
    if is_coco_format:
        # 标准COCO格式，保持原有结构
        save_data = coco_data
    else:
        # list格式
        save_data = data_list
    
    # Save the updated data
    with open(output_file_path, 'w') as f:
        json.dump(save_data, f, indent=2)
    
    print(f"Updated {len(data_list)} items across {len(image_counts)} images")

# Usage example
if __name__ == "__main__":
    # input_file = "/data/xxx/segmentation/CuVLER/datasets/imagenet/annotations/imagenet_val_votecut-dino_b8.json"
    # output_file = "coco_val2017_cutonce_score.json"
    input_file = "pseudo_labels/coco_val2017_cutonce_improve_vote.json"
    output_file = "coco_val2017_cutonce_improve_vote_score.json"
    
    input_file = "coler_official_eval/cls_agnostic_lvis/inference/coco_instances_results.json"
    # input_file = "/data/xxx/datasets/coco/annotations/lvis1.0_cocofied_val_cls_agnostic.json"
    input_file = "/data/xxx/datasets/objects365/annotations/zhiyuan_objv2_val_cls_agnostic.json"
    input_file = "coler_official_eval/cls_agnostic_objects365/inference/coco_instances_results.json"
    input_file = "coler_official_eval/cls_agnostic_objects365/inference/coco_instances_results_dict.json"
    update_coco_scores(input_file, output_file)