{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Main notebook for testing Mean-Reg-MTL\n",
    "\n",
    "## 0. Load packages\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[INFO] running on GPU core 2\n"
     ]
    }
   ],
   "source": [
    "import os, sys, math, copy, torch, scipy, pickle\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "from numpy import random\n",
    "from numpy import matlib as mb\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "\n",
    "BASE_DIR = os.path.dirname(os.path.dirname(os.getcwd()))\n",
    "sys.path.insert(1, BASE_DIR)\n",
    "\n",
    "import config\n",
    "config.init()\n",
    "from config import device\n",
    "\n",
    "random_seed = 5\n",
    "random.seed(random_seed)\n",
    "np.random.seed(random_seed)\n",
    "random_state = np.random.RandomState(random_seed)\n",
    "\n",
    "if torch.cuda.is_available() and not str(device)=='cpu':\n",
    "    print('[INFO] running on GPU core ' + str(torch.cuda.current_device()))\n",
    "else:\n",
    "    print('[WARN] running on CPU')\n",
    "\n",
    "sys.path.append(os.getcwd()+'/assistive_functions')\n",
    "\n",
    "from household import Household, SyNet\n",
    "from server.MTL_server import *\n",
    "\n",
    "# from utils_households import get_lags, connect_to_households\n",
    "# from load_data import get_data_of_a_person"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## 1. Load data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[INFO] loaded data for 24 clients\n",
      "\n",
      "24 households at Lausanne - tilt_std: 5.0, az_std: 15.0, weather_dev: 0.1, irrad_std: 0.2, altitude_dev: 0.1, shadow_peak_red: 0.8, different module_name, different inverter_name, \n",
      "Subset of clients for demonstration:  [12, 14, 15, 17, 22]\n",
      "\n",
      "[INFO] 15 features:  H_sun T2m WS10m station_irrad_direct_prev lag 1 lag 2 lag 4 lag 18 lag 20 lag 22 lag 43 lag 70 lag 74 lag 121 lag 145\n"
     ]
    }
   ],
   "source": [
    "exp_name = 'PV_BiModal'  \n",
    "save = False\n",
    "\n",
    "# ------ LOAD DATA ------\n",
    "# NOTE: env generated in notebook 1_visualization\n",
    "filename_env = config.PVDATA_DIR + '/'+ exp_name+\"_env\"\n",
    "file = open(filename_env, 'rb')\n",
    "env_dict = pickle.load(file)\n",
    "msg = '[INFO] loaded data for {:2.0f} clients'.format(env_dict['num_clients'])\n",
    "print(msg)\n",
    "file.close()\n",
    "num_clients = env_dict['num_clients'] \n",
    "print('\\n'+env_dict['info'])\n",
    "\n",
    "# ----- SELECT A SUBSET OF CLIENTS -----\n",
    "clients_subset= [12, 14, 15, 17, 22]\n",
    "print('Subset of clients for demonstration: ', clients_subset)\n",
    "\n",
    "num_features = len(env_dict['feature_names'])\n",
    "print('\\n[INFO] {:2.0f} features: '.format(\n",
    "    len(env_dict['feature_names'])), *env_dict['feature_names'])\n",
    "    "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# 2. Run"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "# search space\n",
    "models_MTL = {\n",
    "    'sml': {'trained_lambda':None, 'trained_w_0':None}, \n",
    "    '1y': {'trained_lambda':None, 'trained_w_0':None}\n",
    "}\n",
    "results_MTL = {\n",
    "    'sml': {'rsmse': {'criterion_train': np.zeros(num_clients), 'criterion_valid': np.zeros(num_clients)}}, \n",
    "    '1y': {'rsmse': {'criterion_train': np.zeros(num_clients), 'criterion_valid': np.zeros(num_clients)}}\n",
    "}\n",
    "log_lambdas = np.linspace(-3, 3, 40)\n",
    "lambdas = pow(10, log_lambdas)\n",
    "lr=0.1\n",
    "inner_iters=1\n",
    "outer_iters=100\n",
    "valid_frac=0.2\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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B5ibm6Nhw4YYPHgwACAlJQWOjo4AgJkzZypvAX7xxRdV/eMQURUSPeJUltq1a2vqVEREWjVixAisXr0a4eHh+Oijj3Djxg18//33OHPmDA4fPgwTExPcvn0bb7/9NhwdHTF16lTY2toiJSUFMTExAABHR0f8+OOPGDVqFHr27InQ0FAAil8uichwqVU42dnZQSKRqHXC+/fvv1BCRETadOjQIfz8889Yv349+vXrp9zfqVMnBAUFYcuWLejXrx+OHDmCBw8eYN++fWjTpo0ybtasWQCAl156Ce+++y5GjRqFli1b8lYgUQ2hVuEUGRmp/O979+5h1qxZCAwMRLt27QAAR48exd69ezFt2jStJElEpClbtmyBjY0N3nrrLZUngVu3bg1LS0scOHAA/fr1g62tLQBg165deOWVV2BiYqKjjIlIn6hVOIWFhSn/u1evXvjyyy8xZswY5b6PPvoI33//Pf744w9MmDBB81kSEWnIlStXkJOTAycnp1Jfv337NgDA398fvXr1wsyZM7Fo0SIEBASgR48e6NevH8zMzKoyZSLSI6LnOO3duxfz5s0rsT8oKAhTp07VSFJERNoil8vh5OSE9evXl/p68YRviUSCrVu34tixY9i5cyf27t2LwYMH49tvv8WxY8dgaWlZlWkTkZ4QXTjVqVMHO3bswKRJk1T279ixA3Xq1NFYYkRE2tC4cWP88ccfaN++PczNzSuM/9///of//e9/+Prrr7Fhwwb0798fmzZtwtChQ9We+0lEhkN04TRz5kwMHToU8fHx8PX1BQAcP34csbGxWL58ucYTJCLSpN69e+OHH37AV199hdmzZ6u89uTJE+Tl5cHW1hYPHjyAra2tSnFUvNzU48ePAQAWFhYAgOzs7CrJnYh0T3ThNGjQIHh5eWHx4sXKx3K9vLxw6NAhZSFFRKSv/P39MWLECMyZMwdnz57F22+/DRMTE1y5cgVbtmxBVFQU3n33XaxZswY//PADevbsicaNGyM3NxfLly+HtbW1cqkpc3NzeHt7Y/Pmzfi///s/2Nvb4+WXX8bLL7+s45+SiLSlUn2cfH19y5wfQESk75YuXYrWrVtj2bJliIiIQK1ateDh4YEBAwagffv2ABQF1okTJ7Bp0yZkZWXBxsYGbdu2xfr169GwYUPluX7++WeMHTsWEyZMQGFhIWbMmMHCiciA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",
      "text/plain": [
       "<Figure size 600x600 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 600x600 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for scenario_name_fl in ['sml', '1y']:\n",
    "    # 1. define households\n",
    "    clients_data = env_dict['train_scenarios'][scenario_name_fl]['clients_data']\n",
    "    clients_ts = env_dict['train_scenarios'][scenario_name_fl]['time_series']\n",
    "    households = []\n",
    "    for client_num in np.arange(num_clients):\n",
    "        h = Household(\n",
    "            clients_data[client_num], clients_ts[client_num], normalize_data=True, random_seed=random_seed)\n",
    "        h.train_valid_split(valid_frac=valid_frac)\n",
    "        households.append(h)\n",
    "\n",
    "    \n",
    "    # 2. initialize \n",
    "    rsmse_w_n_trn = np.zeros((len(households), len(lambdas)))\n",
    "    rsmse_w_n_vld = np.zeros((len(households), len(lambdas)))\n",
    "    rsmse_w_n_tst = np.zeros((len(households), len(lambdas)))\n",
    "    rsmse_w_0_trn = np.zeros((len(households), len(lambdas)))\n",
    "    rsmse_w_0_vld = np.zeros((len(households), len(lambdas)))\n",
    "    rsmse_w_0_tst = np.zeros((len(households), len(lambdas)))\n",
    "\n",
    "\n",
    "    # 3. grid search lambda\n",
    "    min_rsmse_vld = 1e4\n",
    "    for l_ind, lambda_ in enumerate(lambdas): \n",
    "        # train\n",
    "        result = mtl_train(\n",
    "            households, lr=lr, lambda_=lambda_, \n",
    "            inner_iters=inner_iters, outer_iters=outer_iters, \n",
    "            optim_method='Adam', verbose=False, priv=False,\n",
    "            random_seed=random_seed)\n",
    "        w_0=result['w_0']\n",
    "        init_state_dict=result['init_state_dicts']\n",
    "        # predict\n",
    "        for h_ind, household in enumerate(households): \n",
    "            # predict with w_n \n",
    "            pred_w_n_trn = household.predict(household.X_train, method='MTL').flatten()\n",
    "            pred_w_n_vld = household.predict(household.X_valid,  method='MTL').flatten()\n",
    "            pred_w_n_tst = household.predict(household.X_test,  method='MTL').flatten()\n",
    "            # predict with w_0\n",
    "            pred_w_0_trn = household.predict(household.X_train, method='MTL', model=w_0).flatten()\n",
    "            pred_w_0_vld = household.predict(household.X_valid, method='MTL', model=w_0).flatten()\n",
    "            pred_w_0_tst = household.predict(household.X_test,  method='MTL', model=w_0).flatten()\n",
    "            # errors of w_n\n",
    "            rsmse_w_n_trn[h_ind, l_ind] = (np.mean(\n",
    "                    (pred_w_n_trn-household.y_train.detach().numpy().flatten())**2\n",
    "                )**0.5)/np.std(household.y_train.detach().numpy().flatten())\n",
    "            rsmse_w_n_vld[h_ind, l_ind] = (\n",
    "                    np.mean((pred_w_n_vld-household.y_valid.detach().numpy().flatten())**2\n",
    "                )**0.5)/np.std(household.y_valid.detach().numpy().flatten())\n",
    "            rsmse_w_n_tst[h_ind, l_ind] = (\n",
    "                    np.mean((pred_w_n_tst-household.y_test.detach().numpy().flatten())**2\n",
    "                )**0.5)/np.std(household.y_test.detach().numpy().flatten())\n",
    "            # errors of w_0\n",
    "            rsmse_w_0_trn[h_ind, l_ind] = (\n",
    "                    np.mean((pred_w_0_trn-household.y_train.detach().numpy().flatten())**2\n",
    "                )**0.5)/np.std(household.y_train.detach().numpy().flatten())\n",
    "            rsmse_w_0_vld[h_ind, l_ind] = (\n",
    "                    np.mean((pred_w_0_vld-household.y_valid.detach().numpy().flatten())**2\n",
    "                )**0.5)/np.std(household.y_valid.detach().numpy().flatten())\n",
    "            rsmse_w_0_tst[h_ind, l_ind] = (\n",
    "                    np.mean((pred_w_0_tst-household.y_test.detach().numpy().flatten()\n",
    "                )**2)**0.5 )/np.std(household.y_test.detach().numpy().flatten())\n",
    "        # update best_w_0\n",
    "        if np.mean(rsmse_w_n_vld[:, l_ind].flatten()) < min_rsmse_vld:\n",
    "            min_rsmse_vld = np.mean(rsmse_w_n_vld[:, l_ind].flatten())\n",
    "            models_MTL[scenario_name_fl]['trained_w_0'] = w_0\n",
    "            models_MTL[scenario_name_fl]['trained_lambda'] = lambdas[l_ind]\n",
    "\n",
    "\n",
    "    # 4. compute error metrics\n",
    "    rsmse_w_n_trn_av = np.mean(rsmse_w_n_trn, axis=0)\n",
    "    rsmse_w_n_vld_av = np.mean(rsmse_w_n_vld, axis=0)\n",
    "    rsmse_w_n_tst_av = np.mean(rsmse_w_n_tst, axis=0)\n",
    "    rsmse_w_0_trn_av = np.mean(rsmse_w_0_trn, axis=0)\n",
    "    rsmse_w_0_vld_av = np.mean(rsmse_w_0_vld, axis=0)\n",
    "    rsmse_w_0_tst_av = np.mean(rsmse_w_0_tst, axis=0)\n",
    "    rsmse_w_n_trn_sd = np.var(rsmse_w_n_trn, axis=0)**0.5\n",
    "    rsmse_w_n_vld_sd = np.var(rsmse_w_n_vld, axis=0)**0.5\n",
    "    rsmse_w_n_tst_sd = np.var(rsmse_w_n_tst, axis=0)**0.5\n",
    "    rsmse_w_0_trn_sd = np.var(rsmse_w_0_trn, axis=0)**0.5\n",
    "    rsmse_w_0_vld_sd = np.var(rsmse_w_0_vld, axis=0)**0.5\n",
    "    rsmse_w_0_tst_sd = np.var(rsmse_w_0_tst, axis=0)**0.5\n",
    "\n",
    "\n",
    "    # 5. Plot\n",
    "    xx = log_lambdas\n",
    "    fig,axs = plt.subplots(3,1,figsize=(6,6))\n",
    "    axs[0].scatter(xx, rsmse_w_n_trn_av, color='orange', label='w_n')\n",
    "    axs[0].scatter(xx, rsmse_w_0_trn_av, color='purple', label='w_0')\n",
    "    #axs[0].fill_between(xx, mse_w_0_trn_av-1.96*mse_w_0_trn_sd, mse_w_0_trn_av+1.96*mse_w_0_trn_sd,alpha=0.2, color='purple')\n",
    "    axs[0].set_title('Train')\n",
    "    axs[2].scatter(xx, rsmse_w_n_vld_av, color='orange', label='w_n')\n",
    "    axs[2].scatter(xx, rsmse_w_0_vld_av, color='purple', label='w_0')\n",
    "    #axs[2].fill_between(xx, mse_w_0_vld_av-1.96*mse_w_0_vld_sd, mse_w_0_vld_av+1.96*mse_w_0_vld_sd,alpha=0.2, color='purple')\n",
    "    axs[2].set_title('Valid')\n",
    "    axs[1].scatter(xx, rsmse_w_n_tst_av, color='orange', label='w_n')\n",
    "    axs[1].scatter(xx, rsmse_w_0_tst_av, color='purple', label='w_0')\n",
    "    #axs[1].fill_between(xx, mse_w_0_tst_av-1.96*mse_w_0_tst_sd, mse_w_0_tst_av+1.96*mse_w_0_tst_sd,alpha=0.2, color='purple')\n",
    "    axs[1].set_title('Test')\n",
    "    for ax in axs:\n",
    "        ax.legend()\n",
    "        ax.set_xlabel('log(lambda)')\n",
    "        ax.set_ylabel('RSMSE over households')\n",
    "    plt.tight_layout()\n",
    "    plt.show()\n",
    "\n",
    "\n",
    "    # 6. best lambda\n",
    "    best_l_ind = np.argmin(rsmse_w_n_vld_av)\n",
    "    assert models_MTL[scenario_name_fl]['trained_lambda'] == lambdas[best_l_ind]\n",
    "\n",
    "\n",
    "    # 7. results\n",
    "    results_MTL[scenario_name_fl]['rsmse']['criterion_train'] = (1-valid_frac) * rsmse_w_n_trn[:, best_l_ind].flatten() + valid_frac * rsmse_w_n_vld[:, best_l_ind].flatten()\n",
    "    results_MTL[scenario_name_fl]['rsmse']['criterion_valid'] = rsmse_w_n_tst[:, best_l_ind].flatten() # this is called valid in other notebooks\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "run_cell = False\n",
    "if run_cell:\n",
    "\n",
    "    plt.rc('font', family='serif')\n",
    "    plt.rc('xtick', labelsize='x-small')\n",
    "    plt.rc('ytick', labelsize='x-small')\n",
    "\n",
    "    ## convergence \n",
    "    # params\n",
    "    log_lambda = 1.1\n",
    "    lambda_ = pow(10, log_lambda)\n",
    "    inner_iters=1\n",
    "    outer_iters = 50\n",
    "    # train\n",
    "    result = mtl_train(households, lr=lr, lambda_=lambda_, \n",
    "            inner_iters=inner_iters, outer_iters=outer_iters, \n",
    "            optim_method='Adam', verbose=False)\n",
    "    g_norm=result['g_norm']\n",
    "    g_clipped_norm=result['g_clipped_norm']\n",
    "\n",
    "    fig,ax = plt.subplots(figsize=(8,6))\n",
    "    for hh_num, household in enumerate(households):\n",
    "        ax.plot(np.arange(1,outer_iters+1), g_norm[:][hh_num])\n",
    "\n",
    "    ax.set_xlabel('iteration', fontsize=16)\n",
    "    ax.set_ylabel('norm of update', fontsize=16)\n",
    "    ax.set_title('Norm of Update from Households - Not Private', fontsize=18)\n",
    "    ax.tick_params(axis='both', which='major', labelsize=14)\n",
    "    ax.tick_params(axis='both', which='minor', labelsize=12)\n",
    "    plt.tight_layout()\n",
    "    # plt.savefig('output/norm_update_allhh.png')\n",
    "    plt.show() "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# New Clients"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[INFO] loaded data for 24 clients\n",
      "\n",
      "24 households at Lausanne - tilt_std: 5.0, az_std: 15.0, weather_dev: 0.1, irrad_std: 0.2, altitude_dev: 0.1, shadow_peak_red: 0.8, different module_name, different inverter_name, \n",
      "sml has 150 train and 610 validation samples\n",
      "1y has 610 train and 610 validation samples\n",
      "5y has 3050 train and 610 validation samples\n",
      "14y has 8540 train and 610 validation samples\n",
      "\n",
      "[INFO] 15 features:  H_sun T2m WS10m station_irrad_direct_prev lag 1 lag 2 lag 4 lag 18 lag 20 lag 22 lag 43 lag 70 lag 74 lag 121 lag 145\n"
     ]
    }
   ],
   "source": [
    "exp_name_ptc = exp_name\n",
    "exp_name_new = exp_name_ptc + '_NewClients'\n",
    "\n",
    "\n",
    "# ----- SET UP LOGGER -----\n",
    "filename_env_new = config.PVDATA_DIR + '/'+ exp_name_ptc +\"_new_clients_env\"\n",
    "filename_res_new = os.path.join(os.getcwd(), \"saved_results\", exp_name_new)\n",
    "\n",
    "\n",
    "# ------ LOAD META_TEST DATA ------\n",
    "file = open(filename_env_new, 'rb')\n",
    "env_dict_new = pickle.load(file)\n",
    "msg = '[INFO] loaded data for {:2.0f} clients'.format(env_dict_new['num_clients'])\n",
    "print(msg)\n",
    "file.close()\n",
    "num_clients_new = env_dict_new['num_clients'] \n",
    "print('\\n'+env_dict_new['info'])\n",
    "\n",
    "\n",
    "for scenario_name in env_dict_new['train_scenarios'].keys():\n",
    "    print(scenario_name + ' has {:3.0f} train and {:3.0f} validation samples'.format(\n",
    "        env_dict_new['train_scenarios'][scenario_name]['clients_data'][0][0].shape[0],\n",
    "        env_dict_new['train_scenarios'][scenario_name]['clients_data'][0][2].shape[0]))\n",
    "num_features = len(env_dict_new['feature_names'])\n",
    "print('\\n[INFO] {:2.0f} features: '.format(\n",
    "    len(env_dict_new['feature_names'])), *env_dict_new['feature_names'])\n",
    "\n",
    "# visualize_env(env_dict_new, num_days=5, year=2018, scenario_name='1y')\n",
    "\n",
    "\n",
    "clients_data_new = env_dict_new['train_scenarios']['sml']['clients_data']\n",
    "clients_ts_new = env_dict_new['train_scenarios']['sml']['time_series']\n",
    "households_new = []\n",
    "for client_num in np.arange(num_clients_new):\n",
    "    h = Household(\n",
    "        clients_data_new[client_num], clients_ts_new[client_num], normalize_data=True, random_seed=random_seed)\n",
    "    h.train_valid_split(valid_frac=0.2)\n",
    "    households_new.append(h)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "results_new = {\n",
    "    'sml': {'rsmse': {'criterion_train': np.zeros((len(households))), 'criterion_valid': np.zeros((len(households)))}},\n",
    "    '1y': {'rsmse': {'criterion_train': np.zeros((len(households))), 'criterion_valid': np.zeros((len(households)))}}\n",
    "}\n",
    "\n",
    "for scenario_name_fl in ['sml', '1y']:\n",
    "    # train\n",
    "    mtl_employ(\n",
    "        households_new, lr=lr, num_iters=inner_iters*outer_iters, \n",
    "        trained_lambda=models_MTL[scenario_name_fl]['trained_lambda'], \n",
    "        trained_w_0=models_MTL[scenario_name_fl]['trained_w_0'],\n",
    "        random_seed=random_seed\n",
    "    )\n",
    "    \n",
    "    # evaluate\n",
    "    for h_ind, household in enumerate(households_new): \n",
    "        # predict with w_n \n",
    "        pred_w_n_trn = household.predict(household.X_train, method='MTL').flatten()\n",
    "        pred_w_n_vld = household.predict(household.X_valid,  method='MTL').flatten()\n",
    "        pred_w_n_tst = household.predict(household.X_test,  method='MTL').flatten()\n",
    "        rsmse_trn = (np.mean((pred_w_n_trn-household.y_train.detach().numpy().flatten())**2\n",
    "            )**0.5)/np.std(household.y_train.detach().numpy().flatten())\n",
    "        rsmse_vld = (np.mean((pred_w_n_vld-household.y_valid.detach().numpy().flatten())**2\n",
    "            )**0.5)/np.std(household.y_valid.detach().numpy().flatten())\n",
    "        rsmse_tst = (np.mean((pred_w_n_tst-household.y_test.detach().numpy().flatten())**2\n",
    "            )**0.5)/np.std(household.y_test.detach().numpy().flatten())\n",
    "        results_new[scenario_name_fl]['rsmse']['criterion_train'][h_ind] = (1-valid_frac)*rsmse_trn + valid_frac*rsmse_vld\n",
    "        results_new[scenario_name_fl]['rsmse']['criterion_valid'][h_ind] = rsmse_tst\n",
    "                "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "--- results with random seed =  5 ---\n",
      "\n",
      "existing -  sml :  0.4451800920346521\n",
      "new -  sml :  0.4400961464769073\n",
      "\n",
      "existing -  1y :  0.44614641671272254\n",
      "new -  1y :  0.4473213705370877\n"
     ]
    }
   ],
   "source": [
    "print('--- results with random seed = {:2.0f} ---'.format(random_seed))\n",
    "for scenario_name_fl in ['sml', '1y']:\n",
    "    print('\\nexisting - ', scenario_name_fl, ': ', np.mean(results_MTL[scenario_name_fl]['rsmse']['criterion_valid']))\n",
    "    print('new - ', scenario_name_fl, ': ', np.mean(results_new[scenario_name_fl]['rsmse']['criterion_valid']))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "models saved.\n"
     ]
    }
   ],
   "source": [
    "filename_save = os.path.join(BASE_DIR, 'experiments', 'PV', 'saved_results', exp_name, 'MTL', 'MTL')\n",
    "if save:\n",
    "    file = open(filename_save, 'wb')\n",
    "    pickle.dump({'results': results_MTL, 'models':models_MTL, 'results_new':results_new}, file)\n",
    "    file.close()\n",
    "    print('models saved.')\n",
    "else:\n",
    "    file = open(filename_save, 'rb')\n",
    "    res = pickle.load(file)\n",
    "    file.close()\n",
    "    results_new = res['results_new']\n",
    "    results = res['results']\n",
    "    # print(results, results_new)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.449, 0.002\n"
     ]
    }
   ],
   "source": [
    "# results over seeds 5, 10, 15, 20, 25\n",
    "# Bi-modal, sml\n",
    "# existing:[0.4257355618097296, 0.42568561166358987, 0.4259234271200179, 0.42675086035511245, 0.4258778512630479]\n",
    "# new:     [0.4224890040921965, 0.4225321332483138,  0.4225426771027229, 0.4233890561613494, 0.42260111979131837]\n",
    "\n",
    "# Bi-modal, 1y\n",
    "# existing:[0.41354202059752293, 0.41361989800498994, 0.41361671588496707, 0.413711901362152, 0.41365156647174656]\n",
    "# new:     [0.42961146603698674, 0.4295647017101752,  0.4294588427302908,  0.4294392076215219, 0.42948156601729764] \n",
    "\n",
    "# Uni-modal, sml\n",
    "# existing:[0.4451800920346521, 0.44499762485636735, 0.4448149505907492, 0.4451833216181718, 0.444900388727071, ]\n",
    "# new:     [0.4400961464769073, 0.4392530360017371 , 0.43906559899868114, 0.44041092035628093, 0.4389254795292648]\n",
    "\n",
    "# Uni-modal, 1y\n",
    "# existing:[0.44614641671272254, 0.43962371173266973, 0.4394875304020304, 0.4395229386033684, 0.4396259143742413]\n",
    "# new:     [0.4473213705370877,  0.4491200148172485,  0.44897873641950176, 0.4490947459744383, 0.45106014876453004]\n",
    "\n",
    "a = [0.4473213705370877,  0.4491200148172485,  0.44897873641950176, 0.4490947459744383, 0.45106014876453004]\n",
    "print('{:1.3f}, {:1.3f}'.format(np.mean(a), 1.96*np.std(a)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3.10.4 ('python3')",
   "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.10.4"
  },
  "vscode": {
   "interpreter": {
    "hash": "98d0820a7d16c01dd14be774e41e0e13359f9b2ee065b64ad6e280dcddbc9693"
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
