{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "32715a16",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "from torch import Tensor\n",
    "from torch import nn\n",
    "import warnings\n",
    "import os\n",
    "warnings.filterwarnings(\"ignore\")\n",
    "\n",
    "import sys\n",
    "sys.path.append('../.')\n",
    "\n",
    "from src.datacore import Dataset, DataLoaders , DataLoader\n",
    "from src.learner import Learner\n",
    "from src.callback.core import *\n",
    "from src.callback.tracking import *\n",
    "from src.callback.scheduler import *\n",
    "from src.callback.MVP_simple import *\n",
    "from src.metrics import *\n",
    "from src.models.TiTR_solar import TiTR\n",
    "from dataloader import create_datasets_location\n",
    "\n",
    "import random\n",
    "def set_seed(seed):\n",
    "    torch.manual_seed(seed)\n",
    "    torch.cuda.manual_seed(seed)\n",
    "    torch.cuda.manual_seed_all(seed)\n",
    "    np.random.seed(seed)\n",
    "    random.seed(seed)\n",
    "    torch.backends.cudnn.deterministic = True\n",
    "    torch.backends.cudnn.benchmark = False"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "9c96decc",
   "metadata": {},
   "outputs": [],
   "source": [
    "'''\n",
    "import argparse\n",
    "parser = argparse.ArgumentParser(description=\"get prediction\")\n",
    "parser.add_argument(\"--location\", default=\"GA\")\n",
    "parser.add_argument(\"--gap\", default=48, type=int)\n",
    "parser.add_argument(\"--look_back\", default=336, type=int)\n",
    "parser.add_argument(\"--pred_len\", default=24, type=int)\n",
    "parser.add_argument(\"--truncate\", default=True)\n",
    "parser.add_argument(\"--task_type\", default='all-N')\n",
    "parser.add_argument(\"--seed\", default=42, type=int)\n",
    "args = parser.parse_args()  \n",
    "'''\n",
    "\n",
    "class parser:\n",
    "    location = \"OR\"\n",
    "    gap = 144\n",
    "    look_back = 336\n",
    "    pred_len = 24\n",
    "    truncate = False\n",
    "    task_type = \"SONNET\" \n",
    "    seed = 42\n",
    "    valid = 1\n",
    "args = parser\n",
    "    \n",
    "set_seed(args.seed)\n",
    "masked = 1\n",
    "    \n",
    "class ModelParams:\n",
    "\n",
    "    # [dataloader]\n",
    "    context_window = args.look_back\n",
    "    target_window = args.pred_len\n",
    "    look_back = args.look_back\n",
    "    pred_len = args.pred_len\n",
    "    gap = args.gap\n",
    "    batch_size = 128\n",
    "    num_workers = 8\n",
    "    masked = masked\n",
    "    truncate = args.truncate\n",
    "    location = args.location\n",
    "    task_type = args.task_type\n",
    "\n",
    "    # [model params]\n",
    "    n_layers = 1\n",
    "    if location != \"GA\":\n",
    "        n_heads = 8\n",
    "        d_model = 64\n",
    "        d_ff = 128\n",
    "    else:\n",
    "        n_heads = 8\n",
    "        d_model = 48\n",
    "        d_ff = 96\n",
    "        \n",
    "    dropout = 0.3\n",
    "    fc_dropout = 0.3\n",
    "    head_dropout = 0\n",
    "    \n",
    "    valid = args.valid\n",
    "\n",
    "    # [individual heads]\n",
    "    individual = False\n",
    "\n",
    "    # [patching]\n",
    "    patch_len = 8\n",
    "    stride = 4\n",
    "    padding_patch = None\n",
    "    patch_len2 = 1\n",
    "    stride2 = 1\n",
    "    padding_patch2 = None\n",
    "\n",
    "    # [RevIN]\n",
    "    revin = False\n",
    "    affine = False        \n",
    "\n",
    "    # [decomposition]\n",
    "    head_type = \"flatten\"\n",
    "\n",
    "    # [optimization params]\n",
    "    n_epochs = 300\n",
    "    lr=1e-3\n",
    "\n",
    "    # [probablistic setting]\n",
    "    prediction_type = 'probablistic'\n",
    "    probablistic = True if prediction_type == 'probablistic' else False\n",
    "    loss = 'crps'\n",
    "    n_quantiles = 11\n",
    "\n",
    "    # [path]\n",
    "    save_path = './datasets/'\n",
    "    path = './models_and_scalers/'\n",
    "    fname = location+'_L='+str(look_back)+'_gap='+str(gap)+'_'+task_type\n",
    "    \n",
    "params = ModelParams    \n",
    "if not os.path.exists(params.path):\n",
    "    os.makedirs(params.path)\n",
    "\n",
    "input_datas, output_datas, input_datas_valid, output_datas_valid = create_datasets_location(params)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "9b70d3ea",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " X_train.shape= (11348, 12, 360)  y_train.shape= (11348, 1, 24)\n",
      " X_valid.shape= (600, 12, 360)  y_valid.shape= (600, 1, 24)\n"
     ]
    }
   ],
   "source": [
    "def get_dls(cw=params.context_window, tw=params.target_window):\n",
    "\n",
    "    X_train = input_datas\n",
    "    y_train = output_datas\n",
    "    X_valid, y_valid = input_datas_valid, output_datas_valid  \n",
    "    \n",
    "    # get Dataset\n",
    "    train_ds = Dataset(X_train, y_train)\n",
    "    valid_ds = Dataset(X_valid, y_valid)\n",
    "\n",
    "    # get Dataloader\n",
    "    train_dl = DataLoader(train_ds, batch_size=params.batch_size, shuffle=True)\n",
    "    valid_dl = DataLoader(valid_ds, batch_size=params.batch_size) \n",
    "\n",
    "    dls = DataLoaders(train_dl, valid_dl)\n",
    "\n",
    "    dls.vars, dls.len = X_train.shape[1], X_train.shape[2]\n",
    "    return dls, train_dl, valid_dl, X_train, y_train, X_valid, y_valid\n",
    "\n",
    "\n",
    "dls, train_dl, valid_dl, X_train, y_train, X_valid, y_valid = get_dls()\n",
    "print(' X_train.shape=', X_train.shape, ' y_train.shape=', y_train.shape)\n",
    "print(' X_valid.shape=', X_valid.shape, ' y_valid.shape=', y_valid.shape)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "9e58a167",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "total parameters =  519944\n",
      "backbone.W_pos 1536\n",
      "backbone.W_P.weight 640\n",
      "backbone.W_P.bias 64\n",
      "backbone.encoder.layers.0.self_attn.W_Q.weight 4096\n",
      "backbone.encoder.layers.0.self_attn.W_Q.bias 64\n",
      "backbone.encoder.layers.0.self_attn.W_K.weight 4096\n",
      "backbone.encoder.layers.0.self_attn.W_K.bias 64\n",
      "backbone.encoder.layers.0.self_attn.W_V.weight 4096\n",
      "backbone.encoder.layers.0.self_attn.W_V.bias 64\n",
      "backbone.encoder.layers.0.self_attn.to_out.0.weight 4096\n",
      "backbone.encoder.layers.0.self_attn.to_out.0.bias 64\n",
      "backbone.encoder.layers.0.norm_attn.1.weight 64\n",
      "backbone.encoder.layers.0.norm_attn.1.bias 64\n",
      "backbone.encoder.layers.0.ff.0.weight 8192\n",
      "backbone.encoder.layers.0.ff.0.bias 128\n",
      "backbone.encoder.layers.0.ff.3.weight 8192\n",
      "backbone.encoder.layers.0.ff.3.bias 64\n",
      "backbone.encoder.layers.0.norm_ffn.1.weight 64\n",
      "backbone.encoder.layers.0.norm_ffn.1.bias 64\n",
      "backbone_hist.W_pos 5312\n",
      "backbone_hist.W_P.weight 6144\n",
      "backbone_hist.W_P.bias 64\n",
      "backbone_hist.encoder.layers.0.self_attn.W_Q.weight 4096\n",
      "backbone_hist.encoder.layers.0.self_attn.W_Q.bias 64\n",
      "backbone_hist.encoder.layers.0.self_attn.W_K.weight 4096\n",
      "backbone_hist.encoder.layers.0.self_attn.W_K.bias 64\n",
      "backbone_hist.encoder.layers.0.self_attn.W_V.weight 4096\n",
      "backbone_hist.encoder.layers.0.self_attn.W_V.bias 64\n",
      "backbone_hist.encoder.layers.0.self_attn.to_out.0.weight 4096\n",
      "backbone_hist.encoder.layers.0.self_attn.to_out.0.bias 64\n",
      "backbone_hist.encoder.layers.0.norm_attn.1.weight 64\n",
      "backbone_hist.encoder.layers.0.norm_attn.1.bias 64\n",
      "backbone_hist.encoder.layers.0.ff.0.weight 8192\n",
      "backbone_hist.encoder.layers.0.ff.0.bias 128\n",
      "backbone_hist.encoder.layers.0.ff.3.weight 8192\n",
      "backbone_hist.encoder.layers.0.ff.3.bias 64\n",
      "backbone_hist.encoder.layers.0.norm_ffn.1.weight 64\n",
      "backbone_hist.encoder.layers.0.norm_ffn.1.bias 64\n",
      "cross_attention.layer.self_attn.W_Q.weight 4096\n",
      "cross_attention.layer.self_attn.W_Q.bias 64\n",
      "cross_attention.layer.self_attn.W_K.weight 4096\n",
      "cross_attention.layer.self_attn.W_K.bias 64\n",
      "cross_attention.layer.self_attn.W_V.weight 4096\n",
      "cross_attention.layer.self_attn.W_V.bias 64\n",
      "cross_attention.layer.self_attn.to_out.0.weight 4096\n",
      "cross_attention.layer.self_attn.to_out.0.bias 64\n",
      "cross_attention.layer.norm_attn.1.weight 64\n",
      "cross_attention.layer.norm_attn.1.bias 64\n",
      "cross_attention.layer.ff.0.weight 8192\n",
      "cross_attention.layer.ff.0.bias 128\n",
      "cross_attention.layer.ff.3.weight 8192\n",
      "cross_attention.layer.ff.3.bias 64\n",
      "cross_attention.layer.norm_ffn.1.weight 64\n",
      "cross_attention.layer.norm_ffn.1.bias 64\n",
      "head.linear.weight 405504\n",
      "head.linear.bias 264\n",
      "None\n"
     ]
    }
   ],
   "source": [
    "def count_parameters(model):\n",
    "    return sum(p.numel() for p in model.parameters() if p.requires_grad)\n",
    "\n",
    "def count_detailed_parameters(model):\n",
    "    for name, param in model.named_parameters():\n",
    "        if param.requires_grad:\n",
    "            print(name, param.numel())\n",
    "            \n",
    "def create_model():\n",
    "    model =  TiTR(c_in=dls.vars, context_window=params.context_window, target_window=params.target_window, \n",
    "                  patch_len = params.patch_len, stride=params.stride, padding_patch = params.padding_patch,\n",
    "                  patch_len2 = params.patch_len2, stride2=params.stride2, padding_patch2 = params.padding_patch2,\n",
    "                        n_layers=params.n_layers,\n",
    "                            n_heads=params.n_heads,\n",
    "                            d_model=params.d_model,\n",
    "                            d_ff=params.d_ff,                        \n",
    "                            dropout=params.dropout,\n",
    "                            fc_dropout=params.fc_dropout,\n",
    "                            head_dropout = params.head_dropout,\n",
    "                            act='gelu',\n",
    "                            individual = params.individual,\n",
    "                            revin=params.revin,\n",
    "                            affine=params.affine,\n",
    "                            head_type = params.head_type,\n",
    "                            probablistic=params.probablistic,\n",
    "                            n_quantiles=params.n_quantiles,\n",
    "                            masked = params.masked\n",
    "                            )\n",
    "    return model\n",
    "\n",
    "model = create_model()\n",
    "\n",
    "print('total parameters = ', count_parameters(model))\n",
    "print(count_detailed_parameters(model))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "209cc4ea",
   "metadata": {},
   "outputs": [],
   "source": [
    "def train_func(dls, valid = True):\n",
    "    model = create_model()\n",
    "\n",
    "    # get loss\n",
    "    if params.loss == 'mse': # 'quantile' 'crps'\n",
    "        loss_func = torch.nn.MSELoss(reduction='mean')\n",
    "    elif params.loss == 'quantile':\n",
    "        quantiles=[0.001,0.1,0.2,0.3,0.4,0.5,0.6,0.7,0.8,0.9,0.999]\n",
    "        loss_func = QuantileLoss(quantiles)\n",
    "    elif params.loss == 'crps':\n",
    "        quantiles=[0,0.1,0.2,0.3,0.4,0.5,0.6,0.7,0.8,0.9,1]\n",
    "        loss_func = CRPSLoss(quantiles)\n",
    "\n",
    "    cbs=[SaveModelCB(every_epoch=5, fname=params.fname, path=params.path),\n",
    "        ]\n",
    "\n",
    "    # define learner\n",
    "    learn = Learner(dls, model, \n",
    "                    loss_func, \n",
    "                    lr=params.lr                       \n",
    "                    #metrics=[mse, rmse]\n",
    "                    )  \n",
    "    suggested_lr = learn.lr_finder()\n",
    "    print('suggested_lr', suggested_lr)\n",
    "\n",
    "    # training\n",
    "    model = create_model()\n",
    "    \n",
    "    if valid:\n",
    "        early_stopping_cb = EarlyStoppingCB(patience=30)\n",
    "        learn = Learner(dls, model, \n",
    "                        loss_func, \n",
    "                        lr=params.lr,                          \n",
    "                        # get callbacks\n",
    "                          cbs=[\n",
    "                            SaveModelCB(monitor='valid_loss', fname=params.fname, path=params.path, valid = 1),\n",
    "                            TrackTrainingCB(train_metrics=False, valid_metrics=True), early_stopping_cb]\n",
    "                        )\n",
    "    else:\n",
    "        learn = Learner(dls, model, \n",
    "                    loss_func, \n",
    "                    lr=params.lr,                          \n",
    "                    # get callbacks\n",
    "                      cbs=[\n",
    "                        SaveModelCB(monitor='valid_loss', fname=params.fname, path=params.path, valid = 0),\n",
    "                        TrackTrainingCB(train_metrics=False)]\n",
    "                    )\n",
    "\n",
    "\n",
    "                \n",
    "    learn.fit_one_cycle(n_epochs=params.n_epochs, lr_max=suggested_lr)\n",
    "\n",
    "    # loss curve\n",
    "    plt.figure(figsize=(10,5))\n",
    "    plt.plot(learn.recorder['train_loss'])\n",
    "    plt.plot(learn.recorder['valid_loss'])\n",
    "    \n",
    "     # Return the stopping epoch if early stopping was triggered\n",
    "    if valid and early_stopping_cb.stopped_epoch is not None:\n",
    "        return early_stopping_cb.stopped_epoch\n",
    "    else:\n",
    "        return params.n_epochs  \n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "9db2876f",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "self.smoothed_loss > 4 * self.best_loss\n",
      "suggested_lr 0.00011768119524349978\n",
      "          epoch     train_loss     valid_loss           time\n",
      "Better model found at epoch 0 with valid_loss value: 0.0174153200785319.\n",
      "              0       0.016018       0.017415          00:01\n",
      "Better model found at epoch 1 with valid_loss value: 0.01690968672434489.\n",
      "              1       0.015757       0.016910          00:01\n",
      "Better model found at epoch 2 with valid_loss value: 0.016509939829508463.\n",
      "              2       0.015555       0.016510          00:01\n",
      "Better model found at epoch 3 with valid_loss value: 0.016180928548177084.\n",
      "              3       0.015378       0.016181          00:01\n",
      "Better model found at epoch 4 with valid_loss value: 0.015899596214294435.\n",
      "              4       0.015233       0.015900          00:01\n",
      "Better model found at epoch 5 with valid_loss value: 0.015646074612935382.\n",
      "              5       0.015068       0.015646          00:01\n",
      "Better model found at epoch 6 with valid_loss value: 0.015402557055155437.\n",
      "              6       0.014913       0.015403          00:01\n",
      "Better model found at epoch 7 with valid_loss value: 0.015130426088968913.\n",
      "              7       0.014720       0.015130          00:01\n",
      "Better model found at epoch 8 with valid_loss value: 0.014855106671651205.\n",
      "              8       0.014514       0.014855          00:01\n",
      "Better model found at epoch 9 with valid_loss value: 0.014539341926574707.\n",
      "              9       0.014255       0.014539          00:01\n",
      "Better model found at epoch 10 with valid_loss value: 0.014117627143859864.\n",
      "             10       0.013924       0.014118          00:01\n",
      "Better model found at epoch 11 with valid_loss value: 0.013632559776306152.\n",
      "             11       0.013520       0.013633          00:01\n",
      "Better model found at epoch 12 with valid_loss value: 0.012947755654652914.\n",
      "             12       0.012985       0.012948          00:01\n",
      "Better model found at epoch 13 with valid_loss value: 0.012090665499369303.\n",
      "             13       0.012306       0.012091          00:01\n",
      "Better model found at epoch 14 with valid_loss value: 0.011064549287160238.\n",
      "             14       0.011431       0.011065          00:01\n",
      "Better model found at epoch 15 with valid_loss value: 0.009545219739278158.\n",
      "             15       0.010300       0.009545          00:01\n",
      "Better model found at epoch 16 with valid_loss value: 0.008027345339457193.\n",
      "             16       0.008894       0.008027          00:01\n",
      "Better model found at epoch 17 with valid_loss value: 0.00613211711247762.\n",
      "             17       0.007291       0.006132          00:01\n",
      "Better model found at epoch 18 with valid_loss value: 0.00418397068977356.\n",
      "             18       0.005645       0.004184          00:01\n",
      "Better model found at epoch 19 with valid_loss value: 0.0029414093494415285.\n",
      "             19       0.004397       0.002941          00:01\n",
      "Better model found at epoch 20 with valid_loss value: 0.002305694023768107.\n",
      "             20       0.003713       0.002306          00:01\n",
      "Better model found at epoch 21 with valid_loss value: 0.0021294864018758138.\n",
      "             21       0.003404       0.002129          00:01\n",
      "Better model found at epoch 22 with valid_loss value: 0.0020194141070048015.\n",
      "             22       0.003260       0.002019          00:01\n",
      "Better model found at epoch 23 with valid_loss value: 0.0019067102670669556.\n",
      "             23       0.003116       0.001907          00:01\n",
      "Better model found at epoch 24 with valid_loss value: 0.0017967859903971354.\n",
      "             24       0.002977       0.001797          00:01\n",
      "Better model found at epoch 25 with valid_loss value: 0.00171580175558726.\n",
      "             25       0.002852       0.001716          00:01\n",
      "Better model found at epoch 26 with valid_loss value: 0.0015991212924321492.\n",
      "             26       0.002742       0.001599          00:01\n",
      "Better model found at epoch 27 with valid_loss value: 0.0014992488423983257.\n",
      "             27       0.002581       0.001499          00:01\n",
      "Better model found at epoch 28 with valid_loss value: 0.0013812666138013205.\n",
      "             28       0.002431       0.001381          00:01\n",
      "Better model found at epoch 29 with valid_loss value: 0.0012765437364578246.\n",
      "             29       0.002290       0.001277          00:01\n",
      "Better model found at epoch 30 with valid_loss value: 0.001168056627114614.\n",
      "             30       0.002158       0.001168          00:01\n",
      "Better model found at epoch 31 with valid_loss value: 0.0010480513175328574.\n",
      "             31       0.002001       0.001048          00:01\n",
      "Better model found at epoch 32 with valid_loss value: 0.0009608592589696248.\n",
      "             32       0.001861       0.000961          00:01\n",
      "Better model found at epoch 33 with valid_loss value: 0.0008602783083915711.\n",
      "             33       0.001729       0.000860          00:01\n",
      "Better model found at epoch 34 with valid_loss value: 0.0007654505968093872.\n",
      "             34       0.001572       0.000765          00:01\n",
      "Better model found at epoch 35 with valid_loss value: 0.0006820202867190043.\n",
      "             35       0.001447       0.000682          00:01\n",
      "Better model found at epoch 36 with valid_loss value: 0.0006118920942147573.\n",
      "             36       0.001323       0.000612          00:01\n",
      "Better model found at epoch 37 with valid_loss value: 0.0005791485806306203.\n",
      "             37       0.001213       0.000579          00:01\n",
      "Better model found at epoch 38 with valid_loss value: 0.0005135222276051839.\n",
      "             38       0.001100       0.000514          00:01\n",
      "Better model found at epoch 39 with valid_loss value: 0.00048278530438741047.\n",
      "             39       0.001012       0.000483          00:01\n",
      "Better model found at epoch 40 with valid_loss value: 0.0004449407756328583.\n",
      "             40       0.000921       0.000445          00:01\n",
      "             41       0.000839       0.000458          00:01\n",
      "Better model found at epoch 42 with valid_loss value: 0.00041594281792640687.\n",
      "             42       0.000762       0.000416          00:01\n",
      "             43       0.000695       0.000432          00:01\n",
      "Better model found at epoch 44 with valid_loss value: 0.0004022469868262609.\n",
      "             44       0.000633       0.000402          00:01\n",
      "Better model found at epoch 45 with valid_loss value: 0.0003455411394437154.\n",
      "             45       0.000574       0.000346          00:01\n",
      "             46       0.000524       0.000398          00:01\n",
      "             47       0.000478       0.000363          00:01\n",
      "Better model found at epoch 48 with valid_loss value: 0.00030843297640482584.\n",
      "             48       0.000437       0.000308          00:01\n",
      "             49       0.000408       0.000345          00:01\n",
      "             50       0.000371       0.000311          00:01\n",
      "             51       0.000346       0.000344          00:01\n",
      "             52       0.000329       0.000377          00:01\n",
      "             53       0.000310       0.000445          00:01\n",
      "             54       0.000293       0.000309          00:01\n",
      "Better model found at epoch 55 with valid_loss value: 0.0002896681676308314.\n",
      "             55       0.000290       0.000290          00:01\n",
      "Better model found at epoch 56 with valid_loss value: 0.00028073047598203024.\n",
      "             56       0.000275       0.000281          00:01\n",
      "             57       0.000266       0.000306          00:01\n",
      "             58       0.000257       0.000384          00:01\n",
      "Better model found at epoch 59 with valid_loss value: 0.00023352886239687602.\n",
      "             59       0.000253       0.000234          00:01\n",
      "             60       0.000250       0.000249          00:01\n",
      "             61       0.000242       0.000265          00:01\n",
      "             62       0.000234       0.000260          00:01\n",
      "             63       0.000230       0.000280          00:01\n",
      "Better model found at epoch 64 with valid_loss value: 0.00020976518591245014.\n",
      "             64       0.000235       0.000210          00:01\n",
      "             65       0.000231       0.000230          00:01\n",
      "Better model found at epoch 66 with valid_loss value: 0.00020325606067975361.\n",
      "             66       0.000234       0.000203          00:01\n",
      "             67       0.000227       0.000332          00:01\n",
      "             68       0.000222       0.000247          00:01\n",
      "             69       0.000216       0.000204          00:01\n",
      "Better model found at epoch 70 with valid_loss value: 0.00020181655883789063.\n",
      "             70       0.000220       0.000202          00:01\n",
      "             71       0.000213       0.000215          00:01\n",
      "             72       0.000211       0.000211          00:01\n",
      "Better model found at epoch 73 with valid_loss value: 0.00017787091434001923.\n",
      "             73       0.000213       0.000178          00:01\n",
      "             74       0.000210       0.000208          00:01\n",
      "             75       0.000209       0.000196          00:01\n",
      "Better model found at epoch 76 with valid_loss value: 0.00017781227827072145.\n",
      "             76       0.000202       0.000178          00:01\n",
      "             77       0.000207       0.000201          00:01\n",
      "             78       0.000207       0.000188          00:01\n",
      "Better model found at epoch 79 with valid_loss value: 0.00016866172353426615.\n",
      "             79       0.000197       0.000169          00:01\n",
      "Better model found at epoch 80 with valid_loss value: 0.00016062775005896887.\n",
      "             80       0.000205       0.000161          00:01\n",
      "             81       0.000200       0.000223          00:01\n",
      "             82       0.000195       0.000171          00:01\n",
      "             83       0.000196       0.000219          00:01\n",
      "             84       0.000198       0.000180          00:01\n",
      "             85       0.000199       0.000182          00:01\n",
      "             86       0.000200       0.000162          00:01\n",
      "Better model found at epoch 87 with valid_loss value: 0.00015905520568291345.\n",
      "             87       0.000190       0.000159          00:01\n",
      "             88       0.000188       0.000164          00:01\n",
      "             89       0.000187       0.000166          00:01\n",
      "             90       0.000189       0.000176          00:01\n",
      "             91       0.000189       0.000160          00:01\n",
      "             92       0.000188       0.000198          00:01\n",
      "             93       0.000184       0.000170          00:01\n",
      "             94       0.000184       0.000182          00:01\n",
      "             95       0.000181       0.000174          00:01\n",
      "Better model found at epoch 96 with valid_loss value: 0.00015710691610972086.\n",
      "             96       0.000181       0.000157          00:01\n",
      "Better model found at epoch 97 with valid_loss value: 0.00015583494057257971.\n",
      "             97       0.000182       0.000156          00:01\n",
      "             98       0.000180       0.000164          00:01\n",
      "             99       0.000179       0.000161          00:01\n",
      "            100       0.000180       0.000161          00:01\n",
      "Better model found at epoch 101 with valid_loss value: 0.0001530213157335917.\n",
      "            101       0.000175       0.000153          00:01\n",
      "            102       0.000181       0.000170          00:01\n",
      "            103       0.000179       0.000173          00:01\n",
      "Better model found at epoch 104 with valid_loss value: 0.0001491540546218554.\n",
      "            104       0.000174       0.000149          00:01\n",
      "            105       0.000174       0.000163          00:01\n",
      "            106       0.000170       0.000170          00:01\n",
      "            107       0.000172       0.000151          00:01\n",
      "            108       0.000170       0.000162          00:01\n",
      "            109       0.000170       0.000150          00:01\n",
      "            110       0.000170       0.000162          00:01\n",
      "            111       0.000171       0.000155          00:01\n",
      "Better model found at epoch 112 with valid_loss value: 0.00014835584908723832.\n",
      "            112       0.000169       0.000148          00:01\n",
      "            113       0.000170       0.000164          00:01\n",
      "            114       0.000172       0.000153          00:01\n",
      "Better model found at epoch 115 with valid_loss value: 0.00014528612295786538.\n",
      "            115       0.000168       0.000145          00:01\n",
      "            116       0.000170       0.000151          00:01\n",
      "            117       0.000166       0.000175          00:01\n",
      "            118       0.000162       0.000151          00:01\n",
      "            119       0.000164       0.000164          00:01\n",
      "Better model found at epoch 120 with valid_loss value: 0.0001432116578022639.\n",
      "            120       0.000166       0.000143          00:01\n",
      "            121       0.000164       0.000160          00:01\n",
      "            122       0.000162       0.000166          00:01\n",
      "            123       0.000159       0.000143          00:01\n",
      "            124       0.000162       0.000165          00:01\n",
      "            125       0.000161       0.000188          00:01\n",
      "            126       0.000161       0.000156          00:01\n",
      "            127       0.000160       0.000144          00:01\n",
      "            128       0.000161       0.000164          00:01\n",
      "            129       0.000161       0.000228          00:01\n",
      "Better model found at epoch 130 with valid_loss value: 0.00013822870949904123.\n",
      "            130       0.000170       0.000138          00:01\n",
      "            131       0.000155       0.000147          00:01\n",
      "            132       0.000156       0.000174          00:01\n",
      "            133       0.000156       0.000147          00:01\n",
      "            134       0.000161       0.000151          00:01\n",
      "            135       0.000156       0.000154          00:01\n",
      "            136       0.000154       0.000140          00:01\n",
      "            137       0.000155       0.000155          00:01\n",
      "            138       0.000155       0.000145          00:01\n",
      "Better model found at epoch 139 with valid_loss value: 0.0001377167304356893.\n",
      "            139       0.000155       0.000138          00:01\n",
      "            140       0.000154       0.000158          00:01\n",
      "            141       0.000153       0.000144          00:01\n",
      "            142       0.000152       0.000172          00:01\n",
      "            143       0.000152       0.000155          00:01\n",
      "            144       0.000153       0.000152          00:01\n",
      "Better model found at epoch 145 with valid_loss value: 0.0001363603522380193.\n",
      "            145       0.000150       0.000136          00:01\n",
      "            146       0.000152       0.000150          00:01\n",
      "            147       0.000150       0.000145          00:01\n",
      "            148       0.000153       0.000148          00:01\n",
      "            149       0.000149       0.000158          00:01\n",
      "            150       0.000152       0.000146          00:01\n",
      "            151       0.000153       0.000155          00:01\n",
      "            152       0.000145       0.000143          00:01\n",
      "            153       0.000152       0.000151          00:01\n",
      "            154       0.000146       0.000142          00:01\n",
      "Better model found at epoch 155 with valid_loss value: 0.00013577640056610106.\n",
      "            155       0.000147       0.000136          00:01\n",
      "            156       0.000147       0.000175          00:01\n",
      "            157       0.000144       0.000158          00:01\n",
      "            158       0.000146       0.000141          00:01\n",
      "            159       0.000145       0.000191          00:01\n",
      "            160       0.000148       0.000141          00:01\n",
      "            161       0.000148       0.000140          00:01\n",
      "            162       0.000143       0.000139          00:01\n",
      "            163       0.000143       0.000149          00:01\n",
      "            164       0.000145       0.000151          00:01\n",
      "            165       0.000148       0.000144          00:01\n",
      "            166       0.000147       0.000141          00:01\n",
      "            167       0.000149       0.000185          00:01\n",
      "            168       0.000142       0.000145          00:01\n",
      "            169       0.000142       0.000162          00:01\n",
      "            170       0.000147       0.000192          00:01\n",
      "            171       0.000149       0.000152          00:01\n",
      "            172       0.000143       0.000137          00:01\n",
      "            173       0.000144       0.000157          00:01\n",
      "Better model found at epoch 174 with valid_loss value: 0.00013330160329739251.\n",
      "            174       0.000140       0.000133          00:01\n",
      "            175       0.000140       0.000144          00:01\n",
      "            176       0.000143       0.000144          00:01\n",
      "            177       0.000141       0.000136          00:01\n",
      "            178       0.000140       0.000155          00:01\n",
      "            179       0.000139       0.000153          00:01\n",
      "            180       0.000139       0.000144          00:01\n",
      "            181       0.000137       0.000143          00:01\n",
      "            182       0.000139       0.000142          00:01\n",
      "            183       0.000143       0.000145          00:01\n",
      "            184       0.000140       0.000142          00:01\n",
      "Better model found at epoch 185 with valid_loss value: 0.00013113093872865042.\n",
      "            185       0.000137       0.000131          00:01\n",
      "            186       0.000143       0.000177          00:01\n",
      "            187       0.000138       0.000146          00:01\n",
      "            188       0.000141       0.000148          00:01\n",
      "            189       0.000136       0.000144          00:01\n",
      "            190       0.000138       0.000135          00:01\n",
      "            191       0.000139       0.000132          00:01\n",
      "            192       0.000141       0.000132          00:01\n",
      "Better model found at epoch 193 with valid_loss value: 0.00012788644681374232.\n",
      "            193       0.000135       0.000128          00:01\n",
      "            194       0.000138       0.000159          00:01\n",
      "            195       0.000136       0.000141          00:01\n",
      "            196       0.000136       0.000136          00:01\n",
      "            197       0.000134       0.000135          00:01\n",
      "            198       0.000135       0.000141          00:01\n",
      "            199       0.000137       0.000150          00:01\n",
      "            200       0.000135       0.000147          00:01\n",
      "            201       0.000135       0.000139          00:01\n",
      "            202       0.000132       0.000145          00:01\n",
      "            203       0.000131       0.000144          00:01\n",
      "            204       0.000133       0.000148          00:01\n",
      "            205       0.000138       0.000144          00:01\n",
      "            206       0.000135       0.000137          00:01\n",
      "            207       0.000133       0.000143          00:01\n",
      "            208       0.000131       0.000158          00:01\n",
      "            209       0.000134       0.000132          00:01\n",
      "            210       0.000133       0.000147          00:01\n",
      "            211       0.000133       0.000145          00:01\n",
      "            212       0.000134       0.000154          00:01\n",
      "            213       0.000134       0.000140          00:01\n",
      "            214       0.000131       0.000144          00:01\n",
      "            215       0.000131       0.000148          00:01\n",
      "            216       0.000132       0.000136          00:01\n",
      "            217       0.000132       0.000161          00:01\n",
      "            218       0.000134       0.000136          00:01\n",
      "            219       0.000134       0.000160          00:01\n",
      "            220       0.000133       0.000138          00:01\n",
      "            221       0.000130       0.000140          00:01\n",
      "Better model found at epoch 222 with valid_loss value: 0.00012542193134625754.\n",
      "            222       0.000128       0.000125          00:01\n",
      "            223       0.000129       0.000135          00:01\n",
      "            224       0.000127       0.000155          00:01\n",
      "            225       0.000128       0.000151          00:01\n",
      "            226       0.000127       0.000140          00:01\n",
      "            227       0.000131       0.000153          00:01\n",
      "            228       0.000127       0.000134          00:01\n",
      "            229       0.000127       0.000134          00:01\n",
      "            230       0.000126       0.000146          00:01\n",
      "            231       0.000126       0.000135          00:01\n",
      "            232       0.000127       0.000133          00:01\n",
      "            233       0.000128       0.000136          00:01\n",
      "            234       0.000126       0.000135          00:01\n",
      "            235       0.000129       0.000146          00:01\n",
      "            236       0.000126       0.000135          00:01\n",
      "            237       0.000128       0.000136          00:01\n",
      "            238       0.000126       0.000135          00:01\n",
      "            239       0.000127       0.000141          00:01\n",
      "            240       0.000123       0.000137          00:01\n",
      "            241       0.000125       0.000137          00:01\n",
      "            242       0.000125       0.000143          00:01\n",
      "            243       0.000126       0.000139          00:01\n",
      "            244       0.000124       0.000135          00:01\n",
      "            245       0.000125       0.000131          00:01\n",
      "            246       0.000124       0.000128          00:01\n",
      "            247       0.000123       0.000138          00:01\n",
      "            248       0.000125       0.000141          00:01\n",
      "            249       0.000126       0.000129          00:01\n",
      "            250       0.000124       0.000132          00:01\n",
      "            251       0.000125       0.000148          00:01\n",
      "            252       0.000127       0.000130          00:01\n",
      "No improvement since epoch 222: early stopping\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x360 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Early stopping\n",
    "stopped_epoch = train_func(dls, valid = params.valid)\n",
    "torch.cuda.empty_cache()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "6bc3166f-0c1f-4677-8865-a06bd4b791fb",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " X_train.shape= (12116, 12, 360)  y_train.shape= (12116, 1, 24)\n",
      " X_valid.shape= (12116, 12, 360)  y_valid.shape= (12116, 1, 24)\n",
      "self.smoothed_loss > 4 * self.best_loss\n",
      "suggested_lr 0.000298364724028334\n",
      "          epoch     train_loss     valid_loss           time\n",
      "              0       0.015898       0.014988          00:01\n",
      "              1       0.015394       0.014582          00:01\n",
      "              2       0.015021       0.014229          00:01\n",
      "              3       0.014610       0.013768          00:01\n",
      "              4       0.014130       0.013181          00:01\n",
      "              5       0.013388       0.012307          00:01\n",
      "              6       0.012275       0.010903          00:01\n",
      "              7       0.010572       0.008740          00:01\n",
      "              8       0.008166       0.005808          00:01\n",
      "              9       0.005393       0.003038          00:01\n",
      "             10       0.003732       0.002021          00:01\n",
      "             11       0.003337       0.001820          00:01\n",
      "             12       0.003106       0.001686          00:01\n",
      "             13       0.002852       0.001541          00:01\n",
      "             14       0.002625       0.001370          00:01\n",
      "             15       0.002418       0.001210          00:01\n",
      "             16       0.002180       0.001053          00:01\n",
      "             17       0.001942       0.000890          00:01\n",
      "             18       0.001710       0.000736          00:01\n",
      "             19       0.001479       0.000621          00:01\n",
      "             20       0.001277       0.000527          00:01\n",
      "             21       0.001091       0.000449          00:01\n",
      "             22       0.000937       0.000399          00:01\n",
      "             23       0.000799       0.000403          00:01\n",
      "             24       0.000682       0.000346          00:01\n",
      "             25       0.000586       0.000344          00:01\n",
      "             26       0.000501       0.000304          00:01\n",
      "             27       0.000439       0.000337          00:01\n",
      "             28       0.000390       0.000305          00:01\n",
      "             29       0.000349       0.000292          00:01\n",
      "             30       0.000327       0.000274          00:01\n",
      "             31       0.000296       0.000286          00:01\n",
      "             32       0.000289       0.000242          00:01\n",
      "             33       0.000276       0.000296          00:01\n",
      "             34       0.000270       0.000276          00:01\n",
      "             35       0.000256       0.000214          00:01\n",
      "             36       0.000253       0.000204          00:01\n",
      "             37       0.000254       0.000324          00:01\n",
      "             38       0.000245       0.000190          00:01\n",
      "             39       0.000240       0.000200          00:01\n",
      "             40       0.000237       0.000246          00:01\n",
      "             41       0.000225       0.000227          00:01\n",
      "             42       0.000233       0.000238          00:01\n",
      "             43       0.000223       0.000199          00:01\n",
      "             44       0.000217       0.000198          00:01\n",
      "             45       0.000223       0.000235          00:01\n",
      "             46       0.000214       0.000194          00:01\n",
      "             47       0.000220       0.000172          00:01\n",
      "             48       0.000211       0.000216          00:01\n",
      "             49       0.000221       0.000184          00:01\n",
      "             50       0.000216       0.000201          00:01\n",
      "             51       0.000216       0.000184          00:01\n",
      "             52       0.000208       0.000170          00:01\n",
      "             53       0.000204       0.000179          00:01\n",
      "             54       0.000209       0.000157          00:01\n",
      "             55       0.000207       0.000172          00:01\n",
      "             56       0.000202       0.000173          00:01\n",
      "             57       0.000213       0.000185          00:01\n",
      "             58       0.000200       0.000163          00:01\n",
      "             59       0.000205       0.000178          00:01\n",
      "             60       0.000202       0.000231          00:01\n",
      "             61       0.000204       0.000191          00:01\n",
      "             62       0.000198       0.000186          00:01\n",
      "             63       0.000197       0.000171          00:01\n",
      "             64       0.000196       0.000180          00:01\n",
      "             65       0.000190       0.000171          00:01\n",
      "             66       0.000195       0.000202          00:01\n",
      "             67       0.000190       0.000164          00:01\n",
      "             68       0.000198       0.000177          00:01\n",
      "             69       0.000195       0.000152          00:01\n",
      "             70       0.000186       0.000170          00:01\n",
      "             71       0.000183       0.000140          00:01\n",
      "             72       0.000185       0.000158          00:01\n",
      "             73       0.000194       0.000150          00:01\n",
      "             74       0.000191       0.000168          00:01\n",
      "             75       0.000176       0.000138          00:01\n",
      "             76       0.000183       0.000144          00:01\n",
      "             77       0.000182       0.000169          00:01\n",
      "             78       0.000179       0.000153          00:01\n",
      "             79       0.000182       0.000155          00:01\n",
      "             80       0.000181       0.000134          00:01\n",
      "             81       0.000177       0.000136          00:01\n",
      "             82       0.000175       0.000139          00:01\n",
      "             83       0.000171       0.000143          00:01\n",
      "             84       0.000173       0.000152          00:01\n",
      "             85       0.000180       0.000147          00:01\n",
      "             86       0.000170       0.000149          00:01\n",
      "             87       0.000171       0.000130          00:01\n",
      "             88       0.000163       0.000127          00:01\n",
      "             89       0.000169       0.000128          00:01\n",
      "             90       0.000166       0.000154          00:01\n",
      "             91       0.000167       0.000146          00:01\n",
      "             92       0.000168       0.000129          00:01\n",
      "             93       0.000165       0.000131          00:01\n",
      "             94       0.000161       0.000133          00:01\n",
      "             95       0.000160       0.000130          00:01\n",
      "             96       0.000158       0.000122          00:01\n",
      "             97       0.000161       0.000181          00:01\n",
      "             98       0.000167       0.000129          00:01\n",
      "             99       0.000159       0.000127          00:01\n",
      "            100       0.000158       0.000120          00:01\n",
      "            101       0.000156       0.000127          00:01\n",
      "            102       0.000151       0.000129          00:01\n",
      "            103       0.000153       0.000119          00:01\n",
      "            104       0.000150       0.000132          00:01\n",
      "            105       0.000157       0.000118          00:01\n",
      "            106       0.000159       0.000130          00:01\n",
      "            107       0.000153       0.000113          00:01\n",
      "            108       0.000150       0.000122          00:01\n",
      "            109       0.000146       0.000115          00:01\n",
      "            110       0.000145       0.000118          00:01\n",
      "            111       0.000145       0.000119          00:01\n",
      "            112       0.000150       0.000112          00:01\n",
      "            113       0.000145       0.000116          00:01\n",
      "            114       0.000148       0.000144          00:01\n",
      "            115       0.000154       0.000118          00:01\n",
      "            116       0.000144       0.000139          00:01\n",
      "            117       0.000146       0.000120          00:01\n",
      "            118       0.000146       0.000110          00:01\n",
      "            119       0.000140       0.000108          00:01\n",
      "            120       0.000141       0.000107          00:01\n",
      "            121       0.000140       0.000108          00:01\n",
      "            122       0.000142       0.000111          00:01\n",
      "            123       0.000139       0.000124          00:01\n",
      "            124       0.000139       0.000115          00:01\n",
      "            125       0.000137       0.000106          00:01\n",
      "            126       0.000139       0.000127          00:01\n",
      "            127       0.000134       0.000105          00:01\n",
      "            128       0.000141       0.000113          00:01\n",
      "            129       0.000141       0.000103          00:01\n",
      "            130       0.000137       0.000119          00:01\n",
      "            131       0.000139       0.000106          00:01\n",
      "            132       0.000133       0.000100          00:01\n",
      "            133       0.000134       0.000102          00:01\n",
      "            134       0.000136       0.000117          00:01\n",
      "            135       0.000136       0.000103          00:01\n",
      "            136       0.000137       0.000109          00:01\n",
      "            137       0.000136       0.000105          00:01\n",
      "            138       0.000137       0.000108          00:01\n",
      "            139       0.000133       0.000102          00:01\n",
      "            140       0.000126       0.000095          00:01\n",
      "            141       0.000130       0.000123          00:01\n",
      "            142       0.000134       0.000107          00:01\n",
      "            143       0.000128       0.000092          00:01\n",
      "            144       0.000128       0.000100          00:01\n",
      "            145       0.000128       0.000104          00:01\n",
      "            146       0.000130       0.000102          00:01\n",
      "            147       0.000129       0.000103          00:01\n",
      "            148       0.000130       0.000097          00:01\n",
      "            149       0.000125       0.000104          00:01\n",
      "            150       0.000123       0.000093          00:01\n",
      "            151       0.000131       0.000117          00:01\n",
      "            152       0.000124       0.000098          00:01\n",
      "            153       0.000125       0.000095          00:01\n",
      "            154       0.000127       0.000093          00:01\n",
      "            155       0.000122       0.000095          00:01\n",
      "            156       0.000124       0.000098          00:01\n",
      "            157       0.000128       0.000099          00:01\n",
      "            158       0.000122       0.000109          00:01\n",
      "            159       0.000126       0.000097          00:01\n",
      "            160       0.000124       0.000092          00:01\n",
      "            161       0.000123       0.000090          00:01\n",
      "            162       0.000124       0.000089          00:01\n",
      "            163       0.000125       0.000092          00:01\n",
      "            164       0.000119       0.000095          00:01\n",
      "            165       0.000118       0.000088          00:01\n",
      "            166       0.000119       0.000102          00:01\n",
      "            167       0.000125       0.000088          00:01\n",
      "            168       0.000119       0.000089          00:01\n",
      "            169       0.000118       0.000096          00:01\n",
      "            170       0.000117       0.000095          00:01\n",
      "            171       0.000117       0.000094          00:01\n",
      "            172       0.000118       0.000101          00:01\n",
      "            173       0.000120       0.000093          00:01\n",
      "            174       0.000119       0.000094          00:01\n",
      "            175       0.000119       0.000091          00:01\n",
      "            176       0.000117       0.000089          00:01\n",
      "            177       0.000118       0.000090          00:01\n",
      "            178       0.000116       0.000094          00:01\n",
      "            179       0.000118       0.000093          00:01\n",
      "            180       0.000117       0.000089          00:01\n",
      "            181       0.000116       0.000088          00:01\n",
      "            182       0.000115       0.000089          00:01\n",
      "            183       0.000117       0.000095          00:01\n",
      "            184       0.000118       0.000086          00:01\n",
      "            185       0.000118       0.000087          00:01\n",
      "            186       0.000115       0.000086          00:01\n",
      "            187       0.000115       0.000092          00:01\n",
      "            188       0.000113       0.000090          00:01\n",
      "            189       0.000115       0.000087          00:01\n",
      "            190       0.000113       0.000089          00:01\n",
      "            191       0.000115       0.000094          00:01\n",
      "            192       0.000114       0.000089          00:01\n",
      "            193       0.000118       0.000089          00:01\n",
      "            194       0.000112       0.000087          00:01\n",
      "            195       0.000114       0.000087          00:01\n",
      "            196       0.000114       0.000089          00:01\n",
      "            197       0.000112       0.000087          00:01\n",
      "            198       0.000111       0.000085          00:01\n",
      "            199       0.000113       0.000085          00:01\n",
      "            200       0.000112       0.000085          00:01\n",
      "            201       0.000114       0.000086          00:01\n",
      "            202       0.000111       0.000087          00:01\n",
      "            203       0.000112       0.000086          00:01\n",
      "            204       0.000112       0.000088          00:01\n",
      "            205       0.000112       0.000085          00:01\n",
      "            206       0.000111       0.000086          00:01\n",
      "            207       0.000111       0.000085          00:01\n",
      "            208       0.000110       0.000086          00:01\n",
      "            209       0.000111       0.000084          00:01\n",
      "            210       0.000111       0.000085          00:01\n",
      "            211       0.000109       0.000086          00:01\n",
      "            212       0.000112       0.000084          00:01\n",
      "            213       0.000110       0.000085          00:01\n",
      "            214       0.000110       0.000085          00:01\n",
      "            215       0.000113       0.000084          00:01\n",
      "            216       0.000110       0.000084          00:01\n",
      "            217       0.000110       0.000085          00:01\n",
      "            218       0.000111       0.000084          00:01\n",
      "            219       0.000111       0.000085          00:01\n",
      "            220       0.000112       0.000084          00:01\n",
      "            221       0.000112       0.000086          00:01\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x360 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Re-training useing train + validation data\n",
    "params.valid = 0\n",
    "params.n_epochs = stopped_epoch\n",
    "input_datas, output_datas, input_datas_valid, output_datas_valid = create_datasets_location(params)\n",
    "dls, train_dl, valid_dl, X_train, y_train, X_valid, y_valid = get_dls()\n",
    "print(' X_train.shape=', X_train.shape, ' y_train.shape=', y_train.shape)\n",
    "print(' X_valid.shape=', X_valid.shape, ' y_valid.shape=', y_valid.shape)\n",
    "\n",
    "model = create_model()\n",
    "stopped_epoch = train_func(dls, valid = params.valid)\n",
    "torch.cuda.empty_cache()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4d9fd2b1",
   "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.11.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
