{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "539ebd7b",
   "metadata": {},
   "outputs": [],
   "source": [
    "###This code is about develop a pre-trained model for the CSTR process\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from sklearn import preprocessing\n",
    "from sklearn.model_selection import train_test_split\n",
    "from sklearn.metrics import mean_absolute_percentage_error\n",
    "from keras.models import Sequential\n",
    "from keras.layers import LSTM, Dense, SimpleRNN, Input, Activation, Dropout\n",
    "from keras import backend as K\n",
    "from tensorflow.keras.optimizers import Adam,SGD\n",
    "import tensorflow as tf\n",
    "from keras.models import Model\n",
    "from keras.models import load_model\n",
    "import time "
   ]
  },
  {
   "cell_type": "markdown",
   "id": "069e2e34",
   "metadata": {},
   "source": [
    "# Generate source dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "3a4a2d8e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "number of initial conditions: 242\n",
      "(1, 242)\n",
      "shape of x_deviation is (242, 2)\n",
      "(242, 2)\n"
     ]
    }
   ],
   "source": [
    "# specifying constant parameters\n",
    "#input varioable: Q, C_A0\n",
    "#state variable: T, C_A\n",
    "\n",
    "T_0 = 300\n",
    "V = 1\n",
    "k_0 = 8.46*(np.power(10,6))\n",
    "C_p = 0.231\n",
    "rho_L = 1000\n",
    "F = 5\n",
    "E = 5*(np.power(10,4))\n",
    "delta_H = -1.15*(np.power(10,4))\n",
    "R = 8.314\n",
    "\n",
    "C_A0s = 4   # the steady state for input variable C_A0\n",
    "Q_s = 0.0  # the steady state for input variable Q\n",
    "\n",
    "C_As = 1.95 # the steady state for state variable C_A\n",
    "T_s = 402  # the steady state for state variable T\n",
    "\n",
    "#revised as the target one\n",
    "t_final = 0.05  #the control period\n",
    "t_step = 0.01   # the step to use first-principle to calculate the state\n",
    "P = np.array([[1060, 22], [22, 0.52]])\n",
    "\n",
    "# generating inputs and initial states for CSTR, all expressed in deviation form\n",
    "\n",
    "u1_list = np.linspace(-3.5, 3.5, 10, endpoint=True)\n",
    "u2_list = np.linspace(-5e5, 5e5, 10, endpoint=True)\n",
    "T_initial = np.linspace(300, 550, 40, endpoint=True) - T_s\n",
    "CA_initial = np.linspace(1, 4., 40, endpoint=True) - C_As    # CA and T must be >0\n",
    "\n",
    "\n",
    "# sieve out initial states that lie outside of stability region\n",
    "\n",
    "T_start = list()\n",
    "CA_start = list()\n",
    "\n",
    "for T in T_initial:   \n",
    "    for CA in CA_initial:\n",
    "        x = np.array([CA, T])\n",
    "        if x @ P @ x < 368:   #calculate the stability region for state \n",
    "            CA_start.append(CA)\n",
    "            T_start.append(T)\n",
    "print(\"number of initial conditions: {}\".format(len(CA_start)))\n",
    "\n",
    "# convert to np.arrays\n",
    "CA_start = np.array([CA_start])\n",
    "T_start = np.array([T_start])\n",
    "print(CA_start.shape)\n",
    "x_deviation = np.concatenate((CA_start.T, T_start.T), axis=1)  # every row is a pair of initial states within stability region\n",
    "print(\"shape of x_deviation is {}\".format(x_deviation.shape))\n",
    "print(x_deviation.shape) "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "16075e8a",
   "metadata": {},
   "outputs": [],
   "source": [
    "def CSTR_simulation(F, V, C_A0, k_0, E, R, T_0, delta_H, rho_L, C_p, Q, t_final, t_step, C_A_initial, T_initial):\n",
    "    \"\"\"\n",
    "        simulating CSTR using forward Euler method\n",
    "    \"\"\"\n",
    "    \n",
    "    C_A_list = list()  # evolution of CA over time\n",
    "    T_list = list()  # evolution of T over time\n",
    "    \n",
    "    C_A = C_A_initial + C_As  # the real state.the derivation plus the steady state\n",
    "    T = T_initial + T_s\n",
    "    \n",
    "    for i in range(int(t_final / t_step)):\n",
    "        dCAdt = F / V * (C_A0 - C_A) - k_0 * np.exp(-E / (R * T)) * C_A**2\n",
    "        dTdt = F / V * (T_0 - T) - delta_H / (rho_L * C_p) * k_0 * np.exp(-E / (R * T)) * C_A**2 + Q / (rho_L * C_p * V)\n",
    "        \n",
    "        C_A += dCAdt * t_step\n",
    "        T += dTdt * t_step\n",
    "        \n",
    "       \n",
    "        C_A_list.append(C_A)  # in real value form\n",
    "        T_list.append(T)  # in real value form \n",
    "    \n",
    "    return C_A_list, T_list"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "b400bf04",
   "metadata": {},
   "outputs": [],
   "source": [
    "# get X and y data for training and testing\n",
    "\n",
    "CA_output = list()\n",
    "T_output = list()\n",
    "\n",
    "CA_input = list()\n",
    "T_input = list()\n",
    "CA0_input = list()\n",
    "Q_input = list()  \n",
    "\n",
    "for u1 in u1_list:\n",
    "    C_A0 = u1 + C_A0s\n",
    "    \n",
    "    for u2 in u2_list:\n",
    "        Q = u2 + Q_s\n",
    "        \n",
    "        for C_A_initial, T_initial in x_deviation:\n",
    "            CA0_input.append(u1+ C_A0s)  #real value form\n",
    "            Q_input.append(u2+ Q_s)\n",
    "            CA_input.append(C_A_initial+ C_As)\n",
    "            T_input.append(T_initial+ T_s)\n",
    "            \n",
    "            C_A_list, T_list = CSTR_simulation(F, V, C_A0, k_0, E, R, T_0, delta_H, rho_L, C_p, Q, t_final, t_step, C_A_initial, T_initial)\n",
    "            CA_output.append(C_A_list) #real value form\n",
    "            T_output.append(T_list)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "d18fd7d5",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "RNN_input shape is (24200, 1, 4)\n",
      "RNN_input shape is (24200, 5, 4)\n",
      "RNN_output shape is (24200, 5, 3)\n"
     ]
    }
   ],
   "source": [
    "# collate input for RNN\n",
    "\n",
    "CA0_input = np.array(CA0_input)\n",
    "CA0_input = CA0_input.reshape(-1,1,1)\n",
    "\n",
    "Q_input = np.array(Q_input)\n",
    "Q_input = Q_input.reshape(-1,1,1)\n",
    "\n",
    "CA_input = np.array(CA_input)\n",
    "CA_input = CA_input.reshape(-1,1,1)\n",
    "\n",
    "T_input = np.array(T_input)\n",
    "T_input = T_input.reshape(-1,1,1)\n",
    "\n",
    "RNN_input = np.concatenate((T_input, CA_input, Q_input, CA0_input), axis=2)   #the value for input variable and the initial value for state variable \n",
    "\n",
    "\"\"\"\n",
    "    the input to RNN is in the shape [number of samples x timestep x variables], and the input variables are same for every\n",
    "    time step, not sure if my treatment here is correct\n",
    "\"\"\"\n",
    "print(\"RNN_input shape is {}\".format(RNN_input.shape))\n",
    "RNN_input = RNN_input.repeat(5, axis=1)  \n",
    "print(\"RNN_input shape is {}\".format(RNN_input.shape))\n",
    "\n",
    "# collate output for RNN\n",
    "\n",
    "CA_output = np.array(CA_output)\n",
    "CA_output = CA_output.reshape(-1, 5, 1)\n",
    "\n",
    "T_output = np.array(T_output)\n",
    "T_output = T_output.reshape(-1, 5, 1)\n",
    "\n",
    "RNN_output = np.concatenate((CA_output,CA_output,T_output), axis=2) #2_to_3 align with target features\n",
    "print(\"RNN_output shape is {}\".format(RNN_output.shape))  # output shape: number of samples x timestep x variables"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "aa5fda0a",
   "metadata": {},
   "source": [
    "# Normalization "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "c4172f79",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(18150, 5, 4) (6050, 5, 4) (18150, 5, 3) (6050, 5, 3)\n"
     ]
    }
   ],
   "source": [
    "#target data\n",
    "X_train, X_test, y_train, y_test = train_test_split(RNN_input, RNN_output, test_size=0.25, random_state=123)\n",
    "\n",
    "# define scalers for both X and y base on training data only\n",
    "scaler_X = preprocessing.StandardScaler().fit(X_train.reshape(-1, 4))\n",
    "scaler_y = preprocessing.StandardScaler().fit(y_train.reshape(-1, 3))\n",
    "\n",
    "X_train = scaler_X.transform(X_train.reshape(-1, 4)).reshape(-1,5,4)\n",
    "X_test = scaler_X.transform(X_test.reshape(-1, 4)).reshape(-1,5,4)\n",
    "y_train = scaler_y.transform(y_train.reshape(-1,3)).reshape(-1,5,3)\n",
    "y_test = scaler_y.transform(y_test.reshape(-1,3)).reshape(-1,5,3)\n",
    "\n",
    "print(X_train.shape, X_test.shape, y_train.shape, y_test.shape)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b1f81109",
   "metadata": {},
   "source": [
    "# Develop the pre-trained model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "25925acb",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/500\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-07-16 17:14:42.404173: E tensorflow/stream_executor/cuda/cuda_driver.cc:271] failed call to cuInit: CUDA_ERROR_NO_DEVICE: no CUDA-capable device is detected\n",
      "2025-07-16 17:14:42.404237: I tensorflow/stream_executor/cuda/cuda_diagnostics.cc:156] kernel driver does not appear to be running on this host (wulab2-System-Product-Name): /proc/driver/nvidia/version does not exist\n",
      "2025-07-16 17:14:42.406042: I tensorflow/core/platform/cpu_feature_guard.cc:151] This TensorFlow binary is optimized with oneAPI Deep Neural Network Library (oneDNN) to use the following CPU instructions in performance-critical operations:  AVX2 AVX512F FMA\n",
      "To enable them in other operations, rebuild TensorFlow with the appropriate compiler flags.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "54/54 - 1s - loss: 0.6221 - mse: 0.6221 - val_loss: 0.3367 - val_mse: 0.3367 - 629ms/epoch - 12ms/step\n",
      "Epoch 2/500\n",
      "54/54 - 0s - loss: 0.2584 - mse: 0.2584 - val_loss: 0.2133 - val_mse: 0.2133 - 57ms/epoch - 1ms/step\n",
      "Epoch 3/500\n",
      "54/54 - 0s - loss: 0.1762 - mse: 0.1762 - val_loss: 0.1551 - val_mse: 0.1551 - 58ms/epoch - 1ms/step\n",
      "Epoch 4/500\n",
      "54/54 - 0s - loss: 0.1321 - mse: 0.1321 - val_loss: 0.1211 - val_mse: 0.1211 - 56ms/epoch - 1ms/step\n",
      "Epoch 5/500\n",
      "54/54 - 0s - loss: 0.1056 - mse: 0.1056 - val_loss: 0.0994 - val_mse: 0.0994 - 57ms/epoch - 1ms/step\n",
      "Epoch 6/500\n",
      "54/54 - 0s - loss: 0.0882 - mse: 0.0882 - val_loss: 0.0850 - val_mse: 0.0850 - 63ms/epoch - 1ms/step\n",
      "Epoch 7/500\n",
      "54/54 - 0s - loss: 0.0762 - mse: 0.0762 - val_loss: 0.0740 - val_mse: 0.0740 - 58ms/epoch - 1ms/step\n",
      "Epoch 8/500\n",
      "54/54 - 0s - loss: 0.0666 - mse: 0.0666 - val_loss: 0.0647 - val_mse: 0.0647 - 76ms/epoch - 1ms/step\n",
      "Epoch 9/500\n",
      "54/54 - 0s - loss: 0.0577 - mse: 0.0577 - val_loss: 0.0555 - val_mse: 0.0555 - 97ms/epoch - 2ms/step\n",
      "Epoch 10/500\n",
      "54/54 - 0s - loss: 0.0490 - mse: 0.0490 - val_loss: 0.0464 - val_mse: 0.0464 - 69ms/epoch - 1ms/step\n",
      "Epoch 11/500\n",
      "54/54 - 0s - loss: 0.0408 - mse: 0.0408 - val_loss: 0.0385 - val_mse: 0.0385 - 88ms/epoch - 2ms/step\n",
      "Epoch 12/500\n",
      "54/54 - 0s - loss: 0.0340 - mse: 0.0340 - val_loss: 0.0325 - val_mse: 0.0325 - 99ms/epoch - 2ms/step\n",
      "Epoch 13/500\n",
      "54/54 - 0s - loss: 0.0290 - mse: 0.0290 - val_loss: 0.0282 - val_mse: 0.0282 - 79ms/epoch - 1ms/step\n",
      "Epoch 14/500\n",
      "54/54 - 0s - loss: 0.0253 - mse: 0.0253 - val_loss: 0.0250 - val_mse: 0.0250 - 60ms/epoch - 1ms/step\n",
      "Epoch 15/500\n",
      "54/54 - 0s - loss: 0.0225 - mse: 0.0225 - val_loss: 0.0226 - val_mse: 0.0226 - 66ms/epoch - 1ms/step\n",
      "Epoch 16/500\n",
      "54/54 - 0s - loss: 0.0204 - mse: 0.0204 - val_loss: 0.0204 - val_mse: 0.0204 - 60ms/epoch - 1ms/step\n",
      "Epoch 17/500\n",
      "54/54 - 0s - loss: 0.0186 - mse: 0.0186 - val_loss: 0.0188 - val_mse: 0.0188 - 72ms/epoch - 1ms/step\n",
      "Epoch 18/500\n",
      "54/54 - 0s - loss: 0.0171 - mse: 0.0171 - val_loss: 0.0175 - val_mse: 0.0175 - 97ms/epoch - 2ms/step\n",
      "Epoch 19/500\n",
      "54/54 - 0s - loss: 0.0158 - mse: 0.0158 - val_loss: 0.0163 - val_mse: 0.0163 - 74ms/epoch - 1ms/step\n",
      "Epoch 20/500\n",
      "54/54 - 0s - loss: 0.0148 - mse: 0.0148 - val_loss: 0.0154 - val_mse: 0.0154 - 58ms/epoch - 1ms/step\n",
      "Epoch 21/500\n",
      "54/54 - 0s - loss: 0.0139 - mse: 0.0139 - val_loss: 0.0145 - val_mse: 0.0145 - 55ms/epoch - 1ms/step\n",
      "Epoch 22/500\n",
      "54/54 - 0s - loss: 0.0131 - mse: 0.0131 - val_loss: 0.0139 - val_mse: 0.0139 - 58ms/epoch - 1ms/step\n",
      "Epoch 23/500\n",
      "54/54 - 0s - loss: 0.0124 - mse: 0.0124 - val_loss: 0.0131 - val_mse: 0.0131 - 60ms/epoch - 1ms/step\n",
      "Epoch 24/500\n",
      "54/54 - 0s - loss: 0.0118 - mse: 0.0118 - val_loss: 0.0127 - val_mse: 0.0127 - 62ms/epoch - 1ms/step\n",
      "Epoch 25/500\n",
      "54/54 - 0s - loss: 0.0113 - mse: 0.0113 - val_loss: 0.0122 - val_mse: 0.0122 - 60ms/epoch - 1ms/step\n",
      "Epoch 26/500\n",
      "54/54 - 0s - loss: 0.0108 - mse: 0.0108 - val_loss: 0.0116 - val_mse: 0.0116 - 61ms/epoch - 1ms/step\n",
      "Epoch 27/500\n",
      "54/54 - 0s - loss: 0.0104 - mse: 0.0104 - val_loss: 0.0112 - val_mse: 0.0112 - 55ms/epoch - 1ms/step\n",
      "Epoch 28/500\n",
      "54/54 - 0s - loss: 0.0100 - mse: 0.0100 - val_loss: 0.0110 - val_mse: 0.0110 - 58ms/epoch - 1ms/step\n",
      "Epoch 29/500\n",
      "54/54 - 0s - loss: 0.0096 - mse: 0.0096 - val_loss: 0.0107 - val_mse: 0.0107 - 55ms/epoch - 1ms/step\n",
      "Epoch 30/500\n",
      "54/54 - 0s - loss: 0.0093 - mse: 0.0093 - val_loss: 0.0102 - val_mse: 0.0102 - 54ms/epoch - 1ms/step\n",
      "Epoch 31/500\n",
      "54/54 - 0s - loss: 0.0090 - mse: 0.0090 - val_loss: 0.0101 - val_mse: 0.0101 - 54ms/epoch - 1ms/step\n",
      "Epoch 32/500\n",
      "54/54 - 0s - loss: 0.0087 - mse: 0.0087 - val_loss: 0.0096 - val_mse: 0.0096 - 61ms/epoch - 1ms/step\n",
      "Epoch 33/500\n",
      "54/54 - 0s - loss: 0.0084 - mse: 0.0084 - val_loss: 0.0094 - val_mse: 0.0094 - 75ms/epoch - 1ms/step\n",
      "Epoch 34/500\n",
      "54/54 - 0s - loss: 0.0081 - mse: 0.0081 - val_loss: 0.0091 - val_mse: 0.0091 - 75ms/epoch - 1ms/step\n",
      "Epoch 35/500\n",
      "54/54 - 0s - loss: 0.0080 - mse: 0.0080 - val_loss: 0.0091 - val_mse: 0.0091 - 61ms/epoch - 1ms/step\n",
      "Epoch 36/500\n",
      "54/54 - 0s - loss: 0.0077 - mse: 0.0077 - val_loss: 0.0087 - val_mse: 0.0087 - 54ms/epoch - 997us/step\n",
      "Epoch 37/500\n",
      "54/54 - 0s - loss: 0.0075 - mse: 0.0075 - val_loss: 0.0087 - val_mse: 0.0087 - 54ms/epoch - 1ms/step\n",
      "Epoch 38/500\n",
      "54/54 - 0s - loss: 0.0073 - mse: 0.0073 - val_loss: 0.0083 - val_mse: 0.0083 - 54ms/epoch - 998us/step\n",
      "Epoch 39/500\n",
      "54/54 - 0s - loss: 0.0071 - mse: 0.0071 - val_loss: 0.0081 - val_mse: 0.0081 - 56ms/epoch - 1ms/step\n",
      "Epoch 40/500\n",
      "54/54 - 0s - loss: 0.0069 - mse: 0.0069 - val_loss: 0.0080 - val_mse: 0.0080 - 59ms/epoch - 1ms/step\n",
      "Epoch 41/500\n",
      "54/54 - 0s - loss: 0.0068 - mse: 0.0068 - val_loss: 0.0077 - val_mse: 0.0077 - 64ms/epoch - 1ms/step\n",
      "Epoch 42/500\n",
      "54/54 - 0s - loss: 0.0066 - mse: 0.0066 - val_loss: 0.0076 - val_mse: 0.0076 - 57ms/epoch - 1ms/step\n",
      "Epoch 43/500\n",
      "54/54 - 0s - loss: 0.0064 - mse: 0.0064 - val_loss: 0.0075 - val_mse: 0.0075 - 60ms/epoch - 1ms/step\n",
      "Epoch 44/500\n",
      "54/54 - 0s - loss: 0.0062 - mse: 0.0062 - val_loss: 0.0072 - val_mse: 0.0072 - 61ms/epoch - 1ms/step\n",
      "Epoch 45/500\n",
      "54/54 - 0s - loss: 0.0061 - mse: 0.0061 - val_loss: 0.0072 - val_mse: 0.0072 - 55ms/epoch - 1ms/step\n",
      "Epoch 46/500\n",
      "54/54 - 0s - loss: 0.0060 - mse: 0.0060 - val_loss: 0.0069 - val_mse: 0.0069 - 57ms/epoch - 1ms/step\n",
      "Epoch 47/500\n",
      "54/54 - 0s - loss: 0.0058 - mse: 0.0058 - val_loss: 0.0068 - val_mse: 0.0068 - 54ms/epoch - 1ms/step\n",
      "Epoch 48/500\n",
      "54/54 - 0s - loss: 0.0057 - mse: 0.0057 - val_loss: 0.0066 - val_mse: 0.0066 - 56ms/epoch - 1ms/step\n",
      "Epoch 49/500\n",
      "54/54 - 0s - loss: 0.0055 - mse: 0.0055 - val_loss: 0.0069 - val_mse: 0.0069 - 55ms/epoch - 1ms/step\n",
      "Epoch 50/500\n",
      "54/54 - 0s - loss: 0.0054 - mse: 0.0054 - val_loss: 0.0064 - val_mse: 0.0064 - 59ms/epoch - 1ms/step\n",
      "Epoch 51/500\n",
      "54/54 - 0s - loss: 0.0053 - mse: 0.0053 - val_loss: 0.0063 - val_mse: 0.0063 - 60ms/epoch - 1ms/step\n",
      "Epoch 52/500\n",
      "54/54 - 0s - loss: 0.0051 - mse: 0.0051 - val_loss: 0.0063 - val_mse: 0.0063 - 56ms/epoch - 1ms/step\n",
      "Epoch 53/500\n",
      "54/54 - 0s - loss: 0.0050 - mse: 0.0050 - val_loss: 0.0061 - val_mse: 0.0061 - 55ms/epoch - 1ms/step\n",
      "Epoch 54/500\n",
      "54/54 - 0s - loss: 0.0049 - mse: 0.0049 - val_loss: 0.0060 - val_mse: 0.0060 - 58ms/epoch - 1ms/step\n",
      "Epoch 55/500\n",
      "54/54 - 0s - loss: 0.0048 - mse: 0.0048 - val_loss: 0.0057 - val_mse: 0.0057 - 60ms/epoch - 1ms/step\n",
      "Epoch 56/500\n",
      "54/54 - 0s - loss: 0.0046 - mse: 0.0046 - val_loss: 0.0057 - val_mse: 0.0057 - 56ms/epoch - 1ms/step\n",
      "Epoch 57/500\n",
      "54/54 - 0s - loss: 0.0045 - mse: 0.0045 - val_loss: 0.0056 - val_mse: 0.0056 - 57ms/epoch - 1ms/step\n",
      "Epoch 58/500\n",
      "54/54 - 0s - loss: 0.0044 - mse: 0.0044 - val_loss: 0.0055 - val_mse: 0.0055 - 56ms/epoch - 1ms/step\n",
      "Epoch 59/500\n",
      "54/54 - 0s - loss: 0.0043 - mse: 0.0043 - val_loss: 0.0054 - val_mse: 0.0054 - 53ms/epoch - 990us/step\n",
      "Epoch 60/500\n",
      "54/54 - 0s - loss: 0.0042 - mse: 0.0042 - val_loss: 0.0052 - val_mse: 0.0052 - 53ms/epoch - 978us/step\n",
      "Epoch 61/500\n",
      "54/54 - 0s - loss: 0.0041 - mse: 0.0041 - val_loss: 0.0058 - val_mse: 0.0058 - 53ms/epoch - 977us/step\n",
      "Epoch 62/500\n",
      "54/54 - 0s - loss: 0.0042 - mse: 0.0042 - val_loss: 0.0051 - val_mse: 0.0051 - 54ms/epoch - 1ms/step\n",
      "Epoch 63/500\n",
      "54/54 - 0s - loss: 0.0039 - mse: 0.0039 - val_loss: 0.0050 - val_mse: 0.0050 - 58ms/epoch - 1ms/step\n",
      "Epoch 64/500\n",
      "54/54 - 0s - loss: 0.0039 - mse: 0.0039 - val_loss: 0.0051 - val_mse: 0.0051 - 59ms/epoch - 1ms/step\n",
      "Epoch 65/500\n",
      "54/54 - 0s - loss: 0.0038 - mse: 0.0038 - val_loss: 0.0049 - val_mse: 0.0049 - 70ms/epoch - 1ms/step\n",
      "Epoch 66/500\n",
      "54/54 - 0s - loss: 0.0037 - mse: 0.0037 - val_loss: 0.0048 - val_mse: 0.0048 - 82ms/epoch - 2ms/step\n",
      "Epoch 67/500\n",
      "54/54 - 0s - loss: 0.0036 - mse: 0.0036 - val_loss: 0.0047 - val_mse: 0.0047 - 80ms/epoch - 1ms/step\n",
      "Epoch 68/500\n",
      "54/54 - 0s - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0048 - val_mse: 0.0048 - 82ms/epoch - 2ms/step\n",
      "Epoch 69/500\n",
      "54/54 - 0s - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0047 - val_mse: 0.0047 - 62ms/epoch - 1ms/step\n",
      "Epoch 70/500\n",
      "54/54 - 0s - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0044 - val_mse: 0.0044 - 61ms/epoch - 1ms/step\n",
      "Epoch 71/500\n",
      "54/54 - 0s - loss: 0.0033 - mse: 0.0033 - val_loss: 0.0044 - val_mse: 0.0044 - 61ms/epoch - 1ms/step\n",
      "Epoch 72/500\n",
      "54/54 - 0s - loss: 0.0033 - mse: 0.0033 - val_loss: 0.0042 - val_mse: 0.0042 - 61ms/epoch - 1ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 73/500\n",
      "54/54 - 0s - loss: 0.0032 - mse: 0.0032 - val_loss: 0.0043 - val_mse: 0.0043 - 59ms/epoch - 1ms/step\n",
      "Epoch 74/500\n",
      "54/54 - 0s - loss: 0.0031 - mse: 0.0031 - val_loss: 0.0044 - val_mse: 0.0044 - 55ms/epoch - 1ms/step\n",
      "Epoch 75/500\n",
      "54/54 - 0s - loss: 0.0031 - mse: 0.0031 - val_loss: 0.0040 - val_mse: 0.0040 - 55ms/epoch - 1ms/step\n",
      "Epoch 76/500\n",
      "54/54 - 0s - loss: 0.0030 - mse: 0.0030 - val_loss: 0.0041 - val_mse: 0.0041 - 54ms/epoch - 1ms/step\n",
      "Epoch 77/500\n",
      "54/54 - 0s - loss: 0.0029 - mse: 0.0029 - val_loss: 0.0040 - val_mse: 0.0040 - 60ms/epoch - 1ms/step\n",
      "Epoch 78/500\n",
      "54/54 - 0s - loss: 0.0029 - mse: 0.0029 - val_loss: 0.0039 - val_mse: 0.0039 - 62ms/epoch - 1ms/step\n",
      "Epoch 79/500\n",
      "54/54 - 0s - loss: 0.0028 - mse: 0.0028 - val_loss: 0.0039 - val_mse: 0.0039 - 109ms/epoch - 2ms/step\n",
      "Epoch 80/500\n",
      "54/54 - 0s - loss: 0.0028 - mse: 0.0028 - val_loss: 0.0039 - val_mse: 0.0039 - 87ms/epoch - 2ms/step\n",
      "Epoch 81/500\n",
      "54/54 - 0s - loss: 0.0027 - mse: 0.0027 - val_loss: 0.0038 - val_mse: 0.0038 - 105ms/epoch - 2ms/step\n",
      "Epoch 82/500\n",
      "54/54 - 0s - loss: 0.0027 - mse: 0.0027 - val_loss: 0.0038 - val_mse: 0.0038 - 70ms/epoch - 1ms/step\n",
      "Epoch 83/500\n",
      "54/54 - 0s - loss: 0.0026 - mse: 0.0026 - val_loss: 0.0037 - val_mse: 0.0037 - 56ms/epoch - 1ms/step\n",
      "Epoch 84/500\n",
      "54/54 - 0s - loss: 0.0026 - mse: 0.0026 - val_loss: 0.0036 - val_mse: 0.0036 - 56ms/epoch - 1ms/step\n",
      "Epoch 85/500\n",
      "54/54 - 0s - loss: 0.0025 - mse: 0.0025 - val_loss: 0.0036 - val_mse: 0.0036 - 59ms/epoch - 1ms/step\n",
      "Epoch 86/500\n",
      "54/54 - 0s - loss: 0.0026 - mse: 0.0026 - val_loss: 0.0036 - val_mse: 0.0036 - 58ms/epoch - 1ms/step\n",
      "Epoch 87/500\n",
      "54/54 - 0s - loss: 0.0025 - mse: 0.0025 - val_loss: 0.0036 - val_mse: 0.0036 - 55ms/epoch - 1ms/step\n",
      "Epoch 88/500\n",
      "54/54 - 0s - loss: 0.0024 - mse: 0.0024 - val_loss: 0.0035 - val_mse: 0.0035 - 58ms/epoch - 1ms/step\n",
      "Epoch 89/500\n",
      "54/54 - 0s - loss: 0.0024 - mse: 0.0024 - val_loss: 0.0035 - val_mse: 0.0035 - 64ms/epoch - 1ms/step\n",
      "Epoch 90/500\n",
      "54/54 - 0s - loss: 0.0024 - mse: 0.0024 - val_loss: 0.0034 - val_mse: 0.0034 - 56ms/epoch - 1ms/step\n",
      "Epoch 91/500\n",
      "54/54 - 0s - loss: 0.0023 - mse: 0.0023 - val_loss: 0.0034 - val_mse: 0.0034 - 56ms/epoch - 1ms/step\n",
      "Epoch 92/500\n",
      "54/54 - 0s - loss: 0.0023 - mse: 0.0023 - val_loss: 0.0033 - val_mse: 0.0033 - 57ms/epoch - 1ms/step\n",
      "Epoch 93/500\n",
      "54/54 - 0s - loss: 0.0023 - mse: 0.0023 - val_loss: 0.0035 - val_mse: 0.0035 - 61ms/epoch - 1ms/step\n",
      "Epoch 94/500\n",
      "54/54 - 0s - loss: 0.0023 - mse: 0.0023 - val_loss: 0.0033 - val_mse: 0.0033 - 67ms/epoch - 1ms/step\n",
      "Epoch 95/500\n",
      "54/54 - 0s - loss: 0.0022 - mse: 0.0022 - val_loss: 0.0033 - val_mse: 0.0033 - 68ms/epoch - 1ms/step\n",
      "Epoch 96/500\n",
      "54/54 - 0s - loss: 0.0022 - mse: 0.0022 - val_loss: 0.0032 - val_mse: 0.0032 - 73ms/epoch - 1ms/step\n",
      "Epoch 97/500\n",
      "54/54 - 0s - loss: 0.0021 - mse: 0.0021 - val_loss: 0.0032 - val_mse: 0.0032 - 79ms/epoch - 1ms/step\n",
      "Epoch 98/500\n",
      "54/54 - 0s - loss: 0.0021 - mse: 0.0021 - val_loss: 0.0033 - val_mse: 0.0033 - 68ms/epoch - 1ms/step\n",
      "Epoch 99/500\n",
      "54/54 - 0s - loss: 0.0021 - mse: 0.0021 - val_loss: 0.0032 - val_mse: 0.0032 - 73ms/epoch - 1ms/step\n",
      "Epoch 100/500\n",
      "54/54 - 0s - loss: 0.0021 - mse: 0.0021 - val_loss: 0.0032 - val_mse: 0.0032 - 63ms/epoch - 1ms/step\n",
      "Epoch 101/500\n",
      "54/54 - 0s - loss: 0.0021 - mse: 0.0021 - val_loss: 0.0031 - val_mse: 0.0031 - 61ms/epoch - 1ms/step\n",
      "Epoch 102/500\n",
      "54/54 - 0s - loss: 0.0020 - mse: 0.0020 - val_loss: 0.0031 - val_mse: 0.0031 - 61ms/epoch - 1ms/step\n",
      "Epoch 103/500\n",
      "54/54 - 0s - loss: 0.0020 - mse: 0.0020 - val_loss: 0.0031 - val_mse: 0.0031 - 60ms/epoch - 1ms/step\n",
      "Epoch 104/500\n",
      "54/54 - 0s - loss: 0.0020 - mse: 0.0020 - val_loss: 0.0030 - val_mse: 0.0030 - 61ms/epoch - 1ms/step\n",
      "Epoch 105/500\n",
      "54/54 - 0s - loss: 0.0020 - mse: 0.0020 - val_loss: 0.0032 - val_mse: 0.0032 - 59ms/epoch - 1ms/step\n",
      "Epoch 106/500\n",
      "54/54 - 0s - loss: 0.0019 - mse: 0.0019 - val_loss: 0.0030 - val_mse: 0.0030 - 70ms/epoch - 1ms/step\n",
      "Epoch 107/500\n",
      "54/54 - 0s - loss: 0.0019 - mse: 0.0019 - val_loss: 0.0031 - val_mse: 0.0031 - 81ms/epoch - 1ms/step\n",
      "Epoch 108/500\n",
      "54/54 - 0s - loss: 0.0020 - mse: 0.0020 - val_loss: 0.0032 - val_mse: 0.0032 - 73ms/epoch - 1ms/step\n",
      "Epoch 109/500\n",
      "54/54 - 0s - loss: 0.0019 - mse: 0.0019 - val_loss: 0.0030 - val_mse: 0.0030 - 70ms/epoch - 1ms/step\n",
      "Epoch 110/500\n",
      "54/54 - 0s - loss: 0.0019 - mse: 0.0019 - val_loss: 0.0029 - val_mse: 0.0029 - 63ms/epoch - 1ms/step\n",
      "Epoch 111/500\n",
      "54/54 - 0s - loss: 0.0018 - mse: 0.0018 - val_loss: 0.0029 - val_mse: 0.0029 - 60ms/epoch - 1ms/step\n",
      "Epoch 112/500\n",
      "54/54 - 0s - loss: 0.0018 - mse: 0.0018 - val_loss: 0.0030 - val_mse: 0.0030 - 60ms/epoch - 1ms/step\n",
      "Epoch 113/500\n",
      "54/54 - 0s - loss: 0.0018 - mse: 0.0018 - val_loss: 0.0030 - val_mse: 0.0030 - 60ms/epoch - 1ms/step\n",
      "Epoch 114/500\n",
      "54/54 - 0s - loss: 0.0018 - mse: 0.0018 - val_loss: 0.0030 - val_mse: 0.0030 - 60ms/epoch - 1ms/step\n",
      "Epoch 115/500\n",
      "54/54 - 0s - loss: 0.0018 - mse: 0.0018 - val_loss: 0.0030 - val_mse: 0.0030 - 62ms/epoch - 1ms/step\n",
      "Epoch 116/500\n",
      "54/54 - 0s - loss: 0.0018 - mse: 0.0018 - val_loss: 0.0028 - val_mse: 0.0028 - 62ms/epoch - 1ms/step\n",
      "Epoch 117/500\n",
      "54/54 - 0s - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0028 - val_mse: 0.0028 - 69ms/epoch - 1ms/step\n",
      "Epoch 118/500\n",
      "54/54 - 0s - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0029 - val_mse: 0.0029 - 73ms/epoch - 1ms/step\n",
      "Epoch 119/500\n",
      "54/54 - 0s - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0028 - val_mse: 0.0028 - 80ms/epoch - 1ms/step\n",
      "Epoch 120/500\n",
      "54/54 - 0s - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0029 - val_mse: 0.0029 - 63ms/epoch - 1ms/step\n",
      "Epoch 121/500\n",
      "54/54 - 0s - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0028 - val_mse: 0.0028 - 59ms/epoch - 1ms/step\n",
      "Epoch 122/500\n",
      "54/54 - 0s - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0028 - val_mse: 0.0028 - 59ms/epoch - 1ms/step\n",
      "Epoch 123/500\n",
      "54/54 - 0s - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0028 - val_mse: 0.0028 - 60ms/epoch - 1ms/step\n",
      "Epoch 124/500\n",
      "54/54 - 0s - loss: 0.0016 - mse: 0.0016 - val_loss: 0.0027 - val_mse: 0.0027 - 64ms/epoch - 1ms/step\n",
      "Epoch 125/500\n",
      "54/54 - 0s - loss: 0.0016 - mse: 0.0016 - val_loss: 0.0029 - val_mse: 0.0029 - 62ms/epoch - 1ms/step\n",
      "Epoch 126/500\n",
      "54/54 - 0s - loss: 0.0016 - mse: 0.0016 - val_loss: 0.0027 - val_mse: 0.0027 - 61ms/epoch - 1ms/step\n",
      "Epoch 127/500\n",
      "54/54 - 0s - loss: 0.0016 - mse: 0.0016 - val_loss: 0.0029 - val_mse: 0.0029 - 61ms/epoch - 1ms/step\n",
      "Epoch 128/500\n",
      "54/54 - 0s - loss: 0.0016 - mse: 0.0016 - val_loss: 0.0027 - val_mse: 0.0027 - 61ms/epoch - 1ms/step\n",
      "Epoch 129/500\n",
      "54/54 - 0s - loss: 0.0016 - mse: 0.0016 - val_loss: 0.0027 - val_mse: 0.0027 - 60ms/epoch - 1ms/step\n",
      "Epoch 130/500\n",
      "54/54 - 0s - loss: 0.0016 - mse: 0.0016 - val_loss: 0.0027 - val_mse: 0.0027 - 61ms/epoch - 1ms/step\n",
      "Epoch 131/500\n",
      "54/54 - 0s - loss: 0.0016 - mse: 0.0016 - val_loss: 0.0027 - val_mse: 0.0027 - 58ms/epoch - 1ms/step\n",
      "Epoch 132/500\n",
      "54/54 - 0s - loss: 0.0016 - mse: 0.0016 - val_loss: 0.0027 - val_mse: 0.0027 - 60ms/epoch - 1ms/step\n",
      "Epoch 133/500\n",
      "54/54 - 0s - loss: 0.0016 - mse: 0.0016 - val_loss: 0.0028 - val_mse: 0.0028 - 59ms/epoch - 1ms/step\n",
      "Epoch 134/500\n",
      "54/54 - 0s - loss: 0.0016 - mse: 0.0016 - val_loss: 0.0028 - val_mse: 0.0028 - 61ms/epoch - 1ms/step\n",
      "Epoch 135/500\n",
      "54/54 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0026 - val_mse: 0.0026 - 62ms/epoch - 1ms/step\n",
      "Epoch 136/500\n",
      "54/54 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0026 - val_mse: 0.0026 - 63ms/epoch - 1ms/step\n",
      "Epoch 137/500\n",
      "54/54 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0028 - val_mse: 0.0028 - 61ms/epoch - 1ms/step\n",
      "Epoch 138/500\n",
      "54/54 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0029 - val_mse: 0.0029 - 60ms/epoch - 1ms/step\n",
      "Epoch 139/500\n",
      "54/54 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0026 - val_mse: 0.0026 - 60ms/epoch - 1ms/step\n",
      "Epoch 140/500\n",
      "54/54 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0028 - val_mse: 0.0028 - 59ms/epoch - 1ms/step\n",
      "Epoch 141/500\n",
      "54/54 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0026 - val_mse: 0.0026 - 61ms/epoch - 1ms/step\n",
      "Epoch 142/500\n",
      "54/54 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0027 - val_mse: 0.0027 - 60ms/epoch - 1ms/step\n",
      "Epoch 143/500\n",
      "54/54 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0028 - val_mse: 0.0028 - 60ms/epoch - 1ms/step\n",
      "Epoch 144/500\n",
      "54/54 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0026 - val_mse: 0.0026 - 64ms/epoch - 1ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 145/500\n",
      "54/54 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0027 - val_mse: 0.0027 - 60ms/epoch - 1ms/step\n",
      "Epoch 146/500\n",
      "54/54 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0028 - val_mse: 0.0028 - 58ms/epoch - 1ms/step\n",
      "Epoch 147/500\n",
      "54/54 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0026 - val_mse: 0.0026 - 63ms/epoch - 1ms/step\n",
      "Epoch 148/500\n",
      "54/54 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0025 - val_mse: 0.0025 - 68ms/epoch - 1ms/step\n",
      "Epoch 149/500\n",
      "54/54 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0027 - val_mse: 0.0027 - 73ms/epoch - 1ms/step\n",
      "Epoch 150/500\n",
      "54/54 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0026 - val_mse: 0.0026 - 77ms/epoch - 1ms/step\n",
      "Epoch 151/500\n",
      "54/54 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0025 - val_mse: 0.0025 - 77ms/epoch - 1ms/step\n",
      "Epoch 152/500\n",
      "54/54 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0025 - val_mse: 0.0025 - 66ms/epoch - 1ms/step\n",
      "Epoch 153/500\n",
      "54/54 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0025 - val_mse: 0.0025 - 61ms/epoch - 1ms/step\n",
      "Epoch 154/500\n",
      "54/54 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0025 - val_mse: 0.0025 - 62ms/epoch - 1ms/step\n",
      "Epoch 155/500\n",
      "54/54 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0026 - val_mse: 0.0026 - 60ms/epoch - 1ms/step\n",
      "Epoch 156/500\n",
      "54/54 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0025 - val_mse: 0.0025 - 60ms/epoch - 1ms/step\n",
      "Epoch 157/500\n",
      "54/54 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0025 - val_mse: 0.0025 - 62ms/epoch - 1ms/step\n",
      "Epoch 158/500\n",
      "54/54 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0025 - val_mse: 0.0025 - 61ms/epoch - 1ms/step\n",
      "Epoch 159/500\n",
      "54/54 - 0s - loss: 0.0013 - mse: 0.0013 - val_loss: 0.0025 - val_mse: 0.0025 - 62ms/epoch - 1ms/step\n",
      "Epoch 160/500\n",
      "54/54 - 0s - loss: 0.0013 - mse: 0.0013 - val_loss: 0.0025 - val_mse: 0.0025 - 63ms/epoch - 1ms/step\n",
      "Epoch 161/500\n",
      "54/54 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0025 - val_mse: 0.0025 - 64ms/epoch - 1ms/step\n",
      "Epoch 162/500\n",
      "54/54 - 0s - loss: 0.0013 - mse: 0.0013 - val_loss: 0.0026 - val_mse: 0.0026 - 60ms/epoch - 1ms/step\n",
      "Epoch 163/500\n",
      "54/54 - 0s - loss: 0.0013 - mse: 0.0013 - val_loss: 0.0025 - val_mse: 0.0025 - 62ms/epoch - 1ms/step\n",
      "Epoch 164/500\n",
      "54/54 - 0s - loss: 0.0013 - mse: 0.0013 - val_loss: 0.0025 - val_mse: 0.0025 - 60ms/epoch - 1ms/step\n",
      "Epoch 165/500\n",
      "54/54 - 0s - loss: 0.0013 - mse: 0.0013 - val_loss: 0.0025 - val_mse: 0.0025 - 66ms/epoch - 1ms/step\n",
      "Epoch 166/500\n",
      "54/54 - 0s - loss: 0.0013 - mse: 0.0013 - val_loss: 0.0025 - val_mse: 0.0025 - 59ms/epoch - 1ms/step\n",
      "Epoch 167/500\n",
      "54/54 - 0s - loss: 0.0013 - mse: 0.0013 - val_loss: 0.0024 - val_mse: 0.0024 - 60ms/epoch - 1ms/step\n",
      "Epoch 168/500\n",
      "54/54 - 0s - loss: 0.0013 - mse: 0.0013 - val_loss: 0.0024 - val_mse: 0.0024 - 61ms/epoch - 1ms/step\n",
      "Epoch 169/500\n",
      "54/54 - 0s - loss: 0.0013 - mse: 0.0013 - val_loss: 0.0025 - val_mse: 0.0025 - 59ms/epoch - 1ms/step\n",
      "Epoch 170/500\n",
      "54/54 - 0s - loss: 0.0013 - mse: 0.0013 - val_loss: 0.0024 - val_mse: 0.0024 - 63ms/epoch - 1ms/step\n",
      "Epoch 171/500\n",
      "54/54 - 0s - loss: 0.0013 - mse: 0.0013 - val_loss: 0.0024 - val_mse: 0.0024 - 63ms/epoch - 1ms/step\n",
      "Epoch 172/500\n",
      "54/54 - 0s - loss: 0.0013 - mse: 0.0013 - val_loss: 0.0024 - val_mse: 0.0024 - 61ms/epoch - 1ms/step\n",
      "Epoch 173/500\n",
      "54/54 - 0s - loss: 0.0013 - mse: 0.0013 - val_loss: 0.0027 - val_mse: 0.0027 - 65ms/epoch - 1ms/step\n",
      "Epoch 174/500\n",
      "54/54 - 0s - loss: 0.0013 - mse: 0.0013 - val_loss: 0.0025 - val_mse: 0.0025 - 61ms/epoch - 1ms/step\n",
      "Epoch 175/500\n",
      "54/54 - 0s - loss: 0.0013 - mse: 0.0013 - val_loss: 0.0024 - val_mse: 0.0024 - 62ms/epoch - 1ms/step\n",
      "Epoch 176/500\n",
      "54/54 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0026 - val_mse: 0.0026 - 61ms/epoch - 1ms/step\n",
      "Epoch 177/500\n",
      "54/54 - 0s - loss: 0.0013 - mse: 0.0013 - val_loss: 0.0024 - val_mse: 0.0024 - 61ms/epoch - 1ms/step\n",
      "Epoch 178/500\n",
      "54/54 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0024 - val_mse: 0.0024 - 62ms/epoch - 1ms/step\n",
      "Epoch 179/500\n",
      "54/54 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0024 - val_mse: 0.0024 - 61ms/epoch - 1ms/step\n",
      "Epoch 180/500\n",
      "54/54 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0024 - val_mse: 0.0024 - 64ms/epoch - 1ms/step\n",
      "Epoch 181/500\n",
      "54/54 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0023 - val_mse: 0.0023 - 59ms/epoch - 1ms/step\n",
      "Epoch 182/500\n",
      "54/54 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0024 - val_mse: 0.0024 - 64ms/epoch - 1ms/step\n",
      "Epoch 183/500\n",
      "54/54 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0024 - val_mse: 0.0024 - 63ms/epoch - 1ms/step\n",
      "Epoch 184/500\n",
      "54/54 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0024 - val_mse: 0.0024 - 61ms/epoch - 1ms/step\n",
      "Epoch 185/500\n",
      "54/54 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0023 - val_mse: 0.0023 - 64ms/epoch - 1ms/step\n",
      "Epoch 186/500\n",
      "54/54 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0024 - val_mse: 0.0024 - 60ms/epoch - 1ms/step\n",
      "Epoch 187/500\n",
      "54/54 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0024 - val_mse: 0.0024 - 60ms/epoch - 1ms/step\n",
      "Epoch 188/500\n",
      "54/54 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0023 - val_mse: 0.0023 - 65ms/epoch - 1ms/step\n",
      "Epoch 189/500\n",
      "54/54 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0023 - val_mse: 0.0023 - 64ms/epoch - 1ms/step\n",
      "Epoch 190/500\n",
      "54/54 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0023 - val_mse: 0.0023 - 60ms/epoch - 1ms/step\n",
      "Epoch 191/500\n",
      "54/54 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0024 - val_mse: 0.0024 - 63ms/epoch - 1ms/step\n",
      "Epoch 192/500\n",
      "54/54 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0023 - val_mse: 0.0023 - 61ms/epoch - 1ms/step\n",
      "Epoch 193/500\n",
      "54/54 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0023 - val_mse: 0.0023 - 64ms/epoch - 1ms/step\n",
      "Epoch 194/500\n",
      "54/54 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0023 - val_mse: 0.0023 - 65ms/epoch - 1ms/step\n",
      "Epoch 195/500\n",
      "54/54 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0026 - val_mse: 0.0026 - 60ms/epoch - 1ms/step\n",
      "Epoch 196/500\n",
      "54/54 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0023 - val_mse: 0.0023 - 64ms/epoch - 1ms/step\n",
      "Epoch 197/500\n",
      "54/54 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0024 - val_mse: 0.0024 - 61ms/epoch - 1ms/step\n",
      "Epoch 198/500\n",
      "54/54 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0023 - val_mse: 0.0023 - 59ms/epoch - 1ms/step\n",
      "Epoch 199/500\n",
      "54/54 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0023 - val_mse: 0.0023 - 71ms/epoch - 1ms/step\n",
      "Epoch 200/500\n",
      "54/54 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0023 - val_mse: 0.0023 - 73ms/epoch - 1ms/step\n",
      "Epoch 201/500\n",
      "54/54 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0023 - val_mse: 0.0023 - 81ms/epoch - 1ms/step\n",
      "Epoch 202/500\n",
      "54/54 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0024 - val_mse: 0.0024 - 79ms/epoch - 1ms/step\n",
      "Epoch 203/500\n",
      "54/54 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0023 - val_mse: 0.0023 - 68ms/epoch - 1ms/step\n",
      "Epoch 204/500\n",
      "54/54 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0023 - val_mse: 0.0023 - 60ms/epoch - 1ms/step\n",
      "Epoch 205/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0023 - val_mse: 0.0023 - 66ms/epoch - 1ms/step\n",
      "Epoch 206/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0023 - val_mse: 0.0023 - 65ms/epoch - 1ms/step\n",
      "Epoch 207/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0023 - val_mse: 0.0023 - 59ms/epoch - 1ms/step\n",
      "Epoch 208/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0023 - val_mse: 0.0023 - 71ms/epoch - 1ms/step\n",
      "Epoch 209/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0024 - val_mse: 0.0024 - 63ms/epoch - 1ms/step\n",
      "Epoch 210/500\n",
      "54/54 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0024 - val_mse: 0.0024 - 71ms/epoch - 1ms/step\n",
      "Epoch 211/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0024 - val_mse: 0.0024 - 63ms/epoch - 1ms/step\n",
      "Epoch 212/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0022 - val_mse: 0.0022 - 73ms/epoch - 1ms/step\n",
      "Epoch 213/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0022 - val_mse: 0.0022 - 61ms/epoch - 1ms/step\n",
      "Epoch 214/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0023 - val_mse: 0.0023 - 64ms/epoch - 1ms/step\n",
      "Epoch 215/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0023 - val_mse: 0.0023 - 65ms/epoch - 1ms/step\n",
      "Epoch 216/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0023 - val_mse: 0.0023 - 64ms/epoch - 1ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 217/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0023 - val_mse: 0.0023 - 69ms/epoch - 1ms/step\n",
      "Epoch 218/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0022 - val_mse: 0.0022 - 68ms/epoch - 1ms/step\n",
      "Epoch 219/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0023 - val_mse: 0.0023 - 63ms/epoch - 1ms/step\n",
      "Epoch 220/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0022 - val_mse: 0.0022 - 66ms/epoch - 1ms/step\n",
      "Epoch 221/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0022 - val_mse: 0.0022 - 61ms/epoch - 1ms/step\n",
      "Epoch 222/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0022 - val_mse: 0.0022 - 61ms/epoch - 1ms/step\n",
      "Epoch 223/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0022 - val_mse: 0.0022 - 60ms/epoch - 1ms/step\n",
      "Epoch 224/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0034 - val_mse: 0.0034 - 62ms/epoch - 1ms/step\n",
      "Epoch 225/500\n",
      "54/54 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0022 - val_mse: 0.0022 - 61ms/epoch - 1ms/step\n",
      "Epoch 226/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0022 - val_mse: 0.0022 - 60ms/epoch - 1ms/step\n",
      "Epoch 227/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0024 - val_mse: 0.0024 - 62ms/epoch - 1ms/step\n",
      "Epoch 228/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0022 - val_mse: 0.0022 - 61ms/epoch - 1ms/step\n",
      "Epoch 229/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0022 - val_mse: 0.0022 - 61ms/epoch - 1ms/step\n",
      "Epoch 230/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0024 - val_mse: 0.0024 - 65ms/epoch - 1ms/step\n",
      "Epoch 231/500\n",
      "54/54 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0023 - val_mse: 0.0023 - 61ms/epoch - 1ms/step\n",
      "Epoch 232/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0023 - val_mse: 0.0023 - 68ms/epoch - 1ms/step\n",
      "Epoch 233/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0022 - val_mse: 0.0022 - 64ms/epoch - 1ms/step\n",
      "Epoch 234/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0022 - val_mse: 0.0022 - 60ms/epoch - 1ms/step\n",
      "Epoch 235/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0023 - val_mse: 0.0023 - 65ms/epoch - 1ms/step\n",
      "Epoch 236/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0022 - val_mse: 0.0022 - 68ms/epoch - 1ms/step\n",
      "Epoch 237/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0022 - val_mse: 0.0022 - 75ms/epoch - 1ms/step\n",
      "Epoch 238/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0022 - val_mse: 0.0022 - 82ms/epoch - 2ms/step\n",
      "Epoch 239/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0028 - val_mse: 0.0028 - 81ms/epoch - 2ms/step\n",
      "Epoch 240/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0022 - val_mse: 0.0022 - 79ms/epoch - 1ms/step\n",
      "Epoch 241/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0023 - val_mse: 0.0023 - 61ms/epoch - 1ms/step\n",
      "Epoch 242/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0022 - val_mse: 0.0022 - 55ms/epoch - 1ms/step\n",
      "Epoch 243/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0021 - val_mse: 0.0021 - 57ms/epoch - 1ms/step\n",
      "Epoch 244/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0023 - val_mse: 0.0023 - 56ms/epoch - 1ms/step\n",
      "Epoch 245/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0022 - val_mse: 0.0022 - 63ms/epoch - 1ms/step\n",
      "Epoch 246/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0027 - val_mse: 0.0027 - 82ms/epoch - 2ms/step\n",
      "Epoch 247/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0023 - val_mse: 0.0023 - 78ms/epoch - 1ms/step\n",
      "Epoch 248/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0022 - val_mse: 0.0022 - 71ms/epoch - 1ms/step\n",
      "Epoch 249/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0029 - val_mse: 0.0029 - 62ms/epoch - 1ms/step\n",
      "Epoch 250/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0022 - val_mse: 0.0022 - 57ms/epoch - 1ms/step\n",
      "Epoch 251/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0022 - val_mse: 0.0022 - 55ms/epoch - 1ms/step\n",
      "Epoch 252/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0022 - val_mse: 0.0022 - 57ms/epoch - 1ms/step\n",
      "Epoch 253/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0022 - val_mse: 0.0022 - 56ms/epoch - 1ms/step\n",
      "Epoch 254/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0022 - val_mse: 0.0022 - 56ms/epoch - 1ms/step\n",
      "Epoch 255/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0022 - val_mse: 0.0022 - 57ms/epoch - 1ms/step\n",
      "Epoch 256/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0022 - val_mse: 0.0022 - 57ms/epoch - 1ms/step\n",
      "Epoch 257/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0021 - val_mse: 0.0021 - 56ms/epoch - 1ms/step\n",
      "Epoch 258/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0021 - val_mse: 0.0021 - 57ms/epoch - 1ms/step\n",
      "Epoch 259/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0021 - val_mse: 0.0021 - 58ms/epoch - 1ms/step\n",
      "Epoch 260/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0022 - val_mse: 0.0022 - 61ms/epoch - 1ms/step\n",
      "Epoch 261/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0022 - val_mse: 0.0022 - 67ms/epoch - 1ms/step\n",
      "Epoch 262/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0023 - val_mse: 0.0023 - 60ms/epoch - 1ms/step\n",
      "Epoch 263/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0021 - val_mse: 0.0021 - 57ms/epoch - 1ms/step\n",
      "Epoch 264/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0022 - val_mse: 0.0022 - 60ms/epoch - 1ms/step\n",
      "Epoch 265/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0021 - val_mse: 0.0021 - 72ms/epoch - 1ms/step\n",
      "Epoch 266/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0021 - val_mse: 0.0021 - 70ms/epoch - 1ms/step\n",
      "Epoch 267/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0022 - val_mse: 0.0022 - 63ms/epoch - 1ms/step\n",
      "Epoch 268/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0024 - val_mse: 0.0024 - 68ms/epoch - 1ms/step\n",
      "Epoch 269/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0024 - val_mse: 0.0024 - 74ms/epoch - 1ms/step\n",
      "Epoch 270/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0022 - val_mse: 0.0022 - 76ms/epoch - 1ms/step\n",
      "Epoch 271/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0023 - val_mse: 0.0023 - 71ms/epoch - 1ms/step\n",
      "Epoch 272/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0024 - val_mse: 0.0024 - 72ms/epoch - 1ms/step\n",
      "Epoch 273/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0021 - val_mse: 0.0021 - 74ms/epoch - 1ms/step\n",
      "Epoch 274/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0021 - val_mse: 0.0021 - 62ms/epoch - 1ms/step\n",
      "Epoch 275/500\n",
      "54/54 - 0s - loss: 9.9527e-04 - mse: 9.9527e-04 - val_loss: 0.0022 - val_mse: 0.0022 - 62ms/epoch - 1ms/step\n",
      "Epoch 276/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0024 - val_mse: 0.0024 - 57ms/epoch - 1ms/step\n",
      "Epoch 277/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0021 - val_mse: 0.0021 - 57ms/epoch - 1ms/step\n",
      "Epoch 278/500\n",
      "54/54 - 0s - loss: 9.9690e-04 - mse: 9.9690e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 57ms/epoch - 1ms/step\n",
      "Epoch 279/500\n",
      "54/54 - 0s - loss: 9.8911e-04 - mse: 9.8911e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 56ms/epoch - 1ms/step\n",
      "Epoch 280/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0021 - val_mse: 0.0021 - 56ms/epoch - 1ms/step\n",
      "Epoch 281/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0021 - val_mse: 0.0021 - 56ms/epoch - 1ms/step\n",
      "Epoch 282/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0021 - val_mse: 0.0021 - 57ms/epoch - 1ms/step\n",
      "Epoch 283/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0022 - val_mse: 0.0022 - 54ms/epoch - 1ms/step\n",
      "Epoch 284/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0022 - val_mse: 0.0022 - 57ms/epoch - 1ms/step\n",
      "Epoch 285/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0022 - val_mse: 0.0022 - 55ms/epoch - 1ms/step\n",
      "Epoch 286/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0021 - val_mse: 0.0021 - 56ms/epoch - 1ms/step\n",
      "Epoch 287/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0021 - val_mse: 0.0021 - 55ms/epoch - 1ms/step\n",
      "Epoch 288/500\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "54/54 - 0s - loss: 9.8424e-04 - mse: 9.8424e-04 - val_loss: 0.0022 - val_mse: 0.0022 - 54ms/epoch - 996us/step\n",
      "Epoch 289/500\n",
      "54/54 - 0s - loss: 9.9520e-04 - mse: 9.9520e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 55ms/epoch - 1ms/step\n",
      "Epoch 290/500\n",
      "54/54 - 0s - loss: 9.9500e-04 - mse: 9.9500e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 55ms/epoch - 1ms/step\n",
      "Epoch 291/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0022 - val_mse: 0.0022 - 56ms/epoch - 1ms/step\n",
      "Epoch 292/500\n",
      "54/54 - 0s - loss: 9.8193e-04 - mse: 9.8193e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 56ms/epoch - 1ms/step\n",
      "Epoch 293/500\n",
      "54/54 - 0s - loss: 9.9818e-04 - mse: 9.9818e-04 - val_loss: 0.0022 - val_mse: 0.0022 - 57ms/epoch - 1ms/step\n",
      "Epoch 294/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0021 - val_mse: 0.0021 - 55ms/epoch - 1ms/step\n",
      "Epoch 295/500\n",
      "54/54 - 0s - loss: 9.7426e-04 - mse: 9.7426e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 54ms/epoch - 998us/step\n",
      "Epoch 296/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0022 - val_mse: 0.0022 - 56ms/epoch - 1ms/step\n",
      "Epoch 297/500\n",
      "54/54 - 0s - loss: 9.8406e-04 - mse: 9.8406e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 55ms/epoch - 1ms/step\n",
      "Epoch 298/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0021 - val_mse: 0.0021 - 56ms/epoch - 1ms/step\n",
      "Epoch 299/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0021 - val_mse: 0.0021 - 55ms/epoch - 1ms/step\n",
      "Epoch 300/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0021 - val_mse: 0.0021 - 55ms/epoch - 1ms/step\n",
      "Epoch 301/500\n",
      "54/54 - 0s - loss: 9.8979e-04 - mse: 9.8979e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 55ms/epoch - 1ms/step\n",
      "Epoch 302/500\n",
      "54/54 - 0s - loss: 9.8071e-04 - mse: 9.8071e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 57ms/epoch - 1ms/step\n",
      "Epoch 303/500\n",
      "54/54 - 0s - loss: 9.7757e-04 - mse: 9.7757e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 55ms/epoch - 1ms/step\n",
      "Epoch 304/500\n",
      "54/54 - 0s - loss: 9.8526e-04 - mse: 9.8526e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 56ms/epoch - 1ms/step\n",
      "Epoch 305/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0021 - val_mse: 0.0021 - 56ms/epoch - 1ms/step\n",
      "Epoch 306/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0020 - val_mse: 0.0020 - 56ms/epoch - 1ms/step\n",
      "Epoch 307/500\n",
      "54/54 - 0s - loss: 9.4663e-04 - mse: 9.4663e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 54ms/epoch - 995us/step\n",
      "Epoch 308/500\n",
      "54/54 - 0s - loss: 9.6359e-04 - mse: 9.6359e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 55ms/epoch - 1ms/step\n",
      "Epoch 309/500\n",
      "54/54 - 0s - loss: 9.5191e-04 - mse: 9.5191e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 55ms/epoch - 1ms/step\n",
      "Epoch 310/500\n",
      "54/54 - 0s - loss: 9.8162e-04 - mse: 9.8162e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 56ms/epoch - 1ms/step\n",
      "Epoch 311/500\n",
      "54/54 - 0s - loss: 9.5413e-04 - mse: 9.5413e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 55ms/epoch - 1ms/step\n",
      "Epoch 312/500\n",
      "54/54 - 0s - loss: 9.5240e-04 - mse: 9.5240e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 56ms/epoch - 1ms/step\n",
      "Epoch 313/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0021 - val_mse: 0.0021 - 59ms/epoch - 1ms/step\n",
      "Epoch 314/500\n",
      "54/54 - 0s - loss: 9.9016e-04 - mse: 9.9016e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 54ms/epoch - 993us/step\n",
      "Epoch 315/500\n",
      "54/54 - 0s - loss: 9.9204e-04 - mse: 9.9204e-04 - val_loss: 0.0022 - val_mse: 0.0022 - 54ms/epoch - 1ms/step\n",
      "Epoch 316/500\n",
      "54/54 - 0s - loss: 9.6555e-04 - mse: 9.6555e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 55ms/epoch - 1ms/step\n",
      "Epoch 317/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0021 - val_mse: 0.0021 - 56ms/epoch - 1ms/step\n",
      "Epoch 318/500\n",
      "54/54 - 0s - loss: 9.9558e-04 - mse: 9.9558e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 57ms/epoch - 1ms/step\n",
      "Epoch 319/500\n",
      "54/54 - 0s - loss: 9.7197e-04 - mse: 9.7197e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 57ms/epoch - 1ms/step\n",
      "Epoch 320/500\n",
      "54/54 - 0s - loss: 9.5130e-04 - mse: 9.5130e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 58ms/epoch - 1ms/step\n",
      "Epoch 321/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0023 - val_mse: 0.0023 - 56ms/epoch - 1ms/step\n",
      "Epoch 322/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0020 - val_mse: 0.0020 - 56ms/epoch - 1ms/step\n",
      "Epoch 323/500\n",
      "54/54 - 0s - loss: 9.5704e-04 - mse: 9.5704e-04 - val_loss: 0.0022 - val_mse: 0.0022 - 55ms/epoch - 1ms/step\n",
      "Epoch 324/500\n",
      "54/54 - 0s - loss: 9.5000e-04 - mse: 9.5000e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 55ms/epoch - 1ms/step\n",
      "Epoch 325/500\n",
      "54/54 - 0s - loss: 9.5891e-04 - mse: 9.5891e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 55ms/epoch - 1ms/step\n",
      "Epoch 326/500\n",
      "54/54 - 0s - loss: 9.5398e-04 - mse: 9.5398e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 56ms/epoch - 1ms/step\n",
      "Epoch 327/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0020 - val_mse: 0.0020 - 57ms/epoch - 1ms/step\n",
      "Epoch 328/500\n",
      "54/54 - 0s - loss: 9.6250e-04 - mse: 9.6250e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 55ms/epoch - 1ms/step\n",
      "Epoch 329/500\n",
      "54/54 - 0s - loss: 9.7277e-04 - mse: 9.7277e-04 - val_loss: 0.0022 - val_mse: 0.0022 - 55ms/epoch - 1ms/step\n",
      "Epoch 330/500\n",
      "54/54 - 0s - loss: 9.5664e-04 - mse: 9.5664e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 56ms/epoch - 1ms/step\n",
      "Epoch 331/500\n",
      "54/54 - 0s - loss: 9.4913e-04 - mse: 9.4913e-04 - val_loss: 0.0022 - val_mse: 0.0022 - 60ms/epoch - 1ms/step\n",
      "Epoch 332/500\n",
      "54/54 - 0s - loss: 9.4928e-04 - mse: 9.4928e-04 - val_loss: 0.0022 - val_mse: 0.0022 - 57ms/epoch - 1ms/step\n",
      "Epoch 333/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0020 - val_mse: 0.0020 - 57ms/epoch - 1ms/step\n",
      "Epoch 334/500\n",
      "54/54 - 0s - loss: 9.4887e-04 - mse: 9.4887e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 56ms/epoch - 1ms/step\n",
      "Epoch 335/500\n",
      "54/54 - 0s - loss: 9.4706e-04 - mse: 9.4706e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 59ms/epoch - 1ms/step\n",
      "Epoch 336/500\n",
      "54/54 - 0s - loss: 9.3947e-04 - mse: 9.3947e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 57ms/epoch - 1ms/step\n",
      "Epoch 337/500\n",
      "54/54 - 0s - loss: 9.4718e-04 - mse: 9.4718e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 54ms/epoch - 1ms/step\n",
      "Epoch 338/500\n",
      "54/54 - 0s - loss: 9.5920e-04 - mse: 9.5920e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 56ms/epoch - 1ms/step\n",
      "Epoch 339/500\n",
      "54/54 - 0s - loss: 9.3658e-04 - mse: 9.3658e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 58ms/epoch - 1ms/step\n",
      "Epoch 340/500\n",
      "54/54 - 0s - loss: 9.3671e-04 - mse: 9.3671e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 57ms/epoch - 1ms/step\n",
      "Epoch 341/500\n",
      "54/54 - 0s - loss: 9.8409e-04 - mse: 9.8409e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 56ms/epoch - 1ms/step\n",
      "Epoch 342/500\n",
      "54/54 - 0s - loss: 9.3774e-04 - mse: 9.3774e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 55ms/epoch - 1ms/step\n",
      "Epoch 343/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0024 - val_mse: 0.0024 - 57ms/epoch - 1ms/step\n",
      "Epoch 344/500\n",
      "54/54 - 0s - loss: 9.6786e-04 - mse: 9.6786e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 59ms/epoch - 1ms/step\n",
      "Epoch 345/500\n",
      "54/54 - 0s - loss: 9.7244e-04 - mse: 9.7244e-04 - val_loss: 0.0022 - val_mse: 0.0022 - 56ms/epoch - 1ms/step\n",
      "Epoch 346/500\n",
      "54/54 - 0s - loss: 9.4439e-04 - mse: 9.4439e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 58ms/epoch - 1ms/step\n",
      "Epoch 347/500\n",
      "54/54 - 0s - loss: 9.3046e-04 - mse: 9.3046e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 57ms/epoch - 1ms/step\n",
      "Epoch 348/500\n",
      "54/54 - 0s - loss: 9.3204e-04 - mse: 9.3204e-04 - val_loss: 0.0022 - val_mse: 0.0022 - 56ms/epoch - 1ms/step\n",
      "Epoch 349/500\n",
      "54/54 - 0s - loss: 9.8249e-04 - mse: 9.8249e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 56ms/epoch - 1ms/step\n",
      "Epoch 350/500\n",
      "54/54 - 0s - loss: 9.5381e-04 - mse: 9.5381e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 56ms/epoch - 1ms/step\n",
      "Epoch 351/500\n",
      "54/54 - 0s - loss: 9.6884e-04 - mse: 9.6884e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 56ms/epoch - 1ms/step\n",
      "Epoch 352/500\n",
      "54/54 - 0s - loss: 9.0421e-04 - mse: 9.0421e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 56ms/epoch - 1ms/step\n",
      "Epoch 353/500\n",
      "54/54 - 0s - loss: 9.2567e-04 - mse: 9.2567e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 57ms/epoch - 1ms/step\n",
      "Epoch 354/500\n",
      "54/54 - 0s - loss: 9.9940e-04 - mse: 9.9940e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 55ms/epoch - 1ms/step\n",
      "Epoch 355/500\n",
      "54/54 - 0s - loss: 9.2535e-04 - mse: 9.2535e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 56ms/epoch - 1ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 356/500\n",
      "54/54 - 0s - loss: 9.4917e-04 - mse: 9.4917e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 56ms/epoch - 1ms/step\n",
      "Epoch 357/500\n",
      "54/54 - 0s - loss: 9.6103e-04 - mse: 9.6103e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 58ms/epoch - 1ms/step\n",
      "Epoch 358/500\n",
      "54/54 - 0s - loss: 9.8246e-04 - mse: 9.8246e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 55ms/epoch - 1ms/step\n",
      "Epoch 359/500\n",
      "54/54 - 0s - loss: 9.5139e-04 - mse: 9.5139e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 57ms/epoch - 1ms/step\n",
      "Epoch 360/500\n",
      "54/54 - 0s - loss: 9.7053e-04 - mse: 9.7053e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 56ms/epoch - 1ms/step\n",
      "Epoch 361/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0020 - val_mse: 0.0020 - 57ms/epoch - 1ms/step\n",
      "Epoch 362/500\n",
      "54/54 - 0s - loss: 9.2718e-04 - mse: 9.2718e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 56ms/epoch - 1ms/step\n",
      "Epoch 363/500\n",
      "54/54 - 0s - loss: 9.2020e-04 - mse: 9.2020e-04 - val_loss: 0.0022 - val_mse: 0.0022 - 58ms/epoch - 1ms/step\n",
      "Epoch 364/500\n",
      "54/54 - 0s - loss: 9.4594e-04 - mse: 9.4594e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 56ms/epoch - 1ms/step\n",
      "Epoch 365/500\n",
      "54/54 - 0s - loss: 9.5364e-04 - mse: 9.5364e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 56ms/epoch - 1ms/step\n",
      "Epoch 366/500\n",
      "54/54 - 0s - loss: 9.5567e-04 - mse: 9.5567e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 58ms/epoch - 1ms/step\n",
      "Epoch 367/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0020 - val_mse: 0.0020 - 58ms/epoch - 1ms/step\n",
      "Epoch 368/500\n",
      "54/54 - 0s - loss: 9.3021e-04 - mse: 9.3021e-04 - val_loss: 0.0026 - val_mse: 0.0026 - 55ms/epoch - 1ms/step\n",
      "Epoch 369/500\n",
      "54/54 - 0s - loss: 9.8228e-04 - mse: 9.8228e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 55ms/epoch - 1ms/step\n",
      "Epoch 370/500\n",
      "54/54 - 0s - loss: 9.0674e-04 - mse: 9.0674e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 55ms/epoch - 1ms/step\n",
      "Epoch 371/500\n",
      "54/54 - 0s - loss: 9.3985e-04 - mse: 9.3985e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 56ms/epoch - 1ms/step\n",
      "Epoch 372/500\n",
      "54/54 - 0s - loss: 9.1870e-04 - mse: 9.1870e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 56ms/epoch - 1ms/step\n",
      "Epoch 373/500\n",
      "54/54 - 0s - loss: 9.5344e-04 - mse: 9.5344e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 55ms/epoch - 1ms/step\n",
      "Epoch 374/500\n",
      "54/54 - 0s - loss: 9.0244e-04 - mse: 9.0244e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 57ms/epoch - 1ms/step\n",
      "Epoch 375/500\n",
      "54/54 - 0s - loss: 9.3533e-04 - mse: 9.3533e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 56ms/epoch - 1ms/step\n",
      "Epoch 376/500\n",
      "54/54 - 0s - loss: 9.1478e-04 - mse: 9.1478e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 55ms/epoch - 1ms/step\n",
      "Epoch 377/500\n",
      "54/54 - 0s - loss: 9.6871e-04 - mse: 9.6871e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 58ms/epoch - 1ms/step\n",
      "Epoch 378/500\n",
      "54/54 - 0s - loss: 9.3022e-04 - mse: 9.3022e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 54ms/epoch - 1ms/step\n",
      "Epoch 379/500\n",
      "54/54 - 0s - loss: 9.2184e-04 - mse: 9.2184e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 55ms/epoch - 1ms/step\n",
      "Epoch 380/500\n",
      "54/54 - 0s - loss: 8.9011e-04 - mse: 8.9011e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 54ms/epoch - 1ms/step\n",
      "Epoch 381/500\n",
      "54/54 - 0s - loss: 8.9918e-04 - mse: 8.9918e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 55ms/epoch - 1ms/step\n",
      "Epoch 382/500\n",
      "54/54 - 0s - loss: 9.3100e-04 - mse: 9.3100e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 55ms/epoch - 1ms/step\n",
      "Epoch 383/500\n",
      "54/54 - 0s - loss: 9.6691e-04 - mse: 9.6691e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 57ms/epoch - 1ms/step\n",
      "Epoch 384/500\n",
      "54/54 - 0s - loss: 9.0861e-04 - mse: 9.0861e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 56ms/epoch - 1ms/step\n",
      "Epoch 385/500\n",
      "54/54 - 0s - loss: 8.8077e-04 - mse: 8.8077e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 55ms/epoch - 1ms/step\n",
      "Epoch 386/500\n",
      "54/54 - 0s - loss: 8.9065e-04 - mse: 8.9065e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 55ms/epoch - 1ms/step\n",
      "Epoch 387/500\n",
      "54/54 - 0s - loss: 8.9673e-04 - mse: 8.9673e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 56ms/epoch - 1ms/step\n",
      "Epoch 388/500\n",
      "54/54 - 0s - loss: 9.1886e-04 - mse: 9.1886e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 56ms/epoch - 1ms/step\n",
      "Epoch 389/500\n",
      "54/54 - 0s - loss: 9.1063e-04 - mse: 9.1063e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 55ms/epoch - 1ms/step\n",
      "Epoch 390/500\n",
      "54/54 - 0s - loss: 9.0885e-04 - mse: 9.0885e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 55ms/epoch - 1ms/step\n",
      "Epoch 391/500\n",
      "54/54 - 0s - loss: 8.9682e-04 - mse: 8.9682e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 55ms/epoch - 1ms/step\n",
      "Epoch 392/500\n",
      "54/54 - 0s - loss: 9.0169e-04 - mse: 9.0169e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 55ms/epoch - 1ms/step\n",
      "Epoch 393/500\n",
      "54/54 - 0s - loss: 9.1429e-04 - mse: 9.1429e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 55ms/epoch - 1ms/step\n",
      "Epoch 394/500\n",
      "54/54 - 0s - loss: 8.7162e-04 - mse: 8.7162e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 56ms/epoch - 1ms/step\n",
      "Epoch 395/500\n",
      "54/54 - 0s - loss: 8.9247e-04 - mse: 8.9247e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 54ms/epoch - 1ms/step\n",
      "Epoch 396/500\n",
      "54/54 - 0s - loss: 9.0535e-04 - mse: 9.0535e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 56ms/epoch - 1ms/step\n",
      "Epoch 397/500\n",
      "54/54 - 0s - loss: 9.3403e-04 - mse: 9.3403e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 55ms/epoch - 1ms/step\n",
      "Epoch 398/500\n",
      "54/54 - 0s - loss: 9.1275e-04 - mse: 9.1275e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 56ms/epoch - 1ms/step\n",
      "Epoch 399/500\n",
      "54/54 - 0s - loss: 9.0544e-04 - mse: 9.0544e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 57ms/epoch - 1ms/step\n",
      "Epoch 400/500\n",
      "54/54 - 0s - loss: 9.8765e-04 - mse: 9.8765e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 56ms/epoch - 1ms/step\n",
      "Epoch 401/500\n",
      "54/54 - 0s - loss: 9.1909e-04 - mse: 9.1909e-04 - val_loss: 0.0022 - val_mse: 0.0022 - 55ms/epoch - 1ms/step\n",
      "Epoch 402/500\n",
      "54/54 - 0s - loss: 9.3282e-04 - mse: 9.3282e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 56ms/epoch - 1ms/step\n",
      "Epoch 403/500\n",
      "54/54 - 0s - loss: 8.9403e-04 - mse: 8.9403e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 54ms/epoch - 1ms/step\n",
      "Epoch 404/500\n",
      "54/54 - 0s - loss: 8.9079e-04 - mse: 8.9079e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 56ms/epoch - 1ms/step\n",
      "Epoch 405/500\n",
      "54/54 - 0s - loss: 8.9223e-04 - mse: 8.9223e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 56ms/epoch - 1ms/step\n",
      "Epoch 406/500\n",
      "54/54 - 0s - loss: 8.8160e-04 - mse: 8.8160e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 57ms/epoch - 1ms/step\n",
      "Epoch 407/500\n",
      "54/54 - 0s - loss: 9.7269e-04 - mse: 9.7269e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 55ms/epoch - 1ms/step\n",
      "Epoch 408/500\n",
      "54/54 - 0s - loss: 8.8192e-04 - mse: 8.8192e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 55ms/epoch - 1ms/step\n",
      "Epoch 409/500\n",
      "54/54 - 0s - loss: 9.0092e-04 - mse: 9.0092e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 56ms/epoch - 1ms/step\n",
      "Epoch 410/500\n",
      "54/54 - 0s - loss: 9.2024e-04 - mse: 9.2024e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 56ms/epoch - 1ms/step\n",
      "Epoch 411/500\n",
      "54/54 - 0s - loss: 9.2345e-04 - mse: 9.2345e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 55ms/epoch - 1ms/step\n",
      "Epoch 412/500\n",
      "54/54 - 0s - loss: 9.3692e-04 - mse: 9.3692e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 57ms/epoch - 1ms/step\n",
      "Epoch 413/500\n",
      "54/54 - 0s - loss: 9.2819e-04 - mse: 9.2819e-04 - val_loss: 0.0022 - val_mse: 0.0022 - 57ms/epoch - 1ms/step\n",
      "Epoch 414/500\n",
      "54/54 - 0s - loss: 9.2514e-04 - mse: 9.2514e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 59ms/epoch - 1ms/step\n",
      "Epoch 415/500\n",
      "54/54 - 0s - loss: 9.2118e-04 - mse: 9.2118e-04 - val_loss: 0.0023 - val_mse: 0.0023 - 55ms/epoch - 1ms/step\n",
      "Epoch 416/500\n",
      "54/54 - 0s - loss: 8.7184e-04 - mse: 8.7184e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 55ms/epoch - 1ms/step\n",
      "Epoch 417/500\n",
      "54/54 - 0s - loss: 8.7872e-04 - mse: 8.7872e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 55ms/epoch - 1ms/step\n",
      "Epoch 418/500\n",
      "54/54 - 0s - loss: 8.8906e-04 - mse: 8.8906e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 56ms/epoch - 1ms/step\n",
      "Epoch 419/500\n",
      "54/54 - 0s - loss: 8.8613e-04 - mse: 8.8613e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 56ms/epoch - 1ms/step\n",
      "Epoch 420/500\n",
      "54/54 - 0s - loss: 9.2546e-04 - mse: 9.2546e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 55ms/epoch - 1ms/step\n",
      "Epoch 421/500\n",
      "54/54 - 0s - loss: 8.9289e-04 - mse: 8.9289e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 56ms/epoch - 1ms/step\n",
      "Epoch 422/500\n",
      "54/54 - 0s - loss: 8.7670e-04 - mse: 8.7670e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 55ms/epoch - 1ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 423/500\n",
      "54/54 - 0s - loss: 9.1382e-04 - mse: 9.1382e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 58ms/epoch - 1ms/step\n",
      "Epoch 424/500\n",
      "54/54 - 0s - loss: 8.9576e-04 - mse: 8.9576e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 56ms/epoch - 1ms/step\n",
      "Epoch 425/500\n",
      "54/54 - 0s - loss: 8.6370e-04 - mse: 8.6370e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 55ms/epoch - 1ms/step\n",
      "Epoch 426/500\n",
      "54/54 - 0s - loss: 8.9810e-04 - mse: 8.9810e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 56ms/epoch - 1ms/step\n",
      "Epoch 427/500\n",
      "54/54 - 0s - loss: 8.8999e-04 - mse: 8.8999e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 56ms/epoch - 1ms/step\n",
      "Epoch 428/500\n",
      "54/54 - 0s - loss: 8.6022e-04 - mse: 8.6022e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 58ms/epoch - 1ms/step\n",
      "Epoch 429/500\n",
      "54/54 - 0s - loss: 8.7544e-04 - mse: 8.7544e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 54ms/epoch - 1ms/step\n",
      "Epoch 430/500\n",
      "54/54 - 0s - loss: 8.9333e-04 - mse: 8.9333e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 56ms/epoch - 1ms/step\n",
      "Epoch 431/500\n",
      "54/54 - 0s - loss: 8.5135e-04 - mse: 8.5135e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 56ms/epoch - 1ms/step\n",
      "Epoch 432/500\n",
      "54/54 - 0s - loss: 8.7129e-04 - mse: 8.7129e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 56ms/epoch - 1ms/step\n",
      "Epoch 433/500\n",
      "54/54 - 0s - loss: 8.8967e-04 - mse: 8.8967e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 57ms/epoch - 1ms/step\n",
      "Epoch 434/500\n",
      "54/54 - 0s - loss: 8.6463e-04 - mse: 8.6463e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 55ms/epoch - 1ms/step\n",
      "Epoch 435/500\n",
      "54/54 - 0s - loss: 8.9071e-04 - mse: 8.9071e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 56ms/epoch - 1ms/step\n",
      "Epoch 436/500\n",
      "54/54 - 0s - loss: 8.6631e-04 - mse: 8.6631e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 56ms/epoch - 1ms/step\n",
      "Epoch 437/500\n",
      "54/54 - 0s - loss: 9.4246e-04 - mse: 9.4246e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 57ms/epoch - 1ms/step\n",
      "Epoch 438/500\n",
      "54/54 - 0s - loss: 8.8176e-04 - mse: 8.8176e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 57ms/epoch - 1ms/step\n",
      "Epoch 439/500\n",
      "54/54 - 0s - loss: 9.1696e-04 - mse: 9.1696e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 56ms/epoch - 1ms/step\n",
      "Epoch 440/500\n",
      "54/54 - 0s - loss: 9.0296e-04 - mse: 9.0296e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 57ms/epoch - 1ms/step\n",
      "Epoch 441/500\n",
      "54/54 - 0s - loss: 8.5494e-04 - mse: 8.5494e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 56ms/epoch - 1ms/step\n",
      "Epoch 442/500\n",
      "54/54 - 0s - loss: 8.5192e-04 - mse: 8.5192e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 56ms/epoch - 1ms/step\n",
      "Epoch 443/500\n",
      "54/54 - 0s - loss: 8.5923e-04 - mse: 8.5923e-04 - val_loss: 0.0024 - val_mse: 0.0024 - 55ms/epoch - 1ms/step\n",
      "Epoch 444/500\n",
      "54/54 - 0s - loss: 9.8439e-04 - mse: 9.8439e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 55ms/epoch - 1ms/step\n",
      "Epoch 445/500\n",
      "54/54 - 0s - loss: 8.4186e-04 - mse: 8.4186e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 58ms/epoch - 1ms/step\n",
      "Epoch 446/500\n",
      "54/54 - 0s - loss: 8.8604e-04 - mse: 8.8604e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 56ms/epoch - 1ms/step\n",
      "Epoch 447/500\n",
      "54/54 - 0s - loss: 8.7703e-04 - mse: 8.7703e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 55ms/epoch - 1ms/step\n",
      "Epoch 448/500\n",
      "54/54 - 0s - loss: 8.6241e-04 - mse: 8.6241e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 55ms/epoch - 1ms/step\n",
      "Epoch 449/500\n",
      "54/54 - 0s - loss: 8.6338e-04 - mse: 8.6338e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 56ms/epoch - 1ms/step\n",
      "Epoch 450/500\n",
      "54/54 - 0s - loss: 8.5682e-04 - mse: 8.5682e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 56ms/epoch - 1ms/step\n",
      "Epoch 451/500\n",
      "54/54 - 0s - loss: 9.1582e-04 - mse: 9.1582e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 55ms/epoch - 1ms/step\n",
      "Epoch 452/500\n",
      "54/54 - 0s - loss: 8.7543e-04 - mse: 8.7543e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 57ms/epoch - 1ms/step\n",
      "Epoch 453/500\n",
      "54/54 - 0s - loss: 8.5587e-04 - mse: 8.5587e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 57ms/epoch - 1ms/step\n",
      "Epoch 454/500\n",
      "54/54 - 0s - loss: 9.1368e-04 - mse: 9.1368e-04 - val_loss: 0.0023 - val_mse: 0.0023 - 56ms/epoch - 1ms/step\n",
      "Epoch 455/500\n",
      "54/54 - 0s - loss: 9.3336e-04 - mse: 9.3336e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 56ms/epoch - 1ms/step\n",
      "Epoch 456/500\n",
      "54/54 - 0s - loss: 8.4947e-04 - mse: 8.4947e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 55ms/epoch - 1ms/step\n",
      "Epoch 457/500\n",
      "54/54 - 0s - loss: 8.4991e-04 - mse: 8.4991e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 58ms/epoch - 1ms/step\n",
      "Epoch 458/500\n",
      "54/54 - 0s - loss: 8.8488e-04 - mse: 8.8488e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 58ms/epoch - 1ms/step\n",
      "Epoch 459/500\n",
      "54/54 - 0s - loss: 8.3541e-04 - mse: 8.3541e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 56ms/epoch - 1ms/step\n",
      "Epoch 460/500\n",
      "54/54 - 0s - loss: 8.5073e-04 - mse: 8.5073e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 55ms/epoch - 1ms/step\n",
      "Epoch 461/500\n",
      "54/54 - 0s - loss: 8.5564e-04 - mse: 8.5564e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 59ms/epoch - 1ms/step\n",
      "Epoch 462/500\n",
      "54/54 - 0s - loss: 8.7007e-04 - mse: 8.7007e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 55ms/epoch - 1ms/step\n",
      "Epoch 463/500\n",
      "54/54 - 0s - loss: 8.7968e-04 - mse: 8.7968e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 55ms/epoch - 1ms/step\n",
      "Epoch 464/500\n",
      "54/54 - 0s - loss: 9.3455e-04 - mse: 9.3455e-04 - val_loss: 0.0023 - val_mse: 0.0023 - 57ms/epoch - 1ms/step\n",
      "Epoch 465/500\n",
      "54/54 - 0s - loss: 9.1157e-04 - mse: 9.1157e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 55ms/epoch - 1ms/step\n",
      "Epoch 466/500\n",
      "54/54 - 0s - loss: 8.3760e-04 - mse: 8.3760e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 55ms/epoch - 1ms/step\n",
      "Epoch 467/500\n",
      "54/54 - 0s - loss: 8.9775e-04 - mse: 8.9775e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 56ms/epoch - 1ms/step\n",
      "Epoch 468/500\n",
      "54/54 - 0s - loss: 8.6572e-04 - mse: 8.6572e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 56ms/epoch - 1ms/step\n",
      "Epoch 469/500\n",
      "54/54 - 0s - loss: 8.3581e-04 - mse: 8.3581e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 57ms/epoch - 1ms/step\n",
      "Epoch 470/500\n",
      "54/54 - 0s - loss: 8.5104e-04 - mse: 8.5104e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 57ms/epoch - 1ms/step\n",
      "Epoch 471/500\n",
      "54/54 - 0s - loss: 8.5734e-04 - mse: 8.5734e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 58ms/epoch - 1ms/step\n",
      "Epoch 472/500\n",
      "54/54 - 0s - loss: 8.6269e-04 - mse: 8.6269e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 58ms/epoch - 1ms/step\n",
      "Epoch 473/500\n",
      "54/54 - 0s - loss: 8.6287e-04 - mse: 8.6287e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 55ms/epoch - 1ms/step\n",
      "Epoch 474/500\n",
      "54/54 - 0s - loss: 8.4283e-04 - mse: 8.4283e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 55ms/epoch - 1ms/step\n",
      "Epoch 475/500\n",
      "54/54 - 0s - loss: 8.3476e-04 - mse: 8.3476e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 55ms/epoch - 1ms/step\n",
      "Epoch 476/500\n",
      "54/54 - 0s - loss: 8.9427e-04 - mse: 8.9427e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 56ms/epoch - 1ms/step\n",
      "Epoch 477/500\n",
      "54/54 - 0s - loss: 8.2525e-04 - mse: 8.2525e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 56ms/epoch - 1ms/step\n",
      "Epoch 478/500\n",
      "54/54 - 0s - loss: 8.4969e-04 - mse: 8.4969e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 54ms/epoch - 998us/step\n",
      "Epoch 479/500\n",
      "54/54 - 0s - loss: 8.2599e-04 - mse: 8.2599e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 55ms/epoch - 1ms/step\n",
      "Epoch 480/500\n",
      "54/54 - 0s - loss: 8.7030e-04 - mse: 8.7030e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 59ms/epoch - 1ms/step\n",
      "Epoch 481/500\n",
      "54/54 - 0s - loss: 9.0518e-04 - mse: 9.0518e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 55ms/epoch - 1ms/step\n",
      "Epoch 482/500\n",
      "54/54 - 0s - loss: 8.5167e-04 - mse: 8.5167e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 55ms/epoch - 1ms/step\n",
      "Epoch 483/500\n",
      "54/54 - 0s - loss: 8.5453e-04 - mse: 8.5453e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 56ms/epoch - 1ms/step\n",
      "Epoch 484/500\n",
      "54/54 - 0s - loss: 8.6857e-04 - mse: 8.6857e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 56ms/epoch - 1ms/step\n",
      "Epoch 485/500\n",
      "54/54 - 0s - loss: 8.5135e-04 - mse: 8.5135e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 56ms/epoch - 1ms/step\n",
      "Epoch 486/500\n",
      "54/54 - 0s - loss: 8.3611e-04 - mse: 8.3611e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 55ms/epoch - 1ms/step\n",
      "Epoch 487/500\n",
      "54/54 - 0s - loss: 8.4663e-04 - mse: 8.4663e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 57ms/epoch - 1ms/step\n",
      "Epoch 488/500\n",
      "54/54 - 0s - loss: 8.4115e-04 - mse: 8.4115e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 58ms/epoch - 1ms/step\n",
      "Epoch 489/500\n",
      "54/54 - 0s - loss: 9.8558e-04 - mse: 9.8558e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 55ms/epoch - 1ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 490/500\n",
      "54/54 - 0s - loss: 8.4453e-04 - mse: 8.4453e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 58ms/epoch - 1ms/step\n",
      "Epoch 491/500\n",
      "54/54 - 0s - loss: 8.2979e-04 - mse: 8.2979e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 54ms/epoch - 1ms/step\n",
      "Epoch 492/500\n",
      "54/54 - 0s - loss: 8.3176e-04 - mse: 8.3176e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 54ms/epoch - 1ms/step\n",
      "Epoch 493/500\n",
      "54/54 - 0s - loss: 8.4138e-04 - mse: 8.4138e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 57ms/epoch - 1ms/step\n",
      "Epoch 494/500\n",
      "54/54 - 0s - loss: 8.9978e-04 - mse: 8.9978e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 55ms/epoch - 1ms/step\n",
      "Epoch 495/500\n",
      "54/54 - 0s - loss: 8.7025e-04 - mse: 8.7025e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 53ms/epoch - 988us/step\n",
      "Epoch 496/500\n",
      "54/54 - 0s - loss: 8.1938e-04 - mse: 8.1938e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 57ms/epoch - 1ms/step\n",
      "Epoch 497/500\n",
      "54/54 - 0s - loss: 8.2236e-04 - mse: 8.2236e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 56ms/epoch - 1ms/step\n",
      "Epoch 498/500\n",
      "54/54 - 0s - loss: 8.3282e-04 - mse: 8.3282e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 56ms/epoch - 1ms/step\n",
      "Epoch 499/500\n",
      "54/54 - 0s - loss: 8.4222e-04 - mse: 8.4222e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 56ms/epoch - 1ms/step\n",
      "Epoch 500/500\n",
      "54/54 - 0s - loss: 9.0203e-04 - mse: 9.0203e-04 - val_loss: 0.0022 - val_mse: 0.0022 - 55ms/epoch - 1ms/step\n",
      "31.20127844810486\n"
     ]
    }
   ],
   "source": [
    "model = Sequential()\n",
    "model.add(SimpleRNN(16, activation='tanh', return_sequences=True))\n",
    "model.add(Dense(3, activation='linear'))\n",
    "model.compile(optimizer='adam', loss='mse', metrics=['mse'])\n",
    "\n",
    "t0 = time.time()\n",
    "history = model.fit(X_train, y_train, epochs=500, batch_size=256, validation_split=0.25, verbose=2)\n",
    "t1 = time.time()\n",
    "print(t1-t0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "81f35c9a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "24/24 [==============================] - 0s 618us/step - loss: 7.4508e-04 - mse: 7.4508e-04\n",
      "[0.0007450783741660416, 0.0007450784905813634]\n",
      "31.20127844810486\n"
     ]
    }
   ],
   "source": [
    "#use the SOURCE test data to evaluate the model\n",
    "loss_and_metrics = model.evaluate(X_test, y_test, batch_size=256)\n",
    "print(loss_and_metrics)\n",
    "\n",
    "print(t1-t0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "364b1d8c",
   "metadata": {},
   "outputs": [],
   "source": [
    "model.save(\"pretrained_model.h5\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "9a846ec6",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Save to file\n",
    "np.save('source_input_data.npy', X_train)\n",
    "np.save('source_output_data.npy', y_train)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "82dfe168",
   "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.8.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
