{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "02b860a2",
   "metadata": {
    "scrolled": false
   },
   "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": "1b169e37",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import pickle\n",
    "from collections import defaultdict\n",
    "import numpy as np\n",
    "%matplotlib inline\n",
    "import matplotlib as mpl\n",
    "import re\n",
    "\n",
    "\n",
    "def find_seed(name):\n",
    "    return re.findall('_\\([0-9]+, [0-9]+\\)', name)[0]\n",
    "\n",
    "def name_no_seed(name):\n",
    "    seed = find_seed(name)\n",
    "    return name.replace(seed, '')\n",
    "\n",
    "def filter_name(name):\n",
    "    ind_s = name.find('lr')\n",
    "    ind_e = name.find('ep')\n",
    "    name = name.replace(name[ind_s: ind_e], '')\n",
    "    epochs = re.findall('epochs=[0-9]+', name)[0]\n",
    "    return name.replace(epochs, '')\n",
    "    name_short = name[:name.find('lr') - 1]\n",
    "    name_short =  name_short.replace('P=0-', '').replace('D=0-', '',).replace('R=0_', '').replace('MSE=0', '')\n",
    "    if name_short[-1] in ['-', '_']:\n",
    "        name_short = name_short[:-1]\n",
    "\n",
    "    return name_short\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "f6aac282",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Problems:\n",
      "portfolio-problem_n=200_alpha=2_full_frozen-is-good\n",
      "portfolio-problem_n=200_alpha=2_full_final-february\n",
      "portfolio-problem_n=200_alpha=2_full_QP-vs-true\n",
      "portfolio-problem_n=200_alpha=1_full_final-february\n",
      "portfolio-problem_n=200_alpha=0_full_final-february\n",
      "portfolio-problem_n=200_alpha=0.5_full_final-february\n",
      "portfolio-problem_n=200_alpha=0.25_full_final-february\n",
      "portfolio-problem_n=200_alpha=0.1_full_final-february\n",
      "\n",
      "Chosen: portfolio-problem_n=200_alpha=2_full_QP-vs-true\n",
      "\n",
      "Experiments for this problem:\n",
      "vanilla_lr=3e-05_bs=1_epochs=32_pred-xu_cov-mat_scale0.1-add1_(6778, 8563)\n",
      "vanilla_lr=3e-05_bs=1_epochs=32_pred-xu_cov-mat_scale0.1-add1_(5927, 5537)\n",
      "vanilla_lr=3e-05_bs=1_epochs=32_pred-xu_scale0.1-add1_frozen-Wsq_(6778, 8563)\n",
      "vanilla_lr=3e-05_bs=1_epochs=32_pred-xu_scale0.1-add1_frozen-Wsq_(5927, 5537)\n",
      "vanilla_lr=3e-05_bs=1_epochs=32_pred-xu_scale0.1-add1_frozen-Wsq_(4482, 6628)\n",
      "vanilla_lr=3e-05_bs=1_epochs=32_pred-xu_scale0.1-add1_frozen-Wsq_(5056, 9708)\n",
      "vanilla_lr=3e-05_bs=1_epochs=32_pred-xu_cov-mat_scale0.1-add1_(5056, 9708)\n",
      "vanilla_lr=3e-05_bs=1_epochs=32_pred-xu_cov-mat_scale0.1-add1_(4482, 6628)\n"
     ]
    }
   ],
   "source": [
    "use_wandb = False\n",
    "N = 200\n",
    "folder_name = 'portfolio_optimization_n=%d' % N\n",
    "path_to_problems = path_to_project + 'experiments/%s/' % folder_name\n",
    "#path_to_problems = path_to_project + 'experiments_backup/portfolio_optimization/'\n",
    "problem_names = sorted(os.listdir(path_to_problems))\n",
    "problem_names.reverse()\n",
    "print('Problems:')\n",
    "print('\\n'.join(problem_names))\n",
    "problem_name = problem_names[2]\n",
    "print()\n",
    "print('Chosen:', problem_name)\n",
    "print()\n",
    "experiment_names = sorted(os.listdir(path_to_problems + problem_name), key=lambda x: '0' if 'van' in x else x)\n",
    "print('Experiments for this problem:')\n",
    "print('\\n'.join(experiment_names))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "332afe41",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loaded vanilla_lr=3e-05_bs=1_epochs=32_pred-xu_cov-mat_scale0.1-add1_(6778, 8563)\n",
      "Could not load vanilla_lr=3e-05_bs=1_epochs=32_pred-xu_scale0.1-add1_frozen-Wsq_(6778, 8563)\n"
     ]
    }
   ],
   "source": [
    "train_results_per_run = defaultdict(list)\n",
    "val_results_per_run = defaultdict(list)\n",
    "test_results_per_run = defaultdict(list)\n",
    "for exp_name in experiment_names:\n",
    "    if '6778' not in exp_name:\n",
    "        continue\n",
    "\n",
    "    try: \n",
    "        base_path = path_to_problems + '/%s/%s/' % (problem_name, exp_name)\n",
    "        with open(base_path + '/validate_history.pickle', 'rb') as f:\n",
    "            validate_history = pickle.load(f)\n",
    "        with open(base_path + '/training_history.pickle', 'rb') as f:\n",
    "            train_history = pickle.load(f)\n",
    "        with open(base_path + '/test_history.pickle', 'rb') as f:\n",
    "            test_history = pickle.load(f)\n",
    "        exp_name_no_seed = name_no_seed(exp_name)\n",
    "        train_results_per_run[exp_name_no_seed].append(train_history)\n",
    "        val_results_per_run[exp_name_no_seed].append(validate_history)\n",
    "        test_results_per_run[exp_name_no_seed].append(test_history)\n",
    "        print('Loaded %s' % exp_name)\n",
    "    except:\n",
    "        print('Could not load %s' % exp_name)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "9411ed79",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['vanilla_lr=3e-05_bs=1_epochs=32_pred-xu_cov-mat_scale0.1-add1']"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "keys_to_plot = list(train_results_per_run.keys())\n",
    "keys_to_plot = [k for k in keys_to_plot #if 'lr=0.0001' in k or 'lr=5e-05' in k\n",
    "                if 'MSE' not in k\n",
    "               # if 'frozen' in k #or 'cov' in k\n",
    "               ]\n",
    "keys_to_plot = sorted(keys_to_plot)\n",
    "keys_to_plot"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "ed74ef4d",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/gr1/miniconda3/envs/evcp/lib/python3.8/site-packages/numpy/core/fromnumeric.py:3474: RuntimeWarning: Mean of empty slice.\n",
      "  return _methods._mean(a, axis=axis, dtype=dtype,\n",
      "/home/gr1/miniconda3/envs/evcp/lib/python3.8/site-packages/numpy/core/_methods.py:189: RuntimeWarning: invalid value encountered in double_scalars\n",
      "  ret = ret.dtype.type(ret / rcount)\n",
      "/home/gr1/miniconda3/envs/evcp/lib/python3.8/site-packages/numpy/core/_methods.py:264: RuntimeWarning: Degrees of freedom <= 0 for slice\n",
      "  ret = _var(a, axis=axis, dtype=dtype, out=out, ddof=ddof,\n",
      "/home/gr1/miniconda3/envs/evcp/lib/python3.8/site-packages/numpy/core/_methods.py:222: RuntimeWarning: invalid value encountered in true_divide\n",
      "  arrmean = um.true_divide(arrmean, div, out=arrmean, casting='unsafe',\n",
      "/home/gr1/miniconda3/envs/evcp/lib/python3.8/site-packages/numpy/core/_methods.py:256: RuntimeWarning: invalid value encountered in double_scalars\n",
      "  ret = ret.dtype.type(ret / rcount)\n"
     ]
    },
    {
     "ename": "TypeError",
     "evalue": "object of type 'numpy.float64' has no len()",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mTypeError\u001b[0m                                 Traceback (most recent call last)",
      "Input \u001b[0;32mIn [11]\u001b[0m, in \u001b[0;36m<cell line: 42>\u001b[0;34m()\u001b[0m\n\u001b[1;32m     44\u001b[0m mean_val \u001b[38;5;241m=\u001b[39m np\u001b[38;5;241m.\u001b[39mmean([d[\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mregret\u001b[39m\u001b[38;5;124m'\u001b[39m] \u001b[38;5;28;01mfor\u001b[39;00m d \u001b[38;5;129;01min\u001b[39;00m res_test], axis\u001b[38;5;241m=\u001b[39m\u001b[38;5;241m0\u001b[39m)\n\u001b[1;32m     45\u001b[0m std \u001b[38;5;241m=\u001b[39m np\u001b[38;5;241m.\u001b[39mstd([d[\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mregret\u001b[39m\u001b[38;5;124m'\u001b[39m] \u001b[38;5;28;01mfor\u001b[39;00m d \u001b[38;5;129;01min\u001b[39;00m res_test], axis\u001b[38;5;241m=\u001b[39m\u001b[38;5;241m0\u001b[39m)\n\u001b[0;32m---> 46\u001b[0m x \u001b[38;5;241m=\u001b[39m np\u001b[38;5;241m.\u001b[39marange(\u001b[38;5;241m0\u001b[39m, \u001b[38;5;28;43mlen\u001b[39;49m\u001b[43m(\u001b[49m\u001b[43mmean_val\u001b[49m\u001b[43m)\u001b[49m)\n\u001b[1;32m     47\u001b[0m c \u001b[38;5;241m=\u001b[39m color_dict[key]\n\u001b[1;32m     48\u001b[0m \u001b[38;5;66;03m#m = choose_marker(key)\u001b[39;00m\n",
      "\u001b[0;31mTypeError\u001b[0m: object of type 'numpy.float64' has no len()"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x576 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.rc('font', family='serif')\n",
    "#colors = ['#8A88AC', '#957964', '#10026E', '#AC400A']\n",
    "colors = ['#A5A5A5', '#9BA711', '#0058A0', '#9E0202']\n",
    "#colors = ['#887AE6', '#F6AE43', '#10026E', '#A44700']\n",
    "color_dict = {'vanilla_lr=5e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq': colors[0],\n",
    "              'PD=0.005_lr=5e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq': colors[1],\n",
    "              'LOC=1_lr=5e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq': colors[2],\n",
    "              'R=0_PD=0.005_LOC=1_lr=5e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq': colors[3],\n",
    "             }\n",
    "\n",
    "\"\"\"color_dict = {'vanilla_lr=1e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq': colors[0],\n",
    "              'PD=0.1_lr=1e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq': colors[1],\n",
    "              'LOC=1_lr=1e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq': colors[2],\n",
    "              'R=0_PD=0.1_LOC=1_lr=1e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq': colors[3],\n",
    "             }\"\"\"\n",
    "\n",
    "color_dict = {'vanilla_lr=3e-05_bs=1_epochs=32_pred-xu_cov-mat_scale0.1-add1': colors[0],\n",
    "              'vanilla_lr=1e-05_bs=1_epochs=24_pred-xu_scale0.1-add1_frozen-Wsq': colors[2],\n",
    "              }\n",
    "\n",
    "name_dict = {'vanilla_lr=5e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq': 'Standard',\n",
    "              'PD=0.005_lr=5e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq': 'Proj. distance',\n",
    "              'LOC=1_lr=5e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq': '$r-$smoothing',\n",
    "              'R=0_PD=0.005_LOC=1_lr=5e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq':  '$r-$smoothing + \\nproj.distance',\n",
    "             }\n",
    "\n",
    "\"\"\"name_dict = {'vanilla_lr=1e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq': 'Standard',\n",
    "              'PD=0.1_lr=1e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq': 'Proj. distance',\n",
    "              'LOC=1_lr=1e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq': '$r-$smoothing',\n",
    "              'R=0_PD=0.1_LOC=1_lr=1e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq':  '$r-$smoothing + \\nproj.distance',\n",
    "             }\"\"\"\n",
    "\n",
    "name_dict = {'vanilla_lr=3e-05_bs=1_epochs=32_pred-xu_cov-mat_scale0.1-add1': 'Predict both $\\hat{Q}, \\hat{w}$',\n",
    "              'vanilla_lr=1e-05_bs=1_epochs=24_pred-xu_scale0.1-add1_frozen-Wsq': \n",
    "             'Predict only $\\hat{w},$ fix $\\hat{Q}=I$',\n",
    "              }\n",
    "\n",
    "#name = 'qp_vs_standard'\n",
    "name = 'qp'\n",
    "fig, ax = plt.subplots(figsize=(10, 8))\n",
    "#fig, ax = plt.figure()\n",
    "for key in color_dict:\n",
    "    res_test = test_results_per_run[key]\n",
    "    mean_val = np.mean([d['regret'] for d in res_test], axis=0)\n",
    "    std = np.std([d['regret'] for d in res_test], axis=0)\n",
    "    x = np.arange(0, len(mean_val))\n",
    "    c = color_dict[key]\n",
    "    #m = choose_marker(key)\n",
    "    m = '-' if 'LOC' in key else '--'\n",
    "    m = '-'\n",
    "    #m = '-' if 'froz' in key else '--'\n",
    "    p = ax.plot(x, mean_val, m, color=c, label=name_dict[key], linewidth=6)\n",
    "    #plt.scatter(x, mean_val,  marker='X', s=256, color=p[0].get_color())\n",
    "    ax.fill_between(x, mean_val - std, mean_val + std, color=p[0].get_color(), alpha=0.3)\n",
    "    \n",
    "_ = ax.legend(loc='upper right', prop={'size': 32})\n",
    "#_ = plt.title('Regret on the test set')\n",
    "_ = ax.set_xlabel('Training epoch', fontsize=32)\n",
    "_ = ax.set_ylabel('Regret', rotation=0, fontsize=32)\n",
    "\n",
    "ax.set_xticklabels(map(int, ax.get_xticks()), fontsize=25)\n",
    "ax.set_yticks(ax.get_yticks()[::2])\n",
    "ax.set_yticks([0.03, 0.04, 0.05, .06, ])\n",
    "ax.set_yticklabels(map(lambda x: np.round(x, 4), ax.get_yticks()), fontsize=25)\n",
    "ax.yaxis.set_label_coords(-.08, 0.5)\n",
    "plt.gca().set_position([0, 0, 1, 1])\n",
    "#plt.savefig(name + '.svg')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d79a8566",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 95,
   "id": "40176098",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Loaded vanilla_lr=1e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(3878, 174)\n",
      "Loaded vanilla_lr=1e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(6751, 516)\n",
      "Loaded vanilla_lr=1e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(3953, 5058)\n",
      "Loaded vanilla_lr=1e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(8934, 9776)\n",
      "Loaded LOC=1_lr=1e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(3878, 174)\n",
      "Loaded LOC=1_lr=1e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(3953, 5058)\n",
      "Loaded LOC=1_lr=1e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(6751, 516)\n",
      "Loaded LOC=1_lr=1e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(8934, 9776)\n",
      "Loaded PD=0.1_lr=1e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(3878, 174)\n",
      "Loaded PD=0.1_lr=1e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(3953, 5058)\n",
      "Loaded PD=0.1_lr=1e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(6751, 516)\n",
      "Loaded PD=0.1_lr=1e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(8934, 9776)\n",
      "Loaded R=0_PD=0.1_LOC=1_lr=1e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(3878, 174)\n",
      "Loaded R=0_PD=0.1_LOC=1_lr=1e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(3953, 5058)\n",
      "Loaded R=0_PD=0.1_LOC=1_lr=1e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(6751, 516)\n",
      "Loaded R=0_PD=0.1_LOC=1_lr=1e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(8934, 9776)\n",
      "Loaded vanilla_lr=1e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(1634, 6496)\n",
      "Loaded vanilla_lr=1e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(3015, 1193)\n",
      "Loaded vanilla_lr=1e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(5946, 800)\n",
      "Loaded vanilla_lr=1e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(5382, 5601)\n",
      "Loaded LOC=1_lr=1e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(1634, 6496)\n",
      "Loaded LOC=1_lr=1e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(3015, 1193)\n",
      "Loaded LOC=1_lr=1e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(5382, 5601)\n",
      "Loaded LOC=1_lr=1e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(5946, 800)\n",
      "Loaded PD=0.1_lr=1e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(1634, 6496)\n",
      "Loaded PD=0.1_lr=1e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(3015, 1193)\n",
      "Loaded PD=0.1_lr=1e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(5382, 5601)\n",
      "Loaded PD=0.1_lr=1e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(5946, 800)\n",
      "Loaded R=0_PD=0.1_LOC=1_lr=1e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(1634, 6496)\n",
      "Loaded R=0_PD=0.1_LOC=1_lr=1e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(3015, 1193)\n",
      "Loaded R=0_PD=0.1_LOC=1_lr=1e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(5382, 5601)\n",
      "Loaded R=0_PD=0.1_LOC=1_lr=1e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(5946, 800)\n",
      "Loaded vanilla_lr=5e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(546, 5735)\n",
      "Loaded vanilla_lr=5e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(1566, 8987)\n",
      "Loaded vanilla_lr=5e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(1134, 515)\n",
      "Loaded vanilla_lr=5e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(135, 8844)\n",
      "Loaded LOC=1_lr=5e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(1134, 515)\n",
      "Loaded LOC=1_lr=5e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(135, 8844)\n",
      "Loaded LOC=1_lr=5e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(1566, 8987)\n",
      "Loaded LOC=1_lr=5e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(546, 5735)\n",
      "Loaded PD=0.0025_lr=5e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(1134, 515)\n",
      "Loaded PD=0.0025_lr=5e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(135, 8844)\n",
      "Loaded PD=0.0025_lr=5e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(1566, 8987)\n",
      "Loaded PD=0.0025_lr=5e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(546, 5735)\n",
      "Loaded R=0_PD=0.0025_LOC=1_lr=5e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(1134, 515)\n",
      "Loaded R=0_PD=0.0025_LOC=1_lr=5e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(135, 8844)\n",
      "Loaded R=0_PD=0.0025_LOC=1_lr=5e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(1566, 8987)\n",
      "Loaded R=0_PD=0.0025_LOC=1_lr=5e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(546, 5735)\n",
      "Loaded vanilla_lr=2e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(279, 2809)\n",
      "Loaded vanilla_lr=2e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(5426, 4551)\n",
      "Loaded vanilla_lr=2e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(3235, 2478)\n",
      "Loaded vanilla_lr=2e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(1570, 4545)\n",
      "Loaded LOC=1_lr=2e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(1570, 4545)\n",
      "Loaded LOC=1_lr=2e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(279, 2809)\n",
      "Loaded LOC=1_lr=2e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(3235, 2478)\n",
      "Loaded LOC=1_lr=2e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(5426, 4551)\n",
      "Loaded PD=0.02_lr=2e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(1570, 4545)\n",
      "Loaded PD=0.02_lr=2e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(279, 2809)\n",
      "Loaded PD=0.02_lr=2e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(3235, 2478)\n",
      "Loaded PD=0.02_lr=2e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(5426, 4551)\n",
      "Loaded R=0_PD=0.02_LOC=1_lr=2e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(1570, 4545)\n",
      "Loaded R=0_PD=0.02_LOC=1_lr=2e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(279, 2809)\n",
      "Loaded R=0_PD=0.02_LOC=1_lr=2e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(3235, 2478)\n",
      "Loaded R=0_PD=0.02_LOC=1_lr=2e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(5426, 4551)\n",
      "Loaded vanilla_lr=5e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(9373, 6263)\n",
      "Loaded vanilla_lr=5e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(8132, 8513)\n",
      "Loaded vanilla_lr=5e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(5955, 3002)\n",
      "Loaded vanilla_lr=5e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(9268, 6350)\n",
      "Loaded LOC=1_lr=5e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(5955, 3002)\n",
      "Loaded LOC=1_lr=5e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(8132, 8513)\n",
      "Loaded LOC=1_lr=5e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(9268, 6350)\n",
      "Loaded LOC=1_lr=5e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(9373, 6263)\n",
      "Loaded PD=0.005_lr=5e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(5955, 3002)\n",
      "Loaded PD=0.005_lr=5e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(8132, 8513)\n",
      "Loaded PD=0.005_lr=5e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(9268, 6350)\n",
      "Loaded PD=0.005_lr=5e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(9373, 6263)\n",
      "Loaded R=0_PD=0.005_LOC=1_lr=5e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(5955, 3002)\n",
      "Loaded R=0_PD=0.005_LOC=1_lr=5e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(8132, 8513)\n",
      "Loaded R=0_PD=0.005_LOC=1_lr=5e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(9268, 6350)\n",
      "Loaded R=0_PD=0.005_LOC=1_lr=5e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(9373, 6263)\n",
      "Loaded vanilla_lr=2e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(279, 2809)\n",
      "Loaded vanilla_lr=2e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(5426, 4551)\n",
      "Loaded vanilla_lr=2e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(3235, 2478)\n",
      "Loaded vanilla_lr=2e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(1570, 4545)\n",
      "Loaded LOC=1_lr=2e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(1570, 4545)\n",
      "Loaded LOC=1_lr=2e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(279, 2809)\n",
      "Loaded LOC=1_lr=2e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(3235, 2478)\n",
      "Loaded LOC=1_lr=2e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(5426, 4551)\n",
      "Loaded PD=0.005_lr=2e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(1570, 4545)\n",
      "Loaded PD=0.005_lr=2e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(279, 2809)\n",
      "Loaded PD=0.005_lr=2e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(3235, 2478)\n",
      "Loaded PD=0.005_lr=2e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(5426, 4551)\n",
      "Loaded R=0_PD=0.005_LOC=1_lr=2e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(1570, 4545)\n",
      "Loaded R=0_PD=0.005_LOC=1_lr=2e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(279, 2809)\n",
      "Loaded R=0_PD=0.005_LOC=1_lr=2e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(3235, 2478)\n",
      "Loaded R=0_PD=0.005_LOC=1_lr=2e-05_bs=1_epochs=180_pred-xu_scale0.1-add1_frozen-Wsq_(5426, 4551)\n"
     ]
    }
   ],
   "source": [
    "final_keys = ['vanilla', 'pd', 'loc', 'pd+loc']\n",
    "train_per_alpha = {}\n",
    "val_per_alpha = {}\n",
    "test_per_alpha = {}\n",
    "best_test_per_alpha = defaultdict(dict)\n",
    "problem_names_take = [p for p in problem_names if 'final' in p]\n",
    "\n",
    "for pn in problem_names_take:\n",
    "    experiment_names = sorted(os.listdir(path_to_problems + pn), key=lambda x: '0' if 'van' in x else x)\n",
    "    alpha = float(pn[pn.find('alp')+6: pn.find('ful')-1])\n",
    "    train_results_per_run = defaultdict(list)\n",
    "    val_results_per_run = defaultdict(list)\n",
    "    test_results_per_run = defaultdict(list)\n",
    "    for exp_name in experiment_names:\n",
    "        #if '95,' not in exp_name and '8945,' not in exp_name:\n",
    "        #    continue\n",
    "        try: \n",
    "            base_path = path_to_problems + '/%s/%s/' % (pn, exp_name)\n",
    "            with open(base_path + '/validate_history.pickle', 'rb') as f:\n",
    "                validate_history = pickle.load(f)\n",
    "            with open(base_path + '/training_history.pickle', 'rb') as f:\n",
    "                train_history = pickle.load(f)\n",
    "            with open(base_path + '/test_history.pickle', 'rb') as f:\n",
    "                test_history = pickle.load(f)\n",
    "            exp_name_no_seed = name_no_seed(exp_name)\n",
    "            train_results_per_run[exp_name_no_seed].append(train_history)\n",
    "            val_results_per_run[exp_name_no_seed].append(validate_history)\n",
    "            test_results_per_run[exp_name_no_seed].append(test_history)\n",
    "            print('Loaded %s' % exp_name)\n",
    "        except:\n",
    "            print('Could not load %s' % exp_name)\n",
    "    train_per_alpha[alpha] = dict(train_results_per_run)\n",
    "    val_per_alpha[alpha] = dict(val_results_per_run)\n",
    "    test_per_alpha[alpha] = dict(test_results_per_run)\n",
    "    keys = train_results_per_run.keys()\n",
    "    \n",
    "    for key in keys:\n",
    "        res = val_results_per_run[key]\n",
    "        y = []\n",
    "        for i, d in enumerate(res):\n",
    "            best_val_ind = np.argmin(d['regret'])\n",
    "            test_regret = test_results_per_run[key][i]['regret'][best_val_ind]\n",
    "            y.append(test_regret)\n",
    "        #print('alpha', alpha, key[:10], 'y', y)\n",
    "        best_test_per_alpha[alpha][key] = np.array(y)\n",
    "        "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 116,
   "id": "bbfb6e0d",
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA1UAAAKPCAYAAACFLeA7AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8vihELAAAACXBIWXMAAAsTAAALEwEAmpwYAADy+ElEQVR4nOzdd3jb1d3+8feR5D2y9x5kb5IQEshihL1SkgItFAo8vw4ooy3lgUIHBTqgBTqeAmUVaBP2JhBGyE6cQBYh09nLSex42xrn94dsRbJlWx6yPO7Xdfmy/B1HR07i6PY553OMtRYRERERERGpG0esOyAiIiIiItKcKVSJiIiIiIjUg0KViIiIiIhIPShUiYiIiIiI1INClYiIiIiISD0oVImIiIiIiNSDK9YdkOjq2LGj7du3b6y7ISIiIiLSLKxZs+aotbZTbe5RqGrh+vbtS0ZGRqy7ISIiIiLSLBhjdtf2Hk3/ExERERERqQeFKhERERERkXpQqBIREREREakHhSoREREREZF6UKgSERERERGpB4UqERERERGRelCoEhERERERqQeFKhERERERkXpQqBIREREREakHhSoREREREZF6UKgSERERERGpB4UqERERERGRelCoEhERERERqQeFKhERERERkXpQqBIREREREakHhSoREREREZF6cMW6A9LyPP3f9tWev/HbxxupJyIiIiIi0aeRKhERERERkXpQqBIREREREakHhSoREREREZF60JoqaXAV10w9/d/2WkclIiIiIi2WRqpERERERETqQaFKRERERESkHhSqRERERERE6kGhSkREREREpB4UqkREREREROpBoUpERERERKQeVFJdGtzLL78c8nUyfw05dvXVVzd2l0REREREokYjVSIiIiIiIvWgUCUiIiIiIlIPClVSL9t3vcI321/A53PHuisiIiIiIjGhNVVSL9t3zefA4UVkbHiA8SPvZVD/qyqtmXr6v+258dvHY9RDEREREZHo0kiV1JvPeiguOcqKr+7h5beGa+RKRERERFoVhSppMB5PgcKViIiIiLQ6ClXS4CqGK0DhSkRERERaLIUqiZrycAX4R652/FvhSkRERERaHIUqaRTFJUdZ8eX/KlyJiIiISIujUCWNJjAtUOFKRERERFoQhSppdApXIiIiItKSKFRJzJSHqyWrf8LajX+MdXdE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ci7O6eCP15zKrecN1fQnERERkQagUCVST7nbt7PiJz9h/4cfhj3fmFP9APKK3PzgXyt4aenOSucGdk3jv7dM49T+HRqlLyIiIiKtgUKVSB1FNNXvD3+gf5T3mwr2ZeYx5j7+BdsOVd6f4eop/fjHDZNIT45vlL6IiIiItBYq9SVSS9Zadr/1Fm+MGMG63/0u/Aa+t93GFZs3M+CaaxolUFlreeLDzUy67/1KgSop3sm/bp7Miz86U4FKRKSVefHFFzHGVPr4/PPPY921envggQfCvrZdu3bFumvSCmmkSqQWapzqd+aZTHriCdqPHNlofTqeX8IN/1zKWxl7K50b0ast826dxrCebRutPyIiDa20tJS33nqLN998k6+++ooDBw6Qn59PfHw87dq1o1+/fgwePJixY8cyadIkxo4di0NbRAAwbNgw7rzzTgA+/PBDNm2qvPF7c3X66acHXtu8efPYt29fjHskrZlClUgEPIWFrP/979nwhz80mal+AEu3HOGqJ75g77GCSuduPmsQf7l2Aknx+mcuIs3X4sWLuf7669mxYwcAo0eP5tJLL6Vt27aUlpayb98+VqxYwZIlSwL3tG3bltdff50ZM2ZUam/69OksWrQIgMzMTPr27dsoryNWxo0bx7hx4wA4evRoiwpVZ511FmeddRYAGRkZClUSU3q3JVINay173n6bVbffXmVVv6E//jFj77+f+DZtGq1fPp/l4bc3cN8rX+H12ZBz6UlxPHXTZOac3rfR+iMiEg1Lly7l3HPPpbi4mGHDhvHiiy8yduzYStd5PB5eeuklfvSjH1FQUEBOTg7Hjh2LQY9FpLVSqBKpQu727ay87Tb2ffBB2POxmOoHcCiniO/+bTELNx6sdG7CgA7895Zp9O+S1qh9EhGJhptvvpni4mISExP58MMP6dWrV9jrXC4X1113HR06dODiiy9u5F6KiChUiVRS41S/Ll38U/0aqQhFsI/W7+e7f1vCkdziSud+etFwfjd3LPEuZ6P2SUQkGr766iu+/vprwD9lr6pAFeyiiy5i/PjxZGRkRLt7IiIhFKpEygSm+t1xB/lhKgfFaqofgNvj475XvuThtzdWOtcxLYHnf3AGF4zt2ah9EhGJpm3btgUep6amRnzfWWedpVAlIo1OpXFEgNwdO1h48cV8esUVYQNVlzPO4JKMDE579NFG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IkFycnL49a9/zSOPPFKr+3r06BF4XN9CFbt27Qo87t+/+p/RwUUrGkt5+XGAjRs31nj99u3bqz0f/HprKioRzddrjAkJsDW9NmstO3fujFp/RCKhUCXNUt7OnSy85BI+uewy8jMzK53vPGUKl2RkMOkvfyGhbdvG72CQTzYeZPQv3mHB+gOVzt12/lCW/vp8BnbVAlsRkXC++eYbjh49GvH127ZtCzweN25cpfPlxR+gcjD44IMPeO655wJv0IMLSZw4caLa592zZ0/EfWwowSNJCxcurLZgxP79+2sstNGUXm/wa/vggw+qvXb58uVVVkgUaSwKVdKseIqK+PLXv+aNESPCrp1K7NyZM599lgsWLYr52imP18e989ZyzoMfcSinKORc+9QE3v7pTP587UQS4rS4VkSkKj6fj9/85jcRXfv555+zZs0aAIYNG8aECRMqXdOxY8fA44pTxu644w6uv/76wMjIpEmTAue++OKLwNS4ik6cONFglQZr45xzzgnsJ3X8+HGefPLJKq/905/+VGUVwXLBr/frr78OCajB3G43//3vf+vQ48h95zvfoVevXgBs2LCB96pYLw3+1yYSawpV0mzsfffdZjHVD2DvsQJm/HYBv3tzAxX/DztjcGe+evhiLj61V2w6JyLSzDzxxBP85Cc/qXI/JK/Xy7///W8uvfRSAJKSknjqqafC/l8QPK0suGT4xo0b2bJlCw6HIxBULrvsskBFwby8PK688koOHjwY0l52djazZ8/m+PHj9XuRdWCM4bnnnguUKv/Zz37G+2H2Zfz73//O448/HjI1MpyJEycyffp0wD+lbu7cuZWCVVFREddffz1btmxpmBdRheTkZJ599tnAhsbXX389q1evDrnG4/Fwzz338M4770RUdl0kmkxNv7WQ5m38+PE2IyMjpn2ob6GKvJ07WXn77ex9992w55tKVb9yb2fs4fp/LuN4foXgZ+Cey0Zx/+zRuJz6fYZILK1Zs4ZTTz011t2Qahw/fpzZs2ezePHiQGW3+Ph4Jk6cyODBg0lLS6OkpIS9e/eyYsWKwBTBoUOH8vTTTzN58uQq2x0+fDiHDh0iISGBK6+8kri4ON566y2OHz/O//zP//B///d/geu3bNnCeeedF1hvlJaWxtSpU+nXrx9ZWVl8+OGHOJ1ORo0axeeffw7AeeedF9iwtnwU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hVlsbKyrq0B22rRpkwAQABIcHGwzfa9evbT0vr6+kpqamiVNVFSUlqZbt25Sp04diYuLM0kzbdo0ASBt2rQx2T5y5Ejt2F69esmdO3dM9l++fFlatWolAEQpJbNmzbJa3+y8N2f5888/pVixYgJAAgMDZffu3Sb7Hzx4ICNHjpSgoCB57LHHtDqeOXPGYp5z5szR0o0fP95smhdffFE7L7t27cqy/8SJE/LEE09Y/TyM20NUVJRd77devXoCQNq3by/Xr1832ZeRkSELFiwQb29vrT3Y0qZNG60OXbp0kWeffVaSk5NN0ixYsEBL065dO6v5zZgxQ0v79NNPy9WrV032P3jwQL755htxc3MTANKoUSOz+UyfPl3LJzIyUm7dumWyPzExUSIjI7U03377rc33WlA5+h0PIFayec3Nnipyusz3TKmX5mWZvMKa5JQHePs/O/Hj1tNZ9lUv54NFw9ogPDTA4XoSEdnj37+UcXUV8pXX+9x0dRUsWrduHZYuXaq9/vDDD+Hp6Wn1mDVr1uDgwYOoXr26yfaXX345y8QLK1euxJQpUwAADRs2xIIFC+Dh4WGSpnz58vj9999Rq1YtXLt2DUOGDEHTpk3RsGFDR96a09y9exevvfYa0vV/q+fNm6f1mhm4u7tj8uTJOHbsGH7//XenlHv16lUsW7YMANCrVy80adIkS5qaNWti4cKFqFu3rlPKNObl5YXFixejTBnT/89KKfTt2xc3btzAO++8g5UrV2LDhg3ac7ps2b9/P06ePImSJUuabO/bty+mTZuGffv2YdOmTYiPjzc7xHPPnj147733AAAVKlTA8uXLUaqU6fM13d3dMWzYMJw/f97iIwX27NmjtdcaNWpg0aJFWYbCli5dGr/88gsee+wxnD17FtHR0ejSpUuWtk85w5tQKF/ZH38TYaNWmg2oejcPwd5JkQyoiIhIk5KSgsOHD2P06NHo1q0bMjIyAOguakeOHGnz+GeeecbsRXxgYCDOnz+PJUuWANCN7Bk9erS2/6OPPsoSUBmULl0aQ4cOBQCkpqZavccory1YsEAbutaoUSN06dLFYtoRI0Y4rdzTp09r56aYmQmtDOrUqYMWLVogNDTUaWW/+eabmD59epaAytiLL76orRvOuT369++fJaAyaN26tba+a9cus2nGjRuHhw8fAgDefffdLAGVscGD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GX755Re8+OKLuHbtGjp06AA/Pz+0adMGjRs3xqpVq7B+/XqsX78eX3/9Nd555x2b72HDhg14+eWXkZCQAE9PT7Rv3x6hoaG4desW1q9fj2nTpuGbb77B8OHDMXHiRLi5Wf793pG8/Pz8EB0dDQBYs2aNFoj26tULVapUMSknNDTU5vvatWsXIiMjERISgqeffhppaWnYuHEj/v77b/z999/4888/8dtvv0EpleVYS+fG3nTmyl6/fr1dZRsbOXIkvvjiC4gISpYsiW7duqFSpUq4dOkSpk2bhu+++w5//PGHlt7X11ebWr5169Y2PyOyQUS4FOIlLCxMiIjIVGxsrKurQHY6e/asADBZmjRpIsePH3d11bLtxRdfFADi6+sru3btyrL/xIkT8sQTTwgACQ4ONpvHmTNntM+hYcOGUq1aNVmxYkWWNAEBAQJAvLy85PLly9KxY0dZtmyZSbqrV69K9erVBYB4enrKmTNnrNb/999/F3d3dwEg9evXl7i4OJP9qampMmTIEK1+/fr1y5O8oqKitHSbNm2y+h4MMn+OVatWlR9//DFLHSIjI7V08+bNszvPNm3aOFx2165d7S577NixWtrmzZtLQkKCyf7r169LRESEVKxYUUtnqY05W3BwsACQqKioPClPxPHveACxks1rbpdf9HPJ3YVBFRFRVgyqCo7ly5ebBFTNmjWTu3fvurpa2XblyhVxc3MTAPL6669bTHfs2DG7gyoAMnLkSLPpxo8fr6Vp0aKFDB8+3Gy677//Xks3YcIEi/U6f/68lC5dWgCIt7e3xMfHm02XkZEhHTt21PL87rvvcjUvEceDKgAybNgws+kOHTqkpWnbtq3dedobVFkr+8CBA3aVvWfPHilWrJgAkFKlSsmVK1fMprtz5w6DKjvlJKjiPVVERESUbxnfT1WiRAksWbIEJUqUcGGNcub06dPIyMgAABQrVsxiujp16qBFixZ2DVkDdEPKzGnVqpW2vn37drz55ptm0xnf+7Nz506L5UyZMkW7J+eVV15BcHCw2XRKKYwZM0Z7/cknnyA1NTXX8nKWwYMHm91ev359+Pv7AwB2794N3fV23pTdsGFDlC5d2mbZX3zxBdLT0wEAr776KsqVK2c2nY+PD95++23HK0xm8Z4qIiIiyrcM91MBwJAhQ7LcL5MdH330Ef773/86oVY6n3zy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aKpfXywiSw07RCRFKXUcj6a3bwTdc7aIiPINTlRBRES5xbgXygOPnl/VB7ogaZ6IPLSRRzMAofr1hwBmOrWG1hnfA1bMSjofO/I6l+l1oNlUzpW5THuGEBqnyXx8rlBK1Qbwif7lVegmp8hsv9E6J6sgonyHQRUREeUKETkGYKfRptcy/WvPs6lCjNavikiylbTO/pt212i9pMVUpnW05BAezawH2BEYKKWClVJjlFKj9Q/oza7MZVq9H0nfK2j8sOMtOSgzW/Rl/ge6yTgAYJCFoX37jdZ5XxUR5TsMqoiIKDcZB051lVIDoet92ioiJ+w43jiwKaWsz+7g7IkVLtiZt82H8+pnPvzRaFNPO8ofCmACgOdyMlRQX+YCo02RNg5pCcBfv34JgK0p7J1hGIAW+vWfReRXC+n2G60zqCKifIdBFRER5aZFMA2MZuj/taeXCgB2QTexA6B7qO/TVtL2s7IvJ/42Wm9pLoFSqhKA7nbm9zmAW/r1V5RSNS0lVEqF4lGP3jQ787enzGAraccarX9i58QWOaZ/jxP1L69AF0Rast9o/TH986yIiPINBlVERJRrROQOgCVGm7ygm0Bhifkjshx/GcB8o02zlVLhxmmUUu5KqSkA2jtY3cy2ADitX39OKfVkpnLLAlgMYKM9mYnIRegeAPwAus9hjVLq8czplFJhAFZB94yplQB+zln1ARG5AN29bA+hG2K3UilVPVN5nkqp6QAi9JsWiMgPOS3THvoex9kASug3vSUiNyyl1w8JvKh/6QXddPxERPmGsvIQeyIiIofpp0TfarTpexF5KxvHlwTwGx4FTRnQBTzHoZsAoz10z8JaCaCHPs0R6KZhB3STW9wEMFr/uh6Azvr1HQC2G9KJSFymsltDNxV8CegCkzXQBVqBALoAWAZgIR4FVsbl/iIisWbeTzvohuVV1L+X7dBNG+4JXbDQAroZAhcD6G88bXxOKaXa68sMApAGYL3+ffhB9+yvCvr3Nw26mQkzMh0/CkAZ6KZpH6jffAG6nkiDtSKy1s76DAbwrf7lQhGx2cuolFqJR88+6ysiP9lTFhFRXmBQRUREuU4p9Q8e9S40FZHd2TzeDcD/g26I3xPQ3ftzH8BZAP8D8H/QPRPL3HOq2gGIB3DGRjHtRGSzmbLrAvhQn0956KYa3w/gOxH51crzsQaIyFwL78cbwKvQDR1sACAAuh6s89AFenNF5H826pstSqkS0A0pjNSXWRa6oZlnoQuyfrB0n5tSKh6AtaGDgG7I4Md21CMEukk0fABcBlBPRG7acdxneBQYTxGRD20dQ0SUVxhUEREREREROYD3VBERERERETmAQRUREREREZEDGFQRERERERE5gEEVERERERGRAxhUEREREREROYBBFRERERERkQMYVBERERERETmAQRUREREREZEDGFQRERERERE5gEEVERERERGRAxhUEREREREROYBBFRERERERkQMYVBERERERETng/wMIjQekUz5f4wAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 720x576 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "plt.rc('font', family='serif')\n",
    "colors = ['#887AE6', '#F6AE43', '#10026E', '#A44700']\n",
    "#colors = ['#8A88AC', '#957964', '#10026E', '#AC400A']\n",
    "colors = ['#A5A5A5', '#9BA711', '#0058A0', '#9E0202']\n",
    "methods_ordered = ['vanilla', 'pd', 'loc', 'pd+loc']\n",
    "color_dict = {'vanilla': colors[0],\n",
    "              'pd': colors[1],\n",
    "              'loc': colors[2],\n",
    "              'pd+loc': colors[3],\n",
    "             }\n",
    "name_dict = {'vanilla': 'Standard',\n",
    "              'pd': 'Proj. distance',\n",
    "              'loc': '$r-$smoothing',\n",
    "              'pd+loc':  '$r-$smoothing + \\nproj.distance',\n",
    "             }\n",
    "plot_name = 'lambdas'\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(10, 8))\n",
    "alphas = sorted(list(best_test_per_alpha.keys()))[:]\n",
    "y_per_key = defaultdict(list)\n",
    "for alpha in alphas:\n",
    "    for key, y in best_test_per_alpha[alpha].items():\n",
    "        if 'vanil' in key:\n",
    "            name = 'vanilla'\n",
    "        elif 'LOC' in key and 'PD' in key:\n",
    "            name = 'pd+loc'\n",
    "        elif 'LOC' in key:\n",
    "            name = 'loc'\n",
    "        else:\n",
    "            name = 'pd'\n",
    "        #name = name_dict[name]\n",
    "        y_per_key[name].append(y)\n",
    "\n",
    "markers = ['^', '>', 'v', '<']\n",
    "for name, marker in zip(methods_ordered, markers):\n",
    "    c = color_dict[name]\n",
    "    mean = np.array([np.mean(v) for v in y_per_key[name]])\n",
    "    std = np.array([np.std(v) for v in y_per_key[name]])\n",
    "    m = '-' if 'loc' in name else '--'\n",
    "    m = '-'\n",
    "    p = ax.plot(range(len(alphas)), mean, m, label=name_dict[name], linewidth=4, c=c)\n",
    "    #ax.fill_between(range(len(alphas)), mean - std, mean + std, color=p[0].get_color(), alpha=0.2)\n",
    "    ax.scatter(range(len(alphas)), mean,  marker=marker, s=300, color=p[0].get_color())\n",
    "    ax.errorbar(range(len(alphas)), mean, std, c=c, fmt='none', elinewidth=1, capsize=4, capthick=4)\n",
    "    \n",
    "leg = ax.legend(loc='lower right', prop={'size': 32}, fancybox=True, framealpha=1)\n",
    "_ = ax.set_xlabel('Value of $\\lambda$', fontsize=32)\n",
    "_ = ax.set_ylabel('Regret', rotation=0, fontsize=32)\n",
    "_ = plt.xticks(range(len(alphas)), ['$\\lambda$=%s' %a for a in alphas], fontsize=25)\n",
    "#ax.set_xticklabels(map(str, ax.get_xticks()), fontsize=18)\n",
    "ax.set_yticks([0.01, 0.02, 0.03, .04, 0.05])\n",
    "ax.set_yticklabels(map(lambda x: np.round(x, 4), ax.get_yticks()), fontsize=25)\n",
    "ax.yaxis.set_label_coords(-.08, 0.5)\n",
    "fig.gca().set_position([0, 0, 1, 1])\n",
    "#plt.locator_params(axis='both', nbins=len(alphas))\n",
    "name = 'lambdas'\n",
    "#plt.gca().set_position([0, 0, 1, 1])\n",
    "plt.savefig(name + '.svg')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "09b10077",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[0.0, 0.1, 0.25, 0.5, 1.0, 2.0]"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "alphas"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "e7536683",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'pd'"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "name"
   ]
  }
 ],
 "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.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
