{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd \n",
    "import wandb\n",
    "import tqdm\n",
    "api = wandb.Api()\n",
    "runs = api.runs(\"ph10m/polarity-similarity-november\")\n",
    "\n",
    "config_list = []\n",
    "histories = []\n",
    "for run in tqdm.tqdm(runs):\n",
    "    config_list.append(\n",
    "        {k: v for k,v in run.config.items()\n",
    "          if not k.startswith('_')})\n",
    "    _history = [h for h in run.scan_history()]\n",
    "    _history = [{k: v for k, v in h.items() if k in [\"polarity_mean\", \"semantic_mean\"]} for h in _history]\n",
    "    histories.append(_history)\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "model_translations = {\n",
    "    \"e5-small-v2\": \"e5-small\",\n",
    "    \"gte-base\": \"gte-base\",\n",
    "    \"gte-small\": \"gte-small\",\n",
    "    \"all-MiniLM-L6-v2\": \"minilm-6\"\n",
    "}\n",
    "runs_df = pd.DataFrame({\n",
    "    \"config\": config_list,\n",
    "    \"history\": histories,\n",
    "})\n",
    "runs_df[\"model\"] = runs_df[\"config\"].apply(lambda x: x[\"model\"])\n",
    "runs_df[\"model\"] = runs_df[\"model\"].apply(lambda x: model_translations[x])\n",
    "runs_df[\"dataset\"] = runs_df[\"config\"].apply(lambda x: x[\"dataset\"])\n",
    "runs_df[\"loss\"] = runs_df[\"config\"].apply(lambda x: x[\"loss\"])\n",
    "runs_df = runs_df.drop(columns=[\"config\"])\n",
    "\n",
    "df = runs_df.copy()\n",
    "df = df.explode(\"history\").reset_index(drop=True)\n",
    "df[\"epoch\"] = 1 + df.index % 5  # there's 5 epochs\n",
    "df = df.join(pd.DataFrame(df[\"history\"].tolist()))\n",
    "df = df.drop(columns=[\"history\"])\n",
    "df.to_csv(\"50k_novemberrun_history.csv\", index=False)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "venv",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
