"""Download results of experiment."""

from __future__ import annotations

import sys

import fire
import pandas as pd

sys.path.insert(0, "../../..")
from experiments import utils


def download_results(
    file: str = "experiment_results.csv",
    created_after: str | None = None,
    keys: list[str] | None = [
        # "Train Loss",
        "epoch",
        "Validation Accuracy/dataloader_idx_0",
        "Validation NLL/dataloader_idx_0",
        "Validation ECE/dataloader_idx_0",
        "Mean Parameter Norm/dataloader_idx_0",
        # "Variance val x0/dataloader_idx_0",
        # "Variance val x1/dataloader_idx_0",
        # "Variance val x2/dataloader_idx_0",
        # "Variance val x3/dataloader_idx_0",
        # "Variance val x4/dataloader_idx_0",
        # "Variance val x5/dataloader_idx_0",
        # "Variance val x6/dataloader_idx_0",
        # "Variance val x7/dataloader_idx_0",
        # "Variance val x8/dataloader_idx_0",
        # "Variance val x9/dataloader_idx_0",
        # "Variance val x0/dataloader_idx_1",
        # "Variance val x1/dataloader_idx_1",
        # "Variance val x2/dataloader_idx_1",
        # "Variance val x3/dataloader_idx_1",
        # "Variance val x4/dataloader_idx_1",
        # "Variance val x5/dataloader_idx_1",
        # "Variance val x6/dataloader_idx_1",
        # "Variance val x7/dataloader_idx_1",
        # "Variance val x8/dataloader_idx_1",
        # "Variance val x9/dataloader_idx_1",
    ],
    group: str = "classification_theory",
) -> None:
    """Download results of the experiment."""
    utils.wandb.download_results(
        file=file,
        group=group,
        created_after=created_after,
        keys=keys,
    )

    # Subsample epochs for efficiency
    df = pd.read_csv(file)
    df = df[df["epoch"] % 25 == 0]
    df.to_csv(file, index=False)


if __name__ == "__main__":
    fire.Fire(download_results)
