{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "539ebd7b",
   "metadata": {},
   "outputs": [],
   "source": [
    "###This code is about develop a FNN model forwater tan\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 Target dataset real value form as target one"
   ]
  },
  {
   "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 using scalers for each process, due to different features"
   ]
  },
  {
   "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-06-30 15:35:51.159831: 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-06-30 15:35:51.159883: 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-06-30 15:35:51.160625: 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.4794 - mse: 0.4794 - val_loss: 0.2751 - val_mse: 0.2751 - 604ms/epoch - 11ms/step\n",
      "Epoch 2/500\n",
      "54/54 - 0s - loss: 0.2028 - mse: 0.2028 - val_loss: 0.1718 - val_mse: 0.1718 - 62ms/epoch - 1ms/step\n",
      "Epoch 3/500\n",
      "54/54 - 0s - loss: 0.1479 - mse: 0.1479 - val_loss: 0.1370 - val_mse: 0.1370 - 61ms/epoch - 1ms/step\n",
      "Epoch 4/500\n",
      "54/54 - 0s - loss: 0.1205 - mse: 0.1205 - val_loss: 0.1131 - val_mse: 0.1131 - 60ms/epoch - 1ms/step\n",
      "Epoch 5/500\n",
      "54/54 - 0s - loss: 0.0994 - mse: 0.0994 - val_loss: 0.0928 - val_mse: 0.0928 - 59ms/epoch - 1ms/step\n",
      "Epoch 6/500\n",
      "54/54 - 0s - loss: 0.0803 - mse: 0.0803 - val_loss: 0.0743 - val_mse: 0.0743 - 63ms/epoch - 1ms/step\n",
      "Epoch 7/500\n",
      "54/54 - 0s - loss: 0.0631 - mse: 0.0631 - val_loss: 0.0579 - val_mse: 0.0579 - 60ms/epoch - 1ms/step\n",
      "Epoch 8/500\n",
      "54/54 - 0s - loss: 0.0495 - mse: 0.0495 - val_loss: 0.0462 - val_mse: 0.0462 - 64ms/epoch - 1ms/step\n",
      "Epoch 9/500\n",
      "54/54 - 0s - loss: 0.0395 - mse: 0.0395 - val_loss: 0.0377 - val_mse: 0.0377 - 62ms/epoch - 1ms/step\n",
      "Epoch 10/500\n",
      "54/54 - 0s - loss: 0.0322 - mse: 0.0322 - val_loss: 0.0307 - val_mse: 0.0307 - 61ms/epoch - 1ms/step\n",
      "Epoch 11/500\n",
      "54/54 - 0s - loss: 0.0263 - mse: 0.0263 - val_loss: 0.0255 - val_mse: 0.0255 - 57ms/epoch - 1ms/step\n",
      "Epoch 12/500\n",
      "54/54 - 0s - loss: 0.0219 - mse: 0.0219 - val_loss: 0.0217 - val_mse: 0.0217 - 63ms/epoch - 1ms/step\n",
      "Epoch 13/500\n",
      "54/54 - 0s - loss: 0.0187 - mse: 0.0187 - val_loss: 0.0190 - val_mse: 0.0190 - 62ms/epoch - 1ms/step\n",
      "Epoch 14/500\n",
      "54/54 - 0s - loss: 0.0164 - mse: 0.0164 - val_loss: 0.0168 - val_mse: 0.0168 - 63ms/epoch - 1ms/step\n",
      "Epoch 15/500\n",
      "54/54 - 0s - loss: 0.0146 - mse: 0.0146 - val_loss: 0.0153 - val_mse: 0.0153 - 59ms/epoch - 1ms/step\n",
      "Epoch 16/500\n",
      "54/54 - 0s - loss: 0.0133 - mse: 0.0133 - val_loss: 0.0140 - val_mse: 0.0140 - 62ms/epoch - 1ms/step\n",
      "Epoch 17/500\n",
      "54/54 - 0s - loss: 0.0122 - mse: 0.0122 - val_loss: 0.0130 - val_mse: 0.0130 - 62ms/epoch - 1ms/step\n",
      "Epoch 18/500\n",
      "54/54 - 0s - loss: 0.0113 - mse: 0.0113 - val_loss: 0.0122 - val_mse: 0.0122 - 59ms/epoch - 1ms/step\n",
      "Epoch 19/500\n",
      "54/54 - 0s - loss: 0.0105 - mse: 0.0105 - val_loss: 0.0118 - val_mse: 0.0118 - 63ms/epoch - 1ms/step\n",
      "Epoch 20/500\n",
      "54/54 - 0s - loss: 0.0100 - mse: 0.0100 - val_loss: 0.0113 - val_mse: 0.0113 - 63ms/epoch - 1ms/step\n",
      "Epoch 21/500\n",
      "54/54 - 0s - loss: 0.0095 - mse: 0.0095 - val_loss: 0.0104 - val_mse: 0.0104 - 62ms/epoch - 1ms/step\n",
      "Epoch 22/500\n",
      "54/54 - 0s - loss: 0.0089 - mse: 0.0089 - val_loss: 0.0100 - val_mse: 0.0100 - 58ms/epoch - 1ms/step\n",
      "Epoch 23/500\n",
      "54/54 - 0s - loss: 0.0085 - mse: 0.0085 - val_loss: 0.0095 - val_mse: 0.0095 - 64ms/epoch - 1ms/step\n",
      "Epoch 24/500\n",
      "54/54 - 0s - loss: 0.0081 - mse: 0.0081 - val_loss: 0.0092 - val_mse: 0.0092 - 61ms/epoch - 1ms/step\n",
      "Epoch 25/500\n",
      "54/54 - 0s - loss: 0.0077 - mse: 0.0077 - val_loss: 0.0088 - val_mse: 0.0088 - 63ms/epoch - 1ms/step\n",
      "Epoch 26/500\n",
      "54/54 - 0s - loss: 0.0075 - mse: 0.0075 - val_loss: 0.0085 - val_mse: 0.0085 - 62ms/epoch - 1ms/step\n",
      "Epoch 27/500\n",
      "54/54 - 0s - loss: 0.0072 - mse: 0.0072 - val_loss: 0.0083 - val_mse: 0.0083 - 62ms/epoch - 1ms/step\n",
      "Epoch 28/500\n",
      "54/54 - 0s - loss: 0.0069 - mse: 0.0069 - val_loss: 0.0079 - val_mse: 0.0079 - 62ms/epoch - 1ms/step\n",
      "Epoch 29/500\n",
      "54/54 - 0s - loss: 0.0066 - mse: 0.0066 - val_loss: 0.0077 - val_mse: 0.0077 - 61ms/epoch - 1ms/step\n",
      "Epoch 30/500\n",
      "54/54 - 0s - loss: 0.0064 - mse: 0.0064 - val_loss: 0.0075 - val_mse: 0.0075 - 58ms/epoch - 1ms/step\n",
      "Epoch 31/500\n",
      "54/54 - 0s - loss: 0.0062 - mse: 0.0062 - val_loss: 0.0073 - val_mse: 0.0073 - 63ms/epoch - 1ms/step\n",
      "Epoch 32/500\n",
      "54/54 - 0s - loss: 0.0060 - mse: 0.0060 - val_loss: 0.0072 - val_mse: 0.0072 - 63ms/epoch - 1ms/step\n",
      "Epoch 33/500\n",
      "54/54 - 0s - loss: 0.0057 - mse: 0.0057 - val_loss: 0.0068 - val_mse: 0.0068 - 62ms/epoch - 1ms/step\n",
      "Epoch 34/500\n",
      "54/54 - 0s - loss: 0.0056 - mse: 0.0056 - val_loss: 0.0067 - val_mse: 0.0067 - 57ms/epoch - 1ms/step\n",
      "Epoch 35/500\n",
      "54/54 - 0s - loss: 0.0054 - mse: 0.0054 - val_loss: 0.0065 - val_mse: 0.0065 - 65ms/epoch - 1ms/step\n",
      "Epoch 36/500\n",
      "54/54 - 0s - loss: 0.0052 - mse: 0.0052 - val_loss: 0.0064 - val_mse: 0.0064 - 64ms/epoch - 1ms/step\n",
      "Epoch 37/500\n",
      "54/54 - 0s - loss: 0.0051 - mse: 0.0051 - val_loss: 0.0061 - val_mse: 0.0061 - 62ms/epoch - 1ms/step\n",
      "Epoch 38/500\n",
      "54/54 - 0s - loss: 0.0049 - mse: 0.0049 - val_loss: 0.0059 - val_mse: 0.0059 - 58ms/epoch - 1ms/step\n",
      "Epoch 39/500\n",
      "54/54 - 0s - loss: 0.0047 - mse: 0.0047 - val_loss: 0.0059 - val_mse: 0.0059 - 62ms/epoch - 1ms/step\n",
      "Epoch 40/500\n",
      "54/54 - 0s - loss: 0.0046 - mse: 0.0046 - val_loss: 0.0057 - val_mse: 0.0057 - 62ms/epoch - 1ms/step\n",
      "Epoch 41/500\n",
      "54/54 - 0s - loss: 0.0044 - mse: 0.0044 - val_loss: 0.0056 - val_mse: 0.0056 - 58ms/epoch - 1ms/step\n",
      "Epoch 42/500\n",
      "54/54 - 0s - loss: 0.0043 - mse: 0.0043 - val_loss: 0.0053 - val_mse: 0.0053 - 64ms/epoch - 1ms/step\n",
      "Epoch 43/500\n",
      "54/54 - 0s - loss: 0.0042 - mse: 0.0042 - val_loss: 0.0052 - val_mse: 0.0052 - 63ms/epoch - 1ms/step\n",
      "Epoch 44/500\n",
      "54/54 - 0s - loss: 0.0041 - mse: 0.0041 - val_loss: 0.0052 - val_mse: 0.0052 - 63ms/epoch - 1ms/step\n",
      "Epoch 45/500\n",
      "54/54 - 0s - loss: 0.0040 - mse: 0.0040 - val_loss: 0.0051 - val_mse: 0.0051 - 62ms/epoch - 1ms/step\n",
      "Epoch 46/500\n",
      "54/54 - 0s - loss: 0.0039 - mse: 0.0039 - val_loss: 0.0054 - val_mse: 0.0054 - 59ms/epoch - 1ms/step\n",
      "Epoch 47/500\n",
      "54/54 - 0s - loss: 0.0039 - mse: 0.0039 - val_loss: 0.0049 - val_mse: 0.0049 - 65ms/epoch - 1ms/step\n",
      "Epoch 48/500\n",
      "54/54 - 0s - loss: 0.0037 - mse: 0.0037 - val_loss: 0.0048 - val_mse: 0.0048 - 63ms/epoch - 1ms/step\n",
      "Epoch 49/500\n",
      "54/54 - 0s - loss: 0.0036 - mse: 0.0036 - val_loss: 0.0047 - val_mse: 0.0047 - 62ms/epoch - 1ms/step\n",
      "Epoch 50/500\n",
      "54/54 - 0s - loss: 0.0036 - mse: 0.0036 - val_loss: 0.0050 - val_mse: 0.0050 - 58ms/epoch - 1ms/step\n",
      "Epoch 51/500\n",
      "54/54 - 0s - loss: 0.0036 - mse: 0.0036 - val_loss: 0.0045 - val_mse: 0.0045 - 58ms/epoch - 1ms/step\n",
      "Epoch 52/500\n",
      "54/54 - 0s - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0045 - val_mse: 0.0045 - 68ms/epoch - 1ms/step\n",
      "Epoch 53/500\n",
      "54/54 - 0s - loss: 0.0033 - mse: 0.0033 - val_loss: 0.0044 - val_mse: 0.0044 - 78ms/epoch - 1ms/step\n",
      "Epoch 54/500\n",
      "54/54 - 0s - loss: 0.0033 - mse: 0.0033 - val_loss: 0.0044 - val_mse: 0.0044 - 80ms/epoch - 1ms/step\n",
      "Epoch 55/500\n",
      "54/54 - 0s - loss: 0.0032 - mse: 0.0032 - val_loss: 0.0043 - val_mse: 0.0043 - 61ms/epoch - 1ms/step\n",
      "Epoch 56/500\n",
      "54/54 - 0s - loss: 0.0031 - mse: 0.0031 - val_loss: 0.0043 - val_mse: 0.0043 - 63ms/epoch - 1ms/step\n",
      "Epoch 57/500\n",
      "54/54 - 0s - loss: 0.0031 - mse: 0.0031 - val_loss: 0.0042 - val_mse: 0.0042 - 58ms/epoch - 1ms/step\n",
      "Epoch 58/500\n",
      "54/54 - 0s - loss: 0.0030 - mse: 0.0030 - val_loss: 0.0042 - val_mse: 0.0042 - 57ms/epoch - 1ms/step\n",
      "Epoch 59/500\n",
      "54/54 - 0s - loss: 0.0030 - mse: 0.0030 - val_loss: 0.0041 - val_mse: 0.0041 - 60ms/epoch - 1ms/step\n",
      "Epoch 60/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 61/500\n",
      "54/54 - 0s - loss: 0.0029 - mse: 0.0029 - val_loss: 0.0040 - val_mse: 0.0040 - 68ms/epoch - 1ms/step\n",
      "Epoch 62/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 63/500\n",
      "54/54 - 0s - loss: 0.0028 - mse: 0.0028 - val_loss: 0.0040 - val_mse: 0.0040 - 63ms/epoch - 1ms/step\n",
      "Epoch 64/500\n",
      "54/54 - 0s - loss: 0.0028 - mse: 0.0028 - val_loss: 0.0040 - val_mse: 0.0040 - 65ms/epoch - 1ms/step\n",
      "Epoch 65/500\n",
      "54/54 - 0s - loss: 0.0027 - mse: 0.0027 - val_loss: 0.0038 - val_mse: 0.0038 - 64ms/epoch - 1ms/step\n",
      "Epoch 66/500\n",
      "54/54 - 0s - loss: 0.0027 - mse: 0.0027 - val_loss: 0.0038 - val_mse: 0.0038 - 58ms/epoch - 1ms/step\n",
      "Epoch 67/500\n",
      "54/54 - 0s - loss: 0.0027 - mse: 0.0027 - val_loss: 0.0038 - val_mse: 0.0038 - 57ms/epoch - 1ms/step\n",
      "Epoch 68/500\n",
      "54/54 - 0s - loss: 0.0026 - mse: 0.0026 - val_loss: 0.0039 - val_mse: 0.0039 - 63ms/epoch - 1ms/step\n",
      "Epoch 69/500\n",
      "54/54 - 0s - loss: 0.0026 - mse: 0.0026 - val_loss: 0.0037 - val_mse: 0.0037 - 64ms/epoch - 1ms/step\n",
      "Epoch 70/500\n",
      "54/54 - 0s - loss: 0.0025 - mse: 0.0025 - val_loss: 0.0036 - val_mse: 0.0036 - 58ms/epoch - 1ms/step\n",
      "Epoch 71/500\n",
      "54/54 - 0s - loss: 0.0025 - mse: 0.0025 - val_loss: 0.0036 - val_mse: 0.0036 - 61ms/epoch - 1ms/step\n",
      "Epoch 72/500\n",
      "54/54 - 0s - loss: 0.0024 - mse: 0.0024 - val_loss: 0.0036 - val_mse: 0.0036 - 64ms/epoch - 1ms/step\n",
      "Epoch 73/500\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "54/54 - 0s - loss: 0.0024 - mse: 0.0024 - val_loss: 0.0036 - val_mse: 0.0036 - 61ms/epoch - 1ms/step\n",
      "Epoch 74/500\n",
      "54/54 - 0s - loss: 0.0024 - mse: 0.0024 - val_loss: 0.0035 - val_mse: 0.0035 - 63ms/epoch - 1ms/step\n",
      "Epoch 75/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 76/500\n",
      "54/54 - 0s - loss: 0.0023 - mse: 0.0023 - val_loss: 0.0035 - val_mse: 0.0035 - 65ms/epoch - 1ms/step\n",
      "Epoch 77/500\n",
      "54/54 - 0s - loss: 0.0023 - mse: 0.0023 - val_loss: 0.0034 - val_mse: 0.0034 - 59ms/epoch - 1ms/step\n",
      "Epoch 78/500\n",
      "54/54 - 0s - loss: 0.0023 - mse: 0.0023 - val_loss: 0.0034 - val_mse: 0.0034 - 61ms/epoch - 1ms/step\n",
      "Epoch 79/500\n",
      "54/54 - 0s - loss: 0.0022 - mse: 0.0022 - val_loss: 0.0034 - val_mse: 0.0034 - 60ms/epoch - 1ms/step\n",
      "Epoch 80/500\n",
      "54/54 - 0s - loss: 0.0022 - mse: 0.0022 - val_loss: 0.0034 - val_mse: 0.0034 - 61ms/epoch - 1ms/step\n",
      "Epoch 81/500\n",
      "54/54 - 0s - loss: 0.0022 - mse: 0.0022 - val_loss: 0.0033 - val_mse: 0.0033 - 64ms/epoch - 1ms/step\n",
      "Epoch 82/500\n",
      "54/54 - 0s - loss: 0.0022 - mse: 0.0022 - val_loss: 0.0033 - val_mse: 0.0033 - 58ms/epoch - 1ms/step\n",
      "Epoch 83/500\n",
      "54/54 - 0s - loss: 0.0022 - mse: 0.0022 - val_loss: 0.0034 - val_mse: 0.0034 - 68ms/epoch - 1ms/step\n",
      "Epoch 84/500\n",
      "54/54 - 0s - loss: 0.0021 - mse: 0.0021 - val_loss: 0.0033 - val_mse: 0.0033 - 72ms/epoch - 1ms/step\n",
      "Epoch 85/500\n",
      "54/54 - 0s - loss: 0.0021 - mse: 0.0021 - val_loss: 0.0032 - val_mse: 0.0032 - 77ms/epoch - 1ms/step\n",
      "Epoch 86/500\n",
      "54/54 - 0s - loss: 0.0021 - mse: 0.0021 - val_loss: 0.0033 - val_mse: 0.0033 - 66ms/epoch - 1ms/step\n",
      "Epoch 87/500\n",
      "54/54 - 0s - loss: 0.0021 - mse: 0.0021 - val_loss: 0.0032 - val_mse: 0.0032 - 69ms/epoch - 1ms/step\n",
      "Epoch 88/500\n",
      "54/54 - 0s - loss: 0.0020 - mse: 0.0020 - val_loss: 0.0035 - val_mse: 0.0035 - 66ms/epoch - 1ms/step\n",
      "Epoch 89/500\n",
      "54/54 - 0s - loss: 0.0021 - mse: 0.0021 - val_loss: 0.0031 - val_mse: 0.0031 - 66ms/epoch - 1ms/step\n",
      "Epoch 90/500\n",
      "54/54 - 0s - loss: 0.0020 - mse: 0.0020 - val_loss: 0.0031 - val_mse: 0.0031 - 66ms/epoch - 1ms/step\n",
      "Epoch 91/500\n",
      "54/54 - 0s - loss: 0.0020 - mse: 0.0020 - val_loss: 0.0031 - val_mse: 0.0031 - 68ms/epoch - 1ms/step\n",
      "Epoch 92/500\n",
      "54/54 - 0s - loss: 0.0020 - mse: 0.0020 - val_loss: 0.0032 - val_mse: 0.0032 - 68ms/epoch - 1ms/step\n",
      "Epoch 93/500\n",
      "54/54 - 0s - loss: 0.0020 - mse: 0.0020 - val_loss: 0.0031 - val_mse: 0.0031 - 67ms/epoch - 1ms/step\n",
      "Epoch 94/500\n",
      "54/54 - 0s - loss: 0.0019 - mse: 0.0019 - val_loss: 0.0032 - val_mse: 0.0032 - 64ms/epoch - 1ms/step\n",
      "Epoch 95/500\n",
      "54/54 - 0s - loss: 0.0019 - mse: 0.0019 - val_loss: 0.0030 - val_mse: 0.0030 - 63ms/epoch - 1ms/step\n",
      "Epoch 96/500\n",
      "54/54 - 0s - loss: 0.0019 - mse: 0.0019 - val_loss: 0.0030 - val_mse: 0.0030 - 68ms/epoch - 1ms/step\n",
      "Epoch 97/500\n",
      "54/54 - 0s - loss: 0.0019 - mse: 0.0019 - val_loss: 0.0030 - val_mse: 0.0030 - 65ms/epoch - 1ms/step\n",
      "Epoch 98/500\n",
      "54/54 - 0s - loss: 0.0019 - mse: 0.0019 - val_loss: 0.0030 - val_mse: 0.0030 - 66ms/epoch - 1ms/step\n",
      "Epoch 99/500\n",
      "54/54 - 0s - loss: 0.0018 - mse: 0.0018 - val_loss: 0.0030 - val_mse: 0.0030 - 69ms/epoch - 1ms/step\n",
      "Epoch 100/500\n",
      "54/54 - 0s - loss: 0.0018 - mse: 0.0018 - val_loss: 0.0030 - val_mse: 0.0030 - 66ms/epoch - 1ms/step\n",
      "Epoch 101/500\n",
      "54/54 - 0s - loss: 0.0018 - mse: 0.0018 - val_loss: 0.0031 - val_mse: 0.0031 - 73ms/epoch - 1ms/step\n",
      "Epoch 102/500\n",
      "54/54 - 0s - loss: 0.0018 - mse: 0.0018 - val_loss: 0.0030 - val_mse: 0.0030 - 67ms/epoch - 1ms/step\n",
      "Epoch 103/500\n",
      "54/54 - 0s - loss: 0.0018 - mse: 0.0018 - val_loss: 0.0030 - val_mse: 0.0030 - 66ms/epoch - 1ms/step\n",
      "Epoch 104/500\n",
      "54/54 - 0s - loss: 0.0018 - mse: 0.0018 - val_loss: 0.0029 - val_mse: 0.0029 - 66ms/epoch - 1ms/step\n",
      "Epoch 105/500\n",
      "54/54 - 0s - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0030 - val_mse: 0.0030 - 66ms/epoch - 1ms/step\n",
      "Epoch 106/500\n",
      "54/54 - 0s - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0029 - val_mse: 0.0029 - 67ms/epoch - 1ms/step\n",
      "Epoch 107/500\n",
      "54/54 - 0s - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0029 - val_mse: 0.0029 - 69ms/epoch - 1ms/step\n",
      "Epoch 108/500\n",
      "54/54 - 0s - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0028 - val_mse: 0.0028 - 62ms/epoch - 1ms/step\n",
      "Epoch 109/500\n",
      "54/54 - 0s - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0029 - val_mse: 0.0029 - 60ms/epoch - 1ms/step\n",
      "Epoch 110/500\n",
      "54/54 - 0s - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0029 - val_mse: 0.0029 - 61ms/epoch - 1ms/step\n",
      "Epoch 111/500\n",
      "54/54 - 0s - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0028 - val_mse: 0.0028 - 61ms/epoch - 1ms/step\n",
      "Epoch 112/500\n",
      "54/54 - 0s - loss: 0.0016 - mse: 0.0016 - val_loss: 0.0028 - val_mse: 0.0028 - 62ms/epoch - 1ms/step\n",
      "Epoch 113/500\n",
      "54/54 - 0s - loss: 0.0016 - mse: 0.0016 - val_loss: 0.0028 - val_mse: 0.0028 - 60ms/epoch - 1ms/step\n",
      "Epoch 114/500\n",
      "54/54 - 0s - loss: 0.0016 - mse: 0.0016 - val_loss: 0.0028 - val_mse: 0.0028 - 60ms/epoch - 1ms/step\n",
      "Epoch 115/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 116/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 117/500\n",
      "54/54 - 0s - loss: 0.0016 - mse: 0.0016 - val_loss: 0.0030 - val_mse: 0.0030 - 67ms/epoch - 1ms/step\n",
      "Epoch 118/500\n",
      "54/54 - 0s - loss: 0.0016 - mse: 0.0016 - val_loss: 0.0028 - val_mse: 0.0028 - 65ms/epoch - 1ms/step\n",
      "Epoch 119/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 120/500\n",
      "54/54 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0027 - val_mse: 0.0027 - 62ms/epoch - 1ms/step\n",
      "Epoch 121/500\n",
      "54/54 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0027 - val_mse: 0.0027 - 62ms/epoch - 1ms/step\n",
      "Epoch 122/500\n",
      "54/54 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0027 - val_mse: 0.0027 - 60ms/epoch - 1ms/step\n",
      "Epoch 123/500\n",
      "54/54 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0027 - val_mse: 0.0027 - 63ms/epoch - 1ms/step\n",
      "Epoch 124/500\n",
      "54/54 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0027 - val_mse: 0.0027 - 59ms/epoch - 1ms/step\n",
      "Epoch 125/500\n",
      "54/54 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0027 - val_mse: 0.0027 - 63ms/epoch - 1ms/step\n",
      "Epoch 126/500\n",
      "54/54 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0027 - val_mse: 0.0027 - 69ms/epoch - 1ms/step\n",
      "Epoch 127/500\n",
      "54/54 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0029 - val_mse: 0.0029 - 69ms/epoch - 1ms/step\n",
      "Epoch 128/500\n",
      "54/54 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0026 - val_mse: 0.0026 - 64ms/epoch - 1ms/step\n",
      "Epoch 129/500\n",
      "54/54 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0027 - val_mse: 0.0027 - 70ms/epoch - 1ms/step\n",
      "Epoch 130/500\n",
      "54/54 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0026 - val_mse: 0.0026 - 68ms/epoch - 1ms/step\n",
      "Epoch 131/500\n",
      "54/54 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0026 - val_mse: 0.0026 - 64ms/epoch - 1ms/step\n",
      "Epoch 132/500\n",
      "54/54 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0026 - val_mse: 0.0026 - 76ms/epoch - 1ms/step\n",
      "Epoch 133/500\n",
      "54/54 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0029 - val_mse: 0.0029 - 66ms/epoch - 1ms/step\n",
      "Epoch 134/500\n",
      "54/54 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0026 - val_mse: 0.0026 - 67ms/epoch - 1ms/step\n",
      "Epoch 135/500\n",
      "54/54 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0026 - val_mse: 0.0026 - 70ms/epoch - 1ms/step\n",
      "Epoch 136/500\n",
      "54/54 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0026 - val_mse: 0.0026 - 67ms/epoch - 1ms/step\n",
      "Epoch 137/500\n",
      "54/54 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0025 - val_mse: 0.0025 - 59ms/epoch - 1ms/step\n",
      "Epoch 138/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 139/500\n",
      "54/54 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0030 - val_mse: 0.0030 - 64ms/epoch - 1ms/step\n",
      "Epoch 140/500\n",
      "54/54 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0026 - val_mse: 0.0026 - 62ms/epoch - 1ms/step\n",
      "Epoch 141/500\n",
      "54/54 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0026 - val_mse: 0.0026 - 57ms/epoch - 1ms/step\n",
      "Epoch 142/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 143/500\n",
      "54/54 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0026 - val_mse: 0.0026 - 65ms/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 - 62ms/epoch - 1ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 145/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 146/500\n",
      "54/54 - 0s - loss: 0.0013 - mse: 0.0013 - val_loss: 0.0026 - val_mse: 0.0026 - 58ms/epoch - 1ms/step\n",
      "Epoch 147/500\n",
      "54/54 - 0s - loss: 0.0013 - mse: 0.0013 - val_loss: 0.0025 - val_mse: 0.0025 - 64ms/epoch - 1ms/step\n",
      "Epoch 148/500\n",
      "54/54 - 0s - loss: 0.0013 - mse: 0.0013 - val_loss: 0.0025 - val_mse: 0.0025 - 65ms/epoch - 1ms/step\n",
      "Epoch 149/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 150/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 151/500\n",
      "54/54 - 0s - loss: 0.0013 - mse: 0.0013 - val_loss: 0.0026 - val_mse: 0.0026 - 59ms/epoch - 1ms/step\n",
      "Epoch 152/500\n",
      "54/54 - 0s - loss: 0.0013 - mse: 0.0013 - val_loss: 0.0024 - val_mse: 0.0024 - 66ms/epoch - 1ms/step\n",
      "Epoch 153/500\n",
      "54/54 - 0s - loss: 0.0013 - mse: 0.0013 - val_loss: 0.0027 - val_mse: 0.0027 - 64ms/epoch - 1ms/step\n",
      "Epoch 154/500\n",
      "54/54 - 0s - loss: 0.0013 - mse: 0.0013 - val_loss: 0.0024 - val_mse: 0.0024 - 64ms/epoch - 1ms/step\n",
      "Epoch 155/500\n",
      "54/54 - 0s - loss: 0.0013 - mse: 0.0013 - val_loss: 0.0025 - val_mse: 0.0025 - 64ms/epoch - 1ms/step\n",
      "Epoch 156/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 157/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 158/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 159/500\n",
      "54/54 - 0s - loss: 0.0013 - mse: 0.0013 - val_loss: 0.0024 - val_mse: 0.0024 - 64ms/epoch - 1ms/step\n",
      "Epoch 160/500\n",
      "54/54 - 0s - loss: 0.0013 - mse: 0.0013 - val_loss: 0.0024 - val_mse: 0.0024 - 64ms/epoch - 1ms/step\n",
      "Epoch 161/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 162/500\n",
      "54/54 - 0s - loss: 0.0013 - mse: 0.0013 - val_loss: 0.0024 - val_mse: 0.0024 - 58ms/epoch - 1ms/step\n",
      "Epoch 163/500\n",
      "54/54 - 0s - loss: 0.0013 - mse: 0.0013 - val_loss: 0.0024 - val_mse: 0.0024 - 65ms/epoch - 1ms/step\n",
      "Epoch 164/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 165/500\n",
      "54/54 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0025 - val_mse: 0.0025 - 57ms/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 - 65ms/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 - 66ms/epoch - 1ms/step\n",
      "Epoch 168/500\n",
      "54/54 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0024 - val_mse: 0.0024 - 65ms/epoch - 1ms/step\n",
      "Epoch 169/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 170/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 171/500\n",
      "54/54 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0024 - val_mse: 0.0024 - 58ms/epoch - 1ms/step\n",
      "Epoch 172/500\n",
      "54/54 - 0s - loss: 0.0013 - mse: 0.0013 - val_loss: 0.0023 - val_mse: 0.0023 - 64ms/epoch - 1ms/step\n",
      "Epoch 173/500\n",
      "54/54 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0024 - val_mse: 0.0024 - 66ms/epoch - 1ms/step\n",
      "Epoch 174/500\n",
      "54/54 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0024 - val_mse: 0.0024 - 66ms/epoch - 1ms/step\n",
      "Epoch 175/500\n",
      "54/54 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0025 - val_mse: 0.0025 - 59ms/epoch - 1ms/step\n",
      "Epoch 176/500\n",
      "54/54 - 0s - loss: 0.0013 - mse: 0.0013 - val_loss: 0.0023 - val_mse: 0.0023 - 59ms/epoch - 1ms/step\n",
      "Epoch 177/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 178/500\n",
      "54/54 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0024 - val_mse: 0.0024 - 65ms/epoch - 1ms/step\n",
      "Epoch 179/500\n",
      "54/54 - 0s - loss: 0.0013 - mse: 0.0013 - val_loss: 0.0025 - val_mse: 0.0025 - 65ms/epoch - 1ms/step\n",
      "Epoch 180/500\n",
      "54/54 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0023 - val_mse: 0.0023 - 63ms/epoch - 1ms/step\n",
      "Epoch 181/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 182/500\n",
      "54/54 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0024 - val_mse: 0.0024 - 59ms/epoch - 1ms/step\n",
      "Epoch 183/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 184/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 185/500\n",
      "54/54 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0024 - val_mse: 0.0024 - 65ms/epoch - 1ms/step\n",
      "Epoch 186/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 187/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 188/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 189/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 190/500\n",
      "54/54 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0024 - val_mse: 0.0024 - 65ms/epoch - 1ms/step\n",
      "Epoch 191/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0022 - val_mse: 0.0022 - 63ms/epoch - 1ms/step\n",
      "Epoch 192/500\n",
      "54/54 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0022 - val_mse: 0.0022 - 63ms/epoch - 1ms/step\n",
      "Epoch 193/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 194/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0024 - val_mse: 0.0024 - 58ms/epoch - 1ms/step\n",
      "Epoch 195/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 196/500\n",
      "54/54 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0023 - val_mse: 0.0023 - 66ms/epoch - 1ms/step\n",
      "Epoch 197/500\n",
      "54/54 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0023 - val_mse: 0.0023 - 66ms/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 - 64ms/epoch - 1ms/step\n",
      "Epoch 199/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0022 - val_mse: 0.0022 - 65ms/epoch - 1ms/step\n",
      "Epoch 200/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 201/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 202/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 203/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 204/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 205/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 206/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0022 - val_mse: 0.0022 - 69ms/epoch - 1ms/step\n",
      "Epoch 207/500\n",
      "54/54 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0023 - val_mse: 0.0023 - 62ms/epoch - 1ms/step\n",
      "Epoch 208/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 209/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0023 - val_mse: 0.0023 - 62ms/epoch - 1ms/step\n",
      "Epoch 210/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 211/500\n",
      "54/54 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0022 - val_mse: 0.0022 - 65ms/epoch - 1ms/step\n",
      "Epoch 212/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0023 - val_mse: 0.0023 - 58ms/epoch - 1ms/step\n",
      "Epoch 213/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0021 - val_mse: 0.0021 - 67ms/epoch - 1ms/step\n",
      "Epoch 214/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 215/500\n",
      "54/54 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0021 - val_mse: 0.0021 - 64ms/epoch - 1ms/step\n",
      "Epoch 216/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0021 - val_mse: 0.0021 - 66ms/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.0022 - val_mse: 0.0022 - 64ms/epoch - 1ms/step\n",
      "Epoch 218/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0021 - val_mse: 0.0021 - 62ms/epoch - 1ms/step\n",
      "Epoch 219/500\n",
      "54/54 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0022 - val_mse: 0.0022 - 62ms/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 - 59ms/epoch - 1ms/step\n",
      "Epoch 221/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0021 - val_mse: 0.0021 - 66ms/epoch - 1ms/step\n",
      "Epoch 222/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0021 - val_mse: 0.0021 - 64ms/epoch - 1ms/step\n",
      "Epoch 223/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 224/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0022 - val_mse: 0.0022 - 63ms/epoch - 1ms/step\n",
      "Epoch 225/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0021 - val_mse: 0.0021 - 63ms/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 - 61ms/epoch - 1ms/step\n",
      "Epoch 227/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0022 - val_mse: 0.0022 - 63ms/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 - 64ms/epoch - 1ms/step\n",
      "Epoch 229/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 230/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 231/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 232/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0023 - val_mse: 0.0023 - 61ms/epoch - 1ms/step\n",
      "Epoch 233/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0031 - val_mse: 0.0031 - 63ms/epoch - 1ms/step\n",
      "Epoch 234/500\n",
      "54/54 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0023 - val_mse: 0.0023 - 63ms/epoch - 1ms/step\n",
      "Epoch 235/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0021 - val_mse: 0.0021 - 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 - 65ms/epoch - 1ms/step\n",
      "Epoch 237/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0021 - val_mse: 0.0021 - 63ms/epoch - 1ms/step\n",
      "Epoch 238/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 239/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0022 - val_mse: 0.0022 - 59ms/epoch - 1ms/step\n",
      "Epoch 240/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0021 - val_mse: 0.0021 - 65ms/epoch - 1ms/step\n",
      "Epoch 241/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0021 - val_mse: 0.0021 - 64ms/epoch - 1ms/step\n",
      "Epoch 242/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0021 - val_mse: 0.0021 - 64ms/epoch - 1ms/step\n",
      "Epoch 243/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0021 - val_mse: 0.0021 - 65ms/epoch - 1ms/step\n",
      "Epoch 244/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0020 - val_mse: 0.0020 - 65ms/epoch - 1ms/step\n",
      "Epoch 245/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0024 - val_mse: 0.0024 - 64ms/epoch - 1ms/step\n",
      "Epoch 246/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 247/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 248/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0021 - val_mse: 0.0021 - 63ms/epoch - 1ms/step\n",
      "Epoch 249/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 250/500\n",
      "54/54 - 0s - loss: 9.9940e-04 - mse: 9.9940e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 64ms/epoch - 1ms/step\n",
      "Epoch 251/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0021 - val_mse: 0.0021 - 67ms/epoch - 1ms/step\n",
      "Epoch 252/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0023 - val_mse: 0.0023 - 69ms/epoch - 1ms/step\n",
      "Epoch 253/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0020 - val_mse: 0.0020 - 63ms/epoch - 1ms/step\n",
      "Epoch 254/500\n",
      "54/54 - 0s - loss: 9.7373e-04 - mse: 9.7373e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 64ms/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 - 60ms/epoch - 1ms/step\n",
      "Epoch 256/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0020 - val_mse: 0.0020 - 64ms/epoch - 1ms/step\n",
      "Epoch 257/500\n",
      "54/54 - 0s - loss: 9.8444e-04 - mse: 9.8444e-04 - val_loss: 0.0022 - val_mse: 0.0022 - 63ms/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 - 65ms/epoch - 1ms/step\n",
      "Epoch 259/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0020 - val_mse: 0.0020 - 67ms/epoch - 1ms/step\n",
      "Epoch 260/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0021 - val_mse: 0.0021 - 66ms/epoch - 1ms/step\n",
      "Epoch 261/500\n",
      "54/54 - 0s - loss: 9.8942e-04 - mse: 9.8942e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 65ms/epoch - 1ms/step\n",
      "Epoch 262/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0020 - val_mse: 0.0020 - 65ms/epoch - 1ms/step\n",
      "Epoch 263/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0022 - val_mse: 0.0022 - 66ms/epoch - 1ms/step\n",
      "Epoch 264/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0021 - val_mse: 0.0021 - 64ms/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 - 65ms/epoch - 1ms/step\n",
      "Epoch 266/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0021 - val_mse: 0.0021 - 64ms/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 - 64ms/epoch - 1ms/step\n",
      "Epoch 268/500\n",
      "54/54 - 0s - loss: 9.9403e-04 - mse: 9.9403e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 59ms/epoch - 1ms/step\n",
      "Epoch 269/500\n",
      "54/54 - 0s - loss: 9.6460e-04 - mse: 9.6460e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 64ms/epoch - 1ms/step\n",
      "Epoch 270/500\n",
      "54/54 - 0s - loss: 9.9502e-04 - mse: 9.9502e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 67ms/epoch - 1ms/step\n",
      "Epoch 271/500\n",
      "54/54 - 0s - loss: 9.7699e-04 - mse: 9.7699e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 65ms/epoch - 1ms/step\n",
      "Epoch 272/500\n",
      "54/54 - 0s - loss: 9.6969e-04 - mse: 9.6969e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 65ms/epoch - 1ms/step\n",
      "Epoch 273/500\n",
      "54/54 - 0s - loss: 9.8930e-04 - mse: 9.8930e-04 - val_loss: 0.0022 - val_mse: 0.0022 - 65ms/epoch - 1ms/step\n",
      "Epoch 274/500\n",
      "54/54 - 0s - loss: 9.6841e-04 - mse: 9.6841e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 66ms/epoch - 1ms/step\n",
      "Epoch 275/500\n",
      "54/54 - 0s - loss: 9.7366e-04 - mse: 9.7366e-04 - val_loss: 0.0022 - val_mse: 0.0022 - 65ms/epoch - 1ms/step\n",
      "Epoch 276/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0024 - val_mse: 0.0024 - 64ms/epoch - 1ms/step\n",
      "Epoch 277/500\n",
      "54/54 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0020 - val_mse: 0.0020 - 66ms/epoch - 1ms/step\n",
      "Epoch 278/500\n",
      "54/54 - 0s - loss: 9.9016e-04 - mse: 9.9016e-04 - val_loss: 0.0022 - val_mse: 0.0022 - 65ms/epoch - 1ms/step\n",
      "Epoch 279/500\n",
      "54/54 - 0s - loss: 9.9617e-04 - mse: 9.9617e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 66ms/epoch - 1ms/step\n",
      "Epoch 280/500\n",
      "54/54 - 0s - loss: 9.8837e-04 - mse: 9.8837e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 66ms/epoch - 1ms/step\n",
      "Epoch 281/500\n",
      "54/54 - 0s - loss: 9.3146e-04 - mse: 9.3146e-04 - val_loss: 0.0022 - val_mse: 0.0022 - 63ms/epoch - 1ms/step\n",
      "Epoch 282/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0020 - val_mse: 0.0020 - 59ms/epoch - 1ms/step\n",
      "Epoch 283/500\n",
      "54/54 - 0s - loss: 9.6635e-04 - mse: 9.6635e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 64ms/epoch - 1ms/step\n",
      "Epoch 284/500\n",
      "54/54 - 0s - loss: 9.4754e-04 - mse: 9.4754e-04 - val_loss: 0.0024 - val_mse: 0.0024 - 65ms/epoch - 1ms/step\n",
      "Epoch 285/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0021 - val_mse: 0.0021 - 66ms/epoch - 1ms/step\n",
      "Epoch 286/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0020 - val_mse: 0.0020 - 66ms/epoch - 1ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 287/500\n",
      "54/54 - 0s - loss: 9.5206e-04 - mse: 9.5206e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 64ms/epoch - 1ms/step\n",
      "Epoch 288/500\n",
      "54/54 - 0s - loss: 9.8610e-04 - mse: 9.8610e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 66ms/epoch - 1ms/step\n",
      "Epoch 289/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0021 - val_mse: 0.0021 - 68ms/epoch - 1ms/step\n",
      "Epoch 290/500\n",
      "54/54 - 0s - loss: 9.5254e-04 - mse: 9.5254e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 64ms/epoch - 1ms/step\n",
      "Epoch 291/500\n",
      "54/54 - 0s - loss: 9.2542e-04 - mse: 9.2542e-04 - val_loss: 0.0027 - val_mse: 0.0027 - 62ms/epoch - 1ms/step\n",
      "Epoch 292/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0020 - val_mse: 0.0020 - 63ms/epoch - 1ms/step\n",
      "Epoch 293/500\n",
      "54/54 - 0s - loss: 9.6487e-04 - mse: 9.6487e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 59ms/epoch - 1ms/step\n",
      "Epoch 294/500\n",
      "54/54 - 0s - loss: 9.3740e-04 - mse: 9.3740e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 61ms/epoch - 1ms/step\n",
      "Epoch 295/500\n",
      "54/54 - 0s - loss: 9.6214e-04 - mse: 9.6214e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 64ms/epoch - 1ms/step\n",
      "Epoch 296/500\n",
      "54/54 - 0s - loss: 9.4780e-04 - mse: 9.4780e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 63ms/epoch - 1ms/step\n",
      "Epoch 297/500\n",
      "54/54 - 0s - loss: 9.6886e-04 - mse: 9.6886e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 60ms/epoch - 1ms/step\n",
      "Epoch 298/500\n",
      "54/54 - 0s - loss: 9.8562e-04 - mse: 9.8562e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 63ms/epoch - 1ms/step\n",
      "Epoch 299/500\n",
      "54/54 - 0s - loss: 9.6729e-04 - mse: 9.6729e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 65ms/epoch - 1ms/step\n",
      "Epoch 300/500\n",
      "54/54 - 0s - loss: 9.4084e-04 - mse: 9.4084e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 66ms/epoch - 1ms/step\n",
      "Epoch 301/500\n",
      "54/54 - 0s - loss: 9.5510e-04 - mse: 9.5510e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 64ms/epoch - 1ms/step\n",
      "Epoch 302/500\n",
      "54/54 - 0s - loss: 9.5373e-04 - mse: 9.5373e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 64ms/epoch - 1ms/step\n",
      "Epoch 303/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0022 - val_mse: 0.0022 - 65ms/epoch - 1ms/step\n",
      "Epoch 304/500\n",
      "54/54 - 0s - loss: 9.7723e-04 - mse: 9.7723e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 64ms/epoch - 1ms/step\n",
      "Epoch 305/500\n",
      "54/54 - 0s - loss: 9.5264e-04 - mse: 9.5264e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 69ms/epoch - 1ms/step\n",
      "Epoch 306/500\n",
      "54/54 - 0s - loss: 9.5328e-04 - mse: 9.5328e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 64ms/epoch - 1ms/step\n",
      "Epoch 307/500\n",
      "54/54 - 0s - loss: 9.4403e-04 - mse: 9.4403e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 64ms/epoch - 1ms/step\n",
      "Epoch 308/500\n",
      "54/54 - 0s - loss: 9.4369e-04 - mse: 9.4369e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 64ms/epoch - 1ms/step\n",
      "Epoch 309/500\n",
      "54/54 - 0s - loss: 9.6121e-04 - mse: 9.6121e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 61ms/epoch - 1ms/step\n",
      "Epoch 310/500\n",
      "54/54 - 0s - loss: 9.4933e-04 - mse: 9.4933e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 71ms/epoch - 1ms/step\n",
      "Epoch 311/500\n",
      "54/54 - 0s - loss: 9.2822e-04 - mse: 9.2822e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 65ms/epoch - 1ms/step\n",
      "Epoch 312/500\n",
      "54/54 - 0s - loss: 9.1757e-04 - mse: 9.1757e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 61ms/epoch - 1ms/step\n",
      "Epoch 313/500\n",
      "54/54 - 0s - loss: 9.5072e-04 - mse: 9.5072e-04 - val_loss: 0.0034 - val_mse: 0.0034 - 66ms/epoch - 1ms/step\n",
      "Epoch 314/500\n",
      "54/54 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0021 - val_mse: 0.0021 - 64ms/epoch - 1ms/step\n",
      "Epoch 315/500\n",
      "54/54 - 0s - loss: 9.5100e-04 - mse: 9.5100e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 65ms/epoch - 1ms/step\n",
      "Epoch 316/500\n",
      "54/54 - 0s - loss: 9.1918e-04 - mse: 9.1918e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 65ms/epoch - 1ms/step\n",
      "Epoch 317/500\n",
      "54/54 - 0s - loss: 9.3287e-04 - mse: 9.3287e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 66ms/epoch - 1ms/step\n",
      "Epoch 318/500\n",
      "54/54 - 0s - loss: 9.8442e-04 - mse: 9.8442e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 65ms/epoch - 1ms/step\n",
      "Epoch 319/500\n",
      "54/54 - 0s - loss: 9.2428e-04 - mse: 9.2428e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 64ms/epoch - 1ms/step\n",
      "Epoch 320/500\n",
      "54/54 - 0s - loss: 9.4055e-04 - mse: 9.4055e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 64ms/epoch - 1ms/step\n",
      "Epoch 321/500\n",
      "54/54 - 0s - loss: 9.2882e-04 - mse: 9.2882e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 65ms/epoch - 1ms/step\n",
      "Epoch 322/500\n",
      "54/54 - 0s - loss: 9.1260e-04 - mse: 9.1260e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 62ms/epoch - 1ms/step\n",
      "Epoch 323/500\n",
      "54/54 - 0s - loss: 9.0173e-04 - mse: 9.0172e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 62ms/epoch - 1ms/step\n",
      "Epoch 324/500\n",
      "54/54 - 0s - loss: 9.4014e-04 - mse: 9.4014e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 65ms/epoch - 1ms/step\n",
      "Epoch 325/500\n",
      "54/54 - 0s - loss: 9.0698e-04 - mse: 9.0698e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 67ms/epoch - 1ms/step\n",
      "Epoch 326/500\n",
      "54/54 - 0s - loss: 9.1853e-04 - mse: 9.1852e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 64ms/epoch - 1ms/step\n",
      "Epoch 327/500\n",
      "54/54 - 0s - loss: 9.1151e-04 - mse: 9.1151e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 67ms/epoch - 1ms/step\n",
      "Epoch 328/500\n",
      "54/54 - 0s - loss: 9.2426e-04 - mse: 9.2426e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 68ms/epoch - 1ms/step\n",
      "Epoch 329/500\n",
      "54/54 - 0s - loss: 8.6615e-04 - mse: 8.6615e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 66ms/epoch - 1ms/step\n",
      "Epoch 330/500\n",
      "54/54 - 0s - loss: 8.7936e-04 - mse: 8.7936e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 66ms/epoch - 1ms/step\n",
      "Epoch 331/500\n",
      "54/54 - 0s - loss: 9.0345e-04 - mse: 9.0345e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 64ms/epoch - 1ms/step\n",
      "Epoch 332/500\n",
      "54/54 - 0s - loss: 9.1877e-04 - mse: 9.1877e-04 - val_loss: 0.0022 - val_mse: 0.0022 - 67ms/epoch - 1ms/step\n",
      "Epoch 333/500\n",
      "54/54 - 0s - loss: 9.3297e-04 - mse: 9.3297e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 63ms/epoch - 1ms/step\n",
      "Epoch 334/500\n",
      "54/54 - 0s - loss: 9.0938e-04 - mse: 9.0939e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 65ms/epoch - 1ms/step\n",
      "Epoch 335/500\n",
      "54/54 - 0s - loss: 8.8372e-04 - mse: 8.8372e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 63ms/epoch - 1ms/step\n",
      "Epoch 336/500\n",
      "54/54 - 0s - loss: 9.2742e-04 - mse: 9.2742e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 67ms/epoch - 1ms/step\n",
      "Epoch 337/500\n",
      "54/54 - 0s - loss: 9.7889e-04 - mse: 9.7889e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 65ms/epoch - 1ms/step\n",
      "Epoch 338/500\n",
      "54/54 - 0s - loss: 8.9890e-04 - mse: 8.9890e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 66ms/epoch - 1ms/step\n",
      "Epoch 339/500\n",
      "54/54 - 0s - loss: 8.9618e-04 - mse: 8.9618e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 68ms/epoch - 1ms/step\n",
      "Epoch 340/500\n",
      "54/54 - 0s - loss: 8.9237e-04 - mse: 8.9237e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 64ms/epoch - 1ms/step\n",
      "Epoch 341/500\n",
      "54/54 - 0s - loss: 8.9191e-04 - mse: 8.9191e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 66ms/epoch - 1ms/step\n",
      "Epoch 342/500\n",
      "54/54 - 0s - loss: 9.0479e-04 - mse: 9.0479e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 64ms/epoch - 1ms/step\n",
      "Epoch 343/500\n",
      "54/54 - 0s - loss: 9.4364e-04 - mse: 9.4364e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 67ms/epoch - 1ms/step\n",
      "Epoch 344/500\n",
      "54/54 - 0s - loss: 9.7144e-04 - mse: 9.7144e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 65ms/epoch - 1ms/step\n",
      "Epoch 345/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0028 - val_mse: 0.0028 - 67ms/epoch - 1ms/step\n",
      "Epoch 346/500\n",
      "54/54 - 0s - loss: 9.7597e-04 - mse: 9.7597e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 66ms/epoch - 1ms/step\n",
      "Epoch 347/500\n",
      "54/54 - 0s - loss: 8.9943e-04 - mse: 8.9943e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 65ms/epoch - 1ms/step\n",
      "Epoch 348/500\n",
      "54/54 - 0s - loss: 9.2334e-04 - mse: 9.2334e-04 - val_loss: 0.0024 - val_mse: 0.0024 - 67ms/epoch - 1ms/step\n",
      "Epoch 349/500\n",
      "54/54 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0020 - val_mse: 0.0020 - 65ms/epoch - 1ms/step\n",
      "Epoch 350/500\n",
      "54/54 - 0s - loss: 8.8388e-04 - mse: 8.8388e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 65ms/epoch - 1ms/step\n",
      "Epoch 351/500\n",
      "54/54 - 0s - loss: 8.9058e-04 - mse: 8.9058e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 66ms/epoch - 1ms/step\n",
      "Epoch 352/500\n",
      "54/54 - 0s - loss: 8.5204e-04 - mse: 8.5204e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 67ms/epoch - 1ms/step\n",
      "Epoch 353/500\n",
      "54/54 - 0s - loss: 8.8127e-04 - mse: 8.8127e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 65ms/epoch - 1ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 354/500\n",
      "54/54 - 0s - loss: 8.9827e-04 - mse: 8.9827e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 65ms/epoch - 1ms/step\n",
      "Epoch 355/500\n",
      "54/54 - 0s - loss: 9.1362e-04 - mse: 9.1362e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 60ms/epoch - 1ms/step\n",
      "Epoch 356/500\n",
      "54/54 - 0s - loss: 9.0612e-04 - mse: 9.0612e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 66ms/epoch - 1ms/step\n",
      "Epoch 357/500\n",
      "54/54 - 0s - loss: 8.6083e-04 - mse: 8.6083e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 65ms/epoch - 1ms/step\n",
      "Epoch 358/500\n",
      "54/54 - 0s - loss: 9.3541e-04 - mse: 9.3541e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 58ms/epoch - 1ms/step\n",
      "Epoch 359/500\n",
      "54/54 - 0s - loss: 9.1102e-04 - mse: 9.1102e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 65ms/epoch - 1ms/step\n",
      "Epoch 360/500\n",
      "54/54 - 0s - loss: 8.8051e-04 - mse: 8.8051e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 66ms/epoch - 1ms/step\n",
      "Epoch 361/500\n",
      "54/54 - 0s - loss: 9.1050e-04 - mse: 9.1050e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 59ms/epoch - 1ms/step\n",
      "Epoch 362/500\n",
      "54/54 - 0s - loss: 8.9713e-04 - mse: 8.9713e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 60ms/epoch - 1ms/step\n",
      "Epoch 363/500\n",
      "54/54 - 0s - loss: 8.8662e-04 - mse: 8.8662e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 63ms/epoch - 1ms/step\n",
      "Epoch 364/500\n",
      "54/54 - 0s - loss: 8.8034e-04 - mse: 8.8034e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 65ms/epoch - 1ms/step\n",
      "Epoch 365/500\n",
      "54/54 - 0s - loss: 8.6625e-04 - mse: 8.6625e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 66ms/epoch - 1ms/step\n",
      "Epoch 366/500\n",
      "54/54 - 0s - loss: 9.1940e-04 - mse: 9.1940e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 65ms/epoch - 1ms/step\n",
      "Epoch 367/500\n",
      "54/54 - 0s - loss: 8.6858e-04 - mse: 8.6858e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 66ms/epoch - 1ms/step\n",
      "Epoch 368/500\n",
      "54/54 - 0s - loss: 8.9151e-04 - mse: 8.9151e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 66ms/epoch - 1ms/step\n",
      "Epoch 369/500\n",
      "54/54 - 0s - loss: 8.7552e-04 - mse: 8.7552e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 65ms/epoch - 1ms/step\n",
      "Epoch 370/500\n",
      "54/54 - 0s - loss: 9.1204e-04 - mse: 9.1204e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 66ms/epoch - 1ms/step\n",
      "Epoch 371/500\n",
      "54/54 - 0s - loss: 9.2132e-04 - mse: 9.2132e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 65ms/epoch - 1ms/step\n",
      "Epoch 372/500\n",
      "54/54 - 0s - loss: 8.5934e-04 - mse: 8.5934e-04 - val_loss: 0.0022 - val_mse: 0.0022 - 67ms/epoch - 1ms/step\n",
      "Epoch 373/500\n",
      "54/54 - 0s - loss: 9.3078e-04 - mse: 9.3078e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 65ms/epoch - 1ms/step\n",
      "Epoch 374/500\n",
      "54/54 - 0s - loss: 8.7336e-04 - mse: 8.7336e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 64ms/epoch - 1ms/step\n",
      "Epoch 375/500\n",
      "54/54 - 0s - loss: 9.6255e-04 - mse: 9.6255e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 65ms/epoch - 1ms/step\n",
      "Epoch 376/500\n",
      "54/54 - 0s - loss: 8.6450e-04 - mse: 8.6450e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 65ms/epoch - 1ms/step\n",
      "Epoch 377/500\n",
      "54/54 - 0s - loss: 8.9959e-04 - mse: 8.9959e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 64ms/epoch - 1ms/step\n",
      "Epoch 378/500\n",
      "54/54 - 0s - loss: 8.3850e-04 - mse: 8.3850e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 64ms/epoch - 1ms/step\n",
      "Epoch 379/500\n",
      "54/54 - 0s - loss: 9.1490e-04 - mse: 9.1490e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 65ms/epoch - 1ms/step\n",
      "Epoch 380/500\n",
      "54/54 - 0s - loss: 8.5329e-04 - mse: 8.5329e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 62ms/epoch - 1ms/step\n",
      "Epoch 381/500\n",
      "54/54 - 0s - loss: 8.6408e-04 - mse: 8.6408e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 65ms/epoch - 1ms/step\n",
      "Epoch 382/500\n",
      "54/54 - 0s - loss: 9.0534e-04 - mse: 9.0534e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 63ms/epoch - 1ms/step\n",
      "Epoch 383/500\n",
      "54/54 - 0s - loss: 8.9833e-04 - mse: 8.9833e-04 - val_loss: 0.0023 - val_mse: 0.0023 - 66ms/epoch - 1ms/step\n",
      "Epoch 384/500\n",
      "54/54 - 0s - loss: 9.5415e-04 - mse: 9.5415e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 65ms/epoch - 1ms/step\n",
      "Epoch 385/500\n",
      "54/54 - 0s - loss: 8.4433e-04 - mse: 8.4433e-04 - val_loss: 0.0022 - val_mse: 0.0022 - 67ms/epoch - 1ms/step\n",
      "Epoch 386/500\n",
      "54/54 - 0s - loss: 9.6830e-04 - mse: 9.6830e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 61ms/epoch - 1ms/step\n",
      "Epoch 387/500\n",
      "54/54 - 0s - loss: 9.0792e-04 - mse: 9.0792e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 65ms/epoch - 1ms/step\n",
      "Epoch 388/500\n",
      "54/54 - 0s - loss: 8.4559e-04 - mse: 8.4559e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 64ms/epoch - 1ms/step\n",
      "Epoch 389/500\n",
      "54/54 - 0s - loss: 9.2819e-04 - mse: 9.2819e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 66ms/epoch - 1ms/step\n",
      "Epoch 390/500\n",
      "54/54 - 0s - loss: 8.6468e-04 - mse: 8.6468e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 66ms/epoch - 1ms/step\n",
      "Epoch 391/500\n",
      "54/54 - 0s - loss: 8.8203e-04 - mse: 8.8203e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 65ms/epoch - 1ms/step\n",
      "Epoch 392/500\n",
      "54/54 - 0s - loss: 8.1935e-04 - mse: 8.1935e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 65ms/epoch - 1ms/step\n",
      "Epoch 393/500\n",
      "54/54 - 0s - loss: 8.9679e-04 - mse: 8.9679e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 63ms/epoch - 1ms/step\n",
      "Epoch 394/500\n",
      "54/54 - 0s - loss: 9.2223e-04 - mse: 9.2223e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 66ms/epoch - 1ms/step\n",
      "Epoch 395/500\n",
      "54/54 - 0s - loss: 8.8655e-04 - mse: 8.8655e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 66ms/epoch - 1ms/step\n",
      "Epoch 396/500\n",
      "54/54 - 0s - loss: 8.9528e-04 - mse: 8.9528e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 59ms/epoch - 1ms/step\n",
      "Epoch 397/500\n",
      "54/54 - 0s - loss: 8.2754e-04 - mse: 8.2754e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 66ms/epoch - 1ms/step\n",
      "Epoch 398/500\n",
      "54/54 - 0s - loss: 8.6538e-04 - mse: 8.6538e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 66ms/epoch - 1ms/step\n",
      "Epoch 399/500\n",
      "54/54 - 0s - loss: 8.3710e-04 - mse: 8.3710e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 65ms/epoch - 1ms/step\n",
      "Epoch 400/500\n",
      "54/54 - 0s - loss: 9.3941e-04 - mse: 9.3941e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 66ms/epoch - 1ms/step\n",
      "Epoch 401/500\n",
      "54/54 - 0s - loss: 9.0420e-04 - mse: 9.0420e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 65ms/epoch - 1ms/step\n",
      "Epoch 402/500\n",
      "54/54 - 0s - loss: 8.6727e-04 - mse: 8.6727e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 65ms/epoch - 1ms/step\n",
      "Epoch 403/500\n",
      "54/54 - 0s - loss: 8.5602e-04 - mse: 8.5602e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 66ms/epoch - 1ms/step\n",
      "Epoch 404/500\n",
      "54/54 - 0s - loss: 9.1977e-04 - mse: 9.1977e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 65ms/epoch - 1ms/step\n",
      "Epoch 405/500\n",
      "54/54 - 0s - loss: 8.5526e-04 - mse: 8.5526e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 65ms/epoch - 1ms/step\n",
      "Epoch 406/500\n",
      "54/54 - 0s - loss: 9.0231e-04 - mse: 9.0231e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 65ms/epoch - 1ms/step\n",
      "Epoch 407/500\n",
      "54/54 - 0s - loss: 8.7455e-04 - mse: 8.7455e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 70ms/epoch - 1ms/step\n",
      "Epoch 408/500\n",
      "54/54 - 0s - loss: 8.4756e-04 - mse: 8.4756e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 65ms/epoch - 1ms/step\n",
      "Epoch 409/500\n",
      "54/54 - 0s - loss: 8.6395e-04 - mse: 8.6395e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 66ms/epoch - 1ms/step\n",
      "Epoch 410/500\n",
      "54/54 - 0s - loss: 8.4428e-04 - mse: 8.4428e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 66ms/epoch - 1ms/step\n",
      "Epoch 411/500\n",
      "54/54 - 0s - loss: 9.3668e-04 - mse: 9.3668e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 66ms/epoch - 1ms/step\n",
      "Epoch 412/500\n",
      "54/54 - 0s - loss: 8.2968e-04 - mse: 8.2968e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 66ms/epoch - 1ms/step\n",
      "Epoch 413/500\n",
      "54/54 - 0s - loss: 9.0396e-04 - mse: 9.0396e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 66ms/epoch - 1ms/step\n",
      "Epoch 414/500\n",
      "54/54 - 0s - loss: 8.4579e-04 - mse: 8.4579e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 64ms/epoch - 1ms/step\n",
      "Epoch 415/500\n",
      "54/54 - 0s - loss: 9.2712e-04 - mse: 9.2712e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 65ms/epoch - 1ms/step\n",
      "Epoch 416/500\n",
      "54/54 - 0s - loss: 8.4734e-04 - mse: 8.4734e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 65ms/epoch - 1ms/step\n",
      "Epoch 417/500\n",
      "54/54 - 0s - loss: 8.4097e-04 - mse: 8.4097e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 62ms/epoch - 1ms/step\n",
      "Epoch 418/500\n",
      "54/54 - 0s - loss: 9.5453e-04 - mse: 9.5453e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 64ms/epoch - 1ms/step\n",
      "Epoch 419/500\n",
      "54/54 - 0s - loss: 9.1107e-04 - mse: 9.1107e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 66ms/epoch - 1ms/step\n",
      "Epoch 420/500\n",
      "54/54 - 0s - loss: 8.4136e-04 - mse: 8.4136e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 65ms/epoch - 1ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 421/500\n",
      "54/54 - 0s - loss: 9.3959e-04 - mse: 9.3959e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 65ms/epoch - 1ms/step\n",
      "Epoch 422/500\n",
      "54/54 - 0s - loss: 8.6647e-04 - mse: 8.6647e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 60ms/epoch - 1ms/step\n",
      "Epoch 423/500\n",
      "54/54 - 0s - loss: 8.2246e-04 - mse: 8.2246e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 62ms/epoch - 1ms/step\n",
      "Epoch 424/500\n",
      "54/54 - 0s - loss: 8.5100e-04 - mse: 8.5100e-04 - val_loss: 0.0017 - val_mse: 0.0017 - 59ms/epoch - 1ms/step\n",
      "Epoch 425/500\n",
      "54/54 - 0s - loss: 8.6110e-04 - mse: 8.6110e-04 - val_loss: 0.0017 - val_mse: 0.0017 - 65ms/epoch - 1ms/step\n",
      "Epoch 426/500\n",
      "54/54 - 0s - loss: 8.4524e-04 - mse: 8.4524e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 59ms/epoch - 1ms/step\n",
      "Epoch 427/500\n",
      "54/54 - 0s - loss: 8.2736e-04 - mse: 8.2736e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 65ms/epoch - 1ms/step\n",
      "Epoch 428/500\n",
      "54/54 - 0s - loss: 8.9110e-04 - mse: 8.9110e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 65ms/epoch - 1ms/step\n",
      "Epoch 429/500\n",
      "54/54 - 0s - loss: 9.1675e-04 - mse: 9.1675e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 67ms/epoch - 1ms/step\n",
      "Epoch 430/500\n",
      "54/54 - 0s - loss: 8.8369e-04 - mse: 8.8369e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 63ms/epoch - 1ms/step\n",
      "Epoch 431/500\n",
      "54/54 - 0s - loss: 8.4418e-04 - mse: 8.4418e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 67ms/epoch - 1ms/step\n",
      "Epoch 432/500\n",
      "54/54 - 0s - loss: 8.3738e-04 - mse: 8.3738e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 65ms/epoch - 1ms/step\n",
      "Epoch 433/500\n",
      "54/54 - 0s - loss: 8.5741e-04 - mse: 8.5741e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 65ms/epoch - 1ms/step\n",
      "Epoch 434/500\n",
      "54/54 - 0s - loss: 9.0139e-04 - mse: 9.0139e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 66ms/epoch - 1ms/step\n",
      "Epoch 435/500\n",
      "54/54 - 0s - loss: 8.9135e-04 - mse: 8.9135e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 67ms/epoch - 1ms/step\n",
      "Epoch 436/500\n",
      "54/54 - 0s - loss: 9.0805e-04 - mse: 9.0804e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 67ms/epoch - 1ms/step\n",
      "Epoch 437/500\n",
      "54/54 - 0s - loss: 8.3067e-04 - mse: 8.3067e-04 - val_loss: 0.0017 - val_mse: 0.0017 - 65ms/epoch - 1ms/step\n",
      "Epoch 438/500\n",
      "54/54 - 0s - loss: 8.5565e-04 - mse: 8.5565e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 66ms/epoch - 1ms/step\n",
      "Epoch 439/500\n",
      "54/54 - 0s - loss: 8.4795e-04 - mse: 8.4795e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 67ms/epoch - 1ms/step\n",
      "Epoch 440/500\n",
      "54/54 - 0s - loss: 8.1634e-04 - mse: 8.1634e-04 - val_loss: 0.0017 - val_mse: 0.0017 - 66ms/epoch - 1ms/step\n",
      "Epoch 441/500\n",
      "54/54 - 0s - loss: 8.6527e-04 - mse: 8.6527e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 66ms/epoch - 1ms/step\n",
      "Epoch 442/500\n",
      "54/54 - 0s - loss: 8.6667e-04 - mse: 8.6667e-04 - val_loss: 0.0017 - val_mse: 0.0017 - 64ms/epoch - 1ms/step\n",
      "Epoch 443/500\n",
      "54/54 - 0s - loss: 8.7773e-04 - mse: 8.7773e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 68ms/epoch - 1ms/step\n",
      "Epoch 444/500\n",
      "54/54 - 0s - loss: 8.1824e-04 - mse: 8.1824e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 65ms/epoch - 1ms/step\n",
      "Epoch 445/500\n",
      "54/54 - 0s - loss: 8.3704e-04 - mse: 8.3704e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 65ms/epoch - 1ms/step\n",
      "Epoch 446/500\n",
      "54/54 - 0s - loss: 8.0435e-04 - mse: 8.0435e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 65ms/epoch - 1ms/step\n",
      "Epoch 447/500\n",
      "54/54 - 0s - loss: 8.5896e-04 - mse: 8.5896e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 66ms/epoch - 1ms/step\n",
      "Epoch 448/500\n",
      "54/54 - 0s - loss: 8.9913e-04 - mse: 8.9913e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 64ms/epoch - 1ms/step\n",
      "Epoch 449/500\n",
      "54/54 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0017 - val_mse: 0.0017 - 64ms/epoch - 1ms/step\n",
      "Epoch 450/500\n",
      "54/54 - 0s - loss: 8.1546e-04 - mse: 8.1546e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 64ms/epoch - 1ms/step\n",
      "Epoch 451/500\n",
      "54/54 - 0s - loss: 8.2292e-04 - mse: 8.2292e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 63ms/epoch - 1ms/step\n",
      "Epoch 452/500\n",
      "54/54 - 0s - loss: 8.4187e-04 - mse: 8.4187e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 60ms/epoch - 1ms/step\n",
      "Epoch 453/500\n",
      "54/54 - 0s - loss: 8.5961e-04 - mse: 8.5961e-04 - val_loss: 0.0020 - val_mse: 0.0020 - 65ms/epoch - 1ms/step\n",
      "Epoch 454/500\n",
      "54/54 - 0s - loss: 8.3051e-04 - mse: 8.3051e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 65ms/epoch - 1ms/step\n",
      "Epoch 455/500\n",
      "54/54 - 0s - loss: 8.1398e-04 - mse: 8.1398e-04 - val_loss: 0.0017 - val_mse: 0.0017 - 66ms/epoch - 1ms/step\n",
      "Epoch 456/500\n",
      "54/54 - 0s - loss: 8.0728e-04 - mse: 8.0728e-04 - val_loss: 0.0017 - val_mse: 0.0017 - 65ms/epoch - 1ms/step\n",
      "Epoch 457/500\n",
      "54/54 - 0s - loss: 8.5167e-04 - mse: 8.5167e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 66ms/epoch - 1ms/step\n",
      "Epoch 458/500\n",
      "54/54 - 0s - loss: 8.8304e-04 - mse: 8.8304e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 65ms/epoch - 1ms/step\n",
      "Epoch 459/500\n",
      "54/54 - 0s - loss: 8.0734e-04 - mse: 8.0734e-04 - val_loss: 0.0017 - val_mse: 0.0017 - 66ms/epoch - 1ms/step\n",
      "Epoch 460/500\n",
      "54/54 - 0s - loss: 8.3229e-04 - mse: 8.3229e-04 - val_loss: 0.0017 - val_mse: 0.0017 - 67ms/epoch - 1ms/step\n",
      "Epoch 461/500\n",
      "54/54 - 0s - loss: 8.2573e-04 - mse: 8.2573e-04 - val_loss: 0.0017 - val_mse: 0.0017 - 65ms/epoch - 1ms/step\n",
      "Epoch 462/500\n",
      "54/54 - 0s - loss: 8.4935e-04 - mse: 8.4935e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 68ms/epoch - 1ms/step\n",
      "Epoch 463/500\n",
      "54/54 - 0s - loss: 8.4329e-04 - mse: 8.4329e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 65ms/epoch - 1ms/step\n",
      "Epoch 464/500\n",
      "54/54 - 0s - loss: 8.5036e-04 - mse: 8.5036e-04 - val_loss: 0.0017 - val_mse: 0.0017 - 65ms/epoch - 1ms/step\n",
      "Epoch 465/500\n",
      "54/54 - 0s - loss: 8.3539e-04 - mse: 8.3539e-04 - val_loss: 0.0017 - val_mse: 0.0017 - 66ms/epoch - 1ms/step\n",
      "Epoch 466/500\n",
      "54/54 - 0s - loss: 8.2588e-04 - mse: 8.2588e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 66ms/epoch - 1ms/step\n",
      "Epoch 467/500\n",
      "54/54 - 0s - loss: 8.6955e-04 - mse: 8.6955e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 66ms/epoch - 1ms/step\n",
      "Epoch 468/500\n",
      "54/54 - 0s - loss: 8.5921e-04 - mse: 8.5921e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 65ms/epoch - 1ms/step\n",
      "Epoch 469/500\n",
      "54/54 - 0s - loss: 7.7560e-04 - mse: 7.7560e-04 - val_loss: 0.0017 - val_mse: 0.0017 - 67ms/epoch - 1ms/step\n",
      "Epoch 470/500\n",
      "54/54 - 0s - loss: 7.8084e-04 - mse: 7.8084e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 66ms/epoch - 1ms/step\n",
      "Epoch 471/500\n",
      "54/54 - 0s - loss: 9.2058e-04 - mse: 9.2058e-04 - val_loss: 0.0017 - val_mse: 0.0017 - 66ms/epoch - 1ms/step\n",
      "Epoch 472/500\n",
      "54/54 - 0s - loss: 8.1254e-04 - mse: 8.1254e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 66ms/epoch - 1ms/step\n",
      "Epoch 473/500\n",
      "54/54 - 0s - loss: 7.8478e-04 - mse: 7.8477e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 66ms/epoch - 1ms/step\n",
      "Epoch 474/500\n",
      "54/54 - 0s - loss: 8.2006e-04 - mse: 8.2006e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 64ms/epoch - 1ms/step\n",
      "Epoch 475/500\n",
      "54/54 - 0s - loss: 8.3638e-04 - mse: 8.3638e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 66ms/epoch - 1ms/step\n",
      "Epoch 476/500\n",
      "54/54 - 0s - loss: 8.7849e-04 - mse: 8.7849e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 67ms/epoch - 1ms/step\n",
      "Epoch 477/500\n",
      "54/54 - 0s - loss: 8.4967e-04 - mse: 8.4967e-04 - val_loss: 0.0017 - val_mse: 0.0017 - 65ms/epoch - 1ms/step\n",
      "Epoch 478/500\n",
      "54/54 - 0s - loss: 8.2194e-04 - mse: 8.2194e-04 - val_loss: 0.0017 - val_mse: 0.0017 - 66ms/epoch - 1ms/step\n",
      "Epoch 479/500\n",
      "54/54 - 0s - loss: 7.6359e-04 - mse: 7.6359e-04 - val_loss: 0.0017 - val_mse: 0.0017 - 65ms/epoch - 1ms/step\n",
      "Epoch 480/500\n",
      "54/54 - 0s - loss: 8.0368e-04 - mse: 8.0368e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 66ms/epoch - 1ms/step\n",
      "Epoch 481/500\n",
      "54/54 - 0s - loss: 8.0739e-04 - mse: 8.0739e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 66ms/epoch - 1ms/step\n",
      "Epoch 482/500\n",
      "54/54 - 0s - loss: 8.1085e-04 - mse: 8.1085e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 65ms/epoch - 1ms/step\n",
      "Epoch 483/500\n",
      "54/54 - 0s - loss: 8.8310e-04 - mse: 8.8310e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 65ms/epoch - 1ms/step\n",
      "Epoch 484/500\n",
      "54/54 - 0s - loss: 8.1083e-04 - mse: 8.1083e-04 - val_loss: 0.0017 - val_mse: 0.0017 - 74ms/epoch - 1ms/step\n",
      "Epoch 485/500\n",
      "54/54 - 0s - loss: 8.1169e-04 - mse: 8.1169e-04 - val_loss: 0.0017 - val_mse: 0.0017 - 65ms/epoch - 1ms/step\n",
      "Epoch 486/500\n",
      "54/54 - 0s - loss: 8.3785e-04 - mse: 8.3785e-04 - val_loss: 0.0017 - val_mse: 0.0017 - 61ms/epoch - 1ms/step\n",
      "Epoch 487/500\n",
      "54/54 - 0s - loss: 7.7995e-04 - mse: 7.7995e-04 - val_loss: 0.0016 - val_mse: 0.0016 - 64ms/epoch - 1ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 488/500\n",
      "54/54 - 0s - loss: 8.2462e-04 - mse: 8.2462e-04 - val_loss: 0.0017 - val_mse: 0.0017 - 67ms/epoch - 1ms/step\n",
      "Epoch 489/500\n",
      "54/54 - 0s - loss: 8.7140e-04 - mse: 8.7140e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 66ms/epoch - 1ms/step\n",
      "Epoch 490/500\n",
      "54/54 - 0s - loss: 8.2968e-04 - mse: 8.2968e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 65ms/epoch - 1ms/step\n",
      "Epoch 491/500\n",
      "54/54 - 0s - loss: 8.0379e-04 - mse: 8.0379e-04 - val_loss: 0.0016 - val_mse: 0.0016 - 61ms/epoch - 1ms/step\n",
      "Epoch 492/500\n",
      "54/54 - 0s - loss: 7.6167e-04 - mse: 7.6167e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 66ms/epoch - 1ms/step\n",
      "Epoch 493/500\n",
      "54/54 - 0s - loss: 8.1898e-04 - mse: 8.1898e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 63ms/epoch - 1ms/step\n",
      "Epoch 494/500\n",
      "54/54 - 0s - loss: 7.9519e-04 - mse: 7.9519e-04 - val_loss: 0.0019 - val_mse: 0.0019 - 65ms/epoch - 1ms/step\n",
      "Epoch 495/500\n",
      "54/54 - 0s - loss: 9.0763e-04 - mse: 9.0763e-04 - val_loss: 0.0017 - val_mse: 0.0017 - 65ms/epoch - 1ms/step\n",
      "Epoch 496/500\n",
      "54/54 - 0s - loss: 8.6732e-04 - mse: 8.6732e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 64ms/epoch - 1ms/step\n",
      "Epoch 497/500\n",
      "54/54 - 0s - loss: 8.4959e-04 - mse: 8.4959e-04 - val_loss: 0.0021 - val_mse: 0.0021 - 60ms/epoch - 1ms/step\n",
      "Epoch 498/500\n",
      "54/54 - 0s - loss: 8.5567e-04 - mse: 8.5567e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 66ms/epoch - 1ms/step\n",
      "Epoch 499/500\n",
      "54/54 - 0s - loss: 7.9362e-04 - mse: 7.9362e-04 - val_loss: 0.0017 - val_mse: 0.0017 - 66ms/epoch - 1ms/step\n",
      "Epoch 500/500\n",
      "54/54 - 0s - loss: 8.5429e-04 - mse: 8.5429e-04 - val_loss: 0.0018 - val_mse: 0.0018 - 64ms/epoch - 1ms/step\n",
      "33.039079904556274\n"
     ]
    }
   ],
   "source": [
    "###the standard RNN model is trained as benchmark, to show the priority of transfer learning RNN models\n",
    "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 624us/step - loss: 6.2832e-04 - mse: 6.2832e-04\n",
      "[0.0006283180555328727, 0.0006283180555328727]\n",
      "33.039079904556274\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
}
