{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "0c8b123f",
   "metadata": {},
   "source": [
    "# Table: Experiment Statistics"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "6e14ad17",
   "metadata": {},
   "outputs": [],
   "source": [
    "from collections import defaultdict\n",
    "from tqdm.auto import tqdm\n",
    "from tsbench.experiments.aws import Analysis"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "74568792",
   "metadata": {},
   "source": [
    "## Setup"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "7d4807e4",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "analysis = Analysis(\"ts-bench\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "20f888f9",
   "metadata": {},
   "source": [
    "## Statistics"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "8b21941c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "4,708 jobs\n"
     ]
    }
   ],
   "source": [
    "print(f\"{len(analysis):,} jobs\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "aa725a23",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "59,060,975 s\n",
      "16,406 h\n",
      "684 d\n"
     ]
    }
   ],
   "source": [
    "seconds = sum(j.info[\"TrainingTimeInSeconds\"] for j in analysis)\n",
    "print(f\"{seconds:,} s\")\n",
    "print(f\"{seconds / 3600:,.0f} h\")\n",
    "print(f\"{seconds / 3600 / 24:,.0f} d\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "097d89f8",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "$ 7,267.87\n"
     ]
    }
   ],
   "source": [
    "pricing = {\n",
    "    \"ml.c5.2xlarge\": 0.408,\n",
    "    \"ml.m5.2xlarge\": 0.461,\n",
    "    \"ml.m5.4xlarge\": 0.922,\n",
    "    \"ml.c5.18xlarge\": 3.672,\n",
    "}\n",
    "cost = sum(\n",
    "    j.info[\"TrainingTimeInSeconds\"] / 3600 * pricing[j.info[\"ResourceConfig\"][\"InstanceType\"]]\n",
    "    for j in analysis\n",
    ")\n",
    "print(f\"$ {cost:,.2f}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "fac72f60",
   "metadata": {},
   "outputs": [],
   "source": [
    "large_jobs = defaultdict(set)\n",
    "for job in analysis:\n",
    "    if job.info[\"ResourceConfig\"][\"InstanceType\"] != \"ml.c5.2xlarge\":\n",
    "        large_jobs[job.hyperparameters[\"model\"]].add(\n",
    "            (job.hyperparameters[\"dataset\"], job.info[\"ResourceConfig\"][\"InstanceType\"])\n",
    "        )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "7c947c21",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "defaultdict(set,\n",
       "            {'prophet': {('wind_farms', 'ml.m5.2xlarge')},\n",
       "             'arima': {('taxi', 'ml.c5.18xlarge')},\n",
       "             'deepar': {('corporacion_favorita', 'ml.m5.2xlarge')},\n",
       "             'nbeats': {('corporacion_favorita', 'ml.m5.2xlarge'),\n",
       "              ('london_smart_meters', 'ml.m5.2xlarge'),\n",
       "              ('london_smart_meters', 'ml.m5.4xlarge'),\n",
       "              ('weather', 'ml.m5.2xlarge')}})"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "large_jobs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "348a80fe",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
