import json
import os

# pred_json='/data/xxx/segmentation/CutOnce_old/coler_official_eval/cls_agnostic_objects365/inference/coco_instances_results.json'
# original_coco_json='/data/xxx/datasets/objects365/annotations/zhiyuan_objv2_val_cls_agnostic.json'
# output_json='/data/xxx/segmentation/CutOnce_old/coler_official_eval/cls_agnostic_objects365/inference/coco_instances_results_dict.json'

def convert_coco_dict(pred_json, original_coco_json, output_json):
    # Load detectron2 predictions (list format)
    with open(pred_json, 'r') as f:
        predictions = json.load(f)

    # Load original COCO format file
    with open(original_coco_json, 'r') as f:
        original_coco = json.load(f)

    # Extract images and categories from original COCO file
    original_images = original_coco['images']
    original_categories = original_coco['categories']

    # Reassign annotation IDs to predictions
    ann_id = 1
    for ann in predictions:
        ann['id'] = ann_id
        
        if 'area' not in ann:
            x, y, w, h = ann['bbox']
            ann['area'] = w * h
        if 'iscrowd' not in ann:
            ann['iscrowd'] = 0
        ann_id += 1

    # Build final COCO format dictionary
    new_dict_filtered = {
        # "info": INFO,
        # "licenses": LICENSES,
        "categories": original_categories,
        "images": original_images,
        "annotations": predictions
    }

    # Save the converted file
    with open(output_json, 'w') as f:
        json.dump(new_dict_filtered, f, indent=2)

    print(f"Converted {len(predictions)} predictions with {len(original_images)} images")

DATASET_ROOT=f"/data/xxx/datasets/"
EVAL_ROOT="coler_official_eval/cls_agnostic"
result_eval_dict={
    "coco20k": [f"{DATASET_ROOT}coco/annotations/coco20k_trainval_gt.json", f"{EVAL_ROOT}_coco20k/inference/coco_instances_results.json"],
    "voc": [f"{DATASET_ROOT}voc/annotations/trainvaltest_2007_cls_agnostic.json", f"{EVAL_ROOT}_voc/inference/coco_instances_results.json"],
    "coco": [f"{DATASET_ROOT}coco/annotations/coco_cls_agnostic_instances_val2017.json", f"{EVAL_ROOT}_coco/inference/coco_instances_results.json"],
    "imagenet": [f"{DATASET_ROOT}imagenet/annotations/imagenet_val_cls_agnostic_gt.json", f"{EVAL_ROOT}_imagenet/inference/coco_instances_results.json"],
    "lvis": [f"{DATASET_ROOT}coco/annotations/lvis1.0_cocofied_val_cls_agnostic.json", f"{EVAL_ROOT}_lvis/inference/coco_instances_results.json"],
    "clipart": [f"{DATASET_ROOT}clipart/annotations/traintest_clipart_cls_agnostic.json", f"{EVAL_ROOT}_clipart/inference/coco_instances_results.json"],
    "watercolor": [f"{DATASET_ROOT}watercolor/annotations/traintest_watercolor_cls_agnostic.json", f"{EVAL_ROOT}_watercolor/inference/coco_instances_results.json"],
    "comic": [f"{DATASET_ROOT}comic/annotations/traintest_comic_cls_agnostic.json", f"{EVAL_ROOT}_comic/inference/coco_instances_results.json"],
    "kitti": [f"{DATASET_ROOT}kitti/annotations/trainval_cls_agnostic.json", f"{EVAL_ROOT}_kitti/inference/coco_instances_results.json"],
    "openimages": [f"{DATASET_ROOT}openimages-v7/annotations/openimages_val_cls_agnostic.json", f"{EVAL_ROOT}_openimages/inference/coco_instances_results.json"],
    "objects365": [f"{DATASET_ROOT}objects365/annotations/zhiyuan_objv2_val_cls_agnostic.json", f"{EVAL_ROOT}_objects365/inference/coco_instances_results.json"],
}

def convert_all():
    dataset_names = [
                    # "coco", "coco20k", 
                     "lvis", "voc", 
                    #  "clipart", "watercolor", "comic", 
                     "kitti", "openimages", 
                    #  "objects365"
                     ]
    for dataset_name in dataset_names:
        gt = result_eval_dict[dataset_name][0]
        pred = result_eval_dict[dataset_name][1]
        out = os.path.splitext(pred)[0] + "_dict.json"
        try:
            print(f"=== Converting {dataset_name} ===")
            convert_coco_dict(pred, gt, out)
        except Exception as e:
            print(f"Error in {dataset_name}: {e}")
            continue

if __name__ == "__main__":
    convert_all()
    exit(0)