{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "129a389c-ff08-4b81-ac76-394255a3b426",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "from time import time\n",
    "import matplotlib.pyplot as plt\n",
    "from tqdm.notebook import tqdm, trange\n",
    "\n",
    "from sklearn.metrics import r2_score, mean_squared_error as mse\n",
    "from sklearn.pipeline import Pipeline\n",
    "from sklearn.compose import TransformedTargetRegressor\n",
    "from sklearn.preprocessing import MinMaxScaler, StandardScaler, PowerTransformer\n",
    "\n",
    "# from tmpnn import TMPNNRegressor\n",
    "# from catboost import CatBoostRegressor\n",
    "\n",
    "# import keras\n",
    "# import tensorflow as tf\n",
    "\n",
    "import torch\n",
    "from torch import nn\n",
    "import skorch\n",
    "from skorch import NeuralNetRegressor\n",
    "from TorchDiffEqPack import odesolve_adjoint_sym12, odesolve\n",
    "# from solvers import anderson, broyden\n",
    "# from jacobian import jac_loss_estimate\n",
    "# import torchcde\n",
    "from torch_cfc import Cfc"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "3d8471d0-e55f-4360-b6e3-fd7d2b67de29",
   "metadata": {},
   "outputs": [],
   "source": [
    "# !python3 Prepare_WRF_data.py"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 219,
   "id": "8d53ed7b-aff5-426d-98ad-61384db6693f",
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_data(year):\n",
    "    y = np.load(f'prepaired_data/{year}/y.npy')\n",
    "    mask = (y != 0).any(2).all(1)\n",
    "    y = y.transpose((0,2,1))\n",
    "    y = y[mask].transpose((0,2,1))\n",
    "    sca = np.load(f'prepaired_data/{year}/sca_data.npy')[mask]\n",
    "    seq = np.load(f'prepaired_data/{year}/seq_data.npy')[mask]\n",
    "    flux = np.load(f'prepaired_data/{year}/flux_data.npy')[mask]#[:,[0,1,3,4,2,5]]\n",
    "    return sca, seq, y, flux\n",
    "X0_tr, X1_tr, y_tr, f_tr0 = get_data(2015)\n",
    "h_tr = np.repeat(np.arange(49)[None,None], X1_tr.shape[0], 0)\n",
    "d = X1_tr.shape[1] + 1 + X0_tr.shape[1]\n",
    "X_tr0 = np.concatenate((X1_tr, h_tr, np.repeat(X0_tr[:,:,None], 49, 2)), 1).transpose((0,2,1)).reshape(-1,d)\n",
    "y_tr0 = y_tr.reshape(-1,2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 224,
   "id": "6a47882d-767f-43e2-b893-4799ae9b4139",
   "metadata": {},
   "outputs": [],
   "source": [
    "xpipe0 = MinMaxScaler().fit(X_tr0)\n",
    "ypipe0 = StandardScaler().fit(y_tr0)\n",
    "fpipe0 = StandardScaler().fit(f_tr0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 221,
   "id": "bd7d6cc8-1159-4c78-be00-45e166aef609",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "22\n"
     ]
    }
   ],
   "source": [
    "def get_data(year):\n",
    "    y = np.load(f'prepaired_data/{year}/y.npy')\n",
    "    mask = (y != 0).any(2).all(1)\n",
    "    y = y.transpose((0,2,1))\n",
    "    # y = y[mask].transpose((0,2,1))\n",
    "    sca = np.load(f'prepaired_data/{year}/sca_data.npy')#[mask]\n",
    "    seq = np.load(f'prepaired_data/{year}/seq_data.npy')#[mask]\n",
    "    flux = np.load(f'prepaired_data/{year}/flux_data.npy')#[mask]#[:,[0,1,3,4,2,5]]\n",
    "    return sca, seq, y, flux\n",
    "X0_tr, X1_tr, y_tr, f_tr = get_data(2015)\n",
    "X0_vl, X1_vl, y_vl, f_vl = get_data(2016)\n",
    "h_tr = np.repeat(np.arange(49)[None,None], X1_tr.shape[0], 0)\n",
    "h_vl = np.repeat(np.arange(49)[None,None], X1_vl.shape[0], 0)\n",
    "\n",
    "d = X1_tr.shape[1] + 1 + X0_tr.shape[1]\n",
    "print(d)\n",
    "X_tr = np.concatenate((X1_tr, h_tr, np.repeat(X0_tr[:,:,None], 49, 2)), 1).transpose((0,2,1)).reshape(-1,d)\n",
    "X_vl = np.concatenate((X1_vl, h_vl, np.repeat(X0_vl[:,:,None], 49, 2)), 1).transpose((0,2,1)).reshape(-1,d)\n",
    "y_tr, y_vl = y_tr.reshape(-1,2), y_vl.reshape(-1,2)\n",
    "xpipe = MinMaxScaler()\n",
    "tX_tr = xpipe.fit_transform(X_tr)\n",
    "tX_vl = xpipe.transform(X_vl)\n",
    "ypipe = StandardScaler()\n",
    "ty_tr = ypipe.fit_transform(y_tr)\n",
    "ty_vl = ypipe.transform(y_vl)\n",
    "fpipe = StandardScaler()\n",
    "tf_tr = fpipe.fit_transform(f_tr)\n",
    "tf_vl = fpipe.transform(f_vl)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "d8390bd8-e8df-41bd-8bb0-66946327adf5",
   "metadata": {},
   "outputs": [],
   "source": [
    "m = np.array([1,0,0,1,1,1,0,0,0,1,0,1,1,1,1,1,1,0,0,0,1,1]).astype(bool)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 62,
   "id": "af19423a-ed7a-4616-b648-d837b7eba00d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "13 : SH P_TOT T_KEL QCLOUD QICE OZONE height XLAND COSZEN SOLCON ALBEDO EMISS TSK\n"
     ]
    }
   ],
   "source": [
    "model = CatBoostRegressor(random_state=0, verbose=0, n_estimators=100, objective='MultiRMSE')\n",
    "model.fit(X_tr, np.concatenate((y_tr, np.repeat(f_tr[:,None,:], 49, 1).reshape(-1,6)), 1))\n",
    "imps = pd.Series(model.feature_importances_, \n",
    "         ['SH', 'CF', 'RH', 'P_TOT', 'T_KEL', 'QCLOUD', 'QRAIN', 'QSNOW', 'QVAPOR', 'QICE', 'dT', 'OZONE']\n",
    "         + ['height']\n",
    "         + ['XLAND', 'COSZEN', 'SOLCON', 'ALBEDO', 'XLONG', 'XLAT', 'HGT', 'EMISS', 'TSK'])\n",
    "m = imps>0.1\n",
    "print(m.sum(), ':', *imps[m].index)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "34c217e7-b3d0-4038-a6ba-59606884ff60",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 126,
   "id": "627a1910-973b-4bd9-bafe-8baf17e34820",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [],
   "source": [
    "class ODEfnWrapper(nn.Module):\n",
    "    def __init__(self, model: nn.Module, *args, **kwargs) -> None:\n",
    "        super().__init__(*args, **kwargs)\n",
    "        self.model = model\n",
    "\n",
    "    def forward(self, time, inputs):\n",
    "        return self.model(inputs)\n",
    "\n",
    "class MALI(nn.Module):\n",
    "    options = {'method': 'sym12async', 'h': 0.1, 't0': 0.0, 't1': 1.0, 't_eval':None, 'print_neval': False, \n",
    "               'neval_max': 100000, 'interpolation_method':'linear', 'regenerate_graph':False}\n",
    "    \n",
    "    def __init__(self, model: nn.Module, tol=1e-2, *args, **kwargs) -> None:\n",
    "        super().__init__()\n",
    "        self.model = ODEfnWrapper(model)\n",
    "        self.options.update({'rtol': tol, 'atol': tol})\n",
    "        \n",
    "    def forward(self, inputs):\n",
    "        return odesolve_adjoint_sym12(self.model, inputs, options=self.options)\n",
    "        \n",
    "class ODEfnWrapper(nn.Module):\n",
    "    def __init__(self, model: nn.Module, *args, **kwargs) -> None:\n",
    "        super().__init__(*args, **kwargs)\n",
    "        self.model = model\n",
    "\n",
    "    def forward(self, time, inputs):\n",
    "        return self.model(inputs)\n",
    "\n",
    "class TrellisNet(nn.Module):\n",
    "    def __init__(self, inj, model: nn.Module, *args, **kwargs) -> None:\n",
    "        super().__init__(*args, **kwargs)\n",
    "        self.inj = inj\n",
    "        self.model = model\n",
    "\n",
    "    def forward(self, z, x):\n",
    "        return self.model(self.inj(z) + x)\n",
    "\n",
    "class DEQ(nn.Module):\n",
    "    def __init__(self, model: nn.Module, *args, **kwargs) -> None:\n",
    "        super().__init__(*args, **kwargs)\n",
    "        self.model = model\n",
    "        self.solver = broyden\n",
    "    \n",
    "    def forward(self, x, **kwargs):\n",
    "        z0 = torch.zeros(x.shape).to(x.device)\n",
    "        with torch.no_grad():\n",
    "            z_star = self.solver(lambda z: self.model(z, x), z0, threshold=30)['result']\n",
    "            new_z_star = z_star\n",
    "\n",
    "        if self.training:\n",
    "            new_z_star = self.model(z_star.requires_grad_(), x)\n",
    "            jac_loss = jac_loss_estimate(new_z_star, z_star, vecs=1)\n",
    "            def backward_hook(grad):\n",
    "                if self.hook is not None:\n",
    "                    self.hook.remove()\n",
    "                    torch.cuda.synchronize()\n",
    "                new_grad = self.solver(lambda y: torch.autograd.grad(new_z_star, z_star, y, retain_graph=True)[0] + grad, \\\n",
    "                                       torch.zeros_like(grad), threshold=40)['result']\n",
    "                return new_grad\n",
    "            self.hook = new_z_star.register_hook(backward_hook)\n",
    "            \n",
    "        return new_z_star"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "77fc6839-2dda-49ae-884e-b1c754cdc2a6",
   "metadata": {},
   "source": [
    "# Abstract 2d approaches"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "0089e39a-1b30-4638-af66-e3f9a0ec7d00",
   "metadata": {
    "collapsed": true,
    "jupyter": {
     "outputs_hidden": true,
     "source_hidden": true
    },
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "      2        \u001b[36m0.0001\u001b[0m        \u001b[32m0.0001\u001b[0m  835.6343\n",
      "      3        \u001b[36m0.0001\u001b[0m        \u001b[32m0.0001\u001b[0m  819.0014\n",
      "      4        \u001b[36m0.0001\u001b[0m        \u001b[32m0.0001\u001b[0m  813.4644\n",
      "      5        \u001b[36m0.0001\u001b[0m        \u001b[32m0.0001\u001b[0m  789.0829\n",
      "      6        \u001b[36m0.0001\u001b[0m        \u001b[32m0.0001\u001b[0m  806.9776\n",
      "      7        \u001b[36m0.0001\u001b[0m        \u001b[32m0.0001\u001b[0m  805.7359\n",
      "      8        \u001b[36m0.0001\u001b[0m        \u001b[32m0.0001\u001b[0m  809.0925\n",
      "      9        \u001b[36m0.0001\u001b[0m        \u001b[32m0.0001\u001b[0m  802.9423\n",
      "     10        \u001b[36m0.0001\u001b[0m        \u001b[32m0.0001\u001b[0m  781.6349\n",
      "     11        \u001b[36m0.0001\u001b[0m        \u001b[32m0.0001\u001b[0m  785.1646\n",
      "     12        \u001b[36m0.0001\u001b[0m        \u001b[32m0.0001\u001b[0m  779.3032\n",
      "     13        \u001b[36m0.0001\u001b[0m        \u001b[32m0.0000\u001b[0m  762.7810\n",
      "     14        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  783.6284\n",
      "     15        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  773.3808\n",
      "     16        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  774.4285\n",
      "     17        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  775.9907\n",
      "     18        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  767.1213\n",
      "     19        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  756.7656\n",
      "     20        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  756.4436\n",
      "     21        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  761.5167\n",
      "     22        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  761.7886\n",
      "     23        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  743.1301\n",
      "     24        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  744.8808\n",
      "     25        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  736.1766\n",
      "     26        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  718.5075\n",
      "     27        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  730.0044\n",
      "     28        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  720.6072\n",
      "     29        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  744.4517\n",
      "     30        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  758.8890\n",
      "     31        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  775.5325\n",
      "     32        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  771.0556\n",
      "     33        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  752.2814\n",
      "     34        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  754.5944\n",
      "     35        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  897.0102\n",
      "     36        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  1059.4516\n",
      "     37        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  1056.3444\n",
      "     38        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  1057.8759\n",
      "     39        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  1029.0887\n",
      "     40        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  1020.2437\n",
      "     41        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  982.5488\n",
      "     42        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  1008.6292\n",
      "     43        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  993.6738\n",
      "     44        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  1027.2766\n",
      "     45        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  1011.2265\n",
      "     46        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  1018.2377\n",
      "     47        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  1035.4095\n",
      "     48        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  1045.4782\n",
      "     49        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  1051.5917\n",
      "     50        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  1053.5630\n",
      "     51        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  1047.4357\n",
      "     52        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  1035.8649\n",
      "     53        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  1029.1473\n",
      "     54        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  1028.9646\n",
      "     55        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  1028.4952\n",
      "     56        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  1032.3335\n",
      "     57        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  1019.0490\n",
      "     58        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  1021.3868\n",
      "     59        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  1021.5477\n",
      "     60        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  1006.4072\n",
      "     61        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  1006.0702\n",
      "     62        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  1003.8315\n",
      "     63        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  1007.3494\n",
      "     64        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  1009.8529\n",
      "     65        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  1010.6502\n",
      "     66        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  1009.3174\n",
      "     67        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  1000.5696\n",
      "     68        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  764.9633\n",
      "     69        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  754.8417\n",
      "     70        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  748.7266\n",
      "     71        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  749.9365\n",
      "     72        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  782.8819\n",
      "     73        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  781.5676\n",
      "     74        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  818.2590\n",
      "     75        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  778.4515\n",
      "     76        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  780.4236\n",
      "     77        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  768.8917\n",
      "     78        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  806.9803\n",
      "     79        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  765.3878\n",
      "     80        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  824.5903\n",
      "     81        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  834.9721\n",
      "     82        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  824.5152\n",
      "     83        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  853.6149\n",
      "     84        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  842.7841\n",
      "     85        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  793.6549\n",
      "     86        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  782.7504\n",
      "     87        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  819.6205\n",
      "     88        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  825.2145\n",
      "     89        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  838.3402\n",
      "     90        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  840.7299\n",
      "     91        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  787.3542\n",
      "     92        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  819.8569\n",
      "     93        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  841.9387\n",
      "     94        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  849.9485\n",
      "     95        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  838.0558\n",
      "     96        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  856.3786\n",
      "     97        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  840.4542\n",
      "     98        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  786.8629\n",
      "     99        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  795.0613\n",
      "    100        \u001b[36m0.0000\u001b[0m        \u001b[32m0.0000\u001b[0m  788.0316\n",
      "0.1828613417117288\n",
      "0.12693496778028968 1.1280802672971284\n"
     ]
    }
   ],
   "source": [
    "class DEQ_Trellis(nn.Module):\n",
    "    def __init__(self):\n",
    "        h=128\n",
    "        super().__init__()\n",
    "        self.m = nn.Sequential(\n",
    "            nn.Conv1d(m.sum(),h,3,padding=1),\n",
    "            DEQ(TrellisNet(\n",
    "                nn.Conv1d(h,h,3,padding=1),\n",
    "                nn.Sequential(\n",
    "                    nn.ReLU(True),\n",
    "                    nn.Conv1d(h,h,3,padding=1),\n",
    "                    nn.ReLU(True)\n",
    "                ))),\n",
    "            nn.Conv1d(h,2,3,padding=1),\n",
    "        )\n",
    "        \n",
    "    def forward(self, inp):\n",
    "        # b,cl -> b,c,l\n",
    "        inp = inp.float().reshape(-1,49,m.sum()).transpose(1,2)\n",
    "        return self.m(inp).transpose(1,2).reshape(-1,49*2)\n",
    "        \n",
    "model = NeuralNetRegressor(DEQ_Trellis, max_epochs=100, lr=1e-2, iterator_train__shuffle=True, device='cuda')\n",
    "model.fit(tX_tr[:,m].reshape(-1,49*m.sum()), ty_tr.reshape(-1,49*2))\n",
    "print(model.score(tX_vl[:,m].reshape(-1,49*m.sum()), ty_vl.reshape(-1,49*2)))\n",
    "pred = ypipe.inverse_transform(model.predict(tX_vl[:,m].reshape(-1,49*m.sum())).reshape(-1,2))\n",
    "print(mse(y_vl[:,0], pred[:,0])**0.5 *86400, mse(y_vl[:,1], pred[:,1])**0.5 *86400)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 109,
   "id": "0dbf1e4c-b853-47a2-ae09-6c3be33afeef",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "  epoch    train_loss    valid_loss       dur\n",
      "-------  ------------  ------------  --------\n",
      "      1        \u001b[36m0.3634\u001b[0m        \u001b[32m0.1957\u001b[0m  356.7697\n",
      "      2        \u001b[36m0.1722\u001b[0m        \u001b[32m0.1603\u001b[0m  385.0452\n",
      "      3        \u001b[36m0.1099\u001b[0m        \u001b[32m0.1436\u001b[0m  387.8852\n",
      "      4        \u001b[36m0.0812\u001b[0m        \u001b[32m0.0567\u001b[0m  384.8039\n",
      "      5        \u001b[36m0.0650\u001b[0m        0.0766  385.3840\n",
      "      6        \u001b[36m0.0545\u001b[0m        \u001b[32m0.0342\u001b[0m  387.2824\n",
      "      7        \u001b[36m0.0467\u001b[0m        0.0663  384.9066\n",
      "      8        \u001b[36m0.0411\u001b[0m        \u001b[32m0.0293\u001b[0m  386.3454\n",
      "      9        \u001b[36m0.0366\u001b[0m        \u001b[32m0.0257\u001b[0m  385.3161\n",
      "     10        \u001b[36m0.0328\u001b[0m        0.0315  385.6173\n",
      "     11        \u001b[36m0.0295\u001b[0m        \u001b[32m0.0197\u001b[0m  386.2986\n",
      "     12        \u001b[36m0.0270\u001b[0m        0.0452  384.9971\n",
      "     13        \u001b[36m0.0246\u001b[0m        0.0211  387.5449\n",
      "     14        \u001b[36m0.0229\u001b[0m        \u001b[32m0.0182\u001b[0m  387.4246\n",
      "     15        \u001b[36m0.0212\u001b[0m        \u001b[32m0.0131\u001b[0m  391.2169\n",
      "     16        \u001b[36m0.0196\u001b[0m        0.0158  397.3991\n",
      "     17        \u001b[36m0.0184\u001b[0m        0.0188  406.3209\n",
      "     18        \u001b[36m0.0173\u001b[0m        \u001b[32m0.0119\u001b[0m  414.8214\n",
      "     19        \u001b[36m0.0164\u001b[0m        \u001b[32m0.0096\u001b[0m  430.0209\n",
      "     20        \u001b[36m0.0153\u001b[0m        0.0136  447.7212\n",
      "     21        \u001b[36m0.0147\u001b[0m        0.0209  459.5941\n",
      "     22        \u001b[36m0.0139\u001b[0m        0.0331  473.8654\n",
      "     23        \u001b[36m0.0134\u001b[0m        0.0149  480.1296\n",
      "     24        \u001b[36m0.0127\u001b[0m        \u001b[32m0.0090\u001b[0m  486.1628\n",
      "     25        \u001b[36m0.0122\u001b[0m        0.0095  489.1934\n",
      "     26        \u001b[36m0.0116\u001b[0m        0.0145  489.9381\n",
      "     27        \u001b[36m0.0112\u001b[0m        \u001b[32m0.0078\u001b[0m  492.5027\n",
      "     28        \u001b[36m0.0107\u001b[0m        0.0168  487.7834\n",
      "     29        \u001b[36m0.0104\u001b[0m        \u001b[32m0.0070\u001b[0m  485.4395\n",
      "     30        \u001b[36m0.0098\u001b[0m        0.0080  485.4097\n",
      "     31        \u001b[36m0.0096\u001b[0m        0.0119  484.6580\n",
      "     32        \u001b[36m0.0093\u001b[0m        0.0072  482.4949\n",
      "     33        \u001b[36m0.0089\u001b[0m        0.0091  484.0851\n",
      "     34        \u001b[36m0.0086\u001b[0m        \u001b[32m0.0057\u001b[0m  480.4128\n",
      "     35        \u001b[36m0.0084\u001b[0m        0.0149  483.3842\n",
      "     36        \u001b[36m0.0082\u001b[0m        0.0087  479.6212\n",
      "     37        \u001b[36m0.0078\u001b[0m        \u001b[32m0.0052\u001b[0m  480.5310\n",
      "     38        \u001b[36m0.0076\u001b[0m        0.0068  480.9814\n",
      "     39        \u001b[36m0.0074\u001b[0m        0.0056  481.1771\n",
      "     40        \u001b[36m0.0072\u001b[0m        0.0062  481.5472\n",
      "     41        \u001b[36m0.0070\u001b[0m        \u001b[32m0.0049\u001b[0m  479.3746\n",
      "     42        \u001b[36m0.0068\u001b[0m        0.0070  480.6480\n",
      "     43        \u001b[36m0.0067\u001b[0m        0.0075  479.2944\n",
      "     44        \u001b[36m0.0065\u001b[0m        0.0056  478.4818\n",
      "     45        \u001b[36m0.0064\u001b[0m        0.0050  478.7629\n",
      "     46        \u001b[36m0.0063\u001b[0m        0.0050  479.5558\n",
      "     47        \u001b[36m0.0061\u001b[0m        0.0120  481.1330\n",
      "     48        \u001b[36m0.0059\u001b[0m        \u001b[32m0.0042\u001b[0m  480.2992\n",
      "     49        \u001b[36m0.0058\u001b[0m        0.0131  483.7652\n",
      "     50        \u001b[36m0.0057\u001b[0m        0.0112  479.8940\n",
      "     51        \u001b[36m0.0057\u001b[0m        0.0057  479.3652\n",
      "     52        \u001b[36m0.0055\u001b[0m        0.0078  478.9767\n",
      "     53        \u001b[36m0.0054\u001b[0m        0.0059  478.6109\n",
      "     54        \u001b[36m0.0054\u001b[0m        0.0075  481.1317\n",
      "     55        \u001b[36m0.0052\u001b[0m        0.0073  480.1136\n",
      "     56        \u001b[36m0.0051\u001b[0m        \u001b[32m0.0042\u001b[0m  480.1450\n",
      "     57        0.0052        \u001b[32m0.0034\u001b[0m  480.2368\n",
      "     58        \u001b[36m0.0050\u001b[0m        0.0038  481.5788\n",
      "     59        \u001b[36m0.0049\u001b[0m        \u001b[32m0.0034\u001b[0m  479.5718\n",
      "     60        0.0049        0.0039  480.6566\n",
      "     61        \u001b[36m0.0048\u001b[0m        0.0038  481.8113\n",
      "     62        \u001b[36m0.0048\u001b[0m        0.0048  481.1177\n",
      "     63        \u001b[36m0.0046\u001b[0m        0.0046  482.6694\n",
      "     64        \u001b[36m0.0046\u001b[0m        0.0049  480.7028\n",
      "     65        0.0046        0.0039  481.0160\n",
      "     66        \u001b[36m0.0045\u001b[0m        0.0036  481.8434\n",
      "     67        0.0045        \u001b[32m0.0034\u001b[0m  482.4517\n",
      "     68        \u001b[36m0.0044\u001b[0m        0.0034  479.7392\n",
      "     69        \u001b[36m0.0044\u001b[0m        0.0034  480.6666\n",
      "     70        \u001b[36m0.0044\u001b[0m        0.0038  480.3785\n",
      "     71        \u001b[36m0.0043\u001b[0m        0.0035  480.4134\n",
      "     72        0.0043        0.0036  480.7447\n",
      "     73        \u001b[36m0.0042\u001b[0m        \u001b[32m0.0032\u001b[0m  481.1407\n",
      "     74        0.0042        0.0034  481.4102\n",
      "     75        \u001b[36m0.0042\u001b[0m        \u001b[32m0.0031\u001b[0m  479.9601\n",
      "     76        \u001b[36m0.0041\u001b[0m        0.0031  480.3939\n",
      "     77        \u001b[36m0.0041\u001b[0m        0.0043  483.3271\n",
      "     78        0.0041        0.0036  483.0635\n",
      "     79        \u001b[36m0.0040\u001b[0m        0.0063  482.8301\n",
      "     80        0.0040        0.0037  481.2451\n",
      "     81        \u001b[36m0.0040\u001b[0m        0.0038  483.1550\n",
      "     82        \u001b[36m0.0040\u001b[0m        0.0078  481.5147\n",
      "     83        \u001b[36m0.0039\u001b[0m        0.0031  479.9216\n",
      "     84        \u001b[36m0.0039\u001b[0m        0.0038  485.5643\n",
      "     85        \u001b[36m0.0038\u001b[0m        0.0035  486.5979\n",
      "     86        \u001b[36m0.0038\u001b[0m        0.0047  487.5036\n",
      "     87        0.0038        0.0045  490.0012\n",
      "     88        \u001b[36m0.0037\u001b[0m        0.0036  491.7743\n",
      "     89        0.0038        0.0038  491.3641\n",
      "     90        \u001b[36m0.0037\u001b[0m        \u001b[32m0.0029\u001b[0m  487.1707\n",
      "     91        0.0037        0.0037  492.5219\n",
      "     92        0.0037        0.0030  489.1635\n",
      "     93        \u001b[36m0.0036\u001b[0m        0.0035  487.1315\n",
      "     94        0.0037        0.0033  489.3333\n",
      "     95        \u001b[36m0.0036\u001b[0m        0.0029  486.6443\n",
      "     96        0.0036        0.0030  488.7776\n",
      "     97        0.0036        \u001b[32m0.0029\u001b[0m  488.2199\n",
      "     98        \u001b[36m0.0036\u001b[0m        0.0030  156.2829\n",
      "     99        \u001b[36m0.0036\u001b[0m        0.0031  116.6061\n",
      "    100        \u001b[36m0.0035\u001b[0m        0.0040  112.9251\n",
      "0.941845993476158\n",
      "0.03283612517700037 0.10225186609780253\n"
     ]
    }
   ],
   "source": [
    "class Node2d(nn.Module):\n",
    "    def __init__(self):\n",
    "        h=512\n",
    "        super().__init__()\n",
    "        self.m = nn.Sequential(\n",
    "            nn.Conv1d(m.sum(),h,3,padding=1),\n",
    "            MALI(nn.Sequential(\n",
    "                nn.Conv1d(h,h,3,padding=1),\n",
    "                nn.ReLU(True),\n",
    "                nn.Conv1d(h,h,3,padding=1),\n",
    "                nn.ReLU(True)\n",
    "            )),\n",
    "            nn.Conv1d(h,2,3,padding=1),\n",
    "        )\n",
    "        \n",
    "    def forward(self, inp):\n",
    "        # b,cl -> b,c,l\n",
    "        inp = inp.float().reshape(-1,49,m.sum()).transpose(1,2)\n",
    "        return self.m(inp).transpose(1,2).reshape(-1,49*2)\n",
    "        \n",
    "model = NeuralNetRegressor(Node2d, max_epochs=100, lr=1e-2, iterator_train__shuffle=True, device='cuda')\n",
    "model.fit(tX_tr[:,m].reshape(-1,49*m.sum()), ty_tr.reshape(-1,49*2))\n",
    "print(model.score(tX_vl[:,m].reshape(-1,49*m.sum()), ty_vl.reshape(-1,49*2)))\n",
    "pred = ypipe.inverse_transform(model.predict(tX_vl[:,m].reshape(-1,49*m.sum())).reshape(-1,2))\n",
    "print(mse(y_vl[:,0], pred[:,0])**0.5 *86400, mse(y_vl[:,1], pred[:,1])**0.5 *86400)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "251f3093-8bde-486e-9ea0-f7a5d606903b",
   "metadata": {
    "collapsed": true,
    "jupyter": {
     "outputs_hidden": true,
     "source_hidden": true
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.09366743946077848"
      ]
     },
     "execution_count": 39,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "mse(y_vl.reshape(-1,49), ypipe.inverse_transform(model.predict(tX_vl[:,m].reshape(-1,49*m.sum()))))**0.5 *86400"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "id": "380516e3-c981-4ce0-b44f-cad9c3f90c71",
   "metadata": {
    "collapsed": true,
    "jupyter": {
     "outputs_hidden": true,
     "source_hidden": true
    },
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "  epoch    train_loss    valid_loss      dur\n",
      "-------  ------------  ------------  -------\n",
      "      1        \u001b[36m0.3396\u001b[0m        \u001b[32m0.1905\u001b[0m  49.7550\n",
      "      2        \u001b[36m0.1166\u001b[0m        \u001b[32m0.0830\u001b[0m  49.6107\n",
      "      3        \u001b[36m0.0738\u001b[0m        \u001b[32m0.0763\u001b[0m  50.7532\n",
      "      4        \u001b[36m0.0537\u001b[0m        \u001b[32m0.0288\u001b[0m  51.5271\n",
      "      5        \u001b[36m0.0410\u001b[0m        0.0484  50.8005\n",
      "      6        \u001b[36m0.0335\u001b[0m        \u001b[32m0.0216\u001b[0m  50.1706\n",
      "      7        \u001b[36m0.0283\u001b[0m        0.0404  51.6096\n",
      "      8        \u001b[36m0.0245\u001b[0m        \u001b[32m0.0191\u001b[0m  50.5963\n",
      "      9        \u001b[36m0.0221\u001b[0m        \u001b[32m0.0149\u001b[0m  51.4586\n",
      "     10        \u001b[36m0.0198\u001b[0m        \u001b[32m0.0118\u001b[0m  51.5753\n",
      "     11        \u001b[36m0.0185\u001b[0m        0.0135  48.0963\n",
      "     12        \u001b[36m0.0170\u001b[0m        \u001b[32m0.0109\u001b[0m  46.9201\n",
      "     13        \u001b[36m0.0160\u001b[0m        0.0163  46.4124\n",
      "     14        \u001b[36m0.0151\u001b[0m        0.0110  46.2558\n",
      "     15        \u001b[36m0.0144\u001b[0m        0.0190  45.8799\n",
      "     16        \u001b[36m0.0138\u001b[0m        0.0129  46.9736\n",
      "     17        \u001b[36m0.0133\u001b[0m        \u001b[32m0.0100\u001b[0m  46.1735\n",
      "     18        \u001b[36m0.0127\u001b[0m        0.0135  45.9290\n",
      "     19        \u001b[36m0.0124\u001b[0m        \u001b[32m0.0095\u001b[0m  46.3343\n",
      "     20        \u001b[36m0.0121\u001b[0m        \u001b[32m0.0091\u001b[0m  46.3053\n",
      "     21        \u001b[36m0.0117\u001b[0m        0.0172  46.2829\n",
      "     22        \u001b[36m0.0114\u001b[0m        0.0145  46.4252\n",
      "     23        \u001b[36m0.0111\u001b[0m        \u001b[32m0.0087\u001b[0m  46.2414\n",
      "     24        \u001b[36m0.0109\u001b[0m        0.0101  45.3793\n",
      "     25        \u001b[36m0.0108\u001b[0m        0.0179  45.1882\n",
      "     26        \u001b[36m0.0104\u001b[0m        0.0099  46.6176\n",
      "     27        0.0105        \u001b[32m0.0082\u001b[0m  46.2086\n",
      "     28        \u001b[36m0.0101\u001b[0m        0.0113  45.8515\n",
      "     29        \u001b[36m0.0100\u001b[0m        0.0083  46.6007\n",
      "     30        \u001b[36m0.0098\u001b[0m        \u001b[32m0.0080\u001b[0m  45.2507\n",
      "     31        \u001b[36m0.0096\u001b[0m        0.0082  46.3042\n",
      "     32        \u001b[36m0.0095\u001b[0m        0.0080  45.5654\n",
      "     33        \u001b[36m0.0094\u001b[0m        0.0087  45.5666\n",
      "     34        \u001b[36m0.0094\u001b[0m        0.0111  45.4914\n",
      "     35        \u001b[36m0.0092\u001b[0m        0.0107  45.8118\n",
      "     36        \u001b[36m0.0092\u001b[0m        0.0081  46.4067\n",
      "     37        \u001b[36m0.0090\u001b[0m        0.0107  45.4042\n",
      "     38        \u001b[36m0.0089\u001b[0m        0.0093  45.6933\n",
      "     39        \u001b[36m0.0088\u001b[0m        \u001b[32m0.0079\u001b[0m  45.6607\n",
      "     40        \u001b[36m0.0087\u001b[0m        0.0092  44.7593\n",
      "     41        \u001b[36m0.0087\u001b[0m        0.0084  45.1650\n",
      "     42        \u001b[36m0.0085\u001b[0m        0.0097  45.0772\n",
      "     43        \u001b[36m0.0084\u001b[0m        \u001b[32m0.0073\u001b[0m  44.6018\n",
      "     44        \u001b[36m0.0084\u001b[0m        \u001b[32m0.0073\u001b[0m  45.9070\n",
      "     45        \u001b[36m0.0083\u001b[0m        0.0077  47.1465\n",
      "     46        0.0083        0.0083  46.5174\n",
      "     47        \u001b[36m0.0082\u001b[0m        0.0074  44.4017\n",
      "     48        \u001b[36m0.0081\u001b[0m        0.0079  45.6666\n",
      "     49        0.0081        0.0075  44.1232\n",
      "     50        0.0081        0.0076  45.0031\n",
      "     51        \u001b[36m0.0080\u001b[0m        0.0088  44.8192\n",
      "     52        \u001b[36m0.0079\u001b[0m        0.0134  45.1612\n",
      "     53        0.0079        0.0076  45.4601\n",
      "     54        \u001b[36m0.0077\u001b[0m        0.0073  45.6683\n",
      "     55        0.0078        \u001b[32m0.0072\u001b[0m  46.2411\n",
      "     56        0.0077        0.0074  45.4223\n",
      "     57        \u001b[36m0.0077\u001b[0m        0.0084  45.2579\n",
      "     58        \u001b[36m0.0076\u001b[0m        \u001b[32m0.0067\u001b[0m  45.4912\n",
      "     59        0.0076        0.0081  44.8627\n",
      "     60        \u001b[36m0.0075\u001b[0m        0.0070  44.5220\n",
      "     61        \u001b[36m0.0075\u001b[0m        \u001b[32m0.0066\u001b[0m  44.1885\n",
      "     62        \u001b[36m0.0074\u001b[0m        0.0080  43.7374\n",
      "     63        0.0074        \u001b[32m0.0066\u001b[0m  42.8259\n",
      "     64        0.0074        0.0068  43.9525\n",
      "     65        \u001b[36m0.0073\u001b[0m        0.0069  44.1503\n",
      "     66        \u001b[36m0.0073\u001b[0m        0.0082  45.1775\n",
      "     67        \u001b[36m0.0072\u001b[0m        0.0080  44.2188\n",
      "     68        \u001b[36m0.0072\u001b[0m        0.0073  42.3798\n",
      "     69        \u001b[36m0.0072\u001b[0m        0.0067  42.9767\n",
      "     70        0.0072        0.0068  43.2906\n",
      "     71        \u001b[36m0.0071\u001b[0m        0.0071  41.6548\n",
      "     72        0.0071        \u001b[32m0.0065\u001b[0m  42.9400\n",
      "     73        \u001b[36m0.0071\u001b[0m        0.0069  43.4021\n",
      "     74        \u001b[36m0.0070\u001b[0m        0.0065  41.6563\n",
      "     75        \u001b[36m0.0070\u001b[0m        0.0080  43.3027\n",
      "     76        \u001b[36m0.0070\u001b[0m        0.0073  43.5488\n",
      "     77        \u001b[36m0.0070\u001b[0m        \u001b[32m0.0065\u001b[0m  42.0984\n",
      "     78        \u001b[36m0.0069\u001b[0m        0.0066  43.2974\n",
      "     79        \u001b[36m0.0069\u001b[0m        0.0066  42.5014\n",
      "     80        0.0069        \u001b[32m0.0064\u001b[0m  42.3113\n",
      "     81        \u001b[36m0.0068\u001b[0m        \u001b[32m0.0062\u001b[0m  42.6587\n",
      "     82        0.0068        0.0067  42.7031\n",
      "     83        \u001b[36m0.0067\u001b[0m        0.0064  42.3574\n",
      "     84        0.0067        0.0088  42.8801\n",
      "     85        \u001b[36m0.0067\u001b[0m        0.0072  43.8693\n",
      "     86        0.0067        0.0064  43.4370\n",
      "     87        \u001b[36m0.0067\u001b[0m        0.0064  42.5924\n",
      "     88        0.0067        0.0081  42.3505\n",
      "     89        \u001b[36m0.0067\u001b[0m        0.0063  43.2222\n",
      "     90        0.0067        0.0064  41.8432\n",
      "     91        \u001b[36m0.0067\u001b[0m        0.0062  43.1674\n",
      "     92        \u001b[36m0.0066\u001b[0m        0.0067  43.0915\n",
      "     93        0.0066        0.0063  41.5408\n",
      "     94        0.0067        0.0065  43.5876\n",
      "     95        \u001b[36m0.0066\u001b[0m        0.0089  42.8324\n",
      "     96        0.0066        \u001b[32m0.0061\u001b[0m  41.8918\n",
      "     97        \u001b[36m0.0066\u001b[0m        0.0062  43.3531\n",
      "     98        \u001b[36m0.0065\u001b[0m        \u001b[32m0.0060\u001b[0m  41.4831\n",
      "     99        0.0065        0.0064  42.1179\n",
      "    100        0.0066        0.0063  42.9465\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "0.8927638970453502"
      ]
     },
     "execution_count": 66,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "class СNN2d(nn.Module):\n",
    "    def __init__(self):\n",
    "        h = 512\n",
    "        super().__init__()\n",
    "        self.m = nn.Sequential(\n",
    "            nn.Conv1d(m.sum(),h,3,padding=1),\n",
    "            nn.Sequential(\n",
    "                nn.Conv1d(h,h,3,padding=1),\n",
    "                nn.ReLU(True),\n",
    "                nn.Conv1d(h,h,3,padding=1),\n",
    "                nn.ReLU(True)\n",
    "            ),\n",
    "            nn.Conv1d(h,1,3,padding=1),\n",
    "        )\n",
    "        \n",
    "    def forward(self, inp):\n",
    "        # b,cl -> b,c,l\n",
    "        inp = inp.float().reshape(-1,49,11).transpose(1,2)\n",
    "        return self.m(inp)[:,0]\n",
    "        \n",
    "model = NeuralNetRegressor(СNN2d, max_epochs=100, lr=1e-2, iterator_train__shuffle=True, device='cuda')\n",
    "model.fit(tX_tr[:,m].reshape(-1,49*m.sum()), ty_tr.reshape(-1,49))\n",
    "model.score(tX_vl[:,m].reshape(-1,49*m.sum()), ty_vl.reshape(-1,49))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 67,
   "id": "50d184a8-fb81-4429-91ca-2b8afb48e5a5",
   "metadata": {
    "collapsed": true,
    "jupyter": {
     "outputs_hidden": true,
     "source_hidden": true
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.13042513896906074"
      ]
     },
     "execution_count": 67,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "mse(y_vl.reshape(-1,49), ypipe.inverse_transform(model.predict(tX_vl[:,m].reshape(-1,49*m.sum()))))**0.5 *86400"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "504f1ff0-e141-4c16-9dff-79989b234973",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [],
   "source": [
    "model.module_.load_state_dict(torch.load('weights/cnn128.pt'))\n",
    "model.score(tX_vl[:,m].reshape(-1,49*m.sum()), ty_vl.reshape(-1,49))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 68,
   "id": "8a4ef52a-ada5-478c-993b-5f622dcbe6dd",
   "metadata": {
    "collapsed": true,
    "jupyter": {
     "outputs_hidden": true,
     "source_hidden": true
    },
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "  epoch    train_loss    valid_loss      dur\n",
      "-------  ------------  ------------  -------\n",
      "      1        \u001b[36m0.7073\u001b[0m        \u001b[32m0.6350\u001b[0m  32.5789\n",
      "      2        \u001b[36m0.6082\u001b[0m        \u001b[32m0.5866\u001b[0m  34.8164\n",
      "      3        \u001b[36m0.5726\u001b[0m        \u001b[32m0.5600\u001b[0m  35.3496\n",
      "      4        \u001b[36m0.5506\u001b[0m        \u001b[32m0.5418\u001b[0m  30.1870\n",
      "      5        \u001b[36m0.5344\u001b[0m        \u001b[32m0.5276\u001b[0m  28.4996\n",
      "      6        \u001b[36m0.5214\u001b[0m        \u001b[32m0.5156\u001b[0m  28.7368\n",
      "      7        \u001b[36m0.5102\u001b[0m        \u001b[32m0.5052\u001b[0m  28.0716\n",
      "      8        \u001b[36m0.5003\u001b[0m        \u001b[32m0.4959\u001b[0m  30.6214\n",
      "      9        \u001b[36m0.4913\u001b[0m        \u001b[32m0.4872\u001b[0m  34.4393\n",
      "     10        \u001b[36m0.4830\u001b[0m        \u001b[32m0.4792\u001b[0m  34.3173\n",
      "     11        \u001b[36m0.4753\u001b[0m        \u001b[32m0.4717\u001b[0m  33.4554\n",
      "     12        \u001b[36m0.4681\u001b[0m        \u001b[32m0.4647\u001b[0m  30.7178\n",
      "     13        \u001b[36m0.4612\u001b[0m        \u001b[32m0.4581\u001b[0m  28.0872\n",
      "     14        \u001b[36m0.4547\u001b[0m        \u001b[32m0.4518\u001b[0m  28.4349\n",
      "     15        \u001b[36m0.4485\u001b[0m        \u001b[32m0.4457\u001b[0m  31.0980\n",
      "     16        \u001b[36m0.4426\u001b[0m        \u001b[32m0.4399\u001b[0m  29.5850\n",
      "     17        \u001b[36m0.4369\u001b[0m        \u001b[32m0.4343\u001b[0m  29.0259\n",
      "     18        \u001b[36m0.4315\u001b[0m        \u001b[32m0.4290\u001b[0m  29.9484\n",
      "     19        \u001b[36m0.4263\u001b[0m        \u001b[32m0.4239\u001b[0m  32.1300\n",
      "     20        \u001b[36m0.4212\u001b[0m        \u001b[32m0.4189\u001b[0m  28.6493\n",
      "     21        \u001b[36m0.4164\u001b[0m        \u001b[32m0.4144\u001b[0m  29.7509\n",
      "     22        \u001b[36m0.4117\u001b[0m        \u001b[32m0.4097\u001b[0m  30.8569\n",
      "     23        \u001b[36m0.4072\u001b[0m        \u001b[32m0.4051\u001b[0m  28.5088\n",
      "     24        \u001b[36m0.4028\u001b[0m        \u001b[32m0.4008\u001b[0m  28.3911\n",
      "     25        \u001b[36m0.3985\u001b[0m        \u001b[32m0.3966\u001b[0m  31.0050\n",
      "     26        \u001b[36m0.3944\u001b[0m        \u001b[32m0.3925\u001b[0m  31.4344\n",
      "     27        \u001b[36m0.3904\u001b[0m        \u001b[32m0.3887\u001b[0m  30.4264\n",
      "     28        \u001b[36m0.3866\u001b[0m        \u001b[32m0.3849\u001b[0m  30.0051\n",
      "     29        \u001b[36m0.3828\u001b[0m        \u001b[32m0.3811\u001b[0m  30.9836\n",
      "     30        \u001b[36m0.3791\u001b[0m        \u001b[32m0.3775\u001b[0m  28.6631\n",
      "     31        \u001b[36m0.3756\u001b[0m        \u001b[32m0.3740\u001b[0m  29.6549\n",
      "     32        \u001b[36m0.3721\u001b[0m        \u001b[32m0.3707\u001b[0m  31.2960\n",
      "     33        \u001b[36m0.3687\u001b[0m        \u001b[32m0.3672\u001b[0m  29.0362\n",
      "     34        \u001b[36m0.3654\u001b[0m        \u001b[32m0.3640\u001b[0m  28.3486\n",
      "     35        \u001b[36m0.3622\u001b[0m        \u001b[32m0.3608\u001b[0m  31.4089\n",
      "     36        \u001b[36m0.3591\u001b[0m        \u001b[32m0.3577\u001b[0m  28.1613\n",
      "     37        \u001b[36m0.3561\u001b[0m        \u001b[32m0.3548\u001b[0m  28.9316\n",
      "     38        \u001b[36m0.3531\u001b[0m        \u001b[32m0.3518\u001b[0m  30.7634\n",
      "     39        \u001b[36m0.3502\u001b[0m        \u001b[32m0.3489\u001b[0m  30.1659\n",
      "     40        \u001b[36m0.3474\u001b[0m        \u001b[32m0.3461\u001b[0m  28.1174\n",
      "     41        \u001b[36m0.3446\u001b[0m        \u001b[32m0.3434\u001b[0m  29.2133\n",
      "     42        \u001b[36m0.3419\u001b[0m        \u001b[32m0.3407\u001b[0m  30.2806\n",
      "     43        \u001b[36m0.3392\u001b[0m        \u001b[32m0.3381\u001b[0m  28.6650\n",
      "     44        \u001b[36m0.3366\u001b[0m        \u001b[32m0.3355\u001b[0m  28.8535\n",
      "     45        \u001b[36m0.3341\u001b[0m        \u001b[32m0.3330\u001b[0m  31.7275\n",
      "     46        \u001b[36m0.3316\u001b[0m        \u001b[32m0.3306\u001b[0m  28.9576\n",
      "     47        \u001b[36m0.3291\u001b[0m        \u001b[32m0.3281\u001b[0m  30.0879\n",
      "     48        \u001b[36m0.3268\u001b[0m        \u001b[32m0.3257\u001b[0m  33.4802\n",
      "     49        \u001b[36m0.3244\u001b[0m        \u001b[32m0.3235\u001b[0m  30.6360\n",
      "     50        \u001b[36m0.3221\u001b[0m        \u001b[32m0.3212\u001b[0m  28.5577\n",
      "     51        \u001b[36m0.3199\u001b[0m        \u001b[32m0.3190\u001b[0m  29.7733\n",
      "     52        \u001b[36m0.3177\u001b[0m        \u001b[32m0.3168\u001b[0m  33.5806\n",
      "     53        \u001b[36m0.3155\u001b[0m        \u001b[32m0.3147\u001b[0m  29.3901\n",
      "     54        \u001b[36m0.3134\u001b[0m        \u001b[32m0.3125\u001b[0m  30.9579\n",
      "     55        \u001b[36m0.3113\u001b[0m        \u001b[32m0.3105\u001b[0m  32.1678\n",
      "     56        \u001b[36m0.3093\u001b[0m        \u001b[32m0.3084\u001b[0m  28.2831\n",
      "     57        \u001b[36m0.3072\u001b[0m        \u001b[32m0.3064\u001b[0m  30.2736\n",
      "     58        \u001b[36m0.3053\u001b[0m        \u001b[32m0.3045\u001b[0m  30.9733\n",
      "     59        \u001b[36m0.3033\u001b[0m        \u001b[32m0.3026\u001b[0m  29.0754\n",
      "     60        \u001b[36m0.3014\u001b[0m        \u001b[32m0.3007\u001b[0m  29.8703\n",
      "     61        \u001b[36m0.2995\u001b[0m        \u001b[32m0.2990\u001b[0m  30.8876\n",
      "     62        \u001b[36m0.2977\u001b[0m        \u001b[32m0.2970\u001b[0m  27.2244\n",
      "     63        \u001b[36m0.2959\u001b[0m        \u001b[32m0.2952\u001b[0m  26.9055\n",
      "     64        \u001b[36m0.2941\u001b[0m        \u001b[32m0.2934\u001b[0m  28.3921\n",
      "     65        \u001b[36m0.2924\u001b[0m        \u001b[32m0.2917\u001b[0m  30.4687\n",
      "     66        \u001b[36m0.2906\u001b[0m        \u001b[32m0.2900\u001b[0m  26.5957\n",
      "     67        \u001b[36m0.2889\u001b[0m        \u001b[32m0.2883\u001b[0m  27.0045\n",
      "     68        \u001b[36m0.2873\u001b[0m        \u001b[32m0.2867\u001b[0m  26.3245\n",
      "     69        \u001b[36m0.2856\u001b[0m        \u001b[32m0.2850\u001b[0m  27.2073\n",
      "     70        \u001b[36m0.2840\u001b[0m        \u001b[32m0.2834\u001b[0m  26.1666\n",
      "     71        \u001b[36m0.2824\u001b[0m        \u001b[32m0.2819\u001b[0m  27.2531\n",
      "     72        \u001b[36m0.2808\u001b[0m        \u001b[32m0.2805\u001b[0m  26.6716\n",
      "     73        \u001b[36m0.2793\u001b[0m        \u001b[32m0.2787\u001b[0m  26.6473\n",
      "     74        \u001b[36m0.2778\u001b[0m        \u001b[32m0.2772\u001b[0m  27.2558\n",
      "     75        \u001b[36m0.2763\u001b[0m        \u001b[32m0.2757\u001b[0m  25.7931\n",
      "     76        \u001b[36m0.2748\u001b[0m        \u001b[32m0.2743\u001b[0m  25.3432\n",
      "     77        \u001b[36m0.2733\u001b[0m        \u001b[32m0.2728\u001b[0m  25.5653\n",
      "     78        \u001b[36m0.2719\u001b[0m        \u001b[32m0.2714\u001b[0m  27.5168\n",
      "     79        \u001b[36m0.2705\u001b[0m        \u001b[32m0.2700\u001b[0m  25.8694\n",
      "     80        \u001b[36m0.2690\u001b[0m        \u001b[32m0.2686\u001b[0m  26.2047\n",
      "     81        \u001b[36m0.2677\u001b[0m        \u001b[32m0.2672\u001b[0m  27.2571\n",
      "     82        \u001b[36m0.2663\u001b[0m        \u001b[32m0.2659\u001b[0m  26.5060\n",
      "     83        \u001b[36m0.2650\u001b[0m        \u001b[32m0.2645\u001b[0m  25.8328\n",
      "     84        \u001b[36m0.2636\u001b[0m        \u001b[32m0.2632\u001b[0m  26.8897\n",
      "     85        \u001b[36m0.2623\u001b[0m        \u001b[32m0.2619\u001b[0m  27.2973\n",
      "     86        \u001b[36m0.2610\u001b[0m        \u001b[32m0.2606\u001b[0m  25.7562\n",
      "     87        \u001b[36m0.2598\u001b[0m        \u001b[32m0.2594\u001b[0m  26.0329\n",
      "     88        \u001b[36m0.2585\u001b[0m        \u001b[32m0.2581\u001b[0m  27.7423\n",
      "     89        \u001b[36m0.2573\u001b[0m        \u001b[32m0.2569\u001b[0m  25.3739\n",
      "     90        \u001b[36m0.2560\u001b[0m        \u001b[32m0.2557\u001b[0m  25.3704\n",
      "     91        \u001b[36m0.2548\u001b[0m        \u001b[32m0.2545\u001b[0m  26.3635\n",
      "     92        \u001b[36m0.2536\u001b[0m        \u001b[32m0.2533\u001b[0m  26.3538\n",
      "     93        \u001b[36m0.2524\u001b[0m        \u001b[32m0.2521\u001b[0m  25.6783\n",
      "     94        \u001b[36m0.2513\u001b[0m        \u001b[32m0.2509\u001b[0m  26.3654\n",
      "     95        \u001b[36m0.2501\u001b[0m        \u001b[32m0.2498\u001b[0m  27.4907\n",
      "     96        \u001b[36m0.2490\u001b[0m        \u001b[32m0.2487\u001b[0m  25.6727\n",
      "     97        \u001b[36m0.2478\u001b[0m        \u001b[32m0.2475\u001b[0m  25.7789\n",
      "     98        \u001b[36m0.2467\u001b[0m        \u001b[32m0.2464\u001b[0m  26.4214\n",
      "     99        \u001b[36m0.2456\u001b[0m        \u001b[32m0.2453\u001b[0m  26.4581\n",
      "    100        \u001b[36m0.2445\u001b[0m        \u001b[32m0.2443\u001b[0m  26.3450\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "-0.12353494442760465"
      ]
     },
     "execution_count": 68,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "class Polynom(nn.Module):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "    def forward(self, inp):\n",
    "        n,c,l = inp.shape\n",
    "        return torch.cat([inp, (inp[:,:,None,:]*inp[:,None,:,:]).view(n,c**2,l)], 1)\n",
    "\n",
    "class cpnn2d(nn.Module):\n",
    "    def __init__(self):\n",
    "        self.steps = 7\n",
    "        h = m.sum()\n",
    "        super().__init__()\n",
    "        self.tmap = nn.Sequential(\n",
    "            Polynom(), \n",
    "            nn.Conv1d(h + h**2,1,3,padding=1))\n",
    "            # Polynom(), \n",
    "            # nn.Conv1d(h + 2*h**2 + 2*h**3 + h**4,1,3,padding=1))\n",
    "        \n",
    "    def forward(self, inp):\n",
    "        # b,cl -> b,c,l\n",
    "        inp = inp.float().reshape(-1,49,m.sum()).transpose(1,2)\n",
    "        return self.tmap(inp)[:,0]\n",
    "\n",
    "model = NeuralNetRegressor(cpnn2d, max_epochs=100, lr=5e-3, iterator_train__shuffle=True, device='cuda')\n",
    "model.fit(tX_tr[:,m].reshape(-1,49*m.sum()), ty_tr.reshape(-1,49))\n",
    "model.score(tX_vl[:,m].reshape(-1,49*m.sum()), ty_vl.reshape(-1,49))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 69,
   "id": "64732f0a-2b89-476a-946f-db05647d6657",
   "metadata": {
    "collapsed": true,
    "jupyter": {
     "outputs_hidden": true,
     "source_hidden": true
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.8128040690489062"
      ]
     },
     "execution_count": 69,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "mse(y_vl.reshape(-1,49), ypipe.inverse_transform(model.predict(tX_vl[:,m].reshape(-1,49*m.sum()))))**0.5 *86400"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "4553968a-f2da-465d-ae44-d2329292df27",
   "metadata": {
    "collapsed": true,
    "jupyter": {
     "outputs_hidden": true,
     "source_hidden": true
    },
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "  epoch    train_loss    valid_loss      dur\n",
      "-------  ------------  ------------  -------\n",
      "      1        \u001b[36m0.9024\u001b[0m        \u001b[32m0.8563\u001b[0m  54.1684\n",
      "      2        \u001b[36m0.6732\u001b[0m        \u001b[32m0.4633\u001b[0m  53.5771\n",
      "      3        \u001b[36m0.4376\u001b[0m        \u001b[32m0.2927\u001b[0m  40.8223\n",
      "      4        \u001b[36m0.3327\u001b[0m        0.7593  40.3786\n",
      "      5        \u001b[36m0.2560\u001b[0m        \u001b[32m0.2219\u001b[0m  38.5050\n",
      "      6        \u001b[36m0.2085\u001b[0m        \u001b[32m0.1776\u001b[0m  37.3132\n",
      "      7        \u001b[36m0.1790\u001b[0m        \u001b[32m0.1308\u001b[0m  39.0657\n",
      "      8        \u001b[36m0.1554\u001b[0m        \u001b[32m0.1196\u001b[0m  41.9554\n",
      "      9        \u001b[36m0.1373\u001b[0m        \u001b[32m0.1167\u001b[0m  38.3609\n",
      "     10        \u001b[36m0.1212\u001b[0m        \u001b[32m0.0937\u001b[0m  42.0799\n",
      "     11        \u001b[36m0.1087\u001b[0m        \u001b[32m0.0787\u001b[0m  51.2504\n",
      "     12        \u001b[36m0.0988\u001b[0m        0.0854  48.2697\n",
      "     13        \u001b[36m0.0905\u001b[0m        0.0967  37.9691\n",
      "     14        \u001b[36m0.0840\u001b[0m        \u001b[32m0.0636\u001b[0m  41.5250\n",
      "     15        \u001b[36m0.0779\u001b[0m        0.0700  40.3586\n",
      "     16        \u001b[36m0.0733\u001b[0m        0.0838  36.0022\n",
      "     17        \u001b[36m0.0684\u001b[0m        0.0646  40.5906\n",
      "     18        \u001b[36m0.0645\u001b[0m        0.0670  42.7730\n",
      "     19        \u001b[36m0.0609\u001b[0m        \u001b[32m0.0624\u001b[0m  38.2386\n",
      "     20        \u001b[36m0.0574\u001b[0m        \u001b[32m0.0497\u001b[0m  37.9670\n",
      "     21        \u001b[36m0.0547\u001b[0m        0.0631  40.6936\n",
      "     22        \u001b[36m0.0523\u001b[0m        0.0512  42.9357\n",
      "     23        \u001b[36m0.0499\u001b[0m        \u001b[32m0.0485\u001b[0m  39.1445\n",
      "     24        \u001b[36m0.0478\u001b[0m        0.0520  34.5715\n",
      "     25        \u001b[36m0.0455\u001b[0m        \u001b[32m0.0421\u001b[0m  41.5884\n",
      "     26        \u001b[36m0.0434\u001b[0m        0.0422  41.8693\n",
      "     27        \u001b[36m0.0416\u001b[0m        0.0553  41.7017\n",
      "     28        \u001b[36m0.0401\u001b[0m        \u001b[32m0.0384\u001b[0m  52.0437\n",
      "     29        \u001b[36m0.0385\u001b[0m        \u001b[32m0.0368\u001b[0m  46.6407\n",
      "     30        \u001b[36m0.0371\u001b[0m        0.0443  45.3940\n",
      "     31        \u001b[36m0.0356\u001b[0m        \u001b[32m0.0296\u001b[0m  53.8928\n",
      "     32        \u001b[36m0.0346\u001b[0m        0.0308  42.1914\n",
      "     33        \u001b[36m0.0334\u001b[0m        0.0416  56.9509\n",
      "     34        \u001b[36m0.0322\u001b[0m        0.0386  42.1070\n",
      "     35        \u001b[36m0.0312\u001b[0m        \u001b[32m0.0259\u001b[0m  55.8079\n",
      "     36        \u001b[36m0.0298\u001b[0m        \u001b[32m0.0241\u001b[0m  42.5677\n",
      "     37        \u001b[36m0.0293\u001b[0m        0.0306  51.6492\n",
      "     38        \u001b[36m0.0285\u001b[0m        0.0273  58.0116\n",
      "     39        \u001b[36m0.0279\u001b[0m        0.0304  56.8761\n",
      "     40        \u001b[36m0.0271\u001b[0m        0.0298  54.0824\n",
      "     41        \u001b[36m0.0263\u001b[0m        0.0286  53.9833\n",
      "     42        \u001b[36m0.0256\u001b[0m        0.0272  52.7951\n",
      "     43        \u001b[36m0.0255\u001b[0m        0.0297  53.5195\n",
      "     44        \u001b[36m0.0246\u001b[0m        0.0314  41.0793\n",
      "     45        \u001b[36m0.0241\u001b[0m        0.0260  55.0410\n",
      "     46        \u001b[36m0.0239\u001b[0m        \u001b[32m0.0202\u001b[0m  50.3406\n",
      "     47        \u001b[36m0.0231\u001b[0m        0.0235  47.1657\n",
      "     48        \u001b[36m0.0225\u001b[0m        \u001b[32m0.0173\u001b[0m  33.9863\n",
      "     49        0.0230        0.0308  42.6716\n",
      "     50        \u001b[36m0.0219\u001b[0m        0.0234  44.0037\n",
      "     51        0.0221        0.0176  39.7721\n",
      "     52        \u001b[36m0.0214\u001b[0m        0.0203  59.2431\n",
      "     53        \u001b[36m0.0214\u001b[0m        0.0224  52.1786\n",
      "     54        \u001b[36m0.0208\u001b[0m        0.0181  51.6763\n",
      "     55        \u001b[36m0.0207\u001b[0m        0.0243  53.2285\n",
      "     56        \u001b[36m0.0204\u001b[0m        0.0240  35.8010\n",
      "     57        \u001b[36m0.0201\u001b[0m        \u001b[32m0.0155\u001b[0m  36.0638\n",
      "     58        \u001b[36m0.0195\u001b[0m        0.0166  39.9703\n",
      "     59        0.0196        0.0202  42.0488\n",
      "     60        \u001b[36m0.0193\u001b[0m        0.0179  36.5772\n",
      "     61        \u001b[36m0.0190\u001b[0m        0.0182  34.1031\n",
      "     62        \u001b[36m0.0188\u001b[0m        0.0204  35.8407\n",
      "     63        \u001b[36m0.0184\u001b[0m        0.0155  58.3653\n",
      "     64        0.0187        0.0164  42.2227\n",
      "     65        \u001b[36m0.0181\u001b[0m        \u001b[32m0.0138\u001b[0m  46.4131\n",
      "     66        0.0182        0.0195  49.6297\n",
      "     67        \u001b[36m0.0176\u001b[0m        0.0163  44.2639\n",
      "     68        0.0179        0.0147  56.4154\n",
      "     69        0.0177        0.0190  55.0940\n",
      "     70        \u001b[36m0.0175\u001b[0m        0.0165  45.8280\n",
      "     71        \u001b[36m0.0172\u001b[0m        0.0158  56.3536\n",
      "     72        \u001b[36m0.0168\u001b[0m        0.0143  49.8945\n",
      "     73        0.0169        0.0165  39.4087\n",
      "     74        0.0169        0.0198  49.6750\n",
      "     75        \u001b[36m0.0164\u001b[0m        0.0196  46.3746\n",
      "     76        0.0165        0.0143  48.1378\n",
      "     77        \u001b[36m0.0162\u001b[0m        0.0180  40.4423\n",
      "     78        \u001b[36m0.0161\u001b[0m        0.0173  42.5609\n",
      "     79        \u001b[36m0.0159\u001b[0m        0.0159  46.4319\n",
      "     80        \u001b[36m0.0159\u001b[0m        0.0185  42.2305\n",
      "     81        \u001b[36m0.0158\u001b[0m        0.0149  43.5154\n",
      "     82        0.0158        0.0146  43.9083\n",
      "     83        \u001b[36m0.0155\u001b[0m        0.0162  41.4259\n",
      "     84        \u001b[36m0.0152\u001b[0m        0.0168  49.5612\n",
      "     85        0.0153        0.0192  43.9369\n",
      "     86        \u001b[36m0.0149\u001b[0m        0.0194  45.1554\n",
      "     87        0.0152        0.0148  44.3984\n",
      "     88        \u001b[36m0.0149\u001b[0m        0.0142  43.2976\n",
      "     89        0.0149        0.0155  45.0872\n",
      "     90        \u001b[36m0.0144\u001b[0m        0.0167  48.8876\n",
      "     91        0.0148        \u001b[32m0.0122\u001b[0m  47.1328\n",
      "     92        0.0145        \u001b[32m0.0116\u001b[0m  43.2988\n",
      "     93        0.0145        0.0189  54.5241\n",
      "     94        \u001b[36m0.0143\u001b[0m        \u001b[32m0.0114\u001b[0m  45.1865\n",
      "     95        \u001b[36m0.0141\u001b[0m        0.0137  45.6268\n",
      "     96        \u001b[36m0.0140\u001b[0m        0.0117  47.3325\n",
      "     97        \u001b[36m0.0139\u001b[0m        0.0189  39.5592\n",
      "     98        0.0140        0.0135  40.7046\n",
      "     99        \u001b[36m0.0135\u001b[0m        0.0141  44.2638\n",
      "    100        0.0139        0.0156  44.3049\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "0.7843524260290679"
      ]
     },
     "execution_count": 31,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "class Polynom(nn.Module):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "    def forward(self, inp):\n",
    "        n,c,l = inp.shape\n",
    "        return torch.cat([inp, (inp[:,:,None,:]*inp[:,None,:,:]).view(n,c**2,l)], 1)\n",
    "\n",
    "class tmpnn2d(nn.Module):\n",
    "    def __init__(self):\n",
    "        h = 16\n",
    "        self.steps = 15\n",
    "        super().__init__()\n",
    "        self.enc = nn.Conv1d(m.sum(),h,3,padding=1)\n",
    "        self.tmap = nn.Sequential(Polynom(), nn.Conv1d(h+h**2,h,3,padding=1))\n",
    "        self.dec = nn.Conv1d(h,1,3,padding=1)\n",
    "        \n",
    "    def forward(self, inp):\n",
    "        # b,cl -> b,c,l\n",
    "        inp = inp.float().reshape(-1,49,m.sum()).transpose(1,2)\n",
    "        mm = self.enc(inp)\n",
    "        for _ in range(self.steps):\n",
    "            mm = mm + self.tmap(mm)/self.steps\n",
    "        return self.dec(mm)[:,0]\n",
    "        \n",
    "model = NeuralNetRegressor(tmpnn2d, max_epochs=100, lr=1e-3, iterator_train__shuffle=True, device='cuda', batch_size=512)\n",
    "model.fit(tX_tr[:,m].reshape(-1,49*m.sum()), ty_tr.reshape(-1,49))\n",
    "model.score(tX_vl[:,m].reshape(-1,49*m.sum()), ty_vl.reshape(-1,49))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "d1202fff-9abe-48a9-a431-99de06106b64",
   "metadata": {
    "collapsed": true,
    "jupyter": {
     "outputs_hidden": true,
     "source_hidden": true
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.19003813826524565"
      ]
     },
     "execution_count": 32,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "mse(y_vl.reshape(-1,49), ypipe.inverse_transform(model.predict(tX_vl[:,m].reshape(-1,49*m.sum()))))**0.5 *86400"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "db80795c-db44-4d59-97ae-d5535241f6a2",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "  epoch    train_loss    valid_loss       dur\n",
      "-------  ------------  ------------  --------\n",
      "      1        \u001b[36m0.2601\u001b[0m        \u001b[32m0.1260\u001b[0m  166.8252\n",
      "      2        \u001b[36m0.0877\u001b[0m        \u001b[32m0.0906\u001b[0m  168.0628\n",
      "      3        \u001b[36m0.0544\u001b[0m        \u001b[32m0.0407\u001b[0m  172.6233\n",
      "      4        \u001b[36m0.0396\u001b[0m        \u001b[32m0.0351\u001b[0m  171.6279\n",
      "      5        \u001b[36m0.0309\u001b[0m        \u001b[32m0.0281\u001b[0m  165.3864\n",
      "      6        \u001b[36m0.0253\u001b[0m        \u001b[32m0.0213\u001b[0m  170.6661\n",
      "      7        \u001b[36m0.0215\u001b[0m        \u001b[32m0.0135\u001b[0m  170.1260\n",
      "      8        \u001b[36m0.0186\u001b[0m        0.0489  172.5565\n",
      "      9        \u001b[36m0.0164\u001b[0m        \u001b[32m0.0106\u001b[0m  171.8387\n",
      "     10        \u001b[36m0.0146\u001b[0m        \u001b[32m0.0094\u001b[0m  162.0149\n",
      "     11        \u001b[36m0.0132\u001b[0m        \u001b[32m0.0094\u001b[0m  168.3426\n",
      "     12        \u001b[36m0.0121\u001b[0m        0.0094  168.1675\n",
      "     13        \u001b[36m0.0111\u001b[0m        \u001b[32m0.0072\u001b[0m  169.2001\n",
      "     14        \u001b[36m0.0104\u001b[0m        0.0079  169.7679\n",
      "     15        \u001b[36m0.0096\u001b[0m        0.0109  168.4488\n",
      "     16        \u001b[36m0.0091\u001b[0m        0.0099  170.2746\n",
      "     17        \u001b[36m0.0085\u001b[0m        \u001b[32m0.0056\u001b[0m  170.9045\n",
      "     18        \u001b[36m0.0081\u001b[0m        0.0098  173.0510\n",
      "     19        \u001b[36m0.0076\u001b[0m        0.0098  160.8825\n",
      "     20        \u001b[36m0.0073\u001b[0m        0.0056  167.2041\n",
      "     21        \u001b[36m0.0070\u001b[0m        0.0101  164.8673\n",
      "     22        \u001b[36m0.0067\u001b[0m        \u001b[32m0.0048\u001b[0m  166.9617\n",
      "     23        \u001b[36m0.0064\u001b[0m        \u001b[32m0.0046\u001b[0m  173.9679\n",
      "     24        \u001b[36m0.0062\u001b[0m        0.0046  162.9781\n",
      "     25        \u001b[36m0.0059\u001b[0m        \u001b[32m0.0044\u001b[0m  169.2358\n",
      "     26        \u001b[36m0.0057\u001b[0m        0.0049  171.1931\n",
      "     27        \u001b[36m0.0055\u001b[0m        \u001b[32m0.0040\u001b[0m  169.7739\n",
      "     28        \u001b[36m0.0053\u001b[0m        0.0064  170.5531\n",
      "     29        \u001b[36m0.0052\u001b[0m        \u001b[32m0.0037\u001b[0m  164.1012\n",
      "     30        \u001b[36m0.0050\u001b[0m        0.0060  169.7930\n",
      "     31        \u001b[36m0.0049\u001b[0m        0.0106  174.7347\n",
      "     32        \u001b[36m0.0047\u001b[0m        0.0042  167.3532\n",
      "     33        \u001b[36m0.0046\u001b[0m        \u001b[32m0.0037\u001b[0m  170.8356\n",
      "     34        \u001b[36m0.0044\u001b[0m        0.0043  165.2177\n",
      "     35        \u001b[36m0.0044\u001b[0m        0.0084  167.3403\n",
      "     36        \u001b[36m0.0043\u001b[0m        0.0042  171.5994\n",
      "     37        \u001b[36m0.0042\u001b[0m        0.0041  174.3683\n",
      "     38        \u001b[36m0.0041\u001b[0m        0.0051  170.0911\n",
      "     39        \u001b[36m0.0040\u001b[0m        \u001b[32m0.0036\u001b[0m  169.4579\n",
      "     40        \u001b[36m0.0039\u001b[0m        \u001b[32m0.0033\u001b[0m  171.2968\n",
      "     41        \u001b[36m0.0039\u001b[0m        \u001b[32m0.0032\u001b[0m  169.9857\n",
      "     42        \u001b[36m0.0038\u001b[0m        0.0050  167.2480\n",
      "     43        \u001b[36m0.0037\u001b[0m        \u001b[32m0.0029\u001b[0m  173.5727\n"
     ]
    }
   ],
   "source": [
    "class rnn2d(nn.Module): \n",
    "    def __init__(self):\n",
    "        h = 512\n",
    "        self.steps = 10\n",
    "        super().__init__()\n",
    "        self.enc = nn.Conv1d(m.sum(),h,3,padding=1)\n",
    "        self.map = nn.Sequential(\n",
    "                nn.Conv1d(h,h,3,padding=1),\n",
    "                nn.ReLU(True),\n",
    "                nn.Conv1d(h,h,3,padding=1),\n",
    "                nn.ReLU(True)\n",
    "            )\n",
    "        self.dec = nn.Conv1d(h,8,3,padding=1)\n",
    "        self.fdec = nn.Linear(12,6)\n",
    "        \n",
    "    def forward(self, inp):\n",
    "        # b,cl -> b,c,l\n",
    "        inp = inp.float().reshape(-1,49,m.sum()).transpose(1,2)\n",
    "        mm = self.enc(inp)\n",
    "        for _ in range(self.steps):\n",
    "            mm = mm + self.map(mm)/self.steps\n",
    "        out = self.dec(mm).transpose(1,2)\n",
    "        y = out[:,:,:2].reshape(-1,49*2)\n",
    "        # fup = out[:,-1,[2,3,5,6]]\n",
    "        # fdn = out[:,0,[4,7]]\n",
    "        # return torch.cat((y,fup,fdn),1)\n",
    "        f = self.fdec(out[:,[0,-1],2:].reshape(-1,12))\n",
    "        return torch.cat((y,f),1)\n",
    "        \n",
    "#input maxmin, target standard   \n",
    "# model.warm_start = True\n",
    "model = NeuralNetRegressor(rnn2d, max_epochs=100, lr=1e-2, iterator_train__shuffle=True, device='cuda')\n",
    "model.fit(tX_tr[:,m].reshape(-1,49*m.sum()), np.concatenate((ty_tr.reshape(-1,49*2), tf_tr), 1))\n",
    "# model.module_.load_state_dict(torch.load('weights_wrf/rnn2d128.7.pt'))\n",
    "print(model.score(tX_ts[:,m].reshape(-1,49*m.sum()), np.concatenate((ty_ts.reshape(-1,49*2), tf_ts), 1) ))\n",
    "pred = model.predict(tX_ts[:,m].reshape(-1,49*m.sum()))\n",
    "y_pred = ypipe.inverse_transform(pred[:,:-6].reshape(-1,2))\n",
    "f_pred = fpipe.inverse_transform(pred[:,-6:])\n",
    "print(mse(y_ts[:,0], y_pred[:,0])**0.5 *86400, mse(y_ts[:,1], y_pred[:,1])**0.5 *86400, mse(f_ts, f_pred)**0.5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d96afdd4-12df-4c01-94a5-809212e45fae",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 290,
   "id": "f7dc53d1-60af-4cf3-9c20-b4260f400804",
   "metadata": {},
   "outputs": [],
   "source": [
    "# torch.save(model.module_.state_dict(), 'weights_wrf/rnn2d128.7f.pt')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 105,
   "id": "57f83195-ab41-48c1-b014-535266643558",
   "metadata": {
    "collapsed": true,
    "jupyter": {
     "outputs_hidden": true,
     "source_hidden": true
    },
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "    201        0.0049        0.0047  38.3323\n",
      "    202        0.0049        0.0048  38.2977\n",
      "    203        \u001b[36m0.0049\u001b[0m        0.0047  41.2654\n",
      "    204        0.0049        0.0046  37.7343\n",
      "    205        \u001b[36m0.0049\u001b[0m        0.0048  38.2304\n",
      "    206        \u001b[36m0.0049\u001b[0m        \u001b[32m0.0045\u001b[0m  37.6915\n",
      "    207        \u001b[36m0.0049\u001b[0m        0.0046  37.4080\n",
      "    208        0.0049        0.0045  37.8266\n",
      "    209        0.0049        0.0052  37.5246\n",
      "    210        \u001b[36m0.0049\u001b[0m        0.0049  37.5552\n",
      "    211        \u001b[36m0.0048\u001b[0m        \u001b[32m0.0044\u001b[0m  37.5917\n",
      "    212        \u001b[36m0.0048\u001b[0m        0.0045  38.3610\n",
      "    213        \u001b[36m0.0048\u001b[0m        \u001b[32m0.0044\u001b[0m  39.5694\n",
      "    214        0.0048        0.0047  37.8806\n",
      "    215        0.0048        0.0046  38.9193\n",
      "    216        \u001b[36m0.0048\u001b[0m        0.0047  37.3491\n",
      "    217        \u001b[36m0.0048\u001b[0m        0.0046  37.2853\n",
      "    218        \u001b[36m0.0048\u001b[0m        0.0045  37.0776\n",
      "    219        0.0048        0.0047  36.9383\n",
      "    220        \u001b[36m0.0048\u001b[0m        \u001b[32m0.0044\u001b[0m  37.1349\n",
      "    221        0.0048        0.0047  38.0013\n",
      "    222        \u001b[36m0.0048\u001b[0m        0.0047  37.8926\n",
      "    223        0.0048        0.0047  36.7574\n",
      "    224        \u001b[36m0.0048\u001b[0m        0.0048  37.3297\n",
      "    225        0.0048        0.0048  37.6223\n",
      "    226        \u001b[36m0.0048\u001b[0m        0.0044  37.1632\n",
      "    227        0.0048        0.0045  40.4944\n",
      "    228        \u001b[36m0.0047\u001b[0m        0.0044  39.6153\n",
      "    229        \u001b[36m0.0047\u001b[0m        0.0048  37.2878\n",
      "    230        0.0048        0.0054  37.0606\n",
      "    231        \u001b[36m0.0047\u001b[0m        0.0045  38.2982\n",
      "    232        0.0047        0.0044  37.6787\n",
      "    233        0.0047        0.0044  36.9363\n",
      "    234        \u001b[36m0.0047\u001b[0m        0.0045  38.2050\n",
      "    235        \u001b[36m0.0047\u001b[0m        0.0045  36.7588\n",
      "    236        0.0047        0.0046  37.6379\n",
      "    237        \u001b[36m0.0047\u001b[0m        0.0046  38.0460\n",
      "    238        0.0047        0.0052  37.6950\n",
      "    239        0.0047        \u001b[32m0.0043\u001b[0m  38.1418\n",
      "    240        \u001b[36m0.0047\u001b[0m        0.0043  37.5253\n",
      "    241        0.0047        0.0045  38.1154\n",
      "    242        \u001b[36m0.0047\u001b[0m        0.0046  38.6726\n",
      "    243        0.0047        0.0044  37.8494\n",
      "    244        0.0047        0.0044  39.5312\n",
      "    245        0.0047        0.0059  36.8796\n",
      "    246        0.0047        0.0044  36.7709\n",
      "    247        \u001b[36m0.0047\u001b[0m        0.0050  36.7810\n",
      "    248        \u001b[36m0.0046\u001b[0m        0.0045  37.5929\n",
      "    249        \u001b[36m0.0046\u001b[0m        0.0079  38.2009\n",
      "    250        \u001b[36m0.0046\u001b[0m        0.0046  36.9652\n",
      "    251        \u001b[36m0.0046\u001b[0m        \u001b[32m0.0043\u001b[0m  37.5727\n",
      "    252        \u001b[36m0.0046\u001b[0m        0.0043  37.0910\n",
      "    253        0.0046        0.0044  36.8175\n",
      "    254        0.0046        0.0044  37.6871\n",
      "    255        0.0046        0.0047  39.6769\n",
      "    256        \u001b[36m0.0046\u001b[0m        \u001b[32m0.0042\u001b[0m  37.5866\n",
      "    257        \u001b[36m0.0046\u001b[0m        \u001b[32m0.0042\u001b[0m  38.2624\n",
      "    258        0.0046        0.0044  37.2082\n",
      "    259        0.0046        0.0043  36.7636\n",
      "    260        0.0046        0.0043  36.8380\n",
      "    261        0.0046        0.0043  39.9088\n",
      "    262        0.0046        0.0056  37.0906\n",
      "    263        \u001b[36m0.0046\u001b[0m        0.0043  37.2761\n",
      "    264        \u001b[36m0.0046\u001b[0m        0.0044  36.7103\n",
      "    265        0.0046        0.0042  37.1333\n",
      "    266        \u001b[36m0.0046\u001b[0m        0.0042  37.6542\n",
      "    267        0.0046        0.0043  37.8167\n",
      "    268        \u001b[36m0.0045\u001b[0m        \u001b[32m0.0042\u001b[0m  37.0804\n",
      "    269        0.0046        0.0050  37.5911\n",
      "    270        0.0046        0.0061  37.9258\n",
      "    271        \u001b[36m0.0045\u001b[0m        0.0064  38.0466\n",
      "    272        0.0045        0.0046  37.7208\n",
      "    273        \u001b[36m0.0045\u001b[0m        0.0046  36.9335\n",
      "    274        0.0045        0.0051  37.7409\n",
      "    275        \u001b[36m0.0045\u001b[0m        0.0049  36.7276\n",
      "    276        0.0045        0.0044  37.7749\n",
      "    277        0.0045        0.0044  37.3265\n",
      "    278        0.0045        0.0049  37.7514\n",
      "    279        0.0045        0.0044  37.6004\n",
      "    280        \u001b[36m0.0045\u001b[0m        0.0043  37.5549\n",
      "    281        \u001b[36m0.0045\u001b[0m        \u001b[32m0.0041\u001b[0m  36.9578\n",
      "    282        0.0045        0.0047  39.0817\n",
      "    283        \u001b[36m0.0045\u001b[0m        0.0044  37.5671\n",
      "    284        0.0045        0.0044  37.2345\n",
      "    285        0.0045        0.0042  36.9186\n",
      "    286        0.0045        0.0052  37.1985\n",
      "    287        \u001b[36m0.0045\u001b[0m        0.0042  37.6443\n",
      "    288        \u001b[36m0.0045\u001b[0m        0.0043  38.6850\n",
      "    289        0.0045        0.0042  38.1509\n",
      "    290        \u001b[36m0.0045\u001b[0m        0.0045  37.4684\n",
      "    291        0.0045        0.0047  38.7442\n",
      "    292        \u001b[36m0.0045\u001b[0m        0.0043  38.0105\n",
      "    293        0.0045        0.0045  39.5457\n",
      "    294        \u001b[36m0.0045\u001b[0m        \u001b[32m0.0041\u001b[0m  38.0637\n",
      "    295        \u001b[36m0.0044\u001b[0m        0.0048  36.5999\n",
      "    296        0.0045        0.0045  37.7253\n",
      "    297        0.0045        0.0042  39.5212\n",
      "    298        \u001b[36m0.0044\u001b[0m        0.0043  37.3625\n",
      "    299        0.0045        0.0042  37.2936\n",
      "    300        \u001b[36m0.0044\u001b[0m        0.0045  39.1651\n",
      "    301        \u001b[36m0.0044\u001b[0m        0.0050  38.6393\n",
      "    302        0.0044        0.0048  38.4276\n",
      "    303        \u001b[36m0.0044\u001b[0m        \u001b[32m0.0041\u001b[0m  40.6592\n",
      "    304        0.0044        0.0044  38.9203\n",
      "    305        0.0044        0.0046  37.3341\n",
      "    306        \u001b[36m0.0044\u001b[0m        0.0042  37.6946\n",
      "    307        0.0044        0.0050  39.1796\n",
      "    308        \u001b[36m0.0044\u001b[0m        0.0041  37.3389\n",
      "    309        \u001b[36m0.0044\u001b[0m        0.0092  36.4641\n",
      "    310        \u001b[36m0.0044\u001b[0m        0.0041  37.2474\n",
      "    311        \u001b[36m0.0044\u001b[0m        0.0047  37.3361\n",
      "    312        0.0044        0.0042  38.0080\n",
      "    313        0.0044        0.0043  38.9797\n",
      "    314        \u001b[36m0.0044\u001b[0m        0.0042  37.5391\n",
      "    315        \u001b[36m0.0044\u001b[0m        0.0067  37.9316\n",
      "    316        0.0044        0.0042  36.4881\n",
      "    317        0.0044        0.0043  37.4689\n",
      "    318        \u001b[36m0.0044\u001b[0m        0.0044  39.2733\n",
      "    319        \u001b[36m0.0043\u001b[0m        0.0041  37.1107\n",
      "    320        0.0044        0.0056  37.7886\n",
      "    321        0.0044        0.0044  38.7099\n",
      "    322        0.0044        \u001b[32m0.0041\u001b[0m  37.3612\n",
      "    323        0.0044        0.0043  38.0315\n",
      "    324        0.0044        0.0044  37.9993\n",
      "    325        \u001b[36m0.0043\u001b[0m        0.0041  40.4167\n",
      "    326        0.0044        0.0044  37.7486\n",
      "    327        \u001b[36m0.0043\u001b[0m        0.0045  60.7556\n",
      "    328        0.0043        0.0041  77.5430\n",
      "    329        0.0044        0.0045  65.8896\n",
      "    330        0.0043        \u001b[32m0.0040\u001b[0m  63.1539\n",
      "    331        \u001b[36m0.0043\u001b[0m        0.0043  63.4714\n",
      "    332        \u001b[36m0.0043\u001b[0m        0.0045  63.7004\n",
      "    333        0.0043        0.0043  69.5409\n",
      "    334        \u001b[36m0.0043\u001b[0m        0.0041  68.4361\n",
      "    335        0.0043        0.0045  66.5130\n",
      "    336        0.0043        0.0047  64.5858\n",
      "    337        \u001b[36m0.0043\u001b[0m        0.0041  63.1061\n",
      "    338        0.0043        \u001b[32m0.0040\u001b[0m  40.3416\n",
      "    339        0.0043        0.0043  37.2788\n",
      "    340        0.0043        0.0043  40.9219\n",
      "    341        \u001b[36m0.0043\u001b[0m        0.0044  38.0044\n",
      "    342        \u001b[36m0.0043\u001b[0m        0.0041  37.6115\n",
      "    343        0.0043        0.0043  38.0505\n",
      "    344        0.0043        0.0043  36.9046\n",
      "    345        0.0043        0.0041  37.7937\n",
      "    346        \u001b[36m0.0043\u001b[0m        \u001b[32m0.0040\u001b[0m  38.0570\n",
      "    347        0.0043        0.0040  37.7685\n",
      "    348        0.0043        0.0040  37.9182\n",
      "    349        0.0043        0.0044  36.9784\n",
      "    350        \u001b[36m0.0043\u001b[0m        0.0041  37.5067\n",
      "    351        0.0043        0.0041  38.3565\n",
      "    352        0.0043        0.0041  38.9066\n",
      "    353        \u001b[36m0.0043\u001b[0m        0.0043  38.5598\n",
      "    354        0.0043        0.0040  41.3883\n",
      "    355        0.0043        0.0041  37.2145\n",
      "    356        \u001b[36m0.0043\u001b[0m        0.0043  37.6067\n",
      "    357        0.0043        0.0044  39.0393\n",
      "    358        0.0043        0.0043  39.8295\n",
      "    359        0.0043        0.0048  38.1301\n",
      "    360        \u001b[36m0.0043\u001b[0m        0.0051  36.9695\n",
      "    361        0.0043        \u001b[32m0.0040\u001b[0m  37.4360\n",
      "    362        \u001b[36m0.0042\u001b[0m        0.0041  38.0497\n",
      "    363        0.0043        0.0041  50.8330\n",
      "    364        0.0042        0.0044  73.1591\n",
      "    365        0.0042        0.0059  72.7241\n",
      "    366        0.0042        0.0041  69.2793\n",
      "    367        0.0042        0.0046  66.7129\n",
      "    368        0.0042        0.0046  68.6124\n",
      "    369        \u001b[36m0.0042\u001b[0m        0.0043  70.9393\n",
      "    370        \u001b[36m0.0042\u001b[0m        0.0041  71.4637\n",
      "    371        0.0042        0.0052  69.3969\n",
      "    372        0.0042        0.0041  64.8083\n",
      "    373        \u001b[36m0.0042\u001b[0m        0.0051  68.2782\n",
      "    374        0.0043        0.0040  76.9800\n",
      "    375        0.0042        0.0043  75.4308\n",
      "    376        \u001b[36m0.0042\u001b[0m        0.0042  76.2420\n",
      "    377        \u001b[36m0.0042\u001b[0m        0.0040  71.4393\n",
      "    378        \u001b[36m0.0042\u001b[0m        0.0043  74.5444\n",
      "    379        0.0042        0.0040  71.3263\n",
      "    380        0.0042        0.0041  71.7353\n",
      "    381        0.0042        \u001b[32m0.0039\u001b[0m  72.6262\n",
      "    382        0.0042        0.0045  74.3592\n",
      "    383        0.0042        0.0043  74.8177\n",
      "    384        \u001b[36m0.0042\u001b[0m        0.0041  76.2537\n",
      "    385        0.0042        0.0043  75.1149\n",
      "    386        \u001b[36m0.0042\u001b[0m        0.0040  74.4688\n",
      "    387        \u001b[36m0.0042\u001b[0m        0.0042  75.7384\n",
      "    388        0.0042        0.0041  110.7925\n",
      "    389        0.0042        0.0049  117.4230\n",
      "    390        0.0042        0.0040  128.4304\n",
      "    391        0.0042        0.0040  116.7676\n",
      "    392        0.0042        0.0040  118.8993\n",
      "    393        0.0042        0.0047  121.7318\n",
      "    395        0.0042        0.0042  117.7806\n",
      "    396        \u001b[36m0.0042\u001b[0m        0.0040  116.0734\n",
      "    397        \u001b[36m0.0042\u001b[0m        0.0043  118.5199\n",
      "    398        \u001b[36m0.0042\u001b[0m        0.0040  124.5285\n",
      "    399        0.0042        0.0040  126.5032\n",
      "    400        \u001b[36m0.0042\u001b[0m        \u001b[32m0.0039\u001b[0m  123.8658\n",
      "0.961503591208403\n",
      "0.027820947548469716 0.11015876507131007 3.5635581870961253\n"
     ]
    }
   ],
   "source": [
    "class rnn2d(nn.Module): \n",
    "    def __init__(self):\n",
    "        h = 32\n",
    "        self.steps = 3\n",
    "        super().__init__()\n",
    "        self.enc = nn.Conv1d(m.sum(),h,3,padding=1)\n",
    "        self.map = nn.Sequential(\n",
    "                nn.Conv1d(h,h,3,padding=1),\n",
    "                nn.ReLU(True),\n",
    "                nn.Conv1d(h,h,3,padding=1),\n",
    "                nn.ReLU(True)\n",
    "            )\n",
    "        self.dec = nn.Conv1d(h,8,3,padding=1)\n",
    "        self.fdec = nn.Linear(12,6)\n",
    "        \n",
    "    def forward(self, inp):\n",
    "        # b,cl -> b,c,l\n",
    "        inp = inp.float().reshape(-1,49,m.sum()).transpose(1,2)\n",
    "        mm = self.enc(inp)\n",
    "        for _ in range(self.steps):\n",
    "            mm = mm + self.map(mm)/self.steps\n",
    "        out = self.dec(mm).transpose(1,2)\n",
    "        y = out[:,:,:2].reshape(-1,49*2)\n",
    "        # fup = out[:,-1,[2,3,5,6]]\n",
    "        # fdn = out[:,0,[4,7]]\n",
    "        # return torch.cat((y,fup,fdn),1)\n",
    "        f = self.fdec(out[:,[0,-1],2:].reshape(-1,12))\n",
    "        return torch.cat((y,f),1)\n",
    "        \n",
    "        # ft = out[:,-1,2:4]\n",
    "        # fb = out[:,0,4:]\n",
    "        # return torch.cat((y, ft[:,[0]],fb[:,:2], ft[:,[1]],fb[:,2:]),1)\n",
    "        \n",
    "#input maxmin, target standard   \n",
    "model.warm_start = True\n",
    "# model = NeuralNetRegressor(rnn2d, max_epochs=200, lr=1e-2, iterator_train__shuffle=True, device='cuda')\n",
    "model.fit(tX_tr[:,m].reshape(-1,49*m.sum()), np.concatenate((ty_tr.reshape(-1,49*2), tf_tr), 1))\n",
    "# model.module_.load_state_dict(torch.load('weights_wrf/rnn2d128.7.pt'))\n",
    "print(model.score(tX_ts[:,m].reshape(-1,49*m.sum()), np.concatenate((ty_ts.reshape(-1,49*2), tf_ts), 1) ))\n",
    "pred = model.predict(tX_ts[:,m].reshape(-1,49*m.sum()))\n",
    "y_pred = ypipe.inverse_transform(pred[:,:-6].reshape(-1,2))\n",
    "f_pred = fpipe.inverse_transform(pred[:,-6:])\n",
    "print(mse(y_ts[:,0], y_pred[:,0])**0.5 *86400, mse(y_ts[:,1], y_pred[:,1])**0.5 *86400, mse(f_ts, f_pred)**0.5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 109,
   "id": "b3d0e9ba-aca9-46cd-8f85-19e9168c6eaf",
   "metadata": {},
   "outputs": [],
   "source": [
    "def speed_measure(model, m):\n",
    "    x = tX_vl[:,m].reshape(-1,49*m.sum()) if m is not None else tX_vl.reshape(-1,49*tX_vl.shape[1])\n",
    "    times = []\n",
    "    for i in trange(10, leave=False):\n",
    "        start = time()\n",
    "        model.predict(x)\n",
    "        times.append(time() - start)\n",
    "    return np.mean(times)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 112,
   "id": "ec9584ac-a2e4-4b38-bd6b-c93e59298c37",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/10 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "1.6034378236903375e-05"
      ]
     },
     "execution_count": 112,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model.batch_size = 128*8\n",
    "speed_measure(model, m)/tX_vl.shape[0]*49"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 104,
   "id": "2c116d0c-d544-468f-b802-3e6bc6d0349b",
   "metadata": {
    "collapsed": true,
    "jupyter": {
     "outputs_hidden": true
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "------------------------------------- Calculate Flops Results -------------------------------------\n",
      "Notations:\n",
      "number of parameters (Params), number of multiply-accumulate operations(MACs),\n",
      "number of floating-point operations (FLOPs), floating-point operations per second (FLOPS),\n",
      "fwd FLOPs (model forward propagation FLOPs), bwd FLOPs (model backward propagation FLOPs),\n",
      "default model backpropagation takes 2.00 times as much computation as forward propagation.\n",
      "\n",
      "Total Training Params:                                                  8.34 K  \n",
      "fwd MACs:                                                               1 MMACs \n",
      "fwd FLOPs:                                                              2.02 MFLOPS\n",
      "fwd+bwd MACs:                                                           3.01 MMACs\n",
      "fwd+bwd FLOPs:                                                          6.07 MFLOPS\n",
      "\n",
      "-------------------------------- Detailed Calculated FLOPs Results --------------------------------\n",
      "Each module caculated is listed after its name in the following order: \n",
      "params, percentage of total params, MACs, percentage of total MACs, FLOPS, percentage of total FLOPs\n",
      "\n",
      "Note: 1. A module can have torch.nn.module or torch.nn.functional to compute logits (e.g. CrossEntropyLoss). \n",
      " They are not counted as submodules in calflops and not to be printed out. However they make up the difference between a parent's MACs and the sum of its submodules'.\n",
      "2. Number of floating-point operations is a theoretical estimation, thus FLOPS computed using that could be larger than the maximum system throughput.\n",
      "\n",
      "rnn2d(\n",
      "  8.34 K = 100% Params, 1 MMACs = 100% MACs, 2.02 MFLOPS = 100% FLOPs\n",
      "  (enc): Conv1d(1.28 K = 15.34% Params, 61.15 KMACs = 6.1% MACs, 123.87 KFLOPS = 6.12% FLOPs, 13, 32, kernel_size=(3,), stride=(1,), padding=(1,))\n",
      "  (map): Sequential(\n",
      "    6.21 K = 74.42% Params, 903.17 KMACs = 90.13% MACs, 1.83 MFLOPS = 90.14% FLOPs\n",
      "    (0): Conv1d(3.1 K = 37.21% Params, 451.58 KMACs = 45.07% MACs, 907.87 KFLOPS = 44.84% FLOPs, 32, 32, kernel_size=(3,), stride=(1,), padding=(1,))\n",
      "    (1): ReLU(0 = 0% Params, 0 MACs = 0% MACs, 4.7 KFLOPS = 0.23% FLOPs, inplace=True)\n",
      "    (2): Conv1d(3.1 K = 37.21% Params, 451.58 KMACs = 45.07% MACs, 907.87 KFLOPS = 44.84% FLOPs, 32, 32, kernel_size=(3,), stride=(1,), padding=(1,))\n",
      "    (3): ReLU(0 = 0% Params, 0 MACs = 0% MACs, 4.7 KFLOPS = 0.23% FLOPs, inplace=True)\n",
      "  )\n",
      "  (dec): Conv1d(776 = 9.3% Params, 37.63 KMACs = 3.76% MACs, 75.66 KFLOPS = 3.74% FLOPs, 32, 8, kernel_size=(3,), stride=(1,), padding=(1,))\n",
      "  (fdec): Linear(78 = 0.94% Params, 72 MACs = 0.01% MACs, 144 FLOPS = 0.01% FLOPs, in_features=12, out_features=6, bias=True)\n",
      ")\n",
      "---------------------------------------------------------------------------------------------------\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('2.02 MFLOPS', '1 MMACs', '8.34 K')"
      ]
     },
     "execution_count": 104,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from calflops import calculate_flops\n",
    "calculate_flops(model=model.module_, input_shape=(1,49,13))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 83,
   "id": "e83c51f1-3004-45f0-beff-2bc8a91f81bc",
   "metadata": {
    "collapsed": true,
    "jupyter": {
     "outputs_hidden": true,
     "source_hidden": true
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.025955700492398214 0.11139697346902155 4.458880949438208\n"
     ]
    }
   ],
   "source": [
    "x_scale = np.array([6.74637170e+01, 1.00522898e-05, 8.98302127e-03, 5.03263657e-02,\n",
    "       6.64638512e+01, 2.60919922e+05, 2.08333333e-02, 1.00000000e+00,\n",
    "       1.28768606e+00, 1.06640978e-02, 1.31467809e+00, 9.99999166e+00,\n",
    "       1.09598278e-02])\n",
    "x_min = np.array([6.83261480e-05, -5.21247991e-02, -1.70708094e+00,  3.56175608e-01,\n",
    "        6.73134323e-05,  0.00000000e+00,  0.00000000e+00, -1.00000000e+00,\n",
    "       -1.91880176e-07, -1.41216673e+01, -9.44235675e-02, -8.79999261e+00,\n",
    "       -2.36327608e+00])\n",
    "y_scale = np.array([5.07591444e-06, 1.57800251e-05])\n",
    "y_mean = np.array([7.29721246e-06, -1.20092908e-05])\n",
    "f_scale = np.array([90.82931736, 97.78437341, 206.92674106, 19.42224699, 42.78058925, 36.30502273])\n",
    "f_mean = np.array([96.61348131,  64.1091299, 264.74280423, 237.2289266, 324.8631409, 245.3347716 ])\n",
    "\n",
    "pred = model.predict((X_vl[:,m]*x_scale + x_min).reshape(-1,49*m.sum()))\n",
    "y_pred = pred[:,:-6].reshape(-1,2)*y_scale + y_mean\n",
    "f_pred = pred[:,-6:]*f_scale + f_mean\n",
    "print(mse(y_vl[:,0], y_pred[:,0])**0.5 *86400, mse(y_vl[:,1], y_pred[:,1])**0.5 *86400, mse(f_vl, f_pred)**0.5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 119,
   "id": "d27a3341-689a-45cb-9db6-cdb9930f03d3",
   "metadata": {
    "collapsed": true,
    "jupyter": {
     "outputs_hidden": true,
     "source_hidden": true
    },
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "217754"
      ]
     },
     "execution_count": 119,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "((flux==0).sum(1)==3).sum()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "01a3b419-51f4-47f8-aba7-7b0bfbc6c693",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [],
   "source": [
    "class RNN_bi(nn.Module):\n",
    "    def __init__(self):\n",
    "        super(RNN_bi, self).__init__()\n",
    "        seq_size=6\n",
    "        sca_size=6\n",
    "        hidden_size=emb_size=output_size=128\n",
    "        n_targets = 2\n",
    "        n_toa_fluxes = 1\n",
    "        n_srf_fluxes = 2\n",
    "\n",
    "        self.hidden_size = hidden_size\n",
    "        self.emb_size = emb_size\n",
    "        self.output_size = output_size\n",
    "\n",
    "        self.emb1 = nn.Linear(sca_size, self.emb_size)\n",
    "        self.emb_f = nn.Linear(self.emb_size, self.hidden_size)\n",
    "        self.emb_b = nn.Linear(self.emb_size, self.hidden_size)\n",
    "        self.i2h1_f = nn.Linear(seq_size + hidden_size, hidden_size)\n",
    "        self.i2h2_f = nn.Linear(hidden_size, hidden_size)\n",
    "        self.i2h1_b = nn.Linear(seq_size + hidden_size, hidden_size)\n",
    "        self.i2h2_b = nn.Linear(hidden_size, hidden_size)\n",
    "        self.h2o_f = nn.Linear(hidden_size, output_size)\n",
    "        self.h2o_b = nn.Linear(hidden_size, output_size)\n",
    "        #self.o2o = nn.Linear(2*hidden_size, 2)\n",
    "        self.o2o = nn.Linear(2*hidden_size, n_targets)\n",
    "\n",
    "        #NY\n",
    "        self.hid_hr2toa = nn.Linear(hidden_size + output_size, n_toa_fluxes*n_targets)    # single flux at TOA for each radiation\n",
    "        self.hid_hr2srf = nn.Linear(hidden_size + output_size, n_srf_fluxes*n_targets)  # two fluxes at earth surface for each radiation\n",
    "\n",
    "        nn.init.xavier_uniform_(self.emb1.weight)\n",
    "        nn.init.zeros_(self.emb1.bias)\n",
    "\n",
    "        nn.init.xavier_uniform_(self.emb_f.weight)\n",
    "        nn.init.zeros_(self.emb_f.bias)\n",
    "\n",
    "        nn.init.xavier_uniform_(self.emb_b.weight)\n",
    "        nn.init.zeros_(self.emb_b.bias)\n",
    "\n",
    "        nn.init.xavier_uniform_(self.i2h1_f.weight)\n",
    "        nn.init.zeros_(self.i2h1_f.bias)\n",
    "\n",
    "        nn.init.xavier_uniform_(self.i2h2_f.weight)\n",
    "        nn.init.zeros_(self.i2h2_f.bias)\n",
    "\n",
    "        nn.init.xavier_uniform_(self.i2h1_b.weight)\n",
    "        nn.init.zeros_(self.i2h1_b.bias)\n",
    "\n",
    "        nn.init.xavier_uniform_(self.i2h2_b.weight)\n",
    "        nn.init.zeros_(self.i2h2_b.bias)\n",
    "\n",
    "        nn.init.xavier_uniform_(self.h2o_f.weight)\n",
    "        nn.init.zeros_(self.h2o_f.bias)\n",
    "\n",
    "        nn.init.xavier_uniform_(self.h2o_b.weight)\n",
    "        nn.init.zeros_(self.h2o_b.bias)\n",
    "\n",
    "        nn.init.xavier_uniform_(self.o2o.weight)\n",
    "        nn.init.zeros_(self.o2o.bias)\n",
    "\n",
    "        #NY\n",
    "        nn.init.xavier_uniform_(self.hid_hr2toa.weight)\n",
    "        nn.init.zeros_(self.hid_hr2toa.bias)\n",
    "\n",
    "        nn.init.xavier_uniform_(self.hid_hr2srf.weight)\n",
    "        nn.init.zeros_(self.hid_hr2srf.bias)\n",
    "\n",
    "    def subforward(self, input_f, input_b, hidden_f, hidden_b):\n",
    "        combined_f = torch.cat((input_f, hidden_f), -1)\n",
    "        hidden_f = torch.relu(self.i2h2_f(torch.relu(self.i2h1_f(combined_f))))\n",
    "        output_f = self.h2o_f(hidden_f)\n",
    "        combined_b = torch.cat((input_b, hidden_b), -1)\n",
    "        hidden_b = torch.relu(self.i2h2_b(torch.relu(self.i2h1_b(combined_b))))\n",
    "        output_b = self.h2o_b(hidden_b)\n",
    "        return output_f, output_b, hidden_f, hidden_b\n",
    "\n",
    "    def initHidden(self, in_sca):\n",
    "        # print('in_sca', in_sca.shape)\n",
    "        a1 = torch.relu(self.emb1(in_sca))\n",
    "        return torch.relu(self.emb_f(a1)), torch.relu(self.emb_b(a1))\n",
    "\n",
    "    def forward(self, inp):\n",
    "        inp = inp.float().reshape(-1,49,13)\n",
    "        # (b,c1,l), (l), (b,c0)\n",
    "        in_seq, h, in_sca = inp[:,:,:6], inp[0,:,6], inp[:,0,7:]\n",
    "        \n",
    "        hid_f0, hid_b0 = self.initHidden(in_sca) #NY\n",
    "        hid_f, hid_b = hid_f0, hid_b0\n",
    "        \n",
    "        outputs_f, outputs_b, preds = [], [], []\n",
    "        for i in range(in_seq.size()[1]):\n",
    "            out_f, out_b, hid_f, hid_b = self.subforward(in_seq[:, i, :], in_seq[:, -(1+i), :], hid_f, hid_b)\n",
    "            outputs_f.append(out_f)\n",
    "            outputs_b.append(out_b)\n",
    "        outputs_b = outputs_b[::-1]\n",
    "        \n",
    "        pred_list = []\n",
    "        for i in range(in_seq.size()[1]):\n",
    "            pred_list.append(self.o2o(torch.relu(torch.cat([outputs_f[i], outputs_b[i]], axis=1))))\n",
    "        preds = torch.stack(pred_list, dim=-1)\n",
    "        #NY 2023-06-20\n",
    "        # layer 0  == TOA\n",
    "        # layet 48 == surf\n",
    "        y = preds.reshape(-1,49*2)\n",
    "        ft = self.hid_hr2toa(torch.relu(torch.cat([ hid_f0, outputs_b[0 ]], axis=1)))   #in_seq[:,0,:]  \n",
    "        fb = self.hid_hr2srf(torch.relu(torch.cat([ hid_b0, outputs_f[-1]], axis=1)))   #in_seq[:,-1,:]\n",
    "        \n",
    "        return torch.cat((y, ft[:,[0]],fb[:,:2], ft[:,[1]],fb[:,2:]),1)\n",
    "        "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "9024d37c-319f-4f9f-a7de-bcbef45daeca",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-2.0534669994225556\n",
      "0.4463491801100152 1.625286788595202 99.09090188275358\n"
     ]
    }
   ],
   "source": [
    "model = NeuralNetRegressor(RNN_bi, max_epochs=0, lr=1e-2, iterator_train__shuffle=True, device='cuda', batch_size=128)\n",
    "                           # callbacks=[skorch.callbacks.GradientNormClipping(gradient_clip_value=0.01)])\n",
    "model.fit(tX_tr[:,m].reshape(-1,49*m.sum()), np.concatenate((ty_tr.reshape(-1,49*2), tf_tr), 1))\n",
    "print(model.score(tX_vl[:,m].reshape(-1,49*m.sum()), np.concatenate((ty_vl.reshape(-1,49*2), tf_vl), 1) ))\n",
    "pred = model.predict(tX_vl[:,m].reshape(-1,49*m.sum()))\n",
    "y_pred = ypipe.inverse_transform(pred[:,:-6].reshape(-1,2))\n",
    "f_pred = fpipe.inverse_transform(pred[:,-6:])\n",
    "print(mse(y_vl[:,0], y_pred[:,0])**0.5 *86400, mse(y_vl[:,1], y_pred[:,1])**0.5 *86400, mse(f_vl, f_pred)**0.5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 168,
   "id": "1703cf08-a72b-4922-8272-8c0d1fa1d373",
   "metadata": {
    "collapsed": true,
    "jupyter": {
     "outputs_hidden": true,
     "source_hidden": true
    },
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "    101        \u001b[36m0.0036\u001b[0m        0.0051  29.4808\n",
      "    102        \u001b[36m0.0036\u001b[0m        \u001b[32m0.0026\u001b[0m  30.6182\n",
      "    103        \u001b[36m0.0035\u001b[0m        0.0030  29.5936\n",
      "    104        0.0035        0.0029  34.6468\n",
      "    105        0.0035        0.0027  31.4323\n",
      "    106        \u001b[36m0.0034\u001b[0m        0.0028  30.9167\n",
      "    107        0.0034        0.0041  29.3819\n",
      "    108        \u001b[36m0.0034\u001b[0m        0.0029  29.3158\n",
      "    109        \u001b[36m0.0033\u001b[0m        \u001b[32m0.0025\u001b[0m  29.0004\n",
      "    110        0.0035        0.0031  29.9615\n",
      "    111        0.0034        0.0028  30.3089\n",
      "    112        0.0034        0.0041  29.8193\n",
      "    113        \u001b[36m0.0033\u001b[0m        0.0034  29.3325\n",
      "    114        0.0033        0.0027  29.9281\n",
      "    115        \u001b[36m0.0033\u001b[0m        0.0058  30.0512\n",
      "    116        \u001b[36m0.0033\u001b[0m        0.0033  29.5215\n",
      "    117        \u001b[36m0.0033\u001b[0m        0.0038  30.5310\n",
      "    118        \u001b[36m0.0032\u001b[0m        0.0032  29.6258\n",
      "    119        0.0032        0.0041  29.7628\n",
      "    120        0.0032        0.0028  29.6711\n",
      "    121        \u001b[36m0.0032\u001b[0m        0.0031  29.3053\n",
      "    122        0.0032        0.0027  29.7547\n",
      "    123        0.0032        0.0030  29.3136\n",
      "    124        \u001b[36m0.0031\u001b[0m        0.0025  31.1869\n",
      "    125        0.0031        0.0026  29.9867\n",
      "    126        \u001b[36m0.0031\u001b[0m        \u001b[32m0.0024\u001b[0m  30.6836\n",
      "    127        0.0032        0.0025  29.6815\n",
      "    128        \u001b[36m0.0031\u001b[0m        0.0025  29.9164\n",
      "    129        \u001b[36m0.0031\u001b[0m        0.0028  30.5907\n",
      "    130        0.0031        0.0027  30.2123\n",
      "    131        \u001b[36m0.0030\u001b[0m        0.0024  30.0845\n",
      "    132        0.0031        \u001b[32m0.0023\u001b[0m  30.0432\n",
      "    133        0.0031        0.0061  30.9059\n",
      "    134        0.0031        0.0039  29.5091\n",
      "    135        \u001b[36m0.0030\u001b[0m        0.0026  31.2769\n",
      "    136        \u001b[36m0.0030\u001b[0m        0.0027  32.3494\n",
      "    137        0.0030        0.0025  29.7052\n",
      "    138        0.0030        0.0025  30.3770\n",
      "    139        0.0030        0.0032  29.8810\n",
      "    140        \u001b[36m0.0030\u001b[0m        0.0033  29.6081\n",
      "    141        0.0030        0.0034  29.5915\n",
      "    142        0.0030        0.0024  29.9634\n",
      "    143        \u001b[36m0.0029\u001b[0m        \u001b[32m0.0023\u001b[0m  29.8093\n",
      "    144        \u001b[36m0.0029\u001b[0m        0.0024  30.4196\n",
      "    145        0.0029        0.0030  29.9279\n",
      "    146        \u001b[36m0.0029\u001b[0m        0.0025  29.6021\n",
      "    147        0.0029        0.0025  29.2940\n",
      "    148        0.0029        0.0027  36.3848\n",
      "    149        \u001b[36m0.0029\u001b[0m        0.0024  29.2221\n",
      "    150        0.0029        \u001b[32m0.0023\u001b[0m  29.7050\n",
      "    151        \u001b[36m0.0028\u001b[0m        0.0028  29.8454\n",
      "    152        0.0029        \u001b[32m0.0023\u001b[0m  36.7086\n",
      "    153        0.0028        0.0025  29.2340\n",
      "    154        0.0029        \u001b[32m0.0022\u001b[0m  32.9137\n",
      "    155        \u001b[36m0.0028\u001b[0m        0.0022  29.9415\n",
      "    156        \u001b[36m0.0028\u001b[0m        0.0023  35.7210\n",
      "    157        0.0028        0.0026  30.1515\n",
      "    158        0.0028        0.0024  38.4503\n",
      "    159        \u001b[36m0.0028\u001b[0m        0.0024  38.8838\n",
      "    160        0.0028        0.0025  28.5892\n",
      "    161        0.0028        0.0039  32.7042\n",
      "    162        \u001b[36m0.0027\u001b[0m        \u001b[32m0.0022\u001b[0m  29.9152\n",
      "    163        0.0028        0.0030  28.7888\n",
      "    164        0.0028        0.0025  31.2413\n",
      "    165        0.0028        0.0023  34.3636\n",
      "    166        0.0027        0.0027  32.7648\n",
      "    167        \u001b[36m0.0027\u001b[0m        0.0025  31.1014\n",
      "    169        \u001b[36m0.0027\u001b[0m        0.0023  33.9493\n",
      "    170        0.0027        0.0024  32.6346\n",
      "    171        0.0027        0.0024  28.9885\n",
      "    172        0.0027        0.0027  29.5021\n",
      "    173        \u001b[36m0.0027\u001b[0m        0.0030  29.6340\n",
      "    174        0.0027        0.0024  29.0491\n",
      "    175        0.0027        0.0025  31.3606\n",
      "    176        \u001b[36m0.0027\u001b[0m        0.0024  28.5398\n",
      "    177        0.0027        \u001b[32m0.0021\u001b[0m  30.8750\n",
      "    178        \u001b[36m0.0027\u001b[0m        0.0027  28.7258\n",
      "    179        \u001b[36m0.0026\u001b[0m        0.0040  29.6470\n",
      "    180        0.0027        0.0059  28.7308\n",
      "    181        0.0027        0.0025  28.7457\n",
      "    182        \u001b[36m0.0026\u001b[0m        0.0027  35.9159\n",
      "    183        0.0026        0.0022  28.9744\n",
      "    184        0.0026        0.0026  29.5980\n",
      "    185        0.0027        0.0023  38.0766\n",
      "    186        \u001b[36m0.0025\u001b[0m        0.0033  30.7670\n",
      "    187        0.0026        0.0028  31.2652\n",
      "    188        0.0026        0.0023  31.2722\n",
      "    189        0.0026        0.0026  31.9264\n",
      "    190        0.0026        0.0031  30.9261\n",
      "    191        0.0026        0.0027  31.2986\n",
      "    192        \u001b[36m0.0025\u001b[0m        0.0031  31.2845\n",
      "    193        0.0026        \u001b[32m0.0020\u001b[0m  30.7981\n",
      "    194        0.0026        0.0030  31.1536\n",
      "    195        0.0026        0.0033  30.8077\n",
      "    196        \u001b[36m0.0025\u001b[0m        0.0022  31.2096\n",
      "    197        0.0026        0.0021  30.9290\n",
      "    198        \u001b[36m0.0025\u001b[0m        0.0026  31.5324\n",
      "    199        0.0026        0.0023  30.3005\n",
      "    200        0.0025        0.0035  31.4190\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<class 'skorch.regressor.NeuralNetRegressor'>[initialized](\n",
       "  module_=rnn2d(\n",
       "    (enc): Conv1d(13, 256, kernel_size=(3,), stride=(1,), padding=(1,))\n",
       "    (map): Sequential(\n",
       "      (0): Conv1d(256, 256, kernel_size=(3,), stride=(1,), padding=(1,))\n",
       "      (1): ReLU(inplace=True)\n",
       "      (2): Conv1d(256, 256, kernel_size=(3,), stride=(1,), padding=(1,))\n",
       "      (3): ReLU(inplace=True)\n",
       "    )\n",
       "    (dec): Conv1d(256, 2, kernel_size=(3,), stride=(1,), padding=(1,))\n",
       "  ),\n",
       ")"
      ]
     },
     "execution_count": 168,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model.warm_start=True\n",
    "model.fit(tX_tr[:,m].reshape(-1,49*m.sum()), ty_tr.reshape(-1,49*2))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 169,
   "id": "8d4b5919-4b04-4be2-a06d-a6dacc014f2a",
   "metadata": {
    "collapsed": true,
    "jupyter": {
     "outputs_hidden": true,
     "source_hidden": true
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.9512192511325301\n",
      "0.02184607376094139 0.1220560534732875\n"
     ]
    }
   ],
   "source": [
    "print(model.score(tX_vl[:,m].reshape(-1,49*m.sum()), ty_vl.reshape(-1,49*2)))\n",
    "pred = ypipe.inverse_transform(model.predict(tX_vl[:,m].reshape(-1,49*m.sum())).reshape(-1,2))\n",
    "print(mse(y_vl[:,0], pred[:,0])**0.5 *86400, mse(y_vl[:,1], pred[:,1])**0.5 *86400)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 159,
   "id": "6936bda7-c807-4cfe-a89c-667bfa3acac6",
   "metadata": {
    "collapsed": true,
    "jupyter": {
     "outputs_hidden": true,
     "source_hidden": true
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.02300871279312134 0.10681845879026391\n"
     ]
    }
   ],
   "source": [
    "pred = ypipe.inverse_transform(model.predict(tX_ts[:,m].reshape(-1,49*m.sum())).reshape(-1,2))\n",
    "print(\n",
    "    ((y_ts[:,0]-pred[:,0])[(y_ts[:,0].reshape(-1,49)!=0).any(1,keepdims=True).repeat(49,1).reshape(-1)]**2).mean()**0.5 *86400, \n",
    "    ((y_ts[:,1]-pred[:,1])[(y_ts[:,1].reshape(-1,49)!=0).any(1,keepdims=True).repeat(49,1).reshape(-1)]**2).mean()**0.5 *86400\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "381836f3-0bbd-4ee9-846a-6d2501233b98",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [],
   "source": [
    "mse(y_vl.reshape(-1,49), ypipe.inverse_transform(model.predict(tX_vl[:,m].reshape(-1,49*m.sum()))))**0.5 *86400"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "6c08fe34-2548-4fe2-8a31-2a0fee97793f",
   "metadata": {
    "collapsed": true,
    "jupyter": {
     "outputs_hidden": true,
     "source_hidden": true
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.9283246392378945"
      ]
     },
     "execution_count": 34,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model.score(tX_vl[:,m].reshape(-1,49*m.sum()), ty_vl.reshape(-1,49))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "id": "85b9cf9d-4767-4ce3-ab47-891b1d0a93fb",
   "metadata": {
    "collapsed": true,
    "jupyter": {
     "outputs_hidden": true,
     "source_hidden": true
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<All keys matched successfully>"
      ]
     },
     "execution_count": 51,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model.module_.load_state_dict(torch.load('weights1/rnn2d512.10.pt'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "id": "0bace28c-bb5b-412c-b37b-a1d46eafead6",
   "metadata": {
    "collapsed": true,
    "jupyter": {
     "outputs_hidden": true,
     "source_hidden": true
    },
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "  epoch    train_loss    valid_loss      dur\n",
      "-------  ------------  ------------  -------\n",
      "      1        \u001b[36m1.0886\u001b[0m        \u001b[32m1.0547\u001b[0m  18.6325\n",
      "      2        \u001b[36m1.0389\u001b[0m        \u001b[32m1.0265\u001b[0m  21.8498\n",
      "      3        \u001b[36m0.9722\u001b[0m        \u001b[32m0.7761\u001b[0m  28.2885\n",
      "      4        \u001b[36m0.6795\u001b[0m        \u001b[32m0.5785\u001b[0m  46.6855\n",
      "      5        \u001b[36m0.6265\u001b[0m        0.9384  45.5696\n",
      "      6        0.8464        0.6130  44.0912\n",
      "      7        \u001b[36m0.4988\u001b[0m        \u001b[32m0.3823\u001b[0m  49.5819\n",
      "      8        0.5741        0.7396  41.2280\n",
      "      9        0.5108        \u001b[32m0.3072\u001b[0m  47.3347\n",
      "     10        \u001b[36m0.3491\u001b[0m        \u001b[32m0.2139\u001b[0m  46.7133\n",
      "     11        \u001b[36m0.2780\u001b[0m        0.4625  50.9400\n",
      "     12        \u001b[36m0.2377\u001b[0m        \u001b[32m0.1821\u001b[0m  45.4753\n",
      "     13        \u001b[36m0.2071\u001b[0m        0.2018  52.6728\n",
      "     14        \u001b[36m0.1831\u001b[0m        0.3330  50.3238\n",
      "     15        \u001b[36m0.1680\u001b[0m        0.2059  54.4253\n",
      "     16        \u001b[36m0.1529\u001b[0m        \u001b[32m0.1059\u001b[0m  47.3823\n",
      "     17        \u001b[36m0.1428\u001b[0m        0.1790  50.8502\n",
      "     18        \u001b[36m0.1321\u001b[0m        0.1150  59.7210\n",
      "     19        \u001b[36m0.1236\u001b[0m        0.1163  52.8864\n",
      "     20        \u001b[36m0.1145\u001b[0m        0.1078  52.5962\n",
      "     21        \u001b[36m0.1089\u001b[0m        0.1556  55.7681\n",
      "     22        \u001b[36m0.1026\u001b[0m        \u001b[32m0.0754\u001b[0m  55.7549\n",
      "     23        \u001b[36m0.0968\u001b[0m        0.0964  56.8264\n",
      "     24        \u001b[36m0.0922\u001b[0m        0.0937  55.8359\n",
      "     25        \u001b[36m0.0881\u001b[0m        0.0856  64.1258\n",
      "     26        \u001b[36m0.0832\u001b[0m        \u001b[32m0.0483\u001b[0m  61.5993\n",
      "     27        \u001b[36m0.0793\u001b[0m        0.1806  64.0438\n",
      "     28        \u001b[36m0.0762\u001b[0m        0.0497  59.3018\n",
      "     29        \u001b[36m0.0718\u001b[0m        0.1448  60.3348\n",
      "     30        \u001b[36m0.0700\u001b[0m        0.0692  62.0079\n",
      "     31        \u001b[36m0.0678\u001b[0m        0.0536  54.6984\n",
      "     32        \u001b[36m0.0645\u001b[0m        0.0591  58.1633\n",
      "     33        \u001b[36m0.0622\u001b[0m        0.0529  55.8958\n",
      "     34        \u001b[36m0.0600\u001b[0m        \u001b[32m0.0392\u001b[0m  61.1934\n",
      "     35        \u001b[36m0.0582\u001b[0m        0.0429  61.3125\n",
      "     36        \u001b[36m0.0564\u001b[0m        0.0542  57.1567\n",
      "     37        \u001b[36m0.0546\u001b[0m        0.0608  59.7026\n",
      "     38        \u001b[36m0.0537\u001b[0m        0.0897  66.5121\n",
      "     39        \u001b[36m0.0520\u001b[0m        0.0424  68.9623\n",
      "     40        \u001b[36m0.0504\u001b[0m        0.0526  68.1981\n",
      "     41        \u001b[36m0.0484\u001b[0m        \u001b[32m0.0354\u001b[0m  54.6779\n",
      "     42        \u001b[36m0.0477\u001b[0m        0.0466  64.9923\n",
      "     43        \u001b[36m0.0464\u001b[0m        \u001b[32m0.0340\u001b[0m  58.6799\n",
      "     44        \u001b[36m0.0454\u001b[0m        0.0424  65.5487\n",
      "     45        \u001b[36m0.0437\u001b[0m        0.0408  64.3505\n",
      "     46        \u001b[36m0.0430\u001b[0m        0.0376  63.9077\n",
      "     47        \u001b[36m0.0424\u001b[0m        \u001b[32m0.0288\u001b[0m  60.6344\n",
      "     48        \u001b[36m0.0408\u001b[0m        0.0325  59.0373\n",
      "     49        \u001b[36m0.0402\u001b[0m        0.0309  59.7346\n",
      "     50        \u001b[36m0.0400\u001b[0m        0.0374  53.6971\n",
      "     51        \u001b[36m0.0382\u001b[0m        0.0509  58.1782\n",
      "     52        0.0383        0.0439  64.8844\n",
      "     53        \u001b[36m0.0371\u001b[0m        0.0332  64.4796\n",
      "     54        \u001b[36m0.0367\u001b[0m        0.0337  67.5131\n",
      "     55        \u001b[36m0.0353\u001b[0m        \u001b[32m0.0261\u001b[0m  57.6595\n",
      "     56        \u001b[36m0.0346\u001b[0m        0.0444  60.9848\n",
      "     57        \u001b[36m0.0344\u001b[0m        \u001b[32m0.0254\u001b[0m  62.2717\n",
      "     58        \u001b[36m0.0331\u001b[0m        0.0272  58.8832\n",
      "     59        0.0335        0.0332  58.5128\n",
      "     60        \u001b[36m0.0321\u001b[0m        0.0341  58.6297\n",
      "     61        \u001b[36m0.0320\u001b[0m        \u001b[32m0.0230\u001b[0m  61.7450\n",
      "     62        \u001b[36m0.0316\u001b[0m        0.0491  68.0787\n",
      "     63        \u001b[36m0.0306\u001b[0m        0.0237  61.2486\n",
      "     64        \u001b[36m0.0301\u001b[0m        0.0279  58.5082\n",
      "     65        0.0307        0.0476  66.5049\n",
      "     66        \u001b[36m0.0293\u001b[0m        0.0276  65.0594\n",
      "     67        \u001b[36m0.0289\u001b[0m        0.0248  67.5912\n",
      "     68        \u001b[36m0.0287\u001b[0m        \u001b[32m0.0224\u001b[0m  57.8337\n",
      "     69        \u001b[36m0.0278\u001b[0m        0.0419  59.3494\n",
      "     70        \u001b[36m0.0274\u001b[0m        0.0293  57.7094\n",
      "     71        \u001b[36m0.0267\u001b[0m        \u001b[32m0.0200\u001b[0m  57.6127\n",
      "     72        \u001b[36m0.0265\u001b[0m        \u001b[32m0.0181\u001b[0m  57.6394\n",
      "     73        \u001b[36m0.0265\u001b[0m        0.0651  61.1607\n",
      "     74        0.0266        0.0362  59.6729\n",
      "     75        \u001b[36m0.0263\u001b[0m        0.0251  61.5088\n",
      "     76        \u001b[36m0.0249\u001b[0m        0.0267  57.9339\n",
      "     77        0.0250        0.0196  58.3836\n",
      "     78        \u001b[36m0.0242\u001b[0m        \u001b[32m0.0176\u001b[0m  62.3430\n",
      "     79        0.0246        0.0339  62.5655\n",
      "     80        0.0243        0.0229  52.5310\n",
      "     81        \u001b[36m0.0234\u001b[0m        0.0240  64.3327\n",
      "     82        \u001b[36m0.0232\u001b[0m        0.0248  58.3192\n",
      "     83        \u001b[36m0.0231\u001b[0m        0.0343  61.4156\n",
      "     84        \u001b[36m0.0227\u001b[0m        \u001b[32m0.0167\u001b[0m  59.1330\n",
      "     85        0.0230        0.0213  58.3293\n",
      "     86        \u001b[36m0.0223\u001b[0m        0.0167  65.3839\n",
      "     87        \u001b[36m0.0220\u001b[0m        0.0286  65.7929\n",
      "     88        0.0221        0.0182  58.2389\n",
      "     89        \u001b[36m0.0218\u001b[0m        0.0308  67.1109\n",
      "     90        \u001b[36m0.0211\u001b[0m        0.0212  64.6504\n",
      "     91        \u001b[36m0.0210\u001b[0m        0.0230  58.1835\n",
      "     92        \u001b[36m0.0204\u001b[0m        \u001b[32m0.0147\u001b[0m  62.5444\n",
      "     93        0.0209        0.0149  61.3035\n",
      "     94        0.0206        0.0165  61.9382\n",
      "     95        \u001b[36m0.0199\u001b[0m        0.0296  58.4367\n",
      "     96        0.0201        0.0206  64.6630\n",
      "     97        0.0200        0.0196  58.4066\n",
      "     98        \u001b[36m0.0197\u001b[0m        0.0239  62.4247\n",
      "     99        0.0198        0.0199  66.6929\n",
      "    100        \u001b[36m0.0188\u001b[0m        \u001b[32m0.0137\u001b[0m  58.5453\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "0.8019506177902437"
      ]
     },
     "execution_count": 36,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "class Pode2d(nn.Module):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "        self.m = nn.Sequential(\n",
    "            nn.Conv1d(11,16,3,padding=1),\n",
    "            MALI(nn.Sequential(Polynom(), nn.Conv1d(16+16**2,16,3,padding=1))),\n",
    "            nn.Conv1d(16,1,3,padding=1),\n",
    "        )\n",
    "        \n",
    "    def forward(self, inp):\n",
    "        # b,cl -> b,c,l\n",
    "        inp = inp.float().reshape(-1,49,11).transpose(1,2)\n",
    "        return self.m(inp)[:,0]\n",
    "        \n",
    "model = NeuralNetRegressor(Pode2d, max_epochs=100, lr=1e-3, iterator_train__shuffle=True, device='cuda', batch_size=256)\n",
    "model.fit(tX_vl[:,m].reshape(-1,49*m.sum()), ty_vl.reshape(-1,49))\n",
    "model.score(tX_vl[:,m].reshape(-1,49*m.sum()), ty_vl.reshape(-1,49))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "ecb7a8de-b326-422d-8c6e-18b80d7d325b",
   "metadata": {},
   "outputs": [],
   "source": [
    "def speed_measure(model, m):\n",
    "    x = tX_vl[:,m].reshape(-1,49*m.sum()) if m is not None else tX_vl.reshape(-1,49*tX_vl.shape[1])\n",
    "    times = []\n",
    "    for i in trange(10, leave=False):\n",
    "        start = time()\n",
    "        model.predict(x)\n",
    "        times.append(time() - start)\n",
    "    return np.mean(times)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "b40bdf60-91d8-4ef1-a08a-1dec2818bdbf",
   "metadata": {
    "collapsed": true,
    "jupyter": {
     "outputs_hidden": true,
     "source_hidden": true
    }
   },
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/10 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "1.3508001847197185e-05"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model.batch_size=1024*4\n",
    "speed_measure(model, m)/219046"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "16b0790c-1def-4149-8ece-2f2ebd263628",
   "metadata": {
    "collapsed": true,
    "jupyter": {
     "outputs_hidden": true
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "------------------------------------- Calculate Flops Results -------------------------------------\n",
      "Notations:\n",
      "number of parameters (Params), number of multiply-accumulate operations(MACs),\n",
      "number of floating-point operations (FLOPs), floating-point operations per second (FLOPS),\n",
      "fwd FLOPs (model forward propagation FLOPs), bwd FLOPs (model backward propagation FLOPs),\n",
      "default model backpropagation takes 2.00 times as much computation as forward propagation.\n",
      "\n",
      "Total Training Params:                                                  85.9 K  \n",
      "fwd MACs:                                                               4.16 MMACs\n",
      "fwd FLOPs:                                                              8.31 MFLOPS\n",
      "fwd+bwd MACs:                                                           12.47 MMACs\n",
      "fwd+bwd FLOPs:                                                          24.94 MFLOPS\n",
      "\n",
      "-------------------------------- Detailed Calculated FLOPs Results --------------------------------\n",
      "Each module caculated is listed after its name in the following order: \n",
      "params, percentage of total params, MACs, percentage of total MACs, FLOPS, percentage of total FLOPs\n",
      "\n",
      "Note: 1. A module can have torch.nn.module or torch.nn.functional to compute logits (e.g. CrossEntropyLoss). \n",
      " They are not counted as submodules in calflops and not to be printed out. However they make up the difference between a parent's MACs and the sum of its submodules'.\n",
      "2. Number of floating-point operations is a theoretical estimation, thus FLOPS computed using that could be larger than the maximum system throughput.\n",
      "\n",
      "LNN(\n",
      "  85.9 K = 100% Params, 4.16 MMACs = 100% MACs, 8.31 MFLOPS = 100% FLOPs\n",
      "  (cfc): Cfc(\n",
      "    85.9 K = 100% Params, 4.16 MMACs = 100% MACs, 8.31 MFLOPS = 100% FLOPs\n",
      "    (rnn_cell): CfcCell(\n",
      "      83.84 K = 97.61% Params, 4.05 MMACs = 97.58% MACs, 8.11 MFLOPS = 97.59% FLOPs\n",
      "      (backbone): Sequential(\n",
      "        17.28 K = 20.12% Params, 843.58 KMACs = 20.3% MACs, 1.69 MFLOPS = 20.33% FLOPs\n",
      "        (0): Linear(17.28 K = 20.12% Params, 843.58 KMACs = 20.3% MACs, 1.69 MFLOPS = 20.29% FLOPs, in_features=269, out_features=64, bias=True)\n",
      "        (1): SiLU(0 = 0% Params, 0 MACs = 0% MACs, 3.14 KFLOPS = 0.04% FLOPs)\n",
      "      )\n",
      "      (tanh): Tanh(0 = 0% Params, 0 MACs = 0% MACs, 0 FLOPS = 0% FLOPs)\n",
      "      (sigmoid): Sigmoid(0 = 0% Params, 0 MACs = 0% MACs, 0 FLOPS = 0% FLOPs)\n",
      "      (ff1): Linear(16.64 K = 19.37% Params, 802.82 KMACs = 19.32% MACs, 1.61 MFLOPS = 19.31% FLOPs, in_features=64, out_features=256, bias=True)\n",
      "      (ff2): Linear(16.64 K = 19.37% Params, 802.82 KMACs = 19.32% MACs, 1.61 MFLOPS = 19.31% FLOPs, in_features=64, out_features=256, bias=True)\n",
      "      (time_a): Linear(16.64 K = 19.37% Params, 802.82 KMACs = 19.32% MACs, 1.61 MFLOPS = 19.31% FLOPs, in_features=64, out_features=256, bias=True)\n",
      "      (time_b): Linear(16.64 K = 19.37% Params, 802.82 KMACs = 19.32% MACs, 1.61 MFLOPS = 19.31% FLOPs, in_features=64, out_features=256, bias=True)\n",
      "    )\n",
      "    (fc): Linear(2.06 K = 2.39% Params, 100.35 KMACs = 2.42% MACs, 200.7 KFLOPS = 2.41% FLOPs, in_features=256, out_features=8, bias=True)\n",
      "  )\n",
      ")\n",
      "---------------------------------------------------------------------------------------------------\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "('8.31 MFLOPS', '4.16 MMACs', '85.9 K')"
      ]
     },
     "execution_count": 34,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from calflops import calculate_flops\n",
    "calculate_flops(model=model.module_, input_shape=(1,49,13))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "36516452-141f-4d35-acab-6ff7ee6420b2",
   "metadata": {},
   "source": [
    "# Sequantial approaches"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "id": "5c049572-dde1-43c3-819b-d554e7e0fca7",
   "metadata": {},
   "outputs": [],
   "source": [
    "# torch.save(model.module_.state_dict(), 'weights_wrf/cfc256f.pt')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 92,
   "id": "b10c5936-771a-4bb1-9b29-53c308c3e517",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([5.16640155e-06, 1.73857403e-05])"
      ]
     },
     "execution_count": 92,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "ypipe.scale_"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 261,
   "id": "5c7ce991-093a-4cc4-96b6-0933c3942bd6",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_362/2824044823.py:24: FutureWarning: You are using `torch.load` with `weights_only=False` (the current default value), which uses the default pickle module implicitly. It is possible to construct malicious pickle data which will execute arbitrary code during unpickling (See https://github.com/pytorch/pytorch/blob/main/SECURITY.md#untrusted-models for more details). In a future release, the default value for `weights_only` will be flipped to `True`. This limits the functions that could be executed during unpickling. Arbitrary objects will no longer be allowed to be loaded via this mode unless they are explicitly allowlisted by the user via `torch.serialization.add_safe_globals`. We recommend you start setting `weights_only=True` for any use case where you don't have full control of the loaded file. Please open an issue on GitHub for any issues related to this experimental feature.\n",
      "  model.module_.load_state_dict(torch.load('weights_wrf/cfc256f.pt'))\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.903902716870622\n",
      "0.02708735979582873 0.19669419797659574 5.255090516215507\n"
     ]
    }
   ],
   "source": [
    "class LNN(nn.Module): #all standart\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "        self.cfc = Cfc(13, 256, 8, {\n",
    "            \"clipnorm\": 0,\n",
    "            \"backbone_activation\": \"silu\",\n",
    "            \"backbone_units\": 64,\n",
    "            \"backbone_layers\": 1,\n",
    "            \"backbone_dr\": 0.0,\n",
    "            \"init\": 0.84,\n",
    "        }, return_sequences=True)\n",
    "        self.fdec = nn.Linear(12,6)\n",
    "        \n",
    "    def forward(self, inp):\n",
    "        # b,cl -> b,c,l\n",
    "        inp = inp.float().view(-1,49,13)\n",
    "        out = self.cfc(inp, inp[:,:,6])\n",
    "        y = out[:,:,:2].reshape(-1,49*2)\n",
    "        f = self.fdec(out[:,[0,-1],2:].reshape(-1,12))\n",
    "        return torch.cat((y,f),1)\n",
    "\n",
    "model = NeuralNetRegressor(LNN, max_epochs=0, lr=1e-2, iterator_train__shuffle=True, device='cuda', batch_size=128)\n",
    "model.fit(tX_tr[:,m].reshape(-1,49*m.sum()), np.concatenate((ty_tr.reshape(-1,49*2), tf_tr), 1))\n",
    "model.module_.load_state_dict(torch.load('weights_wrf/cfc256f.pt'))\n",
    "print(model.score(tX_vl[:,m].reshape(-1,49*m.sum()), np.concatenate((ty_vl.reshape(-1,49*2), tf_vl), 1) ))\n",
    "pred = model.predict(tX_vl[:,m].reshape(-1,49*m.sum()))\n",
    "y_pred = ypipe.inverse_transform(pred[:,:-6].reshape(-1,2))\n",
    "f_pred = fpipe.inverse_transform(pred[:,-6:])\n",
    "print(mse(y_vl[:,0], y_pred[:,0])**0.5 *86400, mse(y_vl[:,1], y_pred[:,1])**0.5 *86400, mse(f_vl, f_pred)**0.5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1845197c-0cbb-4920-80ec-0a542b8001f8",
   "metadata": {},
   "outputs": [],
   "source": [
    "0.0273 0.1850"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 289,
   "id": "9299d413-4fcf-48a7-a88e-877b7931f49a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.0058"
      ]
     },
     "execution_count": 289,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.std([0.1850,0.1966])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 76,
   "id": "cf6b01a2-fe8a-4abd-a1c1-30737b438563",
   "metadata": {
    "collapsed": true,
    "jupyter": {
     "outputs_hidden": true,
     "source_hidden": true
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_362/1813069132.py:23: FutureWarning: You are using `torch.load` with `weights_only=False` (the current default value), which uses the default pickle module implicitly. It is possible to construct malicious pickle data which will execute arbitrary code during unpickling (See https://github.com/pytorch/pytorch/blob/main/SECURITY.md#untrusted-models for more details). In a future release, the default value for `weights_only` will be flipped to `True`. This limits the functions that could be executed during unpickling. Arbitrary objects will no longer be allowed to be loaded via this mode unless they are explicitly allowlisted by the user via `torch.serialization.add_safe_globals`. We recommend you start setting `weights_only=True` for any use case where you don't have full control of the loaded file. Please open an issue on GitHub for any issues related to this experimental feature.\n",
      "  model.module_.load_state_dict(torch.load('weights_wrf/cfc256.pt'))\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "-47441.36374399424\n",
      "52.136734999879536 101.1864891759977 393.5655718873286\n"
     ]
    }
   ],
   "source": [
    "class LNN(nn.Module): #all standart\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "        self.cfc = Cfc(13, 256, 8, {\n",
    "            \"clipnorm\": 0,\n",
    "            \"backbone_activation\": \"silu\",\n",
    "            \"backbone_units\": 64,\n",
    "            \"backbone_layers\": 1,\n",
    "            \"backbone_dr\": 0.0,\n",
    "            \"init\": 0.84,\n",
    "        }, return_sequences=True)\n",
    "    def forward(self, inp):\n",
    "        # b,cl -> b,c,l\n",
    "        inp = inp.float().reshape(-1,49,13)\n",
    "        out = self.cfc(inp, inp[:,:,6])\n",
    "        y = out[:,:,:2].reshape(-1,49*2)\n",
    "        fup = out[:,0,2:6]\n",
    "        fdn = out[:,-1,6:]\n",
    "        return torch.cat((y,fup,fdn),1)\n",
    "\n",
    "model = NeuralNetRegressor(LNN, max_epochs=0, lr=1e-2, iterator_train__shuffle=True, device='cuda')\n",
    "model.fit(tX_tr[:,m].reshape(-1,49*m.sum()), np.concatenate((ty_tr.reshape(-1,49*2), tf_tr), 1))\n",
    "model.module_.load_state_dict(torch.load('weights_wrf/cfc256.pt'))\n",
    "print(model.score(tX_vl[:,m].reshape(-1,49*m.sum()), np.concatenate((ty_vl.reshape(-1,49*2), tf_vl), 1) ))\n",
    "pred = model.predict(tX_vl[:,m].reshape(-1,49*m.sum()))\n",
    "y_pred = ypipe.inverse_transform(pred[:,:-6].reshape(-1,2))\n",
    "f_pred = fpipe.inverse_transform(pred[:,-6:])\n",
    "print(mse(y_vl[:,0], y_pred[:,0])**0.5 *86400, mse(y_vl[:,1], y_pred[:,1])**0.5 *86400, mse(f_vl, f_pred)**0.5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "id": "eb457c1c-9ee2-4ec9-8976-9d9fd13c8c80",
   "metadata": {
    "collapsed": true,
    "jupyter": {
     "outputs_hidden": true,
     "source_hidden": true
    },
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "  epoch    train_loss    valid_loss       dur\n",
      "-------  ------------  ------------  --------\n",
      "      1        \u001b[36m0.9752\u001b[0m        \u001b[32m0.9503\u001b[0m  150.5079\n",
      "      2        \u001b[36m0.9447\u001b[0m        \u001b[32m0.9369\u001b[0m  138.2608\n",
      "      3        \u001b[36m0.9372\u001b[0m        \u001b[32m0.9331\u001b[0m  113.5394\n",
      "      4        \u001b[36m0.9348\u001b[0m        \u001b[32m0.9315\u001b[0m  151.4311\n",
      "      5        \u001b[36m0.9335\u001b[0m        \u001b[32m0.9304\u001b[0m  125.9159\n",
      "      6        \u001b[36m0.9325\u001b[0m        \u001b[32m0.9295\u001b[0m  167.7752\n",
      "      7        \u001b[36m0.9316\u001b[0m        \u001b[32m0.9286\u001b[0m  133.6143\n",
      "      8        \u001b[36m0.9307\u001b[0m        \u001b[32m0.9278\u001b[0m  124.1810\n",
      "      9        \u001b[36m0.9299\u001b[0m        \u001b[32m0.9269\u001b[0m  152.9389\n",
      "     10        \u001b[36m0.9291\u001b[0m        \u001b[32m0.9261\u001b[0m  157.4312\n",
      "     11        \u001b[36m0.9282\u001b[0m        \u001b[32m0.9253\u001b[0m  162.9261\n",
      "     12        \u001b[36m0.9275\u001b[0m        \u001b[32m0.9246\u001b[0m  138.3835\n",
      "     13        \u001b[36m0.9267\u001b[0m        \u001b[32m0.9238\u001b[0m  167.7974\n",
      "     14        \u001b[36m0.9259\u001b[0m        \u001b[32m0.9230\u001b[0m  165.0706\n",
      "     15        \u001b[36m0.9252\u001b[0m        \u001b[32m0.9223\u001b[0m  156.1194\n",
      "     16        \u001b[36m0.9245\u001b[0m        \u001b[32m0.9216\u001b[0m  144.0817\n",
      "     17        \u001b[36m0.9238\u001b[0m        \u001b[32m0.9209\u001b[0m  138.9457\n",
      "     18        \u001b[36m0.9231\u001b[0m        \u001b[32m0.9202\u001b[0m  153.4232\n",
      "     19        \u001b[36m0.9224\u001b[0m        \u001b[32m0.9196\u001b[0m  155.5424\n",
      "     20        \u001b[36m0.9218\u001b[0m        \u001b[32m0.9190\u001b[0m  157.2037\n",
      "     21        \u001b[36m0.9212\u001b[0m        \u001b[32m0.9184\u001b[0m  138.8565\n",
      "     22        \u001b[36m0.9207\u001b[0m        \u001b[32m0.9179\u001b[0m  130.7682\n",
      "     23        \u001b[36m0.9202\u001b[0m        \u001b[32m0.9174\u001b[0m  116.9017\n",
      "     24        \u001b[36m0.9197\u001b[0m        \u001b[32m0.9169\u001b[0m  160.0872\n",
      "     25        \u001b[36m0.9192\u001b[0m        \u001b[32m0.9165\u001b[0m  151.9714\n",
      "     26        \u001b[36m0.9188\u001b[0m        \u001b[32m0.9161\u001b[0m  150.1780\n",
      "     27        \u001b[36m0.9185\u001b[0m        \u001b[32m0.9157\u001b[0m  129.3756\n",
      "     28        \u001b[36m0.9181\u001b[0m        \u001b[32m0.9154\u001b[0m  111.6812\n",
      "     29        \u001b[36m0.9178\u001b[0m        \u001b[32m0.9151\u001b[0m  131.4081\n",
      "     30        \u001b[36m0.9175\u001b[0m        \u001b[32m0.9148\u001b[0m  142.4577\n",
      "     31        \u001b[36m0.9172\u001b[0m        \u001b[32m0.9145\u001b[0m  160.6221\n",
      "     32        \u001b[36m0.9170\u001b[0m        \u001b[32m0.9143\u001b[0m  143.5282\n",
      "     33        \u001b[36m0.9167\u001b[0m        \u001b[32m0.9141\u001b[0m  145.4189\n",
      "     34        \u001b[36m0.9165\u001b[0m        \u001b[32m0.9139\u001b[0m  128.8639\n",
      "     35        \u001b[36m0.9163\u001b[0m        \u001b[32m0.9137\u001b[0m  124.4681\n",
      "     36        \u001b[36m0.9161\u001b[0m        \u001b[32m0.9135\u001b[0m  150.9700\n",
      "     37        \u001b[36m0.9160\u001b[0m        \u001b[32m0.9133\u001b[0m  153.2928\n",
      "     38        \u001b[36m0.9158\u001b[0m        \u001b[32m0.9131\u001b[0m  137.4520\n",
      "     39        \u001b[36m0.9156\u001b[0m        \u001b[32m0.9130\u001b[0m  160.5815\n",
      "     40        \u001b[36m0.9155\u001b[0m        \u001b[32m0.9128\u001b[0m  129.9298\n",
      "     41        \u001b[36m0.9153\u001b[0m        \u001b[32m0.9126\u001b[0m  148.9591\n",
      "     42        \u001b[36m0.9151\u001b[0m        \u001b[32m0.9125\u001b[0m  149.5045\n",
      "     43        \u001b[36m0.9150\u001b[0m        \u001b[32m0.9124\u001b[0m  146.7551\n",
      "     44        \u001b[36m0.9148\u001b[0m        \u001b[32m0.9122\u001b[0m  148.6541\n",
      "     45        \u001b[36m0.9147\u001b[0m        \u001b[32m0.9121\u001b[0m  145.9347\n",
      "     46        \u001b[36m0.9146\u001b[0m        \u001b[32m0.9119\u001b[0m  124.5298\n",
      "     47        \u001b[36m0.9144\u001b[0m        \u001b[32m0.9118\u001b[0m  134.5267\n",
      "     48        \u001b[36m0.9143\u001b[0m        \u001b[32m0.9116\u001b[0m  145.1671\n",
      "     49        \u001b[36m0.9141\u001b[0m        \u001b[32m0.9115\u001b[0m  131.3784\n",
      "     50        \u001b[36m0.9140\u001b[0m        \u001b[32m0.9113\u001b[0m  139.7694\n",
      "     51        \u001b[36m0.9138\u001b[0m        \u001b[32m0.9112\u001b[0m  140.1209\n",
      "     52        \u001b[36m0.9137\u001b[0m        \u001b[32m0.9111\u001b[0m  132.0052\n",
      "     53        \u001b[36m0.9136\u001b[0m        \u001b[32m0.9109\u001b[0m  134.5602\n",
      "     54        \u001b[36m0.9134\u001b[0m        \u001b[32m0.9108\u001b[0m  131.7289\n",
      "     55        \u001b[36m0.9133\u001b[0m        \u001b[32m0.9106\u001b[0m  144.8888\n",
      "     56        \u001b[36m0.9131\u001b[0m        \u001b[32m0.9105\u001b[0m  141.1756\n",
      "     57        \u001b[36m0.9130\u001b[0m        \u001b[32m0.9103\u001b[0m  141.3902\n",
      "     58        \u001b[36m0.9128\u001b[0m        \u001b[32m0.9102\u001b[0m  141.1041\n",
      "     59        \u001b[36m0.9127\u001b[0m        \u001b[32m0.9100\u001b[0m  133.8517\n",
      "     60        \u001b[36m0.9125\u001b[0m        \u001b[32m0.9099\u001b[0m  139.9061\n",
      "     61        \u001b[36m0.9124\u001b[0m        \u001b[32m0.9097\u001b[0m  139.4996\n",
      "     62        \u001b[36m0.9122\u001b[0m        \u001b[32m0.9096\u001b[0m  123.3398\n",
      "     63        \u001b[36m0.9121\u001b[0m        \u001b[32m0.9094\u001b[0m  110.6491\n",
      "     64        \u001b[36m0.9119\u001b[0m        \u001b[32m0.9093\u001b[0m  129.0272\n",
      "     65        \u001b[36m0.9117\u001b[0m        \u001b[32m0.9091\u001b[0m  136.6788\n",
      "     66        \u001b[36m0.9116\u001b[0m        \u001b[32m0.9089\u001b[0m  134.6048\n",
      "     67        \u001b[36m0.9114\u001b[0m        \u001b[32m0.9088\u001b[0m  137.3385\n",
      "     68        \u001b[36m0.9113\u001b[0m        \u001b[32m0.9086\u001b[0m  131.2401\n",
      "     69        \u001b[36m0.9111\u001b[0m        \u001b[32m0.9084\u001b[0m  139.6394\n",
      "     70        \u001b[36m0.9109\u001b[0m        \u001b[32m0.9083\u001b[0m  144.2650\n",
      "     71        \u001b[36m0.9108\u001b[0m        \u001b[32m0.9081\u001b[0m  140.5855\n",
      "     72        \u001b[36m0.9106\u001b[0m        \u001b[32m0.9079\u001b[0m  140.4356\n",
      "     73        \u001b[36m0.9104\u001b[0m        \u001b[32m0.9078\u001b[0m  134.5750\n",
      "     74        \u001b[36m0.9102\u001b[0m        \u001b[32m0.9076\u001b[0m  120.9580\n",
      "     75        \u001b[36m0.9101\u001b[0m        \u001b[32m0.9074\u001b[0m  116.7791\n",
      "     76        \u001b[36m0.9099\u001b[0m        \u001b[32m0.9072\u001b[0m  131.4997\n",
      "     77        \u001b[36m0.9097\u001b[0m        \u001b[32m0.9070\u001b[0m  131.2636\n",
      "     78        \u001b[36m0.9095\u001b[0m        \u001b[32m0.9069\u001b[0m  136.3001\n",
      "     79        \u001b[36m0.9093\u001b[0m        \u001b[32m0.9067\u001b[0m  139.3514\n",
      "     80        \u001b[36m0.9091\u001b[0m        \u001b[32m0.9065\u001b[0m  140.1362\n",
      "     81        \u001b[36m0.9089\u001b[0m        \u001b[32m0.9063\u001b[0m  141.1448\n",
      "     82        \u001b[36m0.9087\u001b[0m        \u001b[32m0.9061\u001b[0m  134.4867\n",
      "     83        \u001b[36m0.9085\u001b[0m        \u001b[32m0.9059\u001b[0m  127.0480\n",
      "     84        \u001b[36m0.9083\u001b[0m        \u001b[32m0.9057\u001b[0m  138.0361\n",
      "     85        \u001b[36m0.9081\u001b[0m        \u001b[32m0.9055\u001b[0m  140.3397\n",
      "     86        \u001b[36m0.9079\u001b[0m        \u001b[32m0.9053\u001b[0m  123.4245\n",
      "     87        \u001b[36m0.9077\u001b[0m        \u001b[32m0.9051\u001b[0m  124.7296\n",
      "     88        \u001b[36m0.9075\u001b[0m        \u001b[32m0.9048\u001b[0m  139.4519\n",
      "     89        \u001b[36m0.9073\u001b[0m        \u001b[32m0.9046\u001b[0m  127.1498\n",
      "     90        \u001b[36m0.9071\u001b[0m        \u001b[32m0.9044\u001b[0m  139.3962\n",
      "     91        \u001b[36m0.9069\u001b[0m        \u001b[32m0.9042\u001b[0m  124.9377\n",
      "     92        \u001b[36m0.9066\u001b[0m        \u001b[32m0.9040\u001b[0m  120.0991\n",
      "     93        \u001b[36m0.9064\u001b[0m        \u001b[32m0.9037\u001b[0m  131.9204\n",
      "     94        \u001b[36m0.9062\u001b[0m        \u001b[32m0.9035\u001b[0m  134.4777\n",
      "     95        \u001b[36m0.9059\u001b[0m        \u001b[32m0.9033\u001b[0m  124.6720\n",
      "     96        \u001b[36m0.9057\u001b[0m        \u001b[32m0.9031\u001b[0m  129.8074\n",
      "     97        \u001b[36m0.9055\u001b[0m        \u001b[32m0.9028\u001b[0m  126.2766\n",
      "     98        \u001b[36m0.9052\u001b[0m        \u001b[32m0.9026\u001b[0m  128.8734\n",
      "     99        \u001b[36m0.9050\u001b[0m        \u001b[32m0.9023\u001b[0m  144.7129\n",
      "    100        \u001b[36m0.9048\u001b[0m        \u001b[32m0.9021\u001b[0m  148.7412\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "0.07205057087459672"
      ]
     },
     "execution_count": 50,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "class _GRU(nn.Module):\n",
    "    def __init__(self, input_dim, hidden_dim=None):\n",
    "        if not hidden_dim: hidden_dim = input_dim\n",
    "        super().__init__()\n",
    "        self.hidden_dim = hidden_dim\n",
    "        self.gates = nn.Linear(input_dim + hidden_dim, 2*hidden_dim)  \n",
    "        self.candidate = nn.Linear(input_dim + hidden_dim, hidden_dim)\n",
    "    \n",
    "    def forward(self, input_tensor, h_cur):\n",
    "        gates = torch.sigmoid(self.gates(torch.cat([input_tensor, h_cur], dim=1)))\n",
    "        reset_gate, update_gate = torch.split(gates, self.hidden_dim, dim=1)\n",
    "        cnm = torch.tanh(self.candidate(torch.cat([input_tensor, reset_gate * h_cur], dim=1)))\n",
    "        h_next = (1 - update_gate) * h_cur + update_gate * cnm\n",
    "        return h_next\n",
    "\n",
    "class GRU(nn.Module):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "        self.encoder = nn.Linear(4,64)\n",
    "        self.gru = _GRU(6,64)\n",
    "        self.node = nn.Sequential(\n",
    "                nn.Linear(64,64),\n",
    "                nn.ReLU(True),\n",
    "                nn.Linear(64,64),\n",
    "                nn.ReLU(True)\n",
    "            )\n",
    "        self.decoder = nn.Linear(64,1)\n",
    "\n",
    "    def forward(self, inp):\n",
    "        # b,cl -> b,c,l\n",
    "        inp = inp.float().reshape(-1,49,11).transpose(1,2)\n",
    "        # (b,c1,l), (l), (b,c0)\n",
    "        x1, timeline, x0 = inp[:,:6], inp[0,6], inp[:,7:,0]\n",
    "        h = self.encoder(x0)\n",
    "        y = []\n",
    "        for t in range(49):\n",
    "            h = self.gru(x1[:,:,t], h)\n",
    "            h = h + self.node(h)/50\n",
    "            y.append(self.decoder(h))\n",
    "        return torch.cat(y,1)\n",
    "        \n",
    "model = NeuralNetRegressor(GRU, max_epochs=100, lr=1e-3, iterator_train__shuffle=True, device='cuda', batch_size=512)\n",
    "model.fit(tX_tr[:,m].reshape(-1,49*m.sum()), ty_tr.reshape(-1,49))\n",
    "model.score(tX_vl[:,m].reshape(-1,49*m.sum()), ty_vl.reshape(-1,49))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "id": "f067d234-634c-4c6e-95c8-868838680f32",
   "metadata": {
    "collapsed": true,
    "jupyter": {
     "outputs_hidden": true,
     "source_hidden": true
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1.54151823164199"
      ]
     },
     "execution_count": 51,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "mse(y_vl.reshape(-1,49), ypipe.inverse_transform(model.predict(tX_vl[:,m].reshape(-1,49*m.sum()))))**0.5 *86400"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 285,
   "id": "df5fb646-8e4c-42ed-a8a4-8e7b70d1ec16",
   "metadata": {
    "collapsed": true,
    "jupyter": {
     "outputs_hidden": true,
     "source_hidden": true
    }
   },
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "  0%|          | 0/10 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "4.179734706878662"
      ]
     },
     "execution_count": 285,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model.batch_size = 64*64\n",
    "speed_measure(model, m)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 53,
   "id": "1a90ef86-3669-4c30-8472-b63a7491597c",
   "metadata": {
    "collapsed": true,
    "jupyter": {
     "outputs_hidden": true,
     "source_hidden": true
    },
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "  epoch    train_loss    valid_loss       dur\n",
      "-------  ------------  ------------  --------\n",
      "      1        \u001b[36m0.9872\u001b[0m        \u001b[32m0.9690\u001b[0m  321.7816\n",
      "      2        \u001b[36m0.9611\u001b[0m        \u001b[32m0.9501\u001b[0m  328.8140\n",
      "      3        \u001b[36m0.9472\u001b[0m        \u001b[32m0.9406\u001b[0m  314.0725\n",
      "      4        \u001b[36m0.9406\u001b[0m        \u001b[32m0.9362\u001b[0m  312.2956\n",
      "      5        \u001b[36m0.9376\u001b[0m        \u001b[32m0.9342\u001b[0m  331.8982\n",
      "      6        \u001b[36m0.9361\u001b[0m        \u001b[32m0.9331\u001b[0m  309.4765\n",
      "      7        \u001b[36m0.9352\u001b[0m        \u001b[32m0.9323\u001b[0m  319.5703\n",
      "      8        \u001b[36m0.9345\u001b[0m        \u001b[32m0.9317\u001b[0m  319.4796\n",
      "      9        \u001b[36m0.9340\u001b[0m        \u001b[32m0.9312\u001b[0m  311.5055\n",
      "     10        \u001b[36m0.9335\u001b[0m        \u001b[32m0.9307\u001b[0m  322.6154\n",
      "     12        \u001b[36m0.9325\u001b[0m        \u001b[32m0.9298\u001b[0m  317.3202\n",
      "     13        \u001b[36m0.9321\u001b[0m        \u001b[32m0.9294\u001b[0m  331.4676\n",
      "     14        \u001b[36m0.9317\u001b[0m        \u001b[32m0.9290\u001b[0m  336.3445\n",
      "     15        \u001b[36m0.9313\u001b[0m        \u001b[32m0.9285\u001b[0m  309.0549\n",
      "     16        \u001b[36m0.9308\u001b[0m        \u001b[32m0.9281\u001b[0m  328.1652\n",
      "     17        \u001b[36m0.9304\u001b[0m        \u001b[32m0.9277\u001b[0m  317.6398\n",
      "     18        \u001b[36m0.9300\u001b[0m        \u001b[32m0.9273\u001b[0m  324.2288\n",
      "     19        \u001b[36m0.9296\u001b[0m        \u001b[32m0.9269\u001b[0m  308.3228\n",
      "     20        \u001b[36m0.9292\u001b[0m        \u001b[32m0.9265\u001b[0m  325.6574\n",
      "     21        \u001b[36m0.9288\u001b[0m        \u001b[32m0.9261\u001b[0m  323.5181\n",
      "     22        \u001b[36m0.9284\u001b[0m        \u001b[32m0.9257\u001b[0m  310.6116\n",
      "     23        \u001b[36m0.9280\u001b[0m        \u001b[32m0.9253\u001b[0m  308.3083\n",
      "     24        \u001b[36m0.9277\u001b[0m        \u001b[32m0.9249\u001b[0m  343.6612\n",
      "     25        \u001b[36m0.9273\u001b[0m        \u001b[32m0.9246\u001b[0m  340.6386\n",
      "     26        \u001b[36m0.9269\u001b[0m        \u001b[32m0.9242\u001b[0m  317.9933\n",
      "     27        \u001b[36m0.9265\u001b[0m        \u001b[32m0.9238\u001b[0m  340.8019\n",
      "     28        \u001b[36m0.9262\u001b[0m        \u001b[32m0.9234\u001b[0m  329.4023\n",
      "     29        \u001b[36m0.9258\u001b[0m        \u001b[32m0.9231\u001b[0m  312.3010\n",
      "     30        \u001b[36m0.9254\u001b[0m        \u001b[32m0.9227\u001b[0m  308.9171\n",
      "     31        \u001b[36m0.9251\u001b[0m        \u001b[32m0.9224\u001b[0m  318.5305\n",
      "     32        \u001b[36m0.9247\u001b[0m        \u001b[32m0.9220\u001b[0m  316.1677\n",
      "     33        \u001b[36m0.9244\u001b[0m        \u001b[32m0.9217\u001b[0m  326.8374\n",
      "     34        \u001b[36m0.9240\u001b[0m        \u001b[32m0.9213\u001b[0m  327.4693\n",
      "     35        \u001b[36m0.9237\u001b[0m        \u001b[32m0.9210\u001b[0m  330.8315\n",
      "     36        \u001b[36m0.9234\u001b[0m        \u001b[32m0.9207\u001b[0m  361.0075\n",
      "     37        \u001b[36m0.9231\u001b[0m        \u001b[32m0.9204\u001b[0m  360.9324\n",
      "     38        \u001b[36m0.9227\u001b[0m        \u001b[32m0.9201\u001b[0m  620.5295\n",
      "     39        \u001b[36m0.9224\u001b[0m        \u001b[32m0.9198\u001b[0m  634.1478\n",
      "     40        \u001b[36m0.9221\u001b[0m        \u001b[32m0.9195\u001b[0m  528.4926\n",
      "     41        \u001b[36m0.9219\u001b[0m        \u001b[32m0.9192\u001b[0m  348.6693\n",
      "     42        \u001b[36m0.9216\u001b[0m        \u001b[32m0.9189\u001b[0m  342.8322\n",
      "     43        \u001b[36m0.9213\u001b[0m        \u001b[32m0.9186\u001b[0m  331.2075\n",
      "     44        \u001b[36m0.9210\u001b[0m        \u001b[32m0.9184\u001b[0m  687.2973\n",
      "     45        \u001b[36m0.9208\u001b[0m        \u001b[32m0.9181\u001b[0m  338.8763\n",
      "     46        \u001b[36m0.9205\u001b[0m        \u001b[32m0.9179\u001b[0m  326.5053\n",
      "     47        \u001b[36m0.9203\u001b[0m        \u001b[32m0.9176\u001b[0m  325.7351\n",
      "     48        \u001b[36m0.9201\u001b[0m        \u001b[32m0.9174\u001b[0m  325.5347\n",
      "     49        \u001b[36m0.9199\u001b[0m        \u001b[32m0.9172\u001b[0m  333.8384\n",
      "     50        \u001b[36m0.9196\u001b[0m        \u001b[32m0.9170\u001b[0m  339.4816\n",
      "     51        \u001b[36m0.9194\u001b[0m        \u001b[32m0.9168\u001b[0m  340.2136\n",
      "     52        \u001b[36m0.9192\u001b[0m        \u001b[32m0.9166\u001b[0m  324.3889\n",
      "     53        \u001b[36m0.9191\u001b[0m        \u001b[32m0.9164\u001b[0m  347.4832\n",
      "     54        \u001b[36m0.9189\u001b[0m        \u001b[32m0.9162\u001b[0m  356.5454\n",
      "     55        \u001b[36m0.9187\u001b[0m        \u001b[32m0.9161\u001b[0m  326.1157\n",
      "     56        \u001b[36m0.9185\u001b[0m        \u001b[32m0.9159\u001b[0m  356.3627\n",
      "     57        \u001b[36m0.9184\u001b[0m        \u001b[32m0.9157\u001b[0m  369.4763\n",
      "     58        \u001b[36m0.9182\u001b[0m        \u001b[32m0.9156\u001b[0m  350.9256\n",
      "     59        \u001b[36m0.9181\u001b[0m        \u001b[32m0.9154\u001b[0m  349.0621\n",
      "     60        \u001b[36m0.9179\u001b[0m        \u001b[32m0.9153\u001b[0m  365.7189\n",
      "     61        \u001b[36m0.9178\u001b[0m        \u001b[32m0.9152\u001b[0m  344.9879\n",
      "     62        \u001b[36m0.9177\u001b[0m        \u001b[32m0.9150\u001b[0m  328.3201\n",
      "     63        \u001b[36m0.9175\u001b[0m        \u001b[32m0.9149\u001b[0m  319.4689\n",
      "     64        \u001b[36m0.9174\u001b[0m        \u001b[32m0.9148\u001b[0m  325.8799\n",
      "     65        \u001b[36m0.9173\u001b[0m        \u001b[32m0.9147\u001b[0m  324.8568\n",
      "     66        \u001b[36m0.9172\u001b[0m        \u001b[32m0.9146\u001b[0m  365.7193\n",
      "     67        \u001b[36m0.9171\u001b[0m        \u001b[32m0.9144\u001b[0m  340.0826\n",
      "     68        \u001b[36m0.9170\u001b[0m        \u001b[32m0.9143\u001b[0m  370.1621\n",
      "     69        \u001b[36m0.9169\u001b[0m        \u001b[32m0.9142\u001b[0m  350.2316\n",
      "     70        \u001b[36m0.9167\u001b[0m        \u001b[32m0.9141\u001b[0m  362.7613\n",
      "     71        \u001b[36m0.9166\u001b[0m        \u001b[32m0.9140\u001b[0m  357.1571\n",
      "     72        \u001b[36m0.9165\u001b[0m        \u001b[32m0.9139\u001b[0m  360.8322\n",
      "     73        \u001b[36m0.9164\u001b[0m        \u001b[32m0.9138\u001b[0m  427.3745\n",
      "     74        \u001b[36m0.9164\u001b[0m        \u001b[32m0.9137\u001b[0m  406.7084\n",
      "     75        \u001b[36m0.9163\u001b[0m        \u001b[32m0.9136\u001b[0m  347.3362\n",
      "     76        \u001b[36m0.9162\u001b[0m        \u001b[32m0.9135\u001b[0m  347.2120\n",
      "     77        \u001b[36m0.9161\u001b[0m        \u001b[32m0.9135\u001b[0m  427.7735\n",
      "     78        \u001b[36m0.9160\u001b[0m        \u001b[32m0.9134\u001b[0m  535.1098\n",
      "     79        \u001b[36m0.9159\u001b[0m        \u001b[32m0.9133\u001b[0m  482.3697\n",
      "     80        \u001b[36m0.9158\u001b[0m        \u001b[32m0.9132\u001b[0m  359.8242\n",
      "     81        \u001b[36m0.9157\u001b[0m        \u001b[32m0.9131\u001b[0m  358.6746\n",
      "     82        \u001b[36m0.9156\u001b[0m        \u001b[32m0.9130\u001b[0m  355.3672\n",
      "     83        \u001b[36m0.9155\u001b[0m        \u001b[32m0.9129\u001b[0m  372.1464\n",
      "     84        \u001b[36m0.9155\u001b[0m        \u001b[32m0.9128\u001b[0m  356.5615\n",
      "     85        \u001b[36m0.9154\u001b[0m        \u001b[32m0.9128\u001b[0m  346.6380\n",
      "     86        \u001b[36m0.9153\u001b[0m        \u001b[32m0.9127\u001b[0m  334.4247\n",
      "     87        \u001b[36m0.9152\u001b[0m        \u001b[32m0.9126\u001b[0m  321.7110\n",
      "     88        \u001b[36m0.9151\u001b[0m        \u001b[32m0.9125\u001b[0m  356.9341\n",
      "     89        \u001b[36m0.9150\u001b[0m        \u001b[32m0.9124\u001b[0m  352.0092\n",
      "     90        \u001b[36m0.9149\u001b[0m        \u001b[32m0.9123\u001b[0m  365.7858\n",
      "     91        \u001b[36m0.9149\u001b[0m        \u001b[32m0.9123\u001b[0m  367.9156\n",
      "     92        \u001b[36m0.9148\u001b[0m        \u001b[32m0.9122\u001b[0m  368.6698\n",
      "     93        \u001b[36m0.9147\u001b[0m        \u001b[32m0.9121\u001b[0m  341.1646\n",
      "     94        \u001b[36m0.9146\u001b[0m        \u001b[32m0.9120\u001b[0m  351.9997\n",
      "     95        \u001b[36m0.9145\u001b[0m        \u001b[32m0.9119\u001b[0m  348.7022\n",
      "     96        \u001b[36m0.9144\u001b[0m        \u001b[32m0.9118\u001b[0m  339.5372\n",
      "     97        \u001b[36m0.9144\u001b[0m        \u001b[32m0.9117\u001b[0m  342.6129\n",
      "     98        \u001b[36m0.9143\u001b[0m        \u001b[32m0.9117\u001b[0m  352.5336\n",
      "     99        \u001b[36m0.9142\u001b[0m        \u001b[32m0.9116\u001b[0m  346.9119\n",
      "    100        \u001b[36m0.9141\u001b[0m        \u001b[32m0.9115\u001b[0m  342.3494\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "-0.11314247379114067"
      ]
     },
     "execution_count": 53,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "class GRUODE(nn.Module):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "        self.encoder = nn.Linear(4,64)\n",
    "        self.gru = _GRU(6,64)\n",
    "        self.node = MALI(nn.Sequential(\n",
    "                nn.Linear(64,64),\n",
    "                nn.ReLU(True),\n",
    "                nn.Linear(64,64),\n",
    "                nn.ReLU(True)\n",
    "            ))\n",
    "        nn.init.zeros_(self.node.model.model[0].weight)\n",
    "        nn.init.zeros_(self.node.model.model[2].weight)\n",
    "        self.decoder = nn.Linear(64,1)\n",
    "\n",
    "    def forward(self, inp):\n",
    "        # b,cl -> b,c,l\n",
    "        inp = inp.float().reshape(-1,49,11).transpose(1,2)\n",
    "        # (b,c1,l), (l), (b,c0)\n",
    "        x1, timeline, x0 = inp[:,:6], inp[0,6], inp[:,7:,0]\n",
    "        h = self.encoder(x0)\n",
    "        y = []\n",
    "        for t in range(49):\n",
    "            h = self.gru(x1[:,:,t], h)\n",
    "            h = self.node(h)\n",
    "            y.append(self.decoder(h))\n",
    "        return torch.cat(y,1)\n",
    "        \n",
    "model = NeuralNetRegressor(GRUODE, max_epochs=100, lr=1e-3, iterator_train__shuffle=True, device='cuda', batch_size=1024)\n",
    "model.fit(tX_tr[:,m].reshape(-1,49*m.sum()), ty_tr.reshape(-1,49))\n",
    "model.score(tX_vl[:,m].reshape(-1,49*m.sum()), ty_vl.reshape(-1,49))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "id": "917cbad3-3d85-467b-879a-b7c688fec0b6",
   "metadata": {
    "collapsed": true,
    "jupyter": {
     "outputs_hidden": true,
     "source_hidden": true
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1.5480891362687963"
      ]
     },
     "execution_count": 54,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "mse(y_vl.reshape(-1,49), ypipe.inverse_transform(model.predict(tX_vl[:,m].reshape(-1,49*m.sum()))))**0.5 *86400"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b1c9c07a-33a4-479e-86ff-a31ab6789c3b",
   "metadata": {
    "collapsed": true,
    "jupyter": {
     "outputs_hidden": true,
     "source_hidden": true
    },
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "  epoch    train_loss    valid_loss      dur\n",
      "-------  ------------  ------------  -------\n",
      "      1        \u001b[36m0.9817\u001b[0m        \u001b[32m0.9636\u001b[0m  25.8591\n",
      "      2        \u001b[36m0.9543\u001b[0m        \u001b[32m0.9409\u001b[0m  25.2802\n"
     ]
    }
   ],
   "source": [
    "class RNN(nn.Module):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "        h = 64\n",
    "        self.encoder = nn.Sequential(\n",
    "                nn.Linear(m.sum(),h),\n",
    "                nn.ReLU(True),\n",
    "                nn.Linear(h,h),\n",
    "                nn.ReLU(True)\n",
    "            )\n",
    "        self.rnn = nn.Sequential(\n",
    "                nn.Linear(m.sum(),h),\n",
    "                nn.ReLU(True),\n",
    "                nn.Linear(h,h),\n",
    "                nn.ReLU(True)\n",
    "            )\n",
    "        self.decoder = nn.Linear(h,1)\n",
    "\n",
    "    def forward(self, inp):\n",
    "        # b,cl -> b,c,l\n",
    "        inp = inp.float().reshape(-1,49,m.sum())\n",
    "        h = self.encoder(inp[:,0])\n",
    "        y = []\n",
    "        for t in range(49):\n",
    "            h = h + self.rnn(inp[:,t])/50\n",
    "            y.append(self.decoder(h))\n",
    "        return torch.cat(y,1)\n",
    "        \n",
    "model = NeuralNetRegressor(RNN, max_epochs=25, lr=1e-2, iterator_train__shuffle=True, device='cuda', batch_size=128*64)\n",
    "model.fit(tX_tr[:,m].reshape(-1,49*m.sum()), ty_tr.reshape(-1,49))\n",
    "model.score(tX_vl[:,m].reshape(-1,49*m.sum()), ty_vl.reshape(-1,49))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f395353c-a5e0-4227-bca8-0f2782ebdf0a",
   "metadata": {
    "jupyter": {
     "source_hidden": true
    }
   },
   "outputs": [],
   "source": [
    "mse(y_vl.reshape(-1,49), ypipe.inverse_transform(model.predict(tX_vl[:,m].reshape(-1,49*m.sum()))))**0.5 *86400"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c99f4855-1bd9-4c50-af3e-29f460b84d21",
   "metadata": {
    "collapsed": true,
    "jupyter": {
     "outputs_hidden": true,
     "source_hidden": true
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "  epoch    train_loss    valid_loss      dur\n",
      "-------  ------------  ------------  -------\n",
      "      1        \u001b[36m0.9679\u001b[0m        \u001b[32m0.9409\u001b[0m  15.5573\n",
      "      2        \u001b[36m0.9056\u001b[0m        \u001b[32m0.8679\u001b[0m  15.8401\n",
      "      3        \u001b[36m0.8154\u001b[0m        \u001b[32m0.7562\u001b[0m  15.3353\n",
      "      4        \u001b[36m0.6847\u001b[0m        \u001b[32m0.6104\u001b[0m  15.4962\n",
      "      5        \u001b[36m0.5439\u001b[0m        \u001b[32m0.4865\u001b[0m  15.5549\n",
      "      6        \u001b[36m0.4516\u001b[0m        \u001b[32m0.4270\u001b[0m  14.9880\n",
      "      7        \u001b[36m0.4137\u001b[0m        \u001b[32m0.4051\u001b[0m  15.2972\n",
      "      8        \u001b[36m0.3986\u001b[0m        \u001b[32m0.3948\u001b[0m  15.8709\n",
      "      9        \u001b[36m0.3904\u001b[0m        \u001b[32m0.3882\u001b[0m  15.4853\n",
      "     10        \u001b[36m0.3846\u001b[0m        \u001b[32m0.3831\u001b[0m  15.6911\n",
      "     11        \u001b[36m0.3799\u001b[0m        \u001b[32m0.3787\u001b[0m  15.1523\n",
      "     12        \u001b[36m0.3757\u001b[0m        \u001b[32m0.3746\u001b[0m  15.1938\n",
      "     13        \u001b[36m0.3717\u001b[0m        \u001b[32m0.3705\u001b[0m  15.4841\n",
      "     14        \u001b[36m0.3677\u001b[0m        \u001b[32m0.3667\u001b[0m  15.1863\n",
      "     15        \u001b[36m0.3639\u001b[0m        \u001b[32m0.3629\u001b[0m  15.1106\n",
      "     16        \u001b[36m0.3602\u001b[0m        \u001b[32m0.3592\u001b[0m  16.0035\n",
      "     17        \u001b[36m0.3565\u001b[0m        \u001b[32m0.3556\u001b[0m  15.7476\n",
      "     18        \u001b[36m0.3530\u001b[0m        \u001b[32m0.3521\u001b[0m  15.2061\n",
      "     19        \u001b[36m0.3495\u001b[0m        \u001b[32m0.3486\u001b[0m  14.9228\n",
      "     20        \u001b[36m0.3460\u001b[0m        \u001b[32m0.3450\u001b[0m  15.1006\n",
      "     21        \u001b[36m0.3424\u001b[0m        \u001b[32m0.3414\u001b[0m  14.8144\n",
      "     22        \u001b[36m0.3387\u001b[0m        \u001b[32m0.3377\u001b[0m  14.8354\n",
      "     23        \u001b[36m0.3350\u001b[0m        \u001b[32m0.3339\u001b[0m  15.7425\n"
     ]
    }
   ],
   "source": [
    "class RNN_reverse(nn.Module):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "        h = 64\n",
    "        self.encoder = nn.Sequential(\n",
    "                nn.Linear(m.sum(),h),\n",
    "                nn.ReLU(True),\n",
    "                nn.Linear(h,h),\n",
    "                nn.ReLU(True),\n",
    "            )\n",
    "        self.rnn = nn.Sequential(\n",
    "                nn.Linear(m.sum(),h),\n",
    "                nn.ReLU(True),\n",
    "                nn.Linear(h,h),\n",
    "                nn.ReLU(True)\n",
    "            )\n",
    "        self.decoder = nn.Linear(h,1)\n",
    "\n",
    "    def forward(self, inp):\n",
    "        # b,cl -> b,c,l\n",
    "        inp = inp.float().reshape(-1,49,m.sum())\n",
    "        h = self.encoder(inp[:,0])\n",
    "        y = []\n",
    "        for t in range(49):\n",
    "            h = h + self.rnn(inp[:,48-t])/50\n",
    "            y.append(self.decoder(h))\n",
    "        return torch.flip(torch.cat(y,1),[1])\n",
    "        \n",
    "model = NeuralNetRegressor(RNN_reverse, max_epochs=25, lr=1e-2, iterator_train__shuffle=True, device='cuda', batch_size=128*64)\n",
    "model.fit(tX_tr[:,m].reshape(-1,49*m.sum()), ty_tr.reshape(-1,49))\n",
    "model.score(tX_vl[:,m].reshape(-1,49*m.sum()), ty_vl.reshape(-1,49))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "99e64154-02db-4fe3-ac66-c6e1ce37f77f",
   "metadata": {},
   "source": [
    "### Neural CDE:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0a37d4ec-7b7a-4792-8565-b3c555ba2de5",
   "metadata": {},
   "outputs": [],
   "source": [
    "X0_tr, X1_tr, y_tr = get_data(2015)\n",
    "X0_vl, X1_vl, y_vl = get_data(2016)\n",
    "\n",
    "h_tr = np.repeat(np.arange(49)[None,:,None]/49, X1_tr.shape[0], 0)\n",
    "h_vl = np.repeat(np.arange(49)[None,:,None]/49, X1_vl.shape[0], 0)\n",
    "\n",
    "# first channel is 'timeline', heights here\n",
    "X_tr = np.concatenate((h_tr, X1_tr.transpose((0,2,1)), np.repeat(X0_tr[:,None,:], 49, 1)), 2)\n",
    "X_vl = np.concatenate((h_vl, X1_vl.transpose((0,2,1)), np.repeat(X0_vl[:,None,:], 49, 1)), 2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d387dc07-18a0-42d9-bf86-19a9b82d0b7f",
   "metadata": {},
   "outputs": [],
   "source": [
    "xpipe = MinMaxScaler()\n",
    "tX_tr = xpipe.fit_transform(X_tr.reshape(-1,11)).reshape(X_tr.shape)\n",
    "tX_vl = xpipe.transform(X_vl.reshape(-1,11)).reshape(X_vl.shape)\n",
    "ypipe = StandardScaler()\n",
    "ty_tr = ypipe.fit_transform(y_tr.reshape(-1,1)).reshape(y_tr.shape)\n",
    "ty_vl = ypipe.transform(y_vl.reshape(-1,1)).reshape(y_vl.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 245,
   "id": "c8350f16-cc77-4d25-bbfb-3c557fe80cde",
   "metadata": {},
   "outputs": [],
   "source": [
    "class CDEFunc(torch.nn.Module):\n",
    "    def __init__(self, input_channels, hidden_channels):\n",
    "        super(CDEFunc, self).__init__()\n",
    "        self.input_channels = input_channels\n",
    "        self.hidden_channels = hidden_channels\n",
    "\n",
    "        self.linear1 = nn.Linear(hidden_channels, 128)\n",
    "        self.linear2 = nn.Linear(128, input_channels * hidden_channels)\n",
    "\n",
    "    def forward(self, t, z):\n",
    "        z = self.linear1(z)\n",
    "        z = z.relu()\n",
    "        z = self.linear2(z)\n",
    "        z = z.tanh()\n",
    "        z = z.view(z.size(0), self.hidden_channels, self.input_channels)\n",
    "        return z\n",
    "\n",
    "timeline = torch.arange(1,50).cuda()/49\n",
    "class NeuralCDE(torch.nn.Module):\n",
    "    def __init__(self):\n",
    "        super().__init__()\n",
    "        self.func = CDEFunc(11,64)\n",
    "        self.encoder = nn.Linear(11,64)\n",
    "        self.decoder = nn.Linear(64,1)\n",
    "\n",
    "    def forward(self, coeffs):\n",
    "        spline = torchcde.CubicSpline(coeffs)\n",
    "        z0 = self.encoder(spline.evaluate(0))\n",
    "        z_T = torchcde.cdeint(X=spline, z0=z0, func=self.func, t=timeline, adjoint=False)\n",
    "        return self.decoder(z_T)[:,:,0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 246,
   "id": "f66b2a5c-5522-49d8-8877-1a33195f96d1",
   "metadata": {},
   "outputs": [
    {
     "ename": "ValueError",
     "evalue": "t must be monotonically increasing.",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mValueError\u001b[0m                                Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[246], line 1\u001b[0m\n\u001b[0;32m----> 1\u001b[0m coefs_tr \u001b[38;5;241m=\u001b[39m \u001b[43mtorchcde\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mhermite_cubic_coefficients_with_backward_differences\u001b[49m\u001b[43m(\u001b[49m\u001b[43mtorch\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mTensor\u001b[49m\u001b[43m(\u001b[49m\u001b[43mtX_tr\u001b[49m\u001b[43m)\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m      2\u001b[0m coefs_vl \u001b[38;5;241m=\u001b[39m torchcde\u001b[38;5;241m.\u001b[39mhermite_cubic_coefficients_with_backward_differences(torch\u001b[38;5;241m.\u001b[39mTensor(tX_vl))\n",
      "File \u001b[0;32m/opt/conda/lib/python3.11/site-packages/torchcde/interpolation_hermite_cubic_bdiff.py:33\u001b[0m, in \u001b[0;36mhermite_cubic_coefficients_with_backward_differences\u001b[0;34m(x, t)\u001b[0m\n\u001b[1;32m     24\u001b[0m \u001b[38;5;250m\u001b[39m\u001b[38;5;124;03m\"\"\"Computes the coefficients for hermite cubic splines with backward differences.\u001b[39;00m\n\u001b[1;32m     25\u001b[0m \n\u001b[1;32m     26\u001b[0m \u001b[38;5;124;03mArguments:\u001b[39;00m\n\u001b[0;32m   (...)\u001b[0m\n\u001b[1;32m     30\u001b[0m \u001b[38;5;124;03m    A tensor, which should in turn be passed to `torchcde.CubicSpline`.\u001b[39;00m\n\u001b[1;32m     31\u001b[0m \u001b[38;5;124;03m\"\"\"\u001b[39;00m\n\u001b[1;32m     32\u001b[0m \u001b[38;5;66;03m# Linear coeffs\u001b[39;00m\n\u001b[0;32m---> 33\u001b[0m coeffs \u001b[38;5;241m=\u001b[39m \u001b[43mlinear_interpolation_coeffs\u001b[49m\u001b[43m(\u001b[49m\u001b[43mx\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mt\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mt\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mrectilinear\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43;01mNone\u001b[39;49;00m\u001b[43m)\u001b[49m\n\u001b[1;32m     35\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m t \u001b[38;5;129;01mis\u001b[39;00m \u001b[38;5;28;01mNone\u001b[39;00m:\n\u001b[1;32m     36\u001b[0m     t \u001b[38;5;241m=\u001b[39m torch\u001b[38;5;241m.\u001b[39mlinspace(\u001b[38;5;241m0\u001b[39m, coeffs\u001b[38;5;241m.\u001b[39msize(\u001b[38;5;241m-\u001b[39m\u001b[38;5;241m2\u001b[39m) \u001b[38;5;241m-\u001b[39m \u001b[38;5;241m1\u001b[39m, coeffs\u001b[38;5;241m.\u001b[39msize(\u001b[38;5;241m-\u001b[39m\u001b[38;5;241m2\u001b[39m), dtype\u001b[38;5;241m=\u001b[39mcoeffs\u001b[38;5;241m.\u001b[39mdtype, device\u001b[38;5;241m=\u001b[39mcoeffs\u001b[38;5;241m.\u001b[39mdevice)\n",
      "File \u001b[0;32m/opt/conda/lib/python3.11/site-packages/torchcde/interpolation_linear.py:167\u001b[0m, in \u001b[0;36mlinear_interpolation_coeffs\u001b[0;34m(x, t, rectilinear)\u001b[0m\n\u001b[1;32m    159\u001b[0m         warnings\u001b[38;5;241m.\u001b[39mwarn(\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mThe data `x` begins with missing values in some channels. The path will be constructed by \u001b[39m\u001b[38;5;124m\"\u001b[39m\n\u001b[1;32m    160\u001b[0m                       \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mbackward-filling the first observed value, which is not causal. Raising a warning as the \u001b[39m\u001b[38;5;124m\"\u001b[39m\n\u001b[1;32m    161\u001b[0m                       \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124m`rectilinear` argument has also been passed, which is nearly always only used when \u001b[39m\u001b[38;5;124m\"\u001b[39m\n\u001b[1;32m    162\u001b[0m                       \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mcausality is desired. If you need causality then fill in the missing value at the start of \u001b[39m\u001b[38;5;124m\"\u001b[39m\n\u001b[1;32m    163\u001b[0m                       \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124meach channel with whatever you\u001b[39m\u001b[38;5;124m'\u001b[39m\u001b[38;5;124md like it to be. (The mean over that channel is a common \u001b[39m\u001b[38;5;124m\"\u001b[39m\n\u001b[1;32m    164\u001b[0m                       \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mchoice.)\u001b[39m\u001b[38;5;124m\"\u001b[39m)\n\u001b[1;32m    165\u001b[0m     x \u001b[38;5;241m=\u001b[39m _prepare_rectilinear_interpolation(x, rectilinear)\n\u001b[0;32m--> 167\u001b[0m t \u001b[38;5;241m=\u001b[39m \u001b[43mmisc\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mvalidate_input_path\u001b[49m\u001b[43m(\u001b[49m\u001b[43mx\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mt\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    169\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m torch\u001b[38;5;241m.\u001b[39misnan(x)\u001b[38;5;241m.\u001b[39many():\n\u001b[1;32m    170\u001b[0m     x \u001b[38;5;241m=\u001b[39m _linear_interpolation_coeffs_with_missing_values(t, x\u001b[38;5;241m.\u001b[39mtranspose(\u001b[38;5;241m-\u001b[39m\u001b[38;5;241m1\u001b[39m, \u001b[38;5;241m-\u001b[39m\u001b[38;5;241m2\u001b[39m))\u001b[38;5;241m.\u001b[39mtranspose(\u001b[38;5;241m-\u001b[39m\u001b[38;5;241m1\u001b[39m, \u001b[38;5;241m-\u001b[39m\u001b[38;5;241m2\u001b[39m)\n",
      "File \u001b[0;32m/opt/conda/lib/python3.11/site-packages/torchcde/misc.py:88\u001b[0m, in \u001b[0;36mvalidate_input_path\u001b[0;34m(x, t)\u001b[0m\n\u001b[1;32m     86\u001b[0m \u001b[38;5;28;01mfor\u001b[39;00m t_i \u001b[38;5;129;01min\u001b[39;00m t:\n\u001b[1;32m     87\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m t_i \u001b[38;5;241m<\u001b[39m\u001b[38;5;241m=\u001b[39m prev_t_i:\n\u001b[0;32m---> 88\u001b[0m         \u001b[38;5;28;01mraise\u001b[39;00m \u001b[38;5;167;01mValueError\u001b[39;00m(\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mt must be monotonically increasing.\u001b[39m\u001b[38;5;124m\"\u001b[39m)\n\u001b[1;32m     89\u001b[0m     prev_t_i \u001b[38;5;241m=\u001b[39m t_i\n\u001b[1;32m     91\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m x\u001b[38;5;241m.\u001b[39msize(\u001b[38;5;241m-\u001b[39m\u001b[38;5;241m2\u001b[39m) \u001b[38;5;241m!=\u001b[39m t\u001b[38;5;241m.\u001b[39msize(\u001b[38;5;241m0\u001b[39m):\n",
      "\u001b[0;31mValueError\u001b[0m: t must be monotonically increasing."
     ]
    }
   ],
   "source": [
    "coefs_tr = torchcde.hermite_cubic_coefficients_with_backward_differences(torch.Tensor(tX_tr))\n",
    "coefs_vl = torchcde.hermite_cubic_coefficients_with_backward_differences(torch.Tensor(tX_vl))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3152bc50-4797-4047-a969-099b6ab768cc",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "model = NeuralNetRegressor(NeuralCDE, max_epochs=0, lr=1e-2, iterator_train__shuffle=True, device='cuda')\n",
    "model.fit(coefs_tr, ty_tr)\n",
    "model.score(coefs_vl, ty_vl)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a7c46cae-221a-4c81-8d0e-0cff4d253147",
   "metadata": {},
   "source": [
    "# EDA"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 201,
   "id": "b6ac6b79-e43e-4987-91f7-a1b959900e04",
   "metadata": {},
   "outputs": [],
   "source": [
    "class rnn2d(nn.Module): \n",
    "    def __init__(self):\n",
    "        h = 128\n",
    "        self.steps = 7\n",
    "        super().__init__()\n",
    "        self.enc = nn.Conv1d(m.sum(),h,3,padding=1)\n",
    "        self.map = nn.Sequential(\n",
    "                nn.Conv1d(h,h,3,padding=1),\n",
    "                nn.ReLU(True),\n",
    "                nn.Conv1d(h,h,3,padding=1),\n",
    "                nn.ReLU(True)\n",
    "            )\n",
    "        self.dec = nn.Conv1d(h,8,3,padding=1)\n",
    "        # self.fdec = nn.Linear(12,6)\n",
    "        \n",
    "    def forward(self, inp):\n",
    "        # b,cl -> b,c,l\n",
    "        inp = inp.float().reshape(-1,49,m.sum()).transpose(1,2)\n",
    "        mm = self.enc(inp)\n",
    "        for _ in range(self.steps):\n",
    "            mm = mm + self.map(mm)/self.steps\n",
    "        out = self.dec(mm).transpose(1,2)\n",
    "        y = out[:,:,:2]\n",
    "        # fup = out[:,-1,[2,3,5,6]]\n",
    "        # fdn = out[:,0,[4,7]]\n",
    "        # return torch.cat((y,fup,fdn),1)\n",
    "        # f = self.fdec(out[:,[0,-1],2:].reshape(-1,12))\n",
    "        return y"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 202,
   "id": "0fda4a49-4331-4007-bbde-12079d8ade07",
   "metadata": {
    "collapsed": true,
    "jupyter": {
     "outputs_hidden": true
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_362/3413790039.py:3: FutureWarning: You are using `torch.load` with `weights_only=False` (the current default value), which uses the default pickle module implicitly. It is possible to construct malicious pickle data which will execute arbitrary code during unpickling (See https://github.com/pytorch/pytorch/blob/main/SECURITY.md#untrusted-models for more details). In a future release, the default value for `weights_only` will be flipped to `True`. This limits the functions that could be executed during unpickling. Arbitrary objects will no longer be allowed to be loaded via this mode unless they are explicitly allowlisted by the user via `torch.serialization.add_safe_globals`. We recommend you start setting `weights_only=True` for any use case where you don't have full control of the loaded file. Please open an issue on GitHub for any issues related to this experimental feature.\n",
      "  rnn.module_.load_state_dict(torch.load('weights_wrf/rnn2d128.7.pt'))\n",
      "/tmp/ipykernel_362/3413790039.py:7: FutureWarning: You are using `torch.load` with `weights_only=False` (the current default value), which uses the default pickle module implicitly. It is possible to construct malicious pickle data which will execute arbitrary code during unpickling (See https://github.com/pytorch/pytorch/blob/main/SECURITY.md#untrusted-models for more details). In a future release, the default value for `weights_only` will be flipped to `True`. This limits the functions that could be executed during unpickling. Arbitrary objects will no longer be allowed to be loaded via this mode unless they are explicitly allowlisted by the user via `torch.serialization.add_safe_globals`. We recommend you start setting `weights_only=True` for any use case where you don't have full control of the loaded file. Please open an issue on GitHub for any issues related to this experimental feature.\n",
      "  cfc.module_.load_state_dict(torch.load('weights_wrf/cfc256f.pt'))\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<All keys matched successfully>"
      ]
     },
     "execution_count": 202,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "rnn = NeuralNetRegressor(rnn2d, max_epochs=0, lr=1e-2, device='cuda')\n",
    "rnn.fit(tX_tr[:,m].reshape(-1,49*m.sum()), np.concatenate((ty_tr.reshape(-1,49*2), tf_tr), 1))\n",
    "rnn.module_.load_state_dict(torch.load('weights_wrf/rnn2d128.7.pt'))\n",
    "\n",
    "cfc = NeuralNetRegressor(LNN, max_epochs=0, lr=1e-2, device='cuda')\n",
    "cfc.fit(tX_tr[:,m].reshape(-1,49*m.sum()), np.concatenate((ty_tr.reshape(-1,49*2), tf_tr), 1))\n",
    "cfc.module_.load_state_dict(torch.load('weights_wrf/cfc256f.pt'))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 228,
   "id": "6b31ce27-8ab4-4cc5-ab6e-ccf1a5970004",
   "metadata": {},
   "outputs": [],
   "source": [
    "hPa = X_vl[:,3].reshape(-1,49)/100\n",
    "Kd = y_vl[:,0].reshape(-1,49)*86400\n",
    "def get(i):\n",
    "    plt.title(f'RTHRATSW\\ncos zen={X_vl[i*49,14]:.2f}')\n",
    "    plt.plot(Kd[i], hPa[i], '+', label='data', color='blue')\n",
    "\n",
    "    inp = X_vl[i*49 : (i+1)*49]\n",
    "    \n",
    "    predict = rnn.predict(xpipe0.transform(inp)[:,m].reshape(1,49*m.sum()))\n",
    "    predict = 86400*(predict.reshape(-1,2)[:,0]*5.07591444e-06 + 7.29721246e-06)\n",
    "    plt.plot(predict, hPa[i], '-', label='rnn', color='tab:blue')\n",
    "    \n",
    "    predict = cfc.predict(xpipe.transform(inp)[:,m].reshape(1,49*m.sum()))\n",
    "    predict = 86400*ypipe.inverse_transform(predict[:,:-6].reshape(-1,2))[:,0]\n",
    "    plt.plot(predict, hPa[i], '-', label='cfc', color='tab:orange')\n",
    "    \n",
    "    plt.grid(True)\n",
    "    plt.gca().invert_yaxis()\n",
    "    plt.ylabel('Pressure (hPa)')\n",
    "    plt.xlabel('K/d')\n",
    "    plt.legend(loc='lower right')\n",
    "\n",
    "# def get20(i):\n",
    "#     predict = model.predict(tX_vl[i*49 : (i+1)*49, m].reshape(1,49*m.sum()))\n",
    "#     predict = 86400*ypipe.inverse_transform(predict[:,:-6].reshape(-1,2))[:,0]\n",
    "#     plt.plot(predict, hPa[i], '-', label='20 features rnn', color='tab:purple')\n",
    "#     plt.legend(loc='lower right')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 257,
   "id": "e4ca748e-40a2-46fa-8cd3-26fc3f2fe540",
   "metadata": {},
   "outputs": [],
   "source": [
    "hPa = X_vl[:,3].reshape(-1,49)/100\n",
    "Kd = y_vl[:,1].reshape(-1,49)*86400\n",
    "def get(i):\n",
    "    plt.title(f'RTHRATLW\\ncos zen={X_vl[i*49,14]:.2f}')\n",
    "    plt.plot(Kd[i], hPa[i], '+', label='data', color='blue')\n",
    "\n",
    "    inp = X_vl[i*49 : (i+1)*49]\n",
    "    \n",
    "    predict = rnn.predict(xpipe0.transform(inp)[:,m].reshape(1,49*m.sum()))\n",
    "    predict = 86400*(predict.reshape(-1,2)[:,1]* 1.57800251e-05 + -1.20092908e-05)\n",
    "    plt.plot(predict, hPa[i], '-', label='rnn', color='tab:blue')\n",
    "    \n",
    "    predict = cfc.predict(xpipe.transform(inp)[:,m].reshape(1,49*m.sum()))\n",
    "    predict = 86400*ypipe.inverse_transform(predict[:,:-6].reshape(-1,2))[:,1]\n",
    "    plt.plot(predict, hPa[i], '-', label='cfc', color='tab:orange')\n",
    "    \n",
    "    plt.grid(True)\n",
    "    plt.gca().invert_yaxis()\n",
    "    plt.ylabel('Pressure (hPa)')\n",
    "    plt.xlabel('K/d')\n",
    "    plt.legend(loc='lower right')\n",
    "\n",
    "# def get20(i):\n",
    "#     predict = model.predict(tX_vl[i*49 : (i+1)*49, m].reshape(1,49*m.sum()))\n",
    "#     predict = 86400*ypipe.inverse_transform(predict[:,:-6].reshape(-1,2))[:,0]\n",
    "#     plt.plot(predict, hPa[i], '-', label='20 features rnn', color='tab:purple')\n",
    "#     plt.legend(loc='lower right')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 258,
   "id": "96fe8d51-b2a7-47b1-a73d-deeb7a7566db",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABS0AAANnCAYAAADUZn1PAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy81sbWrAAAACXBIWXMAAA9hAAAPYQGoP6dpAAEAAElEQVR4nOzdd3xV9f3H8de9N3vvQQYjbMIKG5migIoM666DqhRba+uqvzoqolarVqt1IrXOuusWB3vvsDeBJED23vOe3x8nk4SdCe/n43Ee9+acc8/5fq+Yb87nOz4WwzAMRERERERERERERNoIa2sXQERERERERERERKQuBS1FRERERERERESkTVHQUkRERERERERERNoUBS1FRERERERERESkTVHQUkRERERERERERNoUBS1FRERERERERESkTVHQUkRERERERERERNoUBS1FRERERERERESkTVHQUkRERERERERERNoUBS1FmsG7776LxWKp2RwcHAgNDeX666/nwIEDzJw5s97xE20zZ84EYNy4cURHRzd6r4yMDCwWC48//njNvmXLltW7js1mIzAwkCuvvJJNmzadsNzffvstFosFf39/SktLa/aPGzfutMpbXYZOnToxZcqUBtdPT0/HarXyu9/9rsGxP/3pT1gsFh566KEGx26//XZsNhvZ2dknLLuIiDQftWtq10REzidq19SuSfvg0NoFEDmfvfPOO/Ts2ZOSkhJWr17N3/72N5YuXcqCBQu48847a86LjY3lrrvu4umnn2b8+PE1+wMDA8/p/tXXKy8vZ8uWLcydO5exY8eydetWunXr1uD8t99+G4CsrCy+/vprrrvuOgBef/118vLyas774YcfeOqpp2rqVy08PPyk5QkMDKRPnz4sXbq0wbFly5bh7u5+wmMDBgzA19f39CouIiLNQu1afWrXRETaN7Vr9aldk7ZGQUuRZhQdHc3gwYMBs/ersrKSOXPmsH37dn7zm9/UnFdSUgJAt27dGD58eJPdv+71Ro8ejY+PD7feeisffvghc+fOrXduSkoKCxYs4OKLL2bNmjW8/fbbNY1g79696527d+/eBvU7XePHj+eVV14hJSWFkJAQwGx0d+zYwf33389LL71Efn4+np6eABw9epRDhw5x//33n/kXICIiTUrtWkNq10RE2i+1aw2pXZO2RNPDRVpQdYOR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",
      "text/plain": [
       "<Figure size 1600x1000 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(16,10))\n",
    "\n",
    "plt.subplot(131)\n",
    "get(7)\n",
    "plt.subplot(132)\n",
    "get(10007)\n",
    "plt.subplot(133)\n",
    "get(11)\n",
    "\n",
    "# m = imps>0.01\n",
    "# plt.subplot(131)\n",
    "# get20(3119)\n",
    "# plt.subplot(132)\n",
    "# get20(10000)\n",
    "# plt.subplot(133)\n",
    "# get20(7)\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 281,
   "id": "c67a88b2-eef9-430c-9487-0e358ab61444",
   "metadata": {},
   "outputs": [],
   "source": [
    "y_pred = rnn.predict(xpipe0.transform(X_vl)[:,m].reshape(-1,49*m.sum())).reshape(-1,2)\n",
    "y_pred[:,0] = y_pred[:,0] * 5.07591444e-06 + 7.29721246e-06\n",
    "y_pred[:,1] = y_pred[:,1] * 1.57800251e-05 + -1.20092908e-05"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 282,
   "id": "cd2077ea-658e-4e07-a325-f993627fd229",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_362/2408588664.py:14: UserWarning: color is redundantly defined by the 'color' keyword argument and the fmt string \"-b\" (-> color='b'). The keyword argument will take precedence.\n",
      "  plt.plot(loss_mean[d,:], 1e-2*pres, '-b', label='mean error', color='tab:blue')\n",
      "/tmp/ipykernel_362/2408588664.py:15: UserWarning: color is redundantly defined by the 'color' keyword argument and the fmt string \"--b\" (-> color='b'). The keyword argument will take precedence.\n",
      "  plt.plot(loss_mean_abs[d,:], 1e-2*pres, '--b', label='mean absolute error', color='tab:blue')\n"
     ]
    },
    {
     "data": {
      "image/png": "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YtiwYbj44ovx7LPPoqqqKu4zs2fPbjb+ln716dOnw383wWAQ9957L4444gjk5OSgS5cuOPvss/H55593+FxRuq7jr3/9K4YPHw6v14uioiJMnDgR7733XovHa5qG999/H9dffz1GjBgBn88Hl8uF3r1745JLLsGKFSvavaamaXj66acxbtw4lJSUwO12o3fv3pg6dSreeOONDo0/+m9+2WWXtfi+EAJXX301JElCbm4uFixY0OJxF198MSRJSrpVB1E2sJs9ACJq3YABA9C1a1cAQHV1NTZs2ICXXnoJc+bMwaxZs9pturlixQqsWbMGRxxxRIvvt9eIs6amBqeddhqWLl0KACgpKcGwYcOg6zo2bNiAVatW4cUXX0RpaSnOOOOMZp93uVw47rjjWj1/WVlZm9c/WH19PcaNG4fly5fD6XTiyCOPRHl5Od5880288847ePHFF3H++ed36JyapuHss8/GO++8A1mWMXToUNTW1uKjjz7CRx99hIcffjjW9DRq9uzZuOqqqwAAdrsdAwcOhMPhwA8//IAXXngB//73v/H3v/8d11xzTYvXrKqqwpQpU/D5559DkiQMHDgQffr0wa5du/DGG2/Abrfj7LPP7tB9tEbXdVx11VWYNWsWcnNz8c4777TYzFTXdcybNw/dunVr89+MKOsJIrKc3r17CwBi1qxZca9XVlaKc889VwAQPp9PVFZWNvvspZdeKgCIQYMGCQDi9ttvb/EamqaJ7t27C5/PJ7p37y4AiAULFsQdc8011wgAoqSkRLz33ntx76mqKj799FNx+eWXi/nz58e9N2vWLAFA9O7du8P33pZrr71WABCDBw8WW7Zsid3Hgw8+KACInJwcsW3btg6d8/777xcARGlpqVi5cmXs9ZdeeknIsiwkSRJffvll3GeefvppMWLECPHCCy+Iurq62OvV1dXisssuEwCEzWYT33zzTbPraZomxowZIwCIadOmie3bt8e9v337dvHpp5926B6i/+aXXnpps2tF3/P5fGLRokWtnmPRokUCgLjiiisSvu7vf/97AUD8/ve/79B4iczEwIfIgloLfISIfHP1er0CgJgzZ06z96Pf6G6//Xbh9XrFYYcdJnRdb3bc/PnzBQBx2WWXif79+zcLfBRFiV3nxRdf7ND4jQh8du3aJex2uwAglixZ0uz9SZMmCQDihhtu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6OvJno/MxcCHiIgScsopp+D666/HTTfdhMLCQpSWluKpp55CfX09Lr/8cvh8PvTv3x/vvfde3OfWrFmDKVOmIDc3F6Wlpbj44otRUVERe3/evHkYM2YMCgoKUFxcjDPOOAMbN26Mvb9lyxZIkoTXXnsN48ePh8fjwdFHH42lS5e2Od7q6mpcc8016Nq1K/Ly8vCjH/0I33zzTez9GTNm4JhjjsFzzz2Hfv36weVyQQgBSZLwz3/+E2effTa8Xi/+8Ic/AACeeOIJ9O/fH06nE4MGDcILL7wQd73WPkfWwsCHiMhkQgj4w2rafgXCWsLHCiE6NNbnn38eJSUl+PLLL3H99dfjF7/4BX7605/ipJNOwooVK3Dqqafi4osvjhVn3L17N8aNG4djjjkGX331FebNm4e9e/fivPPOi52zvr4eN998M5YtW4aPPvoIsizjnHPOga7rcde+6667cOutt2LlypUYOHAgLrzwQqiq2urf6emnn449e/bg3XffxfLlyzFixAhMmDABlZWVseM2bNiA//73v3j11VexcuXK2Ou///3vcfbZZ+O7777DFVdcgblz5+LGG2/ELbfcglWrVuHaa6/F5ZdfjgULFsRd9+DPkfWwjg8RkckCioYjfve+Kddec++p8DgT/1Zw9NFH4//+7/8AAHfccQceeOABlJSU4OqrrwYA/O53v8MTTzyBb7/9FieccAKeeOIJjBgxAn/6059i53juuefQq1cv/PDDDxg4cCB+8pOfxF3j2WefRdeuXbFmzRoMHTo09vqtt96K008/HQBwzz334Mgjj8SmTZtQVFTUbJwLFizAd999h/LycrhcLgDAn//8Z7z++uv43//+h2uuuQZApK7SCy+8gC5dusR9fvr06XGBy/Tp03HZZZfhuuuuAwDcfPPN+Pzzz/HnP/8Z48ePb/VzZD3M+BARUcKOOuqo2O9tNhuKi4sxbNiw2GulpaUAgPLycgDA8uXLsWDBAuTm5sZ+DR48GABi01kbN27E9OnT0a9fP+Tl5aFv374AgG3btrV67bKyMgDAvn37Whzn8uXLUVdXh+Li4rhrb968OW4arXfv3s2CHgA47rjj4v68du1ajB49Ou610aNHY+3atW1+jqyHGR8iIpPlOGxYc++paTmXruuoramFL8+XULG4HIetQ+d3OBxxf5YkKe61aPuN6DSVrus488wz8eCDDzY7VzR4OfPMM9GrVy88/fTT6N69O3Rdx9ChQxEOh1u9dvQ6rU3V6bqOsrIyfPLJJ83eKygoiP3e6/W2+PmWXj+4tUh0PVB7nyNrYeBDRGQySZI6NN3UFl3XoTpt8DjtlqiSO2LECLz66qvo06cP7Pbm97h//36sXbsWTz75JMaOHQsAWLRoUVquu2fPHtjtdvTp0yfl8w0ZMgSLFi3CJZdcEnttyZIlGDJkSMrnpswy/6uCiIgOWb/85S9RWVmJCy64AF9++SU2bdqEDz74AFdccQU0TUNhYSGKi4vx1FNPYcOGDfj4449x8803p3zdiRMn4sQTT8TUqVPx/vvvY8uWLViyZAn+7//+D1999VWHz/eb3/wGs2fPxj//+U+sX78eM2fOxGuvvYZbb7015bFSZjHwISIiw3Tv3h2LFy+Gpmk49dRTMXToUNx4443Iz8+HLMuQZRlz5szB8uXLMXToUPz617/Gww8/nPJ1JUnCu+++i5NPPhlXXHEFBg4ciPPPPx9btmyJrUPqiKlTp+Ivf/kLHn74YRx55JF48sknMWvWLJxyyikpj5UySxId3ctIraqpqUF+fj4qKipQXFxs9nAMoygK3n33XUyZMqXZfP+hhPd5aLHKfQaDQWzevBl9+/Y1pDu1ruuoqalBXl6eJaa6jNRZ7vVQus+2/vvfv38/SkpKUF1djby8PMPGkN1/g0REREQdwMCHiIiIOg0GPkRERNRpMPAhIiKiToOBDxEREXUaDHyIiIio02DgQ0RERJ0GAx8iIiLqNBj4EBERUafBwIeIiDql2bNnx3VqN0KfPn3w2GOPGXoN6hgGPkRERBbxySefQJIkHDhwwOyhHLIY+BARERE0TYOu681eD4fDSZ0v2c8ZjYEPEREl5JRTTsH111+Pm266CYWFhSgtLcVTTz2F+vp6XH755fD5fOjfvz/ee++9uM+tWbMGU6ZMQW5uLkpLS3HxxRejoqIi9v68efMwZswYFBQUoLi4GGeccQY2btwYe3/Lli2QJAmvvfYaxo8fD4/Hg6OPPhpLly5tc7wzZ87EsGHD4PV60atXL1x33XWoq6trdtzrr7+OgQMHwu12Y9KkSdi+fXvsvW+++Qbjx4+Hz+dDXl4ejj32WHz11Vex91999VUceeSRcLlc6NOnDx555JFWxxO9j5UrV8ZeO3DgACRJwieffIItW7Zg/PjxAIDCwkJIkoTLLrsMACCEwMMPP4x+/fohJycHRx99NP73v/+1ef/hcBi//e1v0aNHD3i9Xhx//PH45JNPYu9Hp/refvttHHHEEXC5XNi6dSv69OmDP/zhD7jsssuQn5+Pq6++OqF7be1zVsPAh4jIIvxhtdVfQUVL+7HJeP7551FSUoIvv/wS119/PX7xi1/gpz/9KU466SSsWLECp556Ki6++GL4/X4AwO7duzFu3Dgcc8wx+OqrrzBv3jzs3bsX5513Xuyc9fX1uPnmm7Fs2TJ89NFHkGUZ55xzTrPsw1133YVbb70VK1euxMCBA3HhhRdCVVu/D1mW8de//hWrVq3C888/j48//hi//e1v4/9u/H788Y9/xPPPP4/FixejpqYG559/fuz9Cy+8ED179sSyZcuwfPly3H777XA4HACA5cuX47zzzsP555+P7777DjNmzMDdd9+N2bNnJ/V326tXL7z66qsAgHXr1mH37t34y1/+AgD4wx/+gNmzZ+OJJ57A6tWr8etf/xoXXXQRPv3001bPd/nll2Px4sWYM2cOvv32W/z0pz/FaaedhvXr18fd//33349nnnkGq1evRteuXQEADz/8MIYOHYrly5fj7rvvTvheD/6cJQlKm+rqagFAVFRUmD0UQ4XDYfH666+LcDhs9lAMxfs8tFjlPgOBgFizZo0IBALN3ut929ut/rrsuS/ijh38f++1euy0xz8TmqbFjh1+7wctHtdR48aNE2PGjIn9WVVV4fV6xcUXXxx7bffu3QKAWLp0qRBCiLvvvltMnjw57jzbt28XAMS6detavE55ebkAIL777jshhBCbN28WAMQzzzwTO2b16tUCgPjiiy/i7rUt//3vf0VxcXHsz7NmzRIAxOeffx57be3atbHzCiGEz+cTs2fPbvF806dPF5MmTYp77Te/+Y044ogjYn/u3bu3ePTRR+Pu4+uvv469X1VVJQCIBQsWCCGEWLBggQAgqqqqYsfU1NQIt9stFi1aFHetK6+8UlxwwQUtjm3Dhg1CkiSxc+fOuNcnTJgg7rjjjrj7X7lyZdwxvXv3FlOnTk3qXg/+3MHa+u+/oqJCABDV1dVtniNVzPgQEVHCjjrqqNjvbTYbiouLMWzYsNhrpaWlAIDy8nIAkazIggULkJubG/s1ePBgAIhNZ23cuBHT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3e622D2L1j217kPbeup2a+uluq3as9WzrrFVui0oVUERULAiiBIDGBIgIXP5fc8fk5lkMjNJwCTzmfxez8fDUmZ+Cd9vJvnNO5/vbenSpZowYcJQtm1Q/v3f/12LFi3Spz/9aa1cuVJTp07VNddcoyuvvFKStHXrVjU3N2vhwoXZj6moqNA555yjVatW6aqrrtILL7ygRCKRc01jY6PmzJmjVatWadGiRQX/7a6uLnV1dWX/3t7eLklKJBID7mhdzjJ9G819lOhnb12JlOKJuCojEfmpZNHrRpLvXHaOT3VUA7Yr8/xwtP+XL76tpk0tWnRCvT41r7Hodclk+mvsJ5NK+MMTfoLyfSsFp69B6+dwO+zgc/TRR0uSOjs7dd111+m6667Lzo8pxPM8/elPfzrcf66oN954Qz/84Q913XXX6W//9m+1Zs0aXXvttaqoqNBnP/tZNTc3S5Lq6+tzPq6+vl7btm2TJDU3NysWi2n8+PF512Q+vpCbb75ZN910U97jTz/9tKqrq99v18xramoqdRNGBP3s0TYC7RisjqTkum9hu19do7ZB1q+3r392yNvy9lshNbeHtH3bm3rTe2PA6594dcBL3regfN9KwenraO9nR0fHiPw7hx183nzzzbzHdu3apV27dhW83humQW3f93XaaadpxYoVkqR58+Zpw4YN+uEPf6jPfvazRf991z3W3p+Brrnxxht13XXXZf/e3t6uadOm6bzzzhvVGzYmEgk1NTXpggsuyG5WORrRzx57DsS17q1WTRlbNcKtK+7d9oPSH9cpFvY069Q/G/B6P5XU9vXP6qi5ZygUHtqhsUnxt6R33lblhCmaccrMotft7YirKhbWvKPGF73m/QrK960UnL4GpZ979uwZkX/nsH/6t27dOpTtOGxTpkzRCSeckPPY8ccfr4cffliS1NDQICld1ZkyZUr2mpaWlmwVqKGhQfF4XK2trTlVn5aWln43X6yoqCi4qi0ajY7qb84M+jm69NdP5yXlhSJDHhjej47uEasxFdFDalcoPPT9qIymP1/SV7+f23kpxaKxEfl+Csr3rRScvo72fo5U3w77p3/69OlD2Y7DdvbZZ+u1117LeWzz5s3Z9s2cOVMNDQ1qamrSvHnzJEnxeFwrV67Ud77zHUnS/PnzFY1G1dTUpCVLlkiSdu7cqVdeeUW33nrrCPYG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rdPSpUuHvX9AKe3vSmp/V/nML5nTOFbVsbBa9nXp6QEqKaV20pHjdPYxkwbczTkc8hQLh7T53X2c4QWMAPNndX3sYx/Txz72sYLPOed0++236xvf+IY+9alPSZJ++tOfqr6+Xg888ICuuuoqtbW16cc//rHuvfdeLViwQJJ03333adq0aXrqqae0aNEibdq0SU888YSeffZZnX766ZKku+++W2eeeaZee+01HXfccSPTWWCEhT1PgzhlwYxx1TEtOW2a7ln1pn727Dadfcwks6vPDsXEMRXas79LG99p0+wpY1U/trLUTQJGLfMVn/5s3bpVzc3NWrhwYfaxiooKnXPOOVq1apUk6YUXXlAikci5prGxUXPmzMles3r1atXV1WVDjySdccYZqqury14DjEahkKdy2z7vopMbVT+2Qu8diOuRF3cM/AElsvndffrF82/p+TffG9T1E8dUyPM8bXinTW/v7Rzm1gHBZb7i05/m5mZJUn19fc7j9fX12rZtW/aaWCym8ePH512T+fjm5mZNnjw57/NPnjw5e00hXV1d6urqKU23t7dLkhKJhBKJ0bspWaZvo7mPUkD66Sfl+elJtX6qPIa8wpKuOOMo3frkFj289m2ddfR4HTWhesCPy/RvpPr5yo5W/ezZ7frApBpNrYsNqopTVxFSW2dKG996T/GuMZo6vkqed2gluUB833YLSl+D1s/hVtbBJ6PvjcE5N+DNou81ha4f6PPcfPPNuummm/Ief/rpp1VdPfCNuNw1NTWVugkjIij93L7+2VI3YdAanXTM2JBeb5duePgl/Y8TUppaM7iPHal+uj2epLD+tPuArr5/rU6d5HT+VF+Ng7w1vPyG9PL7+PeD8n0rBaevo72fHR0dI/LvlHXwaWhokJSu2EyZMiX7eEtLS7YK1NDQoHg8rtbW1pyqT0tLi84666zsNe+++27e59+1a1deNam3G2+8Udddd1327+3t7Zo2bZrOO+88TZw48f11zrBEIqGmpiZdcMEFikbt7vnyfpVTP+NJX0nfVzzpK55ySiR9HUyk1BFPqTOeUtL3lfB9JXudCxXxPEXDIUU8X7tfe15HzT1DoXD53BKWH5/U8sc26fVdB/SD1yq0fPHx/R5h4aeS2r7+2RHr5wxJHziuTb9c+45e2tGm53d7en53SB+cPl6fPWPagFWqrmRKnV0p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nXeeO/nkk10ymRzuLhV0qP10zrmf/exn7qabbnJ33323k+TWrl2bd80555zjrrzySrdz587sf3v37h2mXgxsuPo5Gl7PW265xdXW1rqHH37YrV+/3v3FX/yFmzJlimtvb89eU+rX88EHH3TRaNTdfffdbuPGje4rX/mKq6mpcdu2bSt4/RtvvOGqq6vdV77yFbdx40Z39913u2g06n75y19mr1m1apULh8NuxYoVbtOmTW7FihUuEom4Z599dqS6lWc4+vmTn/zEjR07Nue127lz50h1qaBD7efWrVvdtdde637605+6U045xX3lK1/Ju2Y0vJ6D6edoeD2/8pWvuO985ztuzZo1bvPmze7GG2900WjUvfjii9lrhur1JPgM0saNG52knC/w6tWrnST36quvDvrzrFmzxknKvvh79+510WjUPfjgg9lr3n77bRcKhdwTTzwxdB0YpPfbz61bt/YbfAr90JbCcPVzNLyevu+7hoYGd8stt2QfO3jwoKurq3N33XVX9rFSv54f+tCH3NVXX53z2OzZs90NN9xQ8Prrr7/ezZ49O+exq666yp1xxhnZvy9ZssRdeOGFOdcsWrTIXXrppUPU6kM3HP38yU9+4urq6oa8re/Hofazt2Lfi6Ph9eytWD9H2+uZccIJJ7ibbrop+/ehej0Z6hqk1atXq66uTqeffnr2sTPOOEN1dXVatWrVoD9PW1ubPM/TuHHjJEkvvPCCEomEFi5cmL2msbFRc+bMOaTPO1SGqp/F3H///Zo0aZJOPPFEff3rX9e+ffve9+c8HMPVz9Hwem7dulXNzc05faioqNA555yT9zGlej3j8bheeOGFnDZK0sKFC4v2a/Xq1XnXL1q0SM8//7wSiUS/15TitZOGr5+StH//fk2fPl1HHnmkFi9erLVr1w59BwbpcPo5GKPh9Rys0fZ6+r6vffv25RxYOlSvJ4eUDlJzc7MmT56c9/jkyZPV3Nw8qM9x8OBB3XDDDbrsssuyB801NzcrFotp/PjxOdfW19cP+vMOpaHoZzGXX365Zs6cqYaGBr3yyiu68cYb9dJLL6mpqel9fd7DMVz9HA2vZ+bx+vr6nMfr6+u1bdu27N9L+Xru3r1bqVSqYBv761eh65PJpHbv3q0pU6YUvaYUr500fP2cPXu27rnnHs2dO1ft7e3653/+Z5199tl66aWX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",
      "text/plain": [
       "<Figure size 600x1200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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ba3+9m//Vtu2betxnQv382c/+5lmzZql8vJyHXPMMfrzn//c7/XPPPOMjjnmGJWXl+uggw7SnXfe2euaRx55REcccYSi0aiOOOIIPfroo4V6+YOWTT9/+9vf6rTTTtOkSZM0ZswYHX/88frf//3fHtfce++9Gd+vbW1the5Kv7Lp59NPP52xD2+99VaP64r9fmb6zDHGaO7cuelrXLyfzz77rD73uc+ptrZWxhj97ne/G/Bnhuz9aTFo3/ve9+wtt9xir776altdXT2on7nxxhvt6NGj7SOPPGJff/11+4UvfMFOnTrVNjQ0pK+5/PLL7QEHHGBXrFhhX3nlFbto0SL7yU9+0sbj8QL1pH9nnHGGnTdvnl21apVdtWqVnTdvnj377LP7/ZmPP/64x6977rnHGmPs+++/n77m5JNPtpdeemmP6/bt21fo7vQpl34uW7bMnnHGGT36sGfPnh7XFPv93Ldvn128eLF9+OGH7VtvvWVXr15tjzvuOHvMMcf0uG647+dDDz1kI5GIveuuu+z69evtlVdeaUeNGmU3b96c8fqNGzfayspKe+WVV9r169fbu+66y0YiEfuf//mf6WtWrVplQ6GQveGGG+yGDRvsDTfcYMPhsH3hhReGqlu9ZNvPK6+80t500032xRdftO+884697rrrbCQSsa+88kr6ml/+8pd2zJgxvd63wynbfq5cudJKsm+//XaPPnR/n42E+7lv374e/du6dasdP368/f73v5++xsX7+T//8z/229/+tn3kkUesJPvoo4/2e/1Qvj8JPjn45S9/Oajg4/u+rampsTfeeGP6sba2NltdXW3vvPNOa23yD3UkErEPPfRQ+pqPPvrIep5nn3jiicBf+0DWr19vJfX4g7R69Woryb711luDbufcc8+1p5xySo/HTj75ZHvllVcG9VLzkms/ly1bZs8999w+vz9S7+eLL75oJfX4cB7u+3nsscfayy+/vMdjc+bMsddee23G67/5zW/aOXPm9HjssssuswsWLEh/fcEFF9gzzjijxzWnn366vfDCCwN61dnLtp+ZHHHEEfb6669Pfz3Yz7ChlG0/U8Gnrq6uzzZH4v189NFHrTHGfvDBB+nHXLyf3Q0m+Azl+5OhrgLatGmTtm/friVLlqQfi0ajOvnkk7Vq1SpJ0po1axSLxXpcU1tbq3nz5qWvGUqrV69WdXW1jjvuuPRjCxYsUHV19aBfz44dO/T444/rkksu6fW9X/3qV5o4caLmzp2ra665Ro2NjYG99mzk08+nn35akydP1mGHHaZLL71UO3fuTH9vJN5PKXl4oDGm1xDvcN3Pjo4OrVmzpsf/Z0lasmRJn/1avXp1r+tPP/10vfzyy4rFYv1eMxz3Tsqtn/vzfV+NjY29Dn5samrSjBkzdOCBB+rss8/W2rVrA3vd2cqnn0cddZSmTp2qU089VStXruzxvZF4P++++24tXrxYM2bM6PG4S/czF0P5/uSQ0gLavn27JGnKlCk9Hp8yZYo2b96cvqasrEzjxo3rdU3q54fS9u3bNXny5F6PT548edCv57777tPo0aN1/vnn93j84osv1qxZs1RTU6M33nhD1113nV599VWtWLEikNeejVz7eeaZZ+rzn/+8ZsyYoU2bNum73/2uTjnlFK1Zs0bRaHRE3s+2tjZde+21uuiii3ockDic93P37t1KJBIZ31t99Wv79u0Zr4/H49q9e7emTp3a5zXDce+k3Pq5v3/9139Vc3OzLrjggvRjc+bM0b333qsjjzxSDQ0N+slPfqITTzxRr776qg499NBA+zAYufRz6tSp+sUvfqFjjjlG7e3tuv/++3Xqqafq6aef1kknnSSp73terPfz448/1h/+8Ac9+OCDPR537X7mYijfnyUffJYvX67rr7++32teeuklzZ8/P+fnMMb0+Npa2+ux/Q3mmmwMtp9S79eb7eu55557dPHFF6u8vLzH45deemn6v+fNm6dDDz1U8+fP1yuvvKKjjz56UG0PpND9/MIXvpD+73nz5mn+/PmaMWOGHn/88V5BL5t2szVU9zMWi+nCCy+U7/v62c9+1uN7Q3E/B5LteyvT9fs/nsv7tdByfU2//vWvtXz5cv3+97/vEYAXLFjQY1L+iSeeqKOPPlq33367/u3f/i24F56lbPo5e/ZszZ49O/318ccfr61bt+pf/uVf0sEn2zaHSq6v6d5779XYsWN13nnn9Xjc1fuZraF6f5Z88PnqV7864EqUmTNn5tR2TU2NpGSSnTp1avrxnTt3plNrTU2NOjo6VFdX16NKsHPnTp1wwgk5PW8mg+3na6+9ph07dvT63q5du3ol7Uz+/Oc/6+2339bDDz884LVHH320IpGI3n333cD+ohyqfqZMnTpVM2bM0LvvvitpZN3PWCymCy64QJs2bdKf/vSnHtWeTApxP/syceJEhUKhXv/S6/7e2l9NTU3G68PhsCZMmNDvNdn8mQhSLv1Mefjhh3XJJZfoN7/5jRYvXtzvtZ7n6dOf/nT6z/FQy6ef3S1YsEAPPPBA+uuRdD+ttbrnnnu0dOlSlZWV9XvtcN/PXAzp+zOrGUGw1mY/ufmmm25KP9be3p5xcvPDDz+cvmbbtm3DPhn2L3/5S/qxF154YdCTYZctW9Zr9U9fXn/9dSvJPvPMMzm/3lzl28+U3bt322g0au+77z5r7ci5nx0dHfa8886zc+fOtTt37hzUcw31/Tz22GPtV77ylR6PHX744f1Obj788MN7PHb55Zf3mjx55pln9rjmjDPOGPbJsNn001prH3zwQVteXj7ghNIU3/ft/Pnz7Ze+9KV8Xmpecunn/v76r//aLlq0KP31SLmf1nZN5n799dcHfA4X7md3GuTk5qF6fxJ8srB582a7du1ae/3119uqqiq7du1au3btWtvY2Ji+Zvbs2fa3v/1t+usbb7zRVldX29/+9rf29ddft1/84hczLmc/8MAD7VNPPWVfeeUVe8oppwz78udPfOITdvXq1Xb16tX2yCOP7LX8ef9+WmttfX29raystP/+7//eq8333nvPXn/99fall16ymzZtso8//ridM2eOPeqoo4qmn42NjfYb3/iGXbVqld20aZNduXKlPf744+0BBxwwou5nLBaz55xzjj3wwAPtunXreiyPbW9vt9a6cT9Ty4Lvvvtuu379envVVVfZUaNGpVe7XHvttXbp0qXp61PLZf/xH//Rrl+/3t599929lss+//zzNhQK2RtvvNFu2LDB3njjjc4sfx5sPx988EEbDoftT3/60z63Gli+fLl94okn7Pvvv2/Xrl1rv/SlL9lwONwjIA+1bPt566232kcffdS+88479o033rDXXnutlWQfeeSR9DUj4X6m/M3f/I097rjjMrbp4v1sbGxM/x0pyd5yyy127dq16ZWhw/n+JPhkYdmyZVZSr18rV65MXyPJ/vKXv0x/7fu+/f73v29rampsNBq1J510Uq/E3traar/61a/a8ePH24qKCnv22WfbLVu2DFGvetuzZ4+9+OKL7ejRo+3o0aPtxRdf3GvJ6P79tNban//857aioiLjXi5btmyxJ510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",
      "text/plain": [
       "<Figure size 600x1200 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "pres = (hPa*100).mean(0)\n",
    "\n",
    "loss_all = (y_pred-y_vl).reshape(-1,49,2).transpose((0,2,1))* 86400\n",
    "\n",
    "loss_q1   = np.quantile(loss_all, 0.05, axis = 0)\n",
    "loss_mean = np.mean(loss_all, axis = 0)\n",
    "loss_mean_abs = np.mean(np.absolute(loss_all), axis = 0)\n",
    "loss_q3   = np.quantile(loss_all, 0.95, axis = 0)\n",
    "rmse = np.mean(loss_all**2, (0,2))**0.5 \n",
    "\n",
    "for d, t, lim in zip(range(2),['RTHRATSW','RTHRATLW'],[0.2,1]):\n",
    "    fig = plt.figure(figsize=(6,12))\n",
    "    plt.fill_betweenx(1e-2*pres, loss_q1[d,:], loss_q3[d,:], alpha=0.2, color='tab:blue')\n",
    "    plt.plot(loss_mean[d,:], 1e-2*pres, '-b', label='mean error', color='tab:blue')\n",
    "    plt.plot(loss_mean_abs[d,:], 1e-2*pres, '--b', label='mean absolute error', color='tab:blue')\n",
    "    plt.legend(loc = 'upper right')\n",
    "    plt.grid()\n",
    "    plt.gca().invert_yaxis()\n",
    "    plt.xlabel('K/d', fontsize=16)\n",
    "    plt.ylabel('Pressure (hPa)', fontsize=16)\n",
    "    plt.title(t + '\\nRMSE ' + f'{rmse[d]:.3f}' + ' K/d', fontsize=16)\n",
    "    plt.xlim(-lim,lim)\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5831474f-d991-4cee-b07e-ab3cc4b5996b",
   "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.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
