import re

# Define placeholders for dataset paths
CAMBRIAN_737K = {
    "annotation_path": "PATH_TO_CAMBRIAN_737K_ANNOTATION",
    "data_path": "",
}

MP_DOC = {
    "annotation_path": "PATH_TO_MP_DOC_ANNOTATION",
    "data_path": "PATH_TO_MP_DOC_DATA",
}

CLEVR_MC = {
    "annotation_path": "PATH_TO_CLEVR_MC_ANNOTATION",
    "data_path": "PATH_TO_CLEVR_MC_DATA",
}

VIDEOCHATGPT = {
    "annotation_path": "PATH_TO_VIDEOCHATGPT_ANNOTATION",
    "data_path": "PATH_TO_VIDEOCHATGPT_DATA",
}

MY_DATASET = {
    "annotation_path": "dataset/origin.jsonl",
    "data_path": "dataset",  # Can be empty if paths are in annotations
}

original={
    "data_path": "dataset",
    "annotation_path": "dataset/origin.jsonl",
}
extend1={
    "data_path": "dataset",
    "annotation_path": "dataset/extend1.jsonl",
}
extend2={
    "data_path": "dataset",
    "annotation_path": "dataset/extend2.jsonl",
}
extend3= {
    "data_path": "dataset",
    "annotation_path": "dataset/extend3.jsonl",
}



data_dict = {
    "original": original,
    "extend1": extend1,
    "extend2": extend2,
    "extend3": extend3,
    "cambrian_737k": CAMBRIAN_737K,
    "mp_doc": MP_DOC,
    "clevr_mc": CLEVR_MC,
    "videochatgpt": VIDEOCHATGPT,
    "my_dataset": MY_DATASET,
}


def parse_sampling_rate(dataset_name):
    match = re.search(r"%(\d+)$", dataset_name)
    if match:
        return int(match.group(1)) / 100.0
    return 1.0


def data_list(dataset_names):
    config_list = []
    for dataset_name in dataset_names:
        sampling_rate = parse_sampling_rate(dataset_name)
        dataset_name = re.sub(r"%(\d+)$", "", dataset_name)
        if dataset_name in data_dict.keys():
            config = data_dict[dataset_name].copy()
            config["sampling_rate"] = sampling_rate
            config_list.append(config)
        else:
            raise ValueError(f"do not find {dataset_name}")
    return config_list

if __name__ == "__main__":
    dataset_names = ["my_dataset%100"]
    configs = data_list(dataset_names)
    for config in configs:
        print(config)
