import argparse
import os

from loguru import logger as log

from utils.commons.io import load_pkl
from utils.commons.covmat import CovMatEvaluator, print_covmat_results

if __name__ == "__main__":
    parser = argparse.ArgumentParser()
    parser.add_argument(
        "--path", "-p", type=str, help="Path to the data file", required=True
    )
    parser.add_argument(
        "--num_workers", "-n", type=int, default=1, help="Number of workers"
    )
    parser.add_argument(
        "--use_alignmol",
        "-a",
        action="store_true",
        default=False,
        help="Use alignmol for matching",
    )
    args = parser.parse_args()

    path = args.path
    os.path.exists(path), f"Path {path} does not exist"
    packed_data_list = load_pkl(path)

    use_alignmol = args.use_alignmol

    num_workers = args.num_workers
    log.info(f"Using {num_workers} workers for evaluation...")
    evaluator = CovMatEvaluator(num_workers=num_workers, use_alignmol=args.use_alignmol)
    log.info("Evaluation Started...")
    results, rmsd_results = evaluator(packed_data_list)
    log.info("Evaluation finished...")

    # get dataframe of results
    cov_df, matching_metrics = print_covmat_results(results)
    print(cov_df)
    print(matching_metrics)