{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "454dca41",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os, sys\n",
    "path_to_this_notebook = os.path.abspath('.')\n",
    "path_to_project = path_to_this_notebook[:path_to_this_notebook.find('note')]\n",
    "sys.path.append(path_to_project)\n",
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "72c4ba21",
   "metadata": {},
   "outputs": [],
   "source": [
    "from src.experiment import Experiment\n",
    "import time"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "f7f62e86",
   "metadata": {},
   "outputs": [],
   "source": [
    "from IPython.display import HTML, Javascript, display\n",
    "\n",
    "def restart_kernel_and_run_all_cells():\n",
    "    display(HTML(\n",
    "        '''\n",
    "            <script>\n",
    "                code_show = false;\n",
    "                function restart_run_all(){\n",
    "                    IPython.notebook.kernel.restart();\n",
    "                    setTimeout(function(){\n",
    "                        IPython.notebook.execute_all_cells();\n",
    "                    }, 10000)\n",
    "                }\n",
    "                function code_toggle() {\n",
    "                    if (code_show) {\n",
    "                        $('div.input').hide(200);\n",
    "                    } else {\n",
    "                        $('div.input').show(200);\n",
    "                    }\n",
    "                    code_show = !code_show\n",
    "                }\n",
    "                code_toggle() \n",
    "                restart_run_all()\n",
    "            </script>\n",
    "\n",
    "        '''\n",
    "    ))\n",
    "import re\n",
    "\n",
    "def get_seed(name):\n",
    "    return re.findall('([0-9]+, [0-9]+)', name)[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "a02f8598",
   "metadata": {},
   "outputs": [],
   "source": [
    "# SETTINGS\n",
    "problem_class = 'OPF'\n",
    "use_wandb = False"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "19c5fb89",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Problems:\n",
      "VOPF4G12L_g=6_i=25_topology=1_2722_noise=0.1_500-samples_test\n",
      "\n",
      "Chosen: VOPF4G12L_g=6_i=25_topology=1_2722_noise=0.1_500-samples_test\n",
      "\n",
      "Experiments for this problem:\n",
      "LOC=1_lr=0.0001_bs=1_epochs=50_pred-x_u_frozen-Wsq_(492, 3317)\n",
      "vanilla_lr=0.0001_bs=1_epochs=50_pred-x_u_frozen-Wsq_(492, 3317)\n",
      "\n",
      "Chosen: LOC=1_lr=0.0001_bs=1_epochs=50_pred-x_u_frozen-Wsq_(492, 3317)\n"
     ]
    }
   ],
   "source": [
    "path_to_problems = path_to_project + 'experiments/vopf/'\n",
    "problem_names = sorted(os.listdir(path_to_problems))\n",
    "print('Problems:')\n",
    "print('\\n'.join(problem_names))\n",
    "problem_name = problem_names[0]\n",
    "\n",
    "print()\n",
    "print('Chosen:', problem_name)\n",
    "print()\n",
    "experiment_names = sorted(os.listdir(path_to_problems + problem_name), key=get_seed)\n",
    "print('Experiments for this problem:')\n",
    "print('\\n'.join(experiment_names))\n",
    "print()\n",
    "experiment_name = experiment_names[0]\n",
    "print('Chosen:', experiment_name)\n",
    "base_path = path_to_problems + '/%s/%s/' % (problem_name, experiment_name)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "efd0969a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['VOPF4G12L_g=6_i=25_topology=1_2722_noise=0.1_500-samples_test']"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "problem_names_take = [n for n in problem_names\n",
    "                      #if 'compare-methods' in n\n",
    "                     ]\n",
    "problem_names_take"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "29eb3ff9",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Chosen: VOPF4G12L_g=6_i=25_topology=1_2722_noise=0.1_500-samples_test LOC=1_lr=0.0001_bs=1_epochs=50_pred-x_u_frozen-Wsq_(492, 3317)\n",
      "Initializing experiment:\n",
      "Path: /home/gr1/Projects/study-diff-opt-submission/experiments/vopf//VOPF4G12L_g=6_i=25_topology=1_2722_noise=0.1_500-samples_test/LOC=1_lr=0.0001_bs=1_epochs=50_pred-x_u_frozen-Wsq_(492, 3317)/\n",
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/gr1/Projects/study-diff-opt-submission/src/vopf/load_data.py:6: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  return torch.tensor(array, dtype=torch.float64)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Created problem instance!\n",
      "Initialized predictor!\n",
      "Created runner!\n",
      "use_wandb=False, hence not initializing logger!\n",
      "Loaded training epochs 50\n",
      "Chosen: VOPF4G12L_g=6_i=25_topology=1_2722_noise=0.1_500-samples_test vanilla_lr=0.0001_bs=1_epochs=50_pred-x_u_frozen-Wsq_(492, 3317)\n",
      "Initializing experiment:\n",
      "Path: /home/gr1/Projects/study-diff-opt-submission/experiments/vopf//VOPF4G12L_g=6_i=25_topology=1_2722_noise=0.1_500-samples_test/vanilla_lr=0.0001_bs=1_epochs=50_pred-x_u_frozen-Wsq_(492, 3317)/\n",
      "\n",
      "Created problem instance!\n",
      "Initialized predictor!\n",
      "Created runner!\n",
      "use_wandb=False, hence not initializing logger!\n",
      "Loaded training epochs 50\n"
     ]
    }
   ],
   "source": [
    "time_start = time.time()\n",
    "for problem_name in problem_names_take:\n",
    "    experiment_names = sorted(os.listdir(path_to_problems + problem_name), key=get_seed)\n",
    "    for experiment_name in experiment_names:\n",
    "        print('Chosen:', problem_name, experiment_name)\n",
    "        base_path = path_to_problems + '/%s/%s/' % (problem_name, experiment_name)\n",
    "        experiment = Experiment(base_path, problem_class, use_wandb=use_wandb)\n",
    "        experiment.run()\n",
    "        if time.time() - time_start > 600:\n",
    "                restart_kernel_and_run_all_cells()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "594890cc",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.16"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
