{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import warnings\n",
    "warnings.filterwarnings(\"ignore\")\n",
    "import json\n",
    "import argparse\n",
    "from utils import init_dl_program,dict2class\n",
    "from infots import InfoTS as MetaInfoTS\n",
    "import datautils\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "dataset = 'electricity.uni'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "# initialization\n",
    "with open(f'./configures/{dataset}.json') as f:\n",
    "    configs = json.load(f)\n",
    "parser = argparse.ArgumentParser()\n",
    "args = dict2class(**configs)\n",
    "device = init_dl_program(args.gpu, seed=args.seed, max_threads=args.max_threads)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "#prepare datasets\n",
    "valid_dataset = datautils.load_forecast_csv(args.dataset, univar=True)\n",
    "data, train_slice, valid_slice, test_slice, scaler, pred_lens, n_covariate_cols= valid_dataset\n",
    "train_data = data[:, train_slice]\n",
    "\n",
    "#preprocess\n",
    "if train_data.shape[0] == 1:\n",
    "    train_slice_number = int(train_data.shape[1] / args.max_train_length)\n",
    "    if train_slice_number < args.batch_size:\n",
    "        args.batch_size = train_slice_number\n",
    "else:\n",
    "    if train_data.shape[0] < args.batch_size:\n",
    "        args.batch_size = train_data.shape[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "model = MetaInfoTS(\n",
    "    batch_size=args.batch_size,\n",
    "    lr=args.lr,\n",
    "    meta_lr = args.meta_lr,\n",
    "    output_dims=args.repr_dims,\n",
    "    max_train_length=args.max_train_length,\n",
    "    input_dims=train_data.shape[-1],\n",
    "    device=device,\n",
    "    num_cls =  args.batch_size,\n",
    "    aug_p1= args.aug_p1,\n",
    "    eval_every_epoch =20\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{24: {'norm': {'MSE': 0.2617035741779523, 'MAE': 0.2827750840946487}}}\n",
      "{24: {'norm': {'MSE': 0.25555403249750425, 'MAE': 0.28207835478559695}}}\n",
      "{24: {'norm': {'MSE': 0.25305611557088503, 'MAE': 0.2788975711229501}}}\n",
      "{24: {'norm': {'MSE': 0.2510221634294601, 'MAE': 0.2783738773610827}}}\n",
      "{24: {'norm': {'MSE': 0.2495445035724315, 'MAE': 0.27674478465524033}}}\n",
      "{24: {'norm': {'MSE': 0.24886598008380678, 'MAE': 0.2756426609520284}}}\n",
      "{24: {'norm': {'MSE': 0.24876572835797672, 'MAE': 0.2765298394681216}}}\n",
      "{24: {'norm': {'MSE': 0.24844540152186004, 'MAE': 0.27586769437930175}}}\n",
      "{24: {'norm': {'MSE': 0.24826084183136607, 'MAE': 0.2751756799889807}}}\n",
      "{24: {'norm': {'MSE': 0.24813608131457854, 'MAE': 0.2744406462514986}}}\n",
      "{24: {'norm': {'MSE': 0.24819224614026508, 'MAE': 0.27394853203627284}}}\n",
      "{24: {'norm': {'MSE': 0.24827628864825121, 'MAE': 0.2736421273004473}}}\n",
      "{24: {'norm': {'MSE': 0.24831988482442796, 'MAE': 0.27342125963554215}}}\n",
      "{24: {'norm': {'MSE': 0.2483212061066171, 'MAE': 0.2732141618874785}}}\n",
      "{24: {'norm': {'MSE': 0.24833463967543118, 'MAE': 0.27298755548307674}}}\n",
      "{24: {'norm': {'MSE': 0.24832148117996522, 'MAE': 0.2726741040528949}}}\n",
      "{24: {'norm': {'MSE': 0.2482785824603389, 'MAE': 0.272327905598186}}}\n",
      "{24: {'norm': {'MSE': 0.24821856556005142, 'MAE': 0.2720312040422315}}}\n",
      "{24: {'norm': {'MSE': 0.248132591836956, 'MAE': 0.2717795920851257}}}\n",
      "{24: {'norm': {'MSE': 0.24799161868275568, 'MAE': 0.27153638099902927}}}\n",
      "{24: {'norm': {'MSE': 0.24799161868275568, 'MAE': 0.27153638099902927}}, 48: {'norm': {'MSE': 0.294505108392165, 'MAE': 0.2994200139034729}}, 168: {'norm': {'MSE': 0.40605347825887134, 'MAE': 0.3716919988107603}}, 336: {'norm': {'MSE': 0.5446453238393515, 'MAE': 0.45424330417741837}}}\n"
     ]
    }
   ],
   "source": [
    "res = model.fit(train_data,\n",
    "     task_type = 'forecasting',\n",
    "     meta_beta=args.meta_beta,\n",
    "     n_epochs=args.epochs,\n",
    "     n_iters=args.iters,\n",
    "     beta = args.beta,\n",
    "     verbose=False,\n",
    "     miverbose=True,\n",
    "     split_number=args.split_number,\n",
    "     supervised_meta = False, # for forecasting, use unsupervised setting.\n",
    "     valid_dataset = valid_dataset,\n",
    "     train_labels= None\n",
    "    )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "mse = mse[:-1]\n",
    "mae = mae[:-1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYAAAAD4CAYAAADlwTGnAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8vihELAAAACXBIWXMAAAsTAAALEwEAmpwYAAAwZ0lEQVR4nO3deXxU9dn//9c1M9kg7ISyhF1QVgHDJhb3itqCVlpxueW2WK2tra2tFW9b+9W7+rsVvbVa6464VgWqUlsqvRFFlC3sQkACREhAErZACNkm1++Pz0mYhEAGssyEuZ6Px3mccz7nzMk1RznvObuoKsYYY2KPL9IFGGOMiQwLAGOMiVEWAMYYE6MsAIwxJkZZABhjTIwKRLqAk9G+fXvt0aNHpMswxpgmZcWKFXtUNaV6e5MKgB49epCenh7pMowxpkkRka9rardDQMYYE6MsAIwxJkZZABhjTIxqUucAjDGnt9LSUrKzsykqKop0KU1SYmIiqampxMXFhTW/BYAxJmpkZ2fTokULevTogYhEupwmRVXZu3cv2dnZ9OzZM6zP2CEgY0zUKCoqol27drbxPwUiQrt27U5q78kCwBgTVWzjf+pOdt3FxiGgNe9A8UHoPgZSzgKf5Z4xxsRGAHw5GzZ/5IaT2kKPMdD9PNfvMMACwRgTk2Jjy3f9O3DnGpjwF+g7DnatgX/dA8+dB9N6wV+vh8XPwM7VUB6MdLXGmNPQ7t27ufPOOxk8eDDDhg3jlltuYceOHZXTd+zYwYUXXkj//v0ZMGAAf/rTn45ZxuOPP46IsGfPnnqpKTb2AESgTQ/XDb3BtR3YDlmfw9eLXH/TP1x7QivoPtodLupxHnQcDP7YWE3GmIaxZcsWJk6cyL333su0adOIj49n/vz5XH311bzzzjv07t2bQCDA448/zrBhwzh06BDnnHMOl156Kf379wdcQMybN49u3brVW12xu2Vr3Q2GdIMh17nx/Bz4+nPIWuT6X/3Ltce3gG6jXHAMuDpy9RoTYx74+3o27DxYr8vs37klf/jegBPOk5WVxbhx4xg1ahRffPEFw4cP5+abb+YPf/gDubm5vPnmmxw5coQ777wTcCdeFy5cSIsWLZg2bRrvvvsuxcXFXH311TzwwAMA3H777bz66qsMHjy48u9cfPHFvPHGG/z617/m/fffp1OnTnTq1AmAFi1a0K9fP3JycioD4Fe/+hWPPvooEyZMqLf1EbsBUF2rLjD4h64DOPTN0TDYsgBm/ieowsDvR7RMY0zDy8zMZObMmUyfPp3hw4fz1ltvsWjRIubMmcPDDz9MMBjkmWeeYcyYMRQUFJCYmMi8efPYvHkzy5YtQ1UZP348CxcupGPHjqSkpDB48GA+/PBD7r//fnr16oWqMnv2bHw+H3v27KF9+/aVfz8rK4tVq1YxcuRIAD744AO6dOnC2WefXa/f0wLgeFp0hEETXVdaBK9fBe/dBskd3KEhY0yDqu2XekPq2bMngwYNAmDAgAFcfPHFiAiDBg0iKyuLSZMmcdddd3HDDTfw/e9/n9TUVObNm8e8efMYOnQoAAUFBWzevJndu3czatQogsEgDzzwAB9//DH5+fkMHDgQgD59+rBt27bKACgoKOCaa67hySefpGXLlhQWFvLwww8zb968ev+esXESuK7iEmHSW9CmJ7x9PeRmRLoiY0wDSkhIqBz2+XyV4z6fj7KyMqZOncpLL73EkSNHGDNmDBs3bkRVuffee1m9ejWrV68mMzOTKVOmAOD3+9mzZw+9e/emdevWdO/evfLQTm5uLh06dADcozCuueaaymABd/5g27ZtnH322fTo0YPs7GyGDRvGN998U+fvaQEQrmZt4cZZEEiENybCwZ2RrsgYEyFbtmxh0KBB3HPPPQwfPpyNGzdy2WWXMX36dAoKCgDIyckhNzeXgQMHsnTpUtq3b8+WLVvIz89n+/btZGRksG7dOnJzc+nevTuqypQpU+jXrx933XVX5d8aNGgQubm5ZGVlkZWVRWpqKitXrqRjx451/h52COhktO4GN8yCVy6HN38AN/8TEltFuipjTCN78sknWbBgAT6fjwEDBnD55ZeTkJBARkYGo0ePBiA5OZk33niDfv36sX37djZt2sTvfvc7LrzwQnr16sX48eN57LHHmD59OgCff/45r7/+OoMGDWLIkCEAPPzww1xxxRUN9j1EVRts4fUtLS1No+KNYFs+dgHQfYwLhEB8pCsy5rSQkZFBv379Il1GvcvIyOCGG27gkUce4ZJLLgFg5cqV7Ny5k+9973v1/reqr0MRWaGqadXntUNAp6L3RTD+z7DtU/jgZ1BeHumKjDFRrF+/fsyZM4fZs2czbNgwzj77bJ599tkql4VGgh0COlVDroODOfDxf0PLznDpA5GuyBgTxVJTU3nuueciXUYVFgB18e1fuxD4/ElolQojfhzpiowxJmxhHQISkXEisklEMkVkag3T7xKRDSKyVkTmi0j3kGmPish6EckQkafEe16piJwjIuu8ZVa2NykicMVjcOYV8M+7IePvka7IGGPCVmsAiIgfeAa4HOgPXCci/avNtgpIU9XBwCzgUe+z5wJjgMHAQGA4cL73mWeBHwN9vG5cXb9MRPj8cM3L0OUcmH0LbF8a6YqMMSYs4ewBjAAyVXWrqpYAbwNVHkahqgtUtdAbXQKkVkwCEoF4IAGIA3aLSCegpaouUXcZ0mvAVXX9MhET38w9cbRlZ/jrtbBnc6QrMsaYWoUTAF2AHSHj2V7b8UwB5gKo6mJgAbDL6z5S1Qzv89nhLFNEbhWRdBFJz8vLC6PcCGneHm6cDb4AvPF9OLQ70hUZY6LMli1b+NGPfsTAgQM555xz+NWvfsX+/fsrp69evZrRo0czYMAABg8ezDvvvHPMMn7xi1+QnJxcL/XU62WgInIjkAZM88bPAPrh9gi6ABeJyLdPZpmq+oKqpqlqWkpKSn2WW//a9nJ7Aof3wFs/gOJDka7IGBMlli5dyg9/+EOuvfZa1qxZw/LlyxkzZgzjxo1j7969ADRr1ozXXnuN9evX869//Ytf/vKXHDhwoHIZ6enpVQKjrsK5CigH6Boynuq1VSEilwD3AeerarHXfDWwRFULvHnmAqOB1zl6mOi4y2ySupwDP3gV/joJ3p3sAsEfF+mqjGl65k6Fb9bV7zI7DoLL/+eEs4TzOGiAO++8k6KiIpKSknjllVc488wzCQaDTJ06lU8++YTi4mJ+9rOfcdtttxEMBvn5z3/O3//+dzp37lz5tyZOnEibNm24//77eeaZZ+jbt2/ltM6dO9OhQwfy8vJo3bo1wWCQu+++m7feeov33nuvXlZHOHsAy4E+ItJTROKBScCc0BlEZCjwPDBeVXNDJm0HzheRgIjE4U4AZ6jqLuCgiIzyrv65CfigHr5PdOj7HfjuE7BlPvz9TvcYaWNMk5GZmcmvf/1rNm7cyMaNGysfB/3YY4/x8MMPc9ZZZ/HZZ5+xatUqHnzwQf7rv/4LgJdffplWrVqxfPlyli9fzosvvsi2bduYP38+l156KZ07d+all15i6NChTJkyhRtvvJGLL76YdeuODbply5ZRUlJC7969Afjzn//M+PHjK98ZUB9q3QNQ1TIRuQP4CPAD01V1vYg8CKSr6hzcIZ9kYKZ3Ned2VR2PuyLoImAd7oTwv1S14lrJnwIzgCTcOYO59fatosE5k909Ap8+Ai27wEX3RboiY5qWWn6pN6TaHgedn5/P5MmT2bx5MyJCaWkpAPPmzWPt2rXMmjULgPz8fDZv3syaNWsYNWoUeXl5vP766yxevJh169YxadIkADp16kReXh4Vh7l37drFf/zHf/Dqq6/i8/nYuXMnM2fO5JNPPqnX7xnWjWCq+k/gn9Xa7g8ZvuQ4nwsCtx1nWjru0tDT1wX3uhBY+Cig0Oc70KE/JNTPCRxjTMOo7XHQv//977nwwgt57733yMrK4oILLgBAVXn66ae57LLLqixvzZo1+P1+tm7dyujRo0lMTGT48OGV7wDYv38/bdq0AeDgwYNceeWVPPTQQ4waNQqAVatWkZmZyRlnnAFAYWEhZ5xxBpmZmXX6nnYncEMSge8+CYX7YOE01yHuZHHHQVW7Fp3c/MaYqJefn0+XLu7CxRkzZlS2X3bZZTz77LNcdNFFxMXF8dVXX9GlSxcGDhzIkiVLuOOOO1i8eDHFxcWsX7+ePXv28PHHH9O5c2cCgQAlJSVcffXV3HTTTUycOLFyuVdeeWWV5/8nJyfXeeMPFgANzx/nXiaTn+1OaO3+Er5ZC7vWwIb3j86X1PbYUGjf104gGxOFfvvb3zJ58mT++Mc/cuWVV1a233LLLWRlZTFs2DBUlZSUFN5//30uueQSfv/73/PTn/6U66+/nlGjRjFs2DAGDRrE7NmzefrppwF49913WbhwIXv37q0MlhkzZlQ+Hrq+2eOgI6noIOxefzQUvvkScjdAWZGb7o+HlLNcGPS6AAZOBJ89wNWcvk7Xx0EDLFy4kLvvvpunnnqKkSNHEgwGWbRoEQDnn39+LZ8O38k8Dtr2ACIpsSV0H+26CsEy2JtZNRQ2z4PVb8LiZ+DyR6DbqMjVbIw5JWPHjmXGjBn88Y9/ZP369agqF154Ib/73e8iVpMFQLTxB6DDWa4b5B0DVIV1s+Df98P0y9yewKUPuCeQGnOaUVWa4rMhw9GvX7/K+wgawske0bHjCU2BCAz+Afw8Hcb+FjZ+CE+nwSePQElh7Z83polITExk7969J70hM27jv3fvXhITE8P+jJ0DaIr2f+32Bja8D626wqUPwoCr7Soi0+SVlpaSnZ1NUVFRpEtpkhITE0lNTSUururFI8c7B2AB0JRlLXK3y+9eB93OdTfOdDo70lUZY6KMvRP4dNTjPLjtU3evwZ5N8Pz5MOcXUBDFT001xkQNC4CmzueHtJvh5yth1E/d1UJPD4Mv/gxlJZGuzhgTxSwAThdJrWHcw3D7Yug6EubdB8+Ohq/mRboyY0yUsgA43aT0hRtnwfUz3fhbP4A3JkJuRmTrMsZEHQuA01Xf77i9gcsehh1L4S+j4JUrYM3bdumoMQawq4Biw+E9sOp1WPka7NsKCa3cfQXDbmq4q4bKyyFnhbtnYeOH7hWZXYdDt9HuTuYuae5dysaYBmeXgRp3R/HXn8OKV2HDBxAsdgEwbLK76zixVd2WX1YCWZ95G/1/QsE37h3JPb4NbXrAjmXuWUeoa+80xIVBRSg0b18PX9IYU50FgKnqyH5YOxNWvuqeOxRIcjeTDbvJbYzDvamsuAAy/w0b/+FOOBfnQ1wzOOMS6Pc96HMpJLWp+nd3LIfti2H7EreXEPTeINquj/vb3c91/TY97eY2Y+qBBYCpmSrsXOUOD62bBSWH3IZ42E1w9nWQnHLsZwry4Ku5kPEhbP3EbcCT2sKZV0C/77onl8Ylhff3y4ph52ovELxQKDrgpiV/K2QPYbR7KqrPXz/f25gYYgFgaldyGNa/78JgxxJ3mObMK9whona93GGdjf9w07QcWnVzG/yzroSuo9yD7OqqvNzd1FYRBtsXw4HtblpCS28PYYy7Ca7T2fa+BGPCYAFgTk7uRnfieM1foXDv0fYOA7yN/nfdL/LGOESTn+OCIGuRO4ex5yvXHtccuo10h4y6nwddhkEg4cTLMiYG1SkARGQc8CfcS+FfUtX/qTb9LuAWoAzIA36kql+LyIXAEyGzngVMUtX3RWQGcD6Q7037T1VdfaI6LAAioKwYNv0TCnLd8fy2vSJdkavl68/h6y8g63PIXe/aA4mQOtztHXQfA6lp4R+KMuY0dsoBICJ+4CvgUiAbWA5cp6obQua5EFiqqoUicjtwgapeW205bYFMINWbbwbwoarOCvdLWACYGhXuc2Hw9eduL+GbdYC6N6p1OefoIaOuI+3SUxOT6vJGsBFApqpu9Rb0NjABqAwAVV0QMv8S4MYaljMRmKuqdheSqV/N2rrDUv2+68aPHHA3v1UcMlr0BHz2mAuEriOh5/nQc6w7ZGTnEEwMCycAugA7QsazgZEnmH8KMLeG9knA/1Zre0hE7gfmA1NVtbj6h0TkVuBWgG7duoVRrol5Sa2h72WuAyg+5E4ob/sUtn4KCx6CBX+E+Bbu/EGv810odOhv71w2MaVeXwkpIjcCabhj+6HtnYBBwEchzfcC3wDxwAvAPcCD1Zepqi9400lLS2s6Z6xN9Eho4c5f9LnUjRfug20Lve5T2Oz9b9msPfT89tE9hLa97D4Ec1oLJwBygK4h46leWxUicglwH3B+Db/kfwi8p6qlFQ2qussbLBaRV4DfnEzhxpyyZm1hwFWuA8jPPhoIWz+F9e+59lZdXRj0Ot/tKbTsYoFgTivhBMByoI+I9MRt+CcB14fOICJDgeeBcaqaW8MyrsP94g/9TCdV3SXu7c9XAV+efPnG1INWqTDketepwt5Md4PbtoWw6R+w+g03X2Jrd5joW/1dv0N/6NDPHXIypgmqNQBUtUxE7sAdvvED01V1vYg8CKSr6hxgGpAMzHTbc7ar6ngAEemB24P4tNqi3xSRFECA1cBP6uUbGVMXItC+j+tG/NjdmPbNWsheDrvXu8dqr30Xig8e/UzLVBcEocGQcqbdk2Cint0IZszJUnWHjXIz3D0Iuze4h9zlbYJy7yin+KFdb2+PYQC07+v2NFp2huYd6ueuaWPCVJfLQI0xoUSgdVfX9f3O0fZgKezdEhIKGbBrNWx4v9rnfZDc0YVBy87u3ELlsNe16GR7EKbBWQAYU1/8cdDhLNcNvOZoe3EB7NsCB3fBwRw4tAsO7nTDeRshcz6UHj52ec1TvDDoDC06usdlN2vndW1DhttBfPPG+57mtGEBYExDS0h2D6473st3VN05hYM7q3U5rn9gO2Qvc5evcpxDtoGkmoOhsq2te2JraD+umV3VFOMsAIyJNBH3Mp7EVu5k8vGUB6Eo3z2cr8Zu39HhA1+7flH+8ZfnT3DvaqgMhTZVQ6LKNC9MklrbI7lPIxYAxjQVPv/RX/P0Ce8zwVL3Ep6KgDiyz+vvrzpcuA/2ZB5tKy+teXni84Khnbtxrnm7o8PN2nmHqdpWHbcH8kUtCwBjTmf+OEju4LpwqUJJwbFBUbjXvV+6cC8U7jkaGoVL3LAGa15eXDMXBC27HD3hXXFFVEVb8xR7DEcEWAAYY6oScY/PSGgBbbqH95nycvcmt4pDUKFBcXgvHM515zNy0iFjJwRLqn7eFwctO7l7Klp2hlZdjg2M5il2zqKeWQAYY+rO5wv/8JSqC4iDOUdPdOdnHz3xnZMOGXOODYlAons8R+uu0LqbN9z96HhyR9uLOEkWAMaYxiXi3jWdnAKdh9Q8T/WQyM+B/O3uiqgDO2DXWrd3EcoX5/YUKgOiW9WwaNEJAvEN/vWaEgsAY0z0CSckSg67PYcDO9xVT/k7vOHt7t6KQ7uO/Uyz9u5QU4vOXt/rKm6+a9nZneSOkUNNFgDGmKYpvrl75lLKmTVPLyv2AmK761fcgFfR37kSDucd+7lAorvxrnpIJHdw5yGSO7jHeTRr2+QvibUAMMacngIJ7nlM7Xoff56yEij4xt2lfWhntf4uyFnp+mVFx35WfN6lsN6eSvMOx4ZE8/ZH26Lw7XMWAMaY2BWId+cIWp/gbYOq7gqnw3ugINdd0VSQ5/VzXfvhXNi31O1RlB7nrbdJbVwQNE9xwVDjsDee2LpRDkNZABhjzImIuI13Uhv3mPDaFBeEhEReteE8Fxi5G+HwZ+4ei5r44rxgaO/tSaTAxb93J7nrkQWAMcbUp4Rk17XtVfu8wVJ3E93h3KPhcLhaWBzOgz2bQcvrvVQLAGOMiRR/HLT4lusiwO6aMMaYGGUBYIwxMcoCwBhjYpQFgDHGxKiwAkBExonIJhHJFJGpNUy/S0Q2iMhaEZkvIt299gtFZHVIVyQiV3nTeorIUm+Z74iIPaTDGGMaUa0BICJ+4BngcqA/cJ2I9K822yogTVUHA7OARwFUdYGqDlHVIcBFQCEwz/vMI8ATqnoGsB+YUvevY4wxJlzh7AGMADJVdauqlgBvAxNCZ/A29BW3vy0BarpbYSIwV1ULRURwgTDLm/YqcNUp1G+MMeYUhRMAXYAdIePZXtvxTAHm1tA+CfirN9wOOKCqZbUtU0RuFZF0EUnPy6vhwU3GGGNOSb2eBBaRG4E0YFq19k7AIOCjk12mqr6gqmmqmpaSklI/hRpjjAnrTuAcoGvIeKrXVoWIXALcB5yvqsXVJv8QeE9VK940vRdoLSIBby+gxmUaY4xpOOHsASwH+nhX7cTjDuXMCZ1BRIYCzwPjVTW3hmVcx9HDP6iqAgtw5wUAJgMfnHz5xhhjTlWtAeD9Qr8Dd/gmA3hXVdeLyIMiMt6bbRqQDMz0LvesDAgR6YHbg/i02qLvAe4SkUzcOYGX6/pljDHGhE/cj/GmIS0tTdPT0yNdhjHGNCkiskJV06q3253AxhgToywAjDEmRlkAGGNMjLIAMMaYGGUBYIwxMcoCwBhjYpQFgDHGxCgLAGOMiVEWAMYYE6MsAIwxJkZZABhjTIyyADDGmBhlAWCMMTHKAsAYY2KUBYAxxsQoCwBjjIlRFgDGGBOjLACMMSZGWQAYY0yMCisARGSciGwSkUwRmVrD9LtEZIOIrBWR+SLSPWRaNxGZJyIZ3jw9vPYZIrLNe4n8ahEZUl9fyhhjTO1qDQAR8QPPAJcD/YHrRKR/tdlWAWmqOhiYBTwaMu01YJqq9gNGALkh0+5W1SFet/rUv4YxxpiTFc4ewAggU1W3qmoJ8DYwIXQGVV2gqoXe6BIgFcALioCq/tubryBkPmOMMREUTgB0AXaEjGd7bcczBZjrDfcFDojI30RklYhM8/YoKjzkHTZ6QkQSalqYiNwqIukikp6XlxdGucYYY8JRryeBReRGIA2Y5jUFgG8DvwGGA72A//Sm3Quc5bW3Be6paZmq+oKqpqlqWkpKSn2Wa4wxMS2cAMgBuoaMp3ptVYjIJcB9wHhVLfaas4HV3uGjMuB9YBiAqu5Spxh4BXeoyRhjTCMJJwCWA31EpKeIxAOTgDmhM4jIUOB53MY/t9pnW4tIxU/3i4AN3mc6eX0BrgK+rMP3MMYYc5ICtc2gqmUicgfwEeAHpqvqehF5EEhX1Tm4Qz7JwEy3PWe7qo5X1aCI/AaY723oVwAveot+0wsGAVYDP6nn72aMMeYERFUjXUPY0tLSND09PdJlGGNMkyIiK1Q1rXq73QlsjDExygLAGGNilAWAMcbEKAsAY4yJURYAxhgToywAjDEmRlkAGGNMjLIAMMaYGGUBYIwxMcoCwBhjYpQFgDHGxKiYCYCm9MwjY4xpDDERAP/f3Aymzl4X6TKMMSaqxEQABIPKrJXZZO+31xEbY0yFmAiAH53XEwFeXrQt0qUYY0zUiIkA6Nw6ifFnd+ad5TvILyyNdDnGGBMVYiIAAH48theFJUHeWPp1pEsxxpioEDMB0K9TS8b2TeGVz7MoKg1GuhxjjIm4mAkAgJ+M7cWegmLeW5UT6VKMMSbiYioARvdux8AuLXlx4VbKy+2+AGNMbAsrAERknIhsEpFMEZlaw/S7RGSDiKwVkfki0j1kWjcRmSciGd48Pbz2niKy1FvmOyISX2/f6vjfg1vH9mbrnsP8O2N3Q/85Y4yJarUGgIj4gWeAy4H+wHUi0r/abKuANFUdDMwCHg2Z9howTVX7ASOAXK/9EeAJVT0D2A9MqcsXCdcVAzuS2iaJFxZubYw/Z4wxUSucPYARQKaqblXVEuBtYELoDKq6QFUr7rJaAqQCeEERUNV/e/MVqGqhiAhwES4sAF4FrqrrlwlHwO/jlvN6suLr/aRn7WuMP2mMMVEpnADoAuwIGc/22o5nCjDXG+4LHBCRv4nIKhGZ5u1RtAMOqGpZbcsUkVtFJF1E0vPy8sIot3Y/HN6V1s3ieN72AowxMaxeTwKLyI1AGjDNawoA3wZ+AwwHegH/eTLLVNUXVDVNVdNSUlLqpc5m8QFuGtWd/8vYzZa8gnpZpjHGNDXhBEAO0DVkPNVrq0JELgHuA8ararHXnA2s9g4flQHvA8OAvUBrEQmcaJkN6aZzexDv9/HSZ7YXYIyJTeEEwHKgj3fVTjwwCZgTOoOIDAWex238c6t9trWIVPx0vwjYoO7ZzAuAiV77ZOCDU/8aJ699cgLXnJPK7BU55B4qasw/bYwxUaHWAPB+ud8BfARkAO+q6noReVBExnuzTQOSgZkislpE5nifDeIO/8wXkXWAAC96n7kHuEtEMnHnBF6ux+8Vlh9/uxel5eW8+kVWY/9pY4yJOGlKL0pJS0vT9PT0el3mT15fwRdb9rD43otpnhCo/QPGGNPEiMgKVU2r3h5TdwLX5Nbze3GwqIy3l++ofWZjjDmNxHwADOvWhuE92jB90TZKg+WRLscYYxpNzAcAwG1je5Nz4Aj/XLcr0qUYY0yjsQAALjqrA71TmvPcp1vt5fHGmJhhAQD4fMKtY3uRsesgizL3RLocY4xpFBYAnquGdiGlRYI9JM4YEzMsADwJAT83j+nBZ5v38GVOfqTLMcaYBmcBEOKGkd1pHu/nRXs8hDEmBlgAhGiVFMd1I7rx4dpdZO8vrP0DxhjThFkAVPOj83oiwMuLtkW6FGOMaVAWANV0bp3E987uzDvLd5BfWBrpcowxpsFYANTg1rG9KCwJ8sbSryNdijHGNBgLgBr069SSsX1TeOXzLIpKg5EuxxhjGoQFwHHcNrYXewqKeW9Vo76nxhhjGo0FwHGc27sdAzq35MWFWykvt8dDGGNOPxYAxyEi3HZ+b7buOcy/M3ZHuhxjjKl3FgAncMXAjqS2SbLHQxhjTksWACcQ8PuYcl5PVny9n/SsfZEuxxhj6pUFQC2uHd6V1s3ieGzeJrsiyBhzWgkrAERknIhsEpFMEZlaw/S7RGSDiKwVkfki0j1kWtB7UXzly+K99hkisi1k2pB6+Ub1rFl8gHsvP4slW/dx08vLOFBYEumSjDGmXtQaACLiB54BLgf6A9eJSP9qs60C0lR1MDALeDRk2hFVHeJ146t97u6QaatP+Vs0sGuHd+PP1w9l9Y4DTHxusT0nyBhzWghnD2AEkKmqW1W1BHgbmBA6g6ouUNWKreISILV+y4y87w7uzGtTRpB7sIjv/+UL1u+0R0YbY5q2cAKgC7AjZDzbazueKcDckPFEEUkXkSUiclW1eR/yDhs9ISIJNS1MRG71Pp+el5cXRrkNZ1Svdsy6/VwCPuHa55fw2ebI1mOMMXVRryeBReRGIA2YFtLcXVXTgOuBJ0Wkt9d+L3AWMBxoC9xT0zJV9QVVTVPVtJSUlPos95T0/VYL/vbTMaS2SeLmV5bzt5XZkS7JGGNOSTgBkAN0DRlP9dqqEJFLgPuA8apaXNGuqjlefyvwCTDUG9+lTjHwCu5QU5PQsVUi7/5kNCN6tuWud9fwzIJMe5m8MabJCScAlgN9RKSniMQDk4A5oTOIyFDgedzGPzekvU3FoR0RaQ+MATZ44528vgBXAV/W+ds0opaJccy4eQQThnRm2keb+P0HXxK0R0YYY5qQQG0zqGqZiNwBfAT4gemqul5EHgTSVXUO7pBPMjDTbc/Z7l3x0w94XkTKcWHzP6q6wVv0myKSAgiwGvhJ/X61hhcf8PHED4fQqVUSz326hd0Hi3lq0lCS4v2RLs0YY2olTenQRVpamqanp0e6jBq9tjiLP8xZz5CurXl58nDaNo+PdEnGGAOAiKzwzsVWYXcC15ObRvfg2RvOYcPOg1zz7Bds32v3ChhjopsFQD0aN7Ajb/14JPsLS/j+s5+zNvtApEsyxpjjsgCoZ+d0b8vs288lMc7PpBeWsGBTbu0fMsaYCLAAaAC9U5L520/PpVdKc255NZ13l++o/UPGGNPILAAaSIcWibx962jGnNGe385ey+PzNtllosaYqGIB0ICSEwK8PDmNa9O68vTHmVz3whJyDhyJdFnGGANYADS4OL+PRyYO5olrz2b9znwuf3Ihc9ftinRZxhhjAdBYrh6ayj/v/DY9U5K5/c2V3Pu3tRSWlEW6LGNMDLMAaETd2zVn1k9Gc/sFvXl7+Q6+9/Qie6y0MSZiLAAaWZzfxz3jzuLNKSMpKC7j6me+4OVF2+xhcsaYRmcBECHnntGeuXeOZWzfFP77ww3cPGM5eYeKa/+gMcbUEwuACGrbPJ4XbzqH/54wgMVb9nL5nz7j06/sJTPGmMZhARBhIsJ/jO7BnDvOo13zeCZPX8YfP9xAcVkw0qUZY05zFgBR4syOLfjgjjHcNLo7Ly3axvf/8gVb8goiXZYx5jRmARBFEuP8PDhhIC/elMbOA0f47lOLeGf5djtBbIxpEBYAUejS/t9i7p1jGdqtNffMXscdb60iv7A00mUZY04zFgBRqmOrRN6YMpJ7xp3FR+u/4eL//ZRXv8iipKw80qUZY04TFgBRzOcTbr+gN+/9dAy9UprzhznruejxT5i1ItseLGeMqTMLgCZgUGor3rl1FK/9aARtmsXzm5lruMx7ppCdHzDGnKqwAkBExonIJhHJFJGpNUy/S0Q2iMhaEZkvIt1DpgVFZLXXzQlp7ykiS71lviMi9hLdExARxvZNYc4dY3juxmEA3P7mSsb/+XM+/SrPgsAYc9JqDQAR8QPPAJcD/YHrRKR/tdlWAWmqOhiYBTwaMu2Iqg7xuvEh7Y8AT6jqGcB+YEodvkfMEBHGDezER78cy2M/OJt9h0uYPH0Z176whPSsfZEuzxjThISzBzACyFTVrapaArwNTAidQVUXqGrFW9CXAKknWqCICHARLiwAXgWuOom6Y57fJ0w8J5WPf3M+D04YwNa8w0x8bjE/mrHcHjBnjAlLOAHQBQh9p2G213Y8U4C5IeOJIpIuIktE5CqvrR1wQFUrnodc2zLNcSQE/Nw0ugcLf3sB94w7ixVf7+fKpxZxx1sr2Wo3khljTiBQnwsTkRuBNOD8kObuqpojIr2Aj0VkHRD2T1QRuRW4FaBbt271We5ppVl8gNsv6M31I7vx0mdbeXnRNuZ++Q0/OCeVX1zch86tkyJdojEmyoSzB5ADdA0ZT/XaqhCRS4D7gPGqWvlYS1XN8fpbgU+AocBeoLWIVARQjcv0PveCqqapalpKSkoY5ca2Vklx/Po7Z/Lp3Rdy0+ju/G1lDhdM+4TfzlrDB6tz2GmvpDTGeKS2q0e8jfRXwMW4jfRy4HpVXR8yz1Dc8fxxqro5pL0NUKiqxSLSHlgMTFDVDSIyE5itqm+LyHPAWlX9y4lqSUtL0/T09FP6orEq58ARnvq/zfxj3S4Kit0Rt9Q2SYzo2ZaRPdsyvEdberZvjjstY4w5HYnIClVNO6Y9nMsHReQK4EnAD0xX1YdE5EEgXVXniMj/AYOAipfdblfV8SJyLvA8UI7b23hSVV/2ltkLd0K5Le4qohtD9xxqYgFw6oLlSsaugyzbto9l2/axPGsfew+XANA+OYERPdswokdbRvRsx5kdW+D3WSAYc7qoUwBECwuA+qOqbMk7XBkGy7btI8c7PNQiMcDwHm7vYETPtgzq0or4gN0zaExTdbwAqNeTwKbpEBHO6JDMGR2SuX6kO7mevb+wMgyWbdvHxxtzAUiM83FGh2SaxQVIiPORGOd3XaBi2EdSnJ+EivY4H4kBf5VpLRLj6NgqkfbJ8Xa4yZgoYQFgKqW2aUZqm2ZcPdTdxrGnoJj0rH0s2bqPrL2HKSoNcqiojLxDxRSXlVNUGvS6co6UhvcCm/iAj06tEunUKpHOrZLo1DqRTq2S6FzRb5VEy6SAhYQxjcACwBxX++QExg3sxLiBnWqdV1UpLiunuLScorKjwVAREgeOlLLrwBF25RexM7+IXQeOsHTbPr45WHTMg+2axftdQLRO8sIiiW+1TKRVUlxl1zIpQKukOFokxtn5CmNOkQWAqRciUnloqBVxYX8uWK7kHSpmZ/4Rdh44wq4DRezMd/1d+UfY+M0h8g6d8NoAWiQGaJkYVyUgQkOiIiiS4v00jw+QFO+nWbXhpDg/vgYOkrJgOSVBF5LFZeWUlJVTXBZ0wRkyXFIxXhqsnL8kWE6wXAmWK2XlSrC83PWDFePV2ivGvenltZzrq+1coAKqVC5HFRR1fa9dvRkr2ivaKhYtAoL7f0Uqx8X1qw37vD3Ainl9An6fj4BP8PvF9UXw+4SA3+v7fF5f8Hl9f2XfR5xfiPP7CHj9yvFq0+L9PgJVprt+QpyPhICfhICPhIDvtNhLtQAwEeX3CR1bJdKxVSLDurWpcZ6SsnL2FBRzsKiU/MJS8o+UcrCojPwj3nC1/pa8Am+eUopKw39/QlKcC4NmCX6axblwaJ7gJykuQELAR2mwnNKg28CWBsspCyql5UpZ5bDrlwXLj2kvDWq9PsK76sZNCPh9Vce9vt/b+Pl9bgN7IrVtz6puuEM3zq5BAPGB4MPnO7pBr/isqh4THJVhUQ5KudfmAqncG8YbPhqA5ZUBV15ePQCrTm/Ia1ziAz4SqgVDfMBHQtzRkHCdn4Q4H83jAzRPCNA83k/zhADJCW68WYLfDcdXtLnpjREyFgAm6sUHfHRunURnTv5u5qLSIAeLSjlUVMaRkiCFJUEOlxwdLiwp8/pBCovLKCwNcqQkyOHiMo6Uuva9BYWUBssrfyGG/mJMig/5lRjwEedtjOO8+UJ/bVbZSFQZdhuN+MqNSciGw5sn9G/7hNPi12djKC9XgqpHg7jsaICXemFdUhHUFW3l5ZXDFUFfUlZOcTBkr6306F5b5R6bt9dWsRd3uLiMfYdd+xHv/7XDJcGwX+rk9wnN4104NEsI8PLkNLq3a16v68cCwJzWKg5LdWgR6UpMJPh8gg8hzg9J+CNdDuD2aAtLyigoLuNwcZCC4jIXDsVlFBQHvb4bLywJVg4nxdd//RYAxhjTiOIDPuID8bRuFvlXoNjdPcYYE6MsAIwxJkZZABhjTIyyADDGmBhlAWCMMTHKAsAYY2KUBYAxxsQoCwBjjIlRTeqFMCKSB3x9ih9vD+ypx3Lqm9VXN1Zf3Vh9dRPt9XVX1WNeqt6kAqAuRCS9pjfiRAurr26svrqx+uom2us7HjsEZIwxMcoCwBhjYlQsBcALkS6gFlZf3Vh9dWP11U2011ejmDkHYIwxpqpY2gMwxhgTwgLAGGNiVEwEgIiME5FNIpIpIlMjXQ+AiGSJyDoRWS0i6V5bWxH5t4hs9vo1vyS3YeqZLiK5IvJlSFuN9YjzlLc+14rIsAjV9/9EJMdbh6tF5IqQafd69W0Skcsaob6uIrJARDaIyHoRudNrj4p1eIL6omIdikiiiCwTkTVefQ947T1FZKlXxzsiEu+1J3jjmd70HhGqb4aIbAtZf0O89kb/N3JK3IuaT98O8ANbgF5APLAG6B8FdWUB7au1PQpM9YanAo80Yj1jgWHAl7XVA1wBzMW9B3wUsDRC9f0/4Dc1zNvf+++cAPT0/vv7G7i+TsAwb7gF8JVXR1SswxPUFxXr0FsPyd5wHLDUWy/vApO89ueA273hnwLPecOTgHcaeP0dr74ZwMQa5m/0fyOn0sXCHsAIIFNVt6pqCfA2MCHCNR3PBOBVb/hV4KrG+sOquhDYF2Y9E4DX1FkCtBaRThGo73gmAG+rarGqbgMycf8fNBhV3aWqK73hQ0AG0IUoWYcnqO94GnUdeuuhwBuN8zoFLgJmee3V11/Fep0FXCwiEoH6jqfR/42cilgIgC7AjpDxbE78P35jUWCeiKwQkVu9tm+p6i5v+BvgW5EprdLx6ommdXqHt4s9PeSQWUTr8w5HDMX9Soy6dVitPoiSdSgifhFZDeQC/8btdRxQ1bIaaqisz5ueD7RrzPpUtWL9PeStvydEJKF6fTXUHjViIQCi1XmqOgy4HPiZiIwNnahuPzJqrtGNtno8zwK9gSHALuDxiFYDiEgyMBv4paoeDJ0WDeuwhvqiZh2qalBVhwCpuL2NsyJVS02q1yciA4F7cXUOB9oC90SuwpMXCwGQA3QNGU/12iJKVXO8fi7wHu5/+N0Vu4lePzdyFcIJ6omKdaqqu71/lOXAixw9RBGR+kQkDrdxfVNV/+Y1R806rKm+aFuHXk0HgAXAaNyhk0ANNVTW501vBext5PrGeYfWVFWLgVeIgvV3MmIhAJYDfbyrCeJxJ4zmRLIgEWkuIi0qhoHvAF96dU32ZpsMfBCZCisdr545wE3elQ6jgPyQwxyNptox1atx67CivknelSI9gT7AsgauRYCXgQxV/d+QSVGxDo9XX7SsQxFJEZHW3nAScCnuPMUCYKI3W/X1V7FeJwIfe3tYjVnfxpBwF9z5idD1F/F/I7WK9FnoxuhwZ+S/wh1TvC8K6umFu8JiDbC+oibcMcz5wGbg/4C2jVjTX3GHAEpxxyunHK8e3JUNz3jrcx2QFqH6Xvf+/lrcP7hOIfPf59W3Cbi8Eeo7D3d4Zy2w2uuuiJZ1eIL6omIdAoOBVV4dXwL3h/xbWYY7CT0TSPDaE73xTG96rwjV97G3/r4E3uDolUKN/m/kVDp7FIQxxsSoWDgEZIwxpgYWAMYYE6MsAIwxJkZZABhjTIyyADDGmBhlAWCMMTHKAsAYY2LU/w8o6F0lKmkj5QAAAABJRU5ErkJggg==\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "x = 20*np.arange(len(mse))\n",
    "plt.plot(x, mse, label = \"mse@24\")\n",
    "plt.plot(x, mae, label = \"mae@24\")\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "tf2",
   "language": "python",
   "name": "tf2"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
