{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "539ebd7b",
   "metadata": {},
   "outputs": [],
   "source": [
    "###This code is about develop a RNN model for the target CSTR process using heterogeneous transfer learning\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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "3a4a2d8e",
   "metadata": {},
   "outputs": [],
   "source": [
    "# specifying constant parameters\n",
    "#input varioable: Q, C_A0\n",
    "#state variable: T, C_A\n",
    "\n",
    "#parameters\n",
    "T01 = 350\n",
    "CA0 = 5\n",
    "CB0 = 4\n",
    "F1 = 48.0133\n",
    "\n",
    "R = 8.314\n",
    "V = 60\n",
    "Fo1 = 43.34\n",
    "\n",
    "k0 = 1.528e+6\n",
    "E = 71160\n",
    "delta_H = -1.06e+5\n",
    "\n",
    "Pl1 = 639.15\n",
    "Cp = 2.5\n",
    "Cp_modified = 1.55\n",
    "\n",
    "\n",
    "#steady states\n",
    "T1_s = 310.5 #516508  # the steady state for state variable T\n",
    "CA1_s = 5.35319 #46083 # the steady state for state variable C_A\n",
    "CB1_s = 4.24528 #46083 # the steady state for state variable C_B\n",
    "Q1_s = -3279600  # the steady state for input variable Q\n",
    "\n",
    "\n",
    "t_final = 0.05  #the control period\n",
    "t_step = 0.01   # the step to use first-principle to calculate the state"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "63529b65",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(2,)\n",
      "shape of x_deviation is (20, 3)\n"
     ]
    }
   ],
   "source": [
    "#The data size for new-cstr should be consensus with the basic-one\n",
    "# generating inputs and initial states for CSTR, all expressed in deviation form\n",
    "\n",
    "#real value\n",
    "Q1_list = np.linspace(-4320000, -2880000, 5, endpoint=True)\n",
    "#the initial states are in real value\n",
    "T1_initial = np.linspace(-10, 10, 5, endpoint=True) + T1_s\n",
    "CA1_initial = np.linspace(-0.2, 0.2, 2, endpoint=True) + CA1_s\n",
    "CB1_initial = np.linspace(-0.2, 0.2, 2, endpoint=True) + CB1_s\n",
    "\n",
    "print(CA1_initial.shape)\n",
    "#control variable: Q1, Q2\n",
    "#state variable: CA1,CA2,CB1,CB2,T1,T2\n",
    "\n",
    "# sieve out initial states that lie outside of stability region\n",
    "\n",
    "CA1_start = list()\n",
    "CB1_start = list()\n",
    "T1_start = list()\n",
    "\n",
    "for T1 in T1_initial:   \n",
    "    for CA1 in CA1_initial:\n",
    "        for CB1 in CB1_initial:\n",
    "            CA1_start.append(CA1)\n",
    "            CB1_start.append(CB1)\n",
    "            T1_start.append(T1)\n",
    "           \n",
    "\n",
    "# convert to np.arrays\n",
    "CA1_start = np.array([CA1_start])\n",
    "CB1_start = np.array([CB1_start])\n",
    "T1_start = np.array([T1_start])\n",
    "\n",
    "\n",
    "x_deviation = np.concatenate((CA1_start.T, CB1_start.T,T1_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)  # the initial state is in"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "16075e8a",
   "metadata": {},
   "outputs": [],
   "source": [
    "def CSTR_simu(Q1, t_final, t_step, CA1_initial, CB1_initial,T1_initial):\n",
    "    \"\"\"\n",
    "        simulating CSTR using forward Euler method\n",
    "    \"\"\"\n",
    "    CA1_list = list()  # evolution of CA over time\n",
    "    CB1_list = list()  # evolution of CA over time\n",
    "    T1_list = list()  # evolution of T over time\n",
    "        \n",
    "    CA1 = CA1_initial #+ CA1_s  # the real state.the derivation plus the steady state\n",
    "    CB1 = CB1_initial #+ CB1_s\n",
    "    T1 = T1_initial #+ T1_s\n",
    "\n",
    "    \n",
    "    for i in range(int(t_final / t_step)):\n",
    "        par_reaction1 = k0 * np.exp(-E/(R*T1))\n",
    "\n",
    "        dCA1 = (F1*CA0 - Fo1 *CA1)/V - par_reaction1 * CA1 * CB1\n",
    "        dCB1 = (F1*CB0 - Fo1 *CB1)/V - par_reaction1 * CA1 * CB1\n",
    "        dT1 = (F1*T01 - Fo1 *T1)/V - delta_H/(Pl1 * Cp_modified) * par_reaction1 * CA1 * CB1 + Q1/(Pl1 * Cp_modified * V)\n",
    "\n",
    "        CA1 += dCA1 * t_step\n",
    "        CB1 += dCB1 * t_step\n",
    "        T1 += dT1 * t_step\n",
    "        \n",
    "        \n",
    "        #if i%5 ==0:\n",
    "        CA1_list.append(CA1)  # in real value form\n",
    "        CB1_list.append(CB1) \n",
    "        T1_list.append(T1)  \n",
    "    \n",
    "    return CA1_list, CB1_list, T1_list"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "b400bf04",
   "metadata": {},
   "outputs": [],
   "source": [
    "# get X and y data for training and testing\n",
    "\n",
    "CA1_output = list()\n",
    "CB1_output = list()\n",
    "T1_output = list()\n",
    "\n",
    "\n",
    "Q1_input = list()   #input variable for \n",
    "CA1_input = list()\n",
    "CB1_input = list()\n",
    "T1_input = list()\n",
    "\n",
    "\n",
    "for u1 in Q1_list:\n",
    "    Q1 = u1\n",
    "    for CA1_initial, CB1_initial,T1_initial in x_deviation:\n",
    "        Q1_input.append(Q1)\n",
    "        CA1_input.append(CA1_initial)\n",
    "        CB1_input.append(CB1_initial)\n",
    "        T1_input.append(T1_initial)\n",
    "       \n",
    "        CA1_list, CB1_list, T1_list= CSTR_simu(Q1, t_final, t_step, CA1_initial, CB1_initial,T1_initial)\n",
    "\n",
    "        CA1_output.append(CA1_list)\n",
    "        CB1_output.append(CB1_list)\n",
    "        T1_output.append(T1_list)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "d18fd7d5",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "RNN_input shape is (100, 1, 4)\n",
      "RNN_input shape is (100, 5, 4)\n"
     ]
    }
   ],
   "source": [
    "# collate input for RNN\n",
    "\n",
    "Q1_input = np.array(Q1_input)\n",
    "Q1_input = Q1_input.reshape(-1,1,1)\n",
    "\n",
    "CA1_input = np.array(CA1_input)\n",
    "CA1_input = CA1_input.reshape(-1,1,1)\n",
    "\n",
    "CB1_input = np.array(CB1_input)\n",
    "CB1_input = CB1_input.reshape(-1,1,1)\n",
    "\n",
    "T1_input = np.array(T1_input)\n",
    "T1_input = T1_input.reshape(-1,1,1)\n",
    "\n",
    "\n",
    "RNN_input = np.concatenate((Q1_input, T1_input, CA1_input, CB1_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)  # to keep consensus with the shape for RNN_output, since the output variable is collected 100(0.01/1e-4) times for each RNN_input\n",
    "print(\"RNN_input shape is {}\".format(RNN_input.shape))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "93c8309b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "RNN_output shape is (100, 5, 3)\n"
     ]
    }
   ],
   "source": [
    "# collate output for RNN\n",
    "\n",
    "CA1_output = np.array(CA1_output)\n",
    "CA1_output = CA1_output.reshape(-1, 5, 1)\n",
    "\n",
    "\n",
    "CB1_output = np.array(CB1_output)\n",
    "CB1_output = CB1_output.reshape(-1, 5, 1)\n",
    "\n",
    "\n",
    "T1_output = np.array(T1_output)\n",
    "T1_output = T1_output.reshape(-1, 5, 1)\n",
    "\n",
    "\n",
    "RNN_output = np.concatenate((T1_output, CA1_output, CB1_output), axis=2)\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": 8,
   "id": "6b8005e3",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(50, 5, 4) (50, 5, 4) (50, 5, 3) (50, 5, 3)\n"
     ]
    }
   ],
   "source": [
    "# split source dataset into train and test sets\n",
    "X_train, X_test, y_train, y_test = train_test_split(RNN_input, RNN_output, test_size=0.5, 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",
    "#source data\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 benchmark"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "25925acb",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/500\n",
      "1/1 - 0s - loss: 1.6123 - mse: 1.6123 - val_loss: 1.8855 - val_mse: 1.8855 - 439ms/epoch - 439ms/step\n",
      "Epoch 2/500\n",
      "1/1 - 0s - loss: 1.5775 - mse: 1.5775 - val_loss: 1.8452 - val_mse: 1.8452 - 14ms/epoch - 14ms/step\n",
      "Epoch 3/500\n",
      "1/1 - 0s - loss: 1.5432 - mse: 1.5432 - val_loss: 1.8055 - val_mse: 1.8055 - 15ms/epoch - 15ms/step\n",
      "Epoch 4/500\n",
      "1/1 - 0s - loss: 1.5093 - mse: 1.5093 - val_loss: 1.7663 - val_mse: 1.7663 - 16ms/epoch - 16ms/step\n",
      "Epoch 5/500\n",
      "1/1 - 0s - loss: 1.4760 - mse: 1.4760 - val_loss: 1.7277 - val_mse: 1.7277 - 17ms/epoch - 17ms/step\n",
      "Epoch 6/500\n",
      "1/1 - 0s - loss: 1.4432 - mse: 1.4432 - val_loss: 1.6899 - val_mse: 1.6899 - 19ms/epoch - 19ms/step\n",
      "Epoch 7/500\n",
      "1/1 - 0s - loss: 1.4109 - mse: 1.4109 - val_loss: 1.6527 - val_mse: 1.6527 - 19ms/epoch - 19ms/step\n",
      "Epoch 8/500\n",
      "1/1 - 0s - loss: 1.3792 - mse: 1.3792 - val_loss: 1.6162 - val_mse: 1.6162 - 15ms/epoch - 15ms/step\n",
      "Epoch 9/500\n",
      "1/1 - 0s - loss: 1.3480 - mse: 1.3480 - val_loss: 1.5805 - val_mse: 1.5805 - 13ms/epoch - 13ms/step\n",
      "Epoch 10/500\n",
      "1/1 - 0s - loss: 1.3174 - mse: 1.3174 - val_loss: 1.5455 - val_mse: 1.5455 - 13ms/epoch - 13ms/step\n",
      "Epoch 11/500\n",
      "1/1 - 0s - loss: 1.2874 - mse: 1.2874 - val_loss: 1.5113 - val_mse: 1.5113 - 18ms/epoch - 18ms/step\n",
      "Epoch 12/500\n",
      "1/1 - 0s - loss: 1.2580 - mse: 1.2580 - val_loss: 1.4779 - val_mse: 1.4779 - 18ms/epoch - 18ms/step\n",
      "Epoch 13/500\n",
      "1/1 - 0s - loss: 1.2291 - mse: 1.2291 - val_loss: 1.4452 - val_mse: 1.4452 - 19ms/epoch - 19ms/step\n",
      "Epoch 14/500\n",
      "1/1 - 0s - loss: 1.2009 - mse: 1.2009 - val_loss: 1.4132 - val_mse: 1.4132 - 17ms/epoch - 17ms/step\n",
      "Epoch 15/500\n",
      "1/1 - 0s - loss: 1.1733 - mse: 1.1733 - val_loss: 1.3821 - val_mse: 1.3821 - 17ms/epoch - 17ms/step\n",
      "Epoch 16/500\n",
      "1/1 - 0s - loss: 1.1464 - mse: 1.1464 - val_loss: 1.3516 - val_mse: 1.3516 - 17ms/epoch - 17ms/step\n",
      "Epoch 17/500\n",
      "1/1 - 0s - loss: 1.1200 - mse: 1.1200 - val_loss: 1.3219 - val_mse: 1.3219 - 18ms/epoch - 18ms/step\n",
      "Epoch 18/500\n",
      "1/1 - 0s - loss: 1.0943 - mse: 1.0943 - val_loss: 1.2930 - val_mse: 1.2930 - 20ms/epoch - 20ms/step\n",
      "Epoch 19/500\n",
      "1/1 - 0s - loss: 1.0692 - mse: 1.0692 - val_loss: 1.2647 - val_mse: 1.2647 - 18ms/epoch - 18ms/step\n",
      "Epoch 20/500\n",
      "1/1 - 0s - loss: 1.0447 - mse: 1.0447 - val_loss: 1.2372 - val_mse: 1.2372 - 18ms/epoch - 18ms/step\n",
      "Epoch 21/500\n",
      "1/1 - 0s - loss: 1.0209 - mse: 1.0209 - val_loss: 1.2104 - val_mse: 1.2104 - 13ms/epoch - 13ms/step\n",
      "Epoch 22/500\n",
      "1/1 - 0s - loss: 0.9976 - mse: 0.9976 - val_loss: 1.1842 - val_mse: 1.1842 - 12ms/epoch - 12ms/step\n",
      "Epoch 23/500\n",
      "1/1 - 0s - loss: 0.9750 - mse: 0.9750 - val_loss: 1.1587 - val_mse: 1.1587 - 16ms/epoch - 16ms/step\n",
      "Epoch 24/500\n",
      "1/1 - 0s - loss: 0.9530 - mse: 0.9530 - val_loss: 1.1339 - val_mse: 1.1339 - 18ms/epoch - 18ms/step\n",
      "Epoch 25/500\n",
      "1/1 - 0s - loss: 0.9316 - mse: 0.9316 - val_loss: 1.1097 - val_mse: 1.1097 - 17ms/epoch - 17ms/step\n",
      "Epoch 26/500\n",
      "1/1 - 0s - loss: 0.9108 - mse: 0.9108 - val_loss: 1.0861 - val_mse: 1.0861 - 13ms/epoch - 13ms/step\n",
      "Epoch 27/500\n",
      "1/1 - 0s - loss: 0.8905 - mse: 0.8905 - val_loss: 1.0632 - val_mse: 1.0632 - 13ms/epoch - 13ms/step\n",
      "Epoch 28/500\n",
      "1/1 - 0s - loss: 0.8708 - mse: 0.8708 - val_loss: 1.0408 - val_mse: 1.0408 - 15ms/epoch - 15ms/step\n",
      "Epoch 29/500\n",
      "1/1 - 0s - loss: 0.8517 - mse: 0.8517 - val_loss: 1.0190 - val_mse: 1.0190 - 19ms/epoch - 19ms/step\n",
      "Epoch 30/500\n",
      "1/1 - 0s - loss: 0.8331 - mse: 0.8331 - val_loss: 0.9978 - val_mse: 0.9978 - 17ms/epoch - 17ms/step\n",
      "Epoch 31/500\n",
      "1/1 - 0s - loss: 0.8151 - mse: 0.8151 - val_loss: 0.9772 - val_mse: 0.9772 - 13ms/epoch - 13ms/step\n",
      "Epoch 32/500\n",
      "1/1 - 0s - loss: 0.7976 - mse: 0.7976 - val_loss: 0.9570 - val_mse: 0.9570 - 13ms/epoch - 13ms/step\n",
      "Epoch 33/500\n",
      "1/1 - 0s - loss: 0.7805 - mse: 0.7805 - val_loss: 0.9374 - val_mse: 0.9374 - 21ms/epoch - 21ms/step\n",
      "Epoch 34/500\n",
      "1/1 - 0s - loss: 0.7640 - mse: 0.7640 - val_loss: 0.9183 - val_mse: 0.9183 - 19ms/epoch - 19ms/step\n",
      "Epoch 35/500\n",
      "1/1 - 0s - loss: 0.7479 - mse: 0.7479 - val_loss: 0.8996 - val_mse: 0.8996 - 17ms/epoch - 17ms/step\n",
      "Epoch 36/500\n",
      "1/1 - 0s - loss: 0.7322 - mse: 0.7322 - val_loss: 0.8815 - val_mse: 0.8815 - 19ms/epoch - 19ms/step\n",
      "Epoch 37/500\n",
      "1/1 - 0s - loss: 0.7170 - mse: 0.7170 - val_loss: 0.8637 - val_mse: 0.8637 - 15ms/epoch - 15ms/step\n",
      "Epoch 38/500\n",
      "1/1 - 0s - loss: 0.7022 - mse: 0.7022 - val_loss: 0.8465 - val_mse: 0.8465 - 15ms/epoch - 15ms/step\n",
      "Epoch 39/500\n",
      "1/1 - 0s - loss: 0.6878 - mse: 0.6878 - val_loss: 0.8296 - val_mse: 0.8296 - 16ms/epoch - 16ms/step\n",
      "Epoch 40/500\n",
      "1/1 - 0s - loss: 0.6738 - mse: 0.6738 - val_loss: 0.8132 - val_mse: 0.8132 - 16ms/epoch - 16ms/step\n",
      "Epoch 41/500\n",
      "1/1 - 0s - loss: 0.6602 - mse: 0.6602 - val_loss: 0.7972 - val_mse: 0.7972 - 16ms/epoch - 16ms/step\n",
      "Epoch 42/500\n",
      "1/1 - 0s - loss: 0.6469 - mse: 0.6469 - val_loss: 0.7816 - val_mse: 0.7816 - 16ms/epoch - 16ms/step\n",
      "Epoch 43/500\n",
      "1/1 - 0s - loss: 0.6340 - mse: 0.6340 - val_loss: 0.7663 - val_mse: 0.7663 - 16ms/epoch - 16ms/step\n",
      "Epoch 44/500\n",
      "1/1 - 0s - loss: 0.6214 - mse: 0.6214 - val_loss: 0.7515 - val_mse: 0.7515 - 17ms/epoch - 17ms/step\n",
      "Epoch 45/500\n",
      "1/1 - 0s - loss: 0.6091 - mse: 0.6091 - val_loss: 0.7370 - val_mse: 0.7370 - 16ms/epoch - 16ms/step\n",
      "Epoch 46/500\n",
      "1/1 - 0s - loss: 0.5972 - mse: 0.5972 - val_loss: 0.7228 - val_mse: 0.7228 - 14ms/epoch - 14ms/step\n",
      "Epoch 47/500\n",
      "1/1 - 0s - loss: 0.5855 - mse: 0.5855 - val_loss: 0.7091 - val_mse: 0.7091 - 12ms/epoch - 12ms/step\n",
      "Epoch 48/500\n",
      "1/1 - 0s - loss: 0.5741 - mse: 0.5741 - val_loss: 0.6956 - val_mse: 0.6956 - 14ms/epoch - 14ms/step\n",
      "Epoch 49/500\n",
      "1/1 - 0s - loss: 0.5630 - mse: 0.5630 - val_loss: 0.6825 - val_mse: 0.6825 - 16ms/epoch - 16ms/step\n",
      "Epoch 50/500\n",
      "1/1 - 0s - loss: 0.5522 - mse: 0.5522 - val_loss: 0.6698 - val_mse: 0.6698 - 17ms/epoch - 17ms/step\n",
      "Epoch 51/500\n",
      "1/1 - 0s - loss: 0.5416 - mse: 0.5416 - val_loss: 0.6573 - val_mse: 0.6573 - 17ms/epoch - 17ms/step\n",
      "Epoch 52/500\n",
      "1/1 - 0s - loss: 0.5313 - mse: 0.5313 - val_loss: 0.6452 - val_mse: 0.6452 - 16ms/epoch - 16ms/step\n",
      "Epoch 53/500\n",
      "1/1 - 0s - loss: 0.5212 - mse: 0.5212 - val_loss: 0.6333 - val_mse: 0.6333 - 16ms/epoch - 16ms/step\n",
      "Epoch 54/500\n",
      "1/1 - 0s - loss: 0.5113 - mse: 0.5113 - val_loss: 0.6218 - val_mse: 0.6218 - 16ms/epoch - 16ms/step\n",
      "Epoch 55/500\n",
      "1/1 - 0s - loss: 0.5017 - mse: 0.5017 - val_loss: 0.6105 - val_mse: 0.6105 - 17ms/epoch - 17ms/step\n",
      "Epoch 56/500\n",
      "1/1 - 0s - loss: 0.4922 - mse: 0.4922 - val_loss: 0.5995 - val_mse: 0.5995 - 14ms/epoch - 14ms/step\n",
      "Epoch 57/500\n",
      "1/1 - 0s - loss: 0.4830 - mse: 0.4830 - val_loss: 0.5888 - val_mse: 0.5888 - 12ms/epoch - 12ms/step\n",
      "Epoch 58/500\n",
      "1/1 - 0s - loss: 0.4739 - mse: 0.4739 - val_loss: 0.5783 - val_mse: 0.5783 - 13ms/epoch - 13ms/step\n",
      "Epoch 59/500\n",
      "1/1 - 0s - loss: 0.4651 - mse: 0.4651 - val_loss: 0.5681 - val_mse: 0.5681 - 15ms/epoch - 15ms/step\n",
      "Epoch 60/500\n",
      "1/1 - 0s - loss: 0.4564 - mse: 0.4564 - val_loss: 0.5582 - val_mse: 0.5582 - 16ms/epoch - 16ms/step\n",
      "Epoch 61/500\n",
      "1/1 - 0s - loss: 0.4479 - mse: 0.4479 - val_loss: 0.5485 - val_mse: 0.5485 - 17ms/epoch - 17ms/step\n",
      "Epoch 62/500\n",
      "1/1 - 0s - loss: 0.4395 - mse: 0.4395 - val_loss: 0.5390 - val_mse: 0.5390 - 17ms/epoch - 17ms/step\n",
      "Epoch 63/500\n",
      "1/1 - 0s - loss: 0.4314 - mse: 0.4314 - val_loss: 0.5297 - val_mse: 0.5297 - 16ms/epoch - 16ms/step\n",
      "Epoch 64/500\n",
      "1/1 - 0s - loss: 0.4233 - mse: 0.4233 - val_loss: 0.5207 - val_mse: 0.5207 - 16ms/epoch - 16ms/step\n",
      "Epoch 65/500\n",
      "1/1 - 0s - loss: 0.4155 - mse: 0.4155 - val_loss: 0.5119 - val_mse: 0.5119 - 16ms/epoch - 16ms/step\n",
      "Epoch 66/500\n",
      "1/1 - 0s - loss: 0.4078 - mse: 0.4078 - val_loss: 0.5032 - val_mse: 0.5032 - 16ms/epoch - 16ms/step\n",
      "Epoch 67/500\n",
      "1/1 - 0s - loss: 0.4002 - mse: 0.4002 - val_loss: 0.4948 - val_mse: 0.4948 - 17ms/epoch - 17ms/step\n",
      "Epoch 68/500\n",
      "1/1 - 0s - loss: 0.3928 - mse: 0.3928 - val_loss: 0.4866 - val_mse: 0.4866 - 13ms/epoch - 13ms/step\n",
      "Epoch 69/500\n",
      "1/1 - 0s - loss: 0.3855 - mse: 0.3855 - val_loss: 0.4785 - val_mse: 0.4785 - 12ms/epoch - 12ms/step\n",
      "Epoch 70/500\n",
      "1/1 - 0s - loss: 0.3784 - mse: 0.3784 - val_loss: 0.4706 - val_mse: 0.4706 - 14ms/epoch - 14ms/step\n",
      "Epoch 71/500\n",
      "1/1 - 0s - loss: 0.3713 - mse: 0.3713 - val_loss: 0.4629 - val_mse: 0.4629 - 17ms/epoch - 17ms/step\n",
      "Epoch 72/500\n",
      "1/1 - 0s - loss: 0.3645 - mse: 0.3645 - val_loss: 0.4553 - val_mse: 0.4553 - 17ms/epoch - 17ms/step\n",
      "Epoch 73/500\n",
      "1/1 - 0s - loss: 0.3577 - mse: 0.3577 - val_loss: 0.4480 - val_mse: 0.4480 - 16ms/epoch - 16ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 74/500\n",
      "1/1 - 0s - loss: 0.3511 - mse: 0.3511 - val_loss: 0.4407 - val_mse: 0.4407 - 17ms/epoch - 17ms/step\n",
      "Epoch 75/500\n",
      "1/1 - 0s - loss: 0.3446 - mse: 0.3446 - val_loss: 0.4336 - val_mse: 0.4336 - 16ms/epoch - 16ms/step\n",
      "Epoch 76/500\n",
      "1/1 - 0s - loss: 0.3382 - mse: 0.3382 - val_loss: 0.4267 - val_mse: 0.4267 - 16ms/epoch - 16ms/step\n",
      "Epoch 77/500\n",
      "1/1 - 0s - loss: 0.3320 - mse: 0.3320 - val_loss: 0.4199 - val_mse: 0.4199 - 16ms/epoch - 16ms/step\n",
      "Epoch 78/500\n",
      "1/1 - 0s - loss: 0.3259 - mse: 0.3259 - val_loss: 0.4132 - val_mse: 0.4132 - 16ms/epoch - 16ms/step\n",
      "Epoch 79/500\n",
      "1/1 - 0s - loss: 0.3199 - mse: 0.3199 - val_loss: 0.4067 - val_mse: 0.4067 - 15ms/epoch - 15ms/step\n",
      "Epoch 80/500\n",
      "1/1 - 0s - loss: 0.3140 - mse: 0.3140 - val_loss: 0.4003 - val_mse: 0.4003 - 16ms/epoch - 16ms/step\n",
      "Epoch 81/500\n",
      "1/1 - 0s - loss: 0.3083 - mse: 0.3083 - val_loss: 0.3940 - val_mse: 0.3940 - 16ms/epoch - 16ms/step\n",
      "Epoch 82/500\n",
      "1/1 - 0s - loss: 0.3026 - mse: 0.3026 - val_loss: 0.3878 - val_mse: 0.3878 - 15ms/epoch - 15ms/step\n",
      "Epoch 83/500\n",
      "1/1 - 0s - loss: 0.2971 - mse: 0.2971 - val_loss: 0.3818 - val_mse: 0.3818 - 15ms/epoch - 15ms/step\n",
      "Epoch 84/500\n",
      "1/1 - 0s - loss: 0.2918 - mse: 0.2918 - val_loss: 0.3758 - val_mse: 0.3758 - 16ms/epoch - 16ms/step\n",
      "Epoch 85/500\n",
      "1/1 - 0s - loss: 0.2865 - mse: 0.2865 - val_loss: 0.3700 - val_mse: 0.3700 - 15ms/epoch - 15ms/step\n",
      "Epoch 86/500\n",
      "1/1 - 0s - loss: 0.2814 - mse: 0.2814 - val_loss: 0.3643 - val_mse: 0.3643 - 15ms/epoch - 15ms/step\n",
      "Epoch 87/500\n",
      "1/1 - 0s - loss: 0.2763 - mse: 0.2763 - val_loss: 0.3587 - val_mse: 0.3587 - 15ms/epoch - 15ms/step\n",
      "Epoch 88/500\n",
      "1/1 - 0s - loss: 0.2714 - mse: 0.2714 - val_loss: 0.3532 - val_mse: 0.3532 - 15ms/epoch - 15ms/step\n",
      "Epoch 89/500\n",
      "1/1 - 0s - loss: 0.2667 - mse: 0.2667 - val_loss: 0.3479 - val_mse: 0.3479 - 15ms/epoch - 15ms/step\n",
      "Epoch 90/500\n",
      "1/1 - 0s - loss: 0.2620 - mse: 0.2620 - val_loss: 0.3426 - val_mse: 0.3426 - 15ms/epoch - 15ms/step\n",
      "Epoch 91/500\n",
      "1/1 - 0s - loss: 0.2575 - mse: 0.2575 - val_loss: 0.3374 - val_mse: 0.3374 - 15ms/epoch - 15ms/step\n",
      "Epoch 92/500\n",
      "1/1 - 0s - loss: 0.2530 - mse: 0.2530 - val_loss: 0.3324 - val_mse: 0.3324 - 14ms/epoch - 14ms/step\n",
      "Epoch 93/500\n",
      "1/1 - 0s - loss: 0.2487 - mse: 0.2487 - val_loss: 0.3274 - val_mse: 0.3274 - 15ms/epoch - 15ms/step\n",
      "Epoch 94/500\n",
      "1/1 - 0s - loss: 0.2446 - mse: 0.2446 - val_loss: 0.3226 - val_mse: 0.3226 - 16ms/epoch - 16ms/step\n",
      "Epoch 95/500\n",
      "1/1 - 0s - loss: 0.2405 - mse: 0.2405 - val_loss: 0.3178 - val_mse: 0.3178 - 14ms/epoch - 14ms/step\n",
      "Epoch 96/500\n",
      "1/1 - 0s - loss: 0.2365 - mse: 0.2365 - val_loss: 0.3131 - val_mse: 0.3131 - 12ms/epoch - 12ms/step\n",
      "Epoch 97/500\n",
      "1/1 - 0s - loss: 0.2327 - mse: 0.2327 - val_loss: 0.3086 - val_mse: 0.3086 - 12ms/epoch - 12ms/step\n",
      "Epoch 98/500\n",
      "1/1 - 0s - loss: 0.2289 - mse: 0.2289 - val_loss: 0.3041 - val_mse: 0.3041 - 16ms/epoch - 16ms/step\n",
      "Epoch 99/500\n",
      "1/1 - 0s - loss: 0.2253 - mse: 0.2253 - val_loss: 0.2998 - val_mse: 0.2998 - 16ms/epoch - 16ms/step\n",
      "Epoch 100/500\n",
      "1/1 - 0s - loss: 0.2218 - mse: 0.2218 - val_loss: 0.2955 - val_mse: 0.2955 - 18ms/epoch - 18ms/step\n",
      "Epoch 101/500\n",
      "1/1 - 0s - loss: 0.2183 - mse: 0.2183 - val_loss: 0.2913 - val_mse: 0.2913 - 17ms/epoch - 17ms/step\n",
      "Epoch 102/500\n",
      "1/1 - 0s - loss: 0.2150 - mse: 0.2150 - val_loss: 0.2872 - val_mse: 0.2872 - 16ms/epoch - 16ms/step\n",
      "Epoch 103/500\n",
      "1/1 - 0s - loss: 0.2118 - mse: 0.2118 - val_loss: 0.2833 - val_mse: 0.2833 - 16ms/epoch - 16ms/step\n",
      "Epoch 104/500\n",
      "1/1 - 0s - loss: 0.2087 - mse: 0.2087 - val_loss: 0.2794 - val_mse: 0.2794 - 16ms/epoch - 16ms/step\n",
      "Epoch 105/500\n",
      "1/1 - 0s - loss: 0.2056 - mse: 0.2056 - val_loss: 0.2756 - val_mse: 0.2756 - 16ms/epoch - 16ms/step\n",
      "Epoch 106/500\n",
      "1/1 - 0s - loss: 0.2027 - mse: 0.2027 - val_loss: 0.2718 - val_mse: 0.2718 - 16ms/epoch - 16ms/step\n",
      "Epoch 107/500\n",
      "1/1 - 0s - loss: 0.1999 - mse: 0.1999 - val_loss: 0.2682 - val_mse: 0.2682 - 16ms/epoch - 16ms/step\n",
      "Epoch 108/500\n",
      "1/1 - 0s - loss: 0.1971 - mse: 0.1971 - val_loss: 0.2647 - val_mse: 0.2647 - 15ms/epoch - 15ms/step\n",
      "Epoch 109/500\n",
      "1/1 - 0s - loss: 0.1944 - mse: 0.1944 - val_loss: 0.2612 - val_mse: 0.2612 - 16ms/epoch - 16ms/step\n",
      "Epoch 110/500\n",
      "1/1 - 0s - loss: 0.1918 - mse: 0.1918 - val_loss: 0.2578 - val_mse: 0.2578 - 17ms/epoch - 17ms/step\n",
      "Epoch 111/500\n",
      "1/1 - 0s - loss: 0.1893 - mse: 0.1893 - val_loss: 0.2545 - val_mse: 0.2545 - 16ms/epoch - 16ms/step\n",
      "Epoch 112/500\n",
      "1/1 - 0s - loss: 0.1869 - mse: 0.1869 - val_loss: 0.2513 - val_mse: 0.2513 - 16ms/epoch - 16ms/step\n",
      "Epoch 113/500\n",
      "1/1 - 0s - loss: 0.1845 - mse: 0.1845 - val_loss: 0.2481 - val_mse: 0.2481 - 16ms/epoch - 16ms/step\n",
      "Epoch 114/500\n",
      "1/1 - 0s - loss: 0.1822 - mse: 0.1822 - val_loss: 0.2450 - val_mse: 0.2450 - 16ms/epoch - 16ms/step\n",
      "Epoch 115/500\n",
      "1/1 - 0s - loss: 0.1799 - mse: 0.1799 - val_loss: 0.2420 - val_mse: 0.2420 - 16ms/epoch - 16ms/step\n",
      "Epoch 116/500\n",
      "1/1 - 0s - loss: 0.1778 - mse: 0.1778 - val_loss: 0.2391 - val_mse: 0.2391 - 15ms/epoch - 15ms/step\n",
      "Epoch 117/500\n",
      "1/1 - 0s - loss: 0.1757 - mse: 0.1757 - val_loss: 0.2362 - val_mse: 0.2362 - 15ms/epoch - 15ms/step\n",
      "Epoch 118/500\n",
      "1/1 - 0s - loss: 0.1736 - mse: 0.1736 - val_loss: 0.2334 - val_mse: 0.2334 - 15ms/epoch - 15ms/step\n",
      "Epoch 119/500\n",
      "1/1 - 0s - loss: 0.1716 - mse: 0.1716 - val_loss: 0.2307 - val_mse: 0.2307 - 16ms/epoch - 16ms/step\n",
      "Epoch 120/500\n",
      "1/1 - 0s - loss: 0.1697 - mse: 0.1697 - val_loss: 0.2280 - val_mse: 0.2280 - 16ms/epoch - 16ms/step\n",
      "Epoch 121/500\n",
      "1/1 - 0s - loss: 0.1678 - mse: 0.1678 - val_loss: 0.2254 - val_mse: 0.2254 - 15ms/epoch - 15ms/step\n",
      "Epoch 122/500\n",
      "1/1 - 0s - loss: 0.1659 - mse: 0.1659 - val_loss: 0.2228 - val_mse: 0.2228 - 15ms/epoch - 15ms/step\n",
      "Epoch 123/500\n",
      "1/1 - 0s - loss: 0.1641 - mse: 0.1641 - val_loss: 0.2203 - val_mse: 0.2203 - 16ms/epoch - 16ms/step\n",
      "Epoch 124/500\n",
      "1/1 - 0s - loss: 0.1624 - mse: 0.1624 - val_loss: 0.2179 - val_mse: 0.2179 - 16ms/epoch - 16ms/step\n",
      "Epoch 125/500\n",
      "1/1 - 0s - loss: 0.1606 - mse: 0.1606 - val_loss: 0.2155 - val_mse: 0.2155 - 15ms/epoch - 15ms/step\n",
      "Epoch 126/500\n",
      "1/1 - 0s - loss: 0.1590 - mse: 0.1590 - val_loss: 0.2132 - val_mse: 0.2132 - 16ms/epoch - 16ms/step\n",
      "Epoch 127/500\n",
      "1/1 - 0s - loss: 0.1573 - mse: 0.1573 - val_loss: 0.2109 - val_mse: 0.2109 - 16ms/epoch - 16ms/step\n",
      "Epoch 128/500\n",
      "1/1 - 0s - loss: 0.1557 - mse: 0.1557 - val_loss: 0.2087 - val_mse: 0.2087 - 16ms/epoch - 16ms/step\n",
      "Epoch 129/500\n",
      "1/1 - 0s - loss: 0.1542 - mse: 0.1542 - val_loss: 0.2065 - val_mse: 0.2065 - 17ms/epoch - 17ms/step\n",
      "Epoch 130/500\n",
      "1/1 - 0s - loss: 0.1526 - mse: 0.1526 - val_loss: 0.2044 - val_mse: 0.2044 - 17ms/epoch - 17ms/step\n",
      "Epoch 131/500\n",
      "1/1 - 0s - loss: 0.1511 - mse: 0.1511 - val_loss: 0.2023 - val_mse: 0.2023 - 23ms/epoch - 23ms/step\n",
      "Epoch 132/500\n",
      "1/1 - 0s - loss: 0.1497 - mse: 0.1497 - val_loss: 0.2003 - val_mse: 0.2003 - 17ms/epoch - 17ms/step\n",
      "Epoch 133/500\n",
      "1/1 - 0s - loss: 0.1482 - mse: 0.1482 - val_loss: 0.1983 - val_mse: 0.1983 - 16ms/epoch - 16ms/step\n",
      "Epoch 134/500\n",
      "1/1 - 0s - loss: 0.1468 - mse: 0.1468 - val_loss: 0.1964 - val_mse: 0.1964 - 16ms/epoch - 16ms/step\n",
      "Epoch 135/500\n",
      "1/1 - 0s - loss: 0.1455 - mse: 0.1455 - val_loss: 0.1945 - val_mse: 0.1945 - 16ms/epoch - 16ms/step\n",
      "Epoch 136/500\n",
      "1/1 - 0s - loss: 0.1441 - mse: 0.1441 - val_loss: 0.1927 - val_mse: 0.1927 - 16ms/epoch - 16ms/step\n",
      "Epoch 137/500\n",
      "1/1 - 0s - loss: 0.1428 - mse: 0.1428 - val_loss: 0.1909 - val_mse: 0.1909 - 17ms/epoch - 17ms/step\n",
      "Epoch 138/500\n",
      "1/1 - 0s - loss: 0.1415 - mse: 0.1415 - val_loss: 0.1891 - val_mse: 0.1891 - 16ms/epoch - 16ms/step\n",
      "Epoch 139/500\n",
      "1/1 - 0s - loss: 0.1402 - mse: 0.1402 - val_loss: 0.1874 - val_mse: 0.1874 - 15ms/epoch - 15ms/step\n",
      "Epoch 140/500\n",
      "1/1 - 0s - loss: 0.1390 - mse: 0.1390 - val_loss: 0.1857 - val_mse: 0.1857 - 16ms/epoch - 16ms/step\n",
      "Epoch 141/500\n",
      "1/1 - 0s - loss: 0.1377 - mse: 0.1377 - val_loss: 0.1840 - val_mse: 0.1840 - 25ms/epoch - 25ms/step\n",
      "Epoch 142/500\n",
      "1/1 - 0s - loss: 0.1365 - mse: 0.1365 - val_loss: 0.1824 - val_mse: 0.1824 - 16ms/epoch - 16ms/step\n",
      "Epoch 143/500\n",
      "1/1 - 0s - loss: 0.1353 - mse: 0.1353 - val_loss: 0.1808 - val_mse: 0.1808 - 16ms/epoch - 16ms/step\n",
      "Epoch 144/500\n",
      "1/1 - 0s - loss: 0.1342 - mse: 0.1342 - val_loss: 0.1793 - val_mse: 0.1793 - 16ms/epoch - 16ms/step\n",
      "Epoch 145/500\n",
      "1/1 - 0s - loss: 0.1330 - mse: 0.1330 - val_loss: 0.1778 - val_mse: 0.1778 - 16ms/epoch - 16ms/step\n",
      "Epoch 146/500\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1/1 - 0s - loss: 0.1319 - mse: 0.1319 - val_loss: 0.1763 - val_mse: 0.1763 - 16ms/epoch - 16ms/step\n",
      "Epoch 147/500\n",
      "1/1 - 0s - loss: 0.1308 - mse: 0.1308 - val_loss: 0.1749 - val_mse: 0.1749 - 17ms/epoch - 17ms/step\n",
      "Epoch 148/500\n",
      "1/1 - 0s - loss: 0.1297 - mse: 0.1297 - val_loss: 0.1734 - val_mse: 0.1734 - 16ms/epoch - 16ms/step\n",
      "Epoch 149/500\n",
      "1/1 - 0s - loss: 0.1286 - mse: 0.1286 - val_loss: 0.1720 - val_mse: 0.1720 - 15ms/epoch - 15ms/step\n",
      "Epoch 150/500\n",
      "1/1 - 0s - loss: 0.1275 - mse: 0.1275 - val_loss: 0.1707 - val_mse: 0.1707 - 16ms/epoch - 16ms/step\n",
      "Epoch 151/500\n",
      "1/1 - 0s - loss: 0.1265 - mse: 0.1265 - val_loss: 0.1693 - val_mse: 0.1693 - 16ms/epoch - 16ms/step\n",
      "Epoch 152/500\n",
      "1/1 - 0s - loss: 0.1255 - mse: 0.1255 - val_loss: 0.1680 - val_mse: 0.1680 - 16ms/epoch - 16ms/step\n",
      "Epoch 153/500\n",
      "1/1 - 0s - loss: 0.1244 - mse: 0.1244 - val_loss: 0.1667 - val_mse: 0.1667 - 17ms/epoch - 17ms/step\n",
      "Epoch 154/500\n",
      "1/1 - 0s - loss: 0.1234 - mse: 0.1234 - val_loss: 0.1655 - val_mse: 0.1655 - 17ms/epoch - 17ms/step\n",
      "Epoch 155/500\n",
      "1/1 - 0s - loss: 0.1225 - mse: 0.1225 - val_loss: 0.1642 - val_mse: 0.1642 - 17ms/epoch - 17ms/step\n",
      "Epoch 156/500\n",
      "1/1 - 0s - loss: 0.1215 - mse: 0.1215 - val_loss: 0.1630 - val_mse: 0.1630 - 16ms/epoch - 16ms/step\n",
      "Epoch 157/500\n",
      "1/1 - 0s - loss: 0.1205 - mse: 0.1205 - val_loss: 0.1618 - val_mse: 0.1618 - 17ms/epoch - 17ms/step\n",
      "Epoch 158/500\n",
      "1/1 - 0s - loss: 0.1196 - mse: 0.1196 - val_loss: 0.1606 - val_mse: 0.1606 - 16ms/epoch - 16ms/step\n",
      "Epoch 159/500\n",
      "1/1 - 0s - loss: 0.1187 - mse: 0.1187 - val_loss: 0.1595 - val_mse: 0.1595 - 17ms/epoch - 17ms/step\n",
      "Epoch 160/500\n",
      "1/1 - 0s - loss: 0.1177 - mse: 0.1177 - val_loss: 0.1584 - val_mse: 0.1584 - 16ms/epoch - 16ms/step\n",
      "Epoch 161/500\n",
      "1/1 - 0s - loss: 0.1168 - mse: 0.1168 - val_loss: 0.1572 - val_mse: 0.1572 - 16ms/epoch - 16ms/step\n",
      "Epoch 162/500\n",
      "1/1 - 0s - loss: 0.1159 - mse: 0.1159 - val_loss: 0.1561 - val_mse: 0.1561 - 16ms/epoch - 16ms/step\n",
      "Epoch 163/500\n",
      "1/1 - 0s - loss: 0.1151 - mse: 0.1151 - val_loss: 0.1551 - val_mse: 0.1551 - 16ms/epoch - 16ms/step\n",
      "Epoch 164/500\n",
      "1/1 - 0s - loss: 0.1142 - mse: 0.1142 - val_loss: 0.1540 - val_mse: 0.1540 - 16ms/epoch - 16ms/step\n",
      "Epoch 165/500\n",
      "1/1 - 0s - loss: 0.1133 - mse: 0.1133 - val_loss: 0.1529 - val_mse: 0.1529 - 16ms/epoch - 16ms/step\n",
      "Epoch 166/500\n",
      "1/1 - 0s - loss: 0.1125 - mse: 0.1125 - val_loss: 0.1519 - val_mse: 0.1519 - 16ms/epoch - 16ms/step\n",
      "Epoch 167/500\n",
      "1/1 - 0s - loss: 0.1116 - mse: 0.1116 - val_loss: 0.1509 - val_mse: 0.1509 - 16ms/epoch - 16ms/step\n",
      "Epoch 168/500\n",
      "1/1 - 0s - loss: 0.1108 - mse: 0.1108 - val_loss: 0.1499 - val_mse: 0.1499 - 16ms/epoch - 16ms/step\n",
      "Epoch 169/500\n",
      "1/1 - 0s - loss: 0.1100 - mse: 0.1100 - val_loss: 0.1489 - val_mse: 0.1489 - 15ms/epoch - 15ms/step\n",
      "Epoch 170/500\n",
      "1/1 - 0s - loss: 0.1092 - mse: 0.1092 - val_loss: 0.1479 - val_mse: 0.1479 - 16ms/epoch - 16ms/step\n",
      "Epoch 171/500\n",
      "1/1 - 0s - loss: 0.1084 - mse: 0.1084 - val_loss: 0.1469 - val_mse: 0.1469 - 16ms/epoch - 16ms/step\n",
      "Epoch 172/500\n",
      "1/1 - 0s - loss: 0.1076 - mse: 0.1076 - val_loss: 0.1460 - val_mse: 0.1460 - 17ms/epoch - 17ms/step\n",
      "Epoch 173/500\n",
      "1/1 - 0s - loss: 0.1068 - mse: 0.1068 - val_loss: 0.1451 - val_mse: 0.1451 - 16ms/epoch - 16ms/step\n",
      "Epoch 174/500\n",
      "1/1 - 0s - loss: 0.1061 - mse: 0.1061 - val_loss: 0.1441 - val_mse: 0.1441 - 16ms/epoch - 16ms/step\n",
      "Epoch 175/500\n",
      "1/1 - 0s - loss: 0.1053 - mse: 0.1053 - val_loss: 0.1432 - val_mse: 0.1432 - 15ms/epoch - 15ms/step\n",
      "Epoch 176/500\n",
      "1/1 - 0s - loss: 0.1045 - mse: 0.1045 - val_loss: 0.1423 - val_mse: 0.1423 - 15ms/epoch - 15ms/step\n",
      "Epoch 177/500\n",
      "1/1 - 0s - loss: 0.1038 - mse: 0.1038 - val_loss: 0.1414 - val_mse: 0.1414 - 16ms/epoch - 16ms/step\n",
      "Epoch 178/500\n",
      "1/1 - 0s - loss: 0.1031 - mse: 0.1031 - val_loss: 0.1405 - val_mse: 0.1405 - 16ms/epoch - 16ms/step\n",
      "Epoch 179/500\n",
      "1/1 - 0s - loss: 0.1023 - mse: 0.1023 - val_loss: 0.1397 - val_mse: 0.1397 - 16ms/epoch - 16ms/step\n",
      "Epoch 180/500\n",
      "1/1 - 0s - loss: 0.1016 - mse: 0.1016 - val_loss: 0.1388 - val_mse: 0.1388 - 16ms/epoch - 16ms/step\n",
      "Epoch 181/500\n",
      "1/1 - 0s - loss: 0.1009 - mse: 0.1009 - val_loss: 0.1380 - val_mse: 0.1380 - 16ms/epoch - 16ms/step\n",
      "Epoch 182/500\n",
      "1/1 - 0s - loss: 0.1002 - mse: 0.1002 - val_loss: 0.1371 - val_mse: 0.1371 - 16ms/epoch - 16ms/step\n",
      "Epoch 183/500\n",
      "1/1 - 0s - loss: 0.0995 - mse: 0.0995 - val_loss: 0.1363 - val_mse: 0.1363 - 16ms/epoch - 16ms/step\n",
      "Epoch 184/500\n",
      "1/1 - 0s - loss: 0.0988 - mse: 0.0988 - val_loss: 0.1355 - val_mse: 0.1355 - 16ms/epoch - 16ms/step\n",
      "Epoch 185/500\n",
      "1/1 - 0s - loss: 0.0981 - mse: 0.0981 - val_loss: 0.1346 - val_mse: 0.1346 - 15ms/epoch - 15ms/step\n",
      "Epoch 186/500\n",
      "1/1 - 0s - loss: 0.0975 - mse: 0.0975 - val_loss: 0.1338 - val_mse: 0.1338 - 15ms/epoch - 15ms/step\n",
      "Epoch 187/500\n",
      "1/1 - 0s - loss: 0.0968 - mse: 0.0968 - val_loss: 0.1330 - val_mse: 0.1330 - 17ms/epoch - 17ms/step\n",
      "Epoch 188/500\n",
      "1/1 - 0s - loss: 0.0961 - mse: 0.0961 - val_loss: 0.1323 - val_mse: 0.1323 - 15ms/epoch - 15ms/step\n",
      "Epoch 189/500\n",
      "1/1 - 0s - loss: 0.0955 - mse: 0.0955 - val_loss: 0.1315 - val_mse: 0.1315 - 17ms/epoch - 17ms/step\n",
      "Epoch 190/500\n",
      "1/1 - 0s - loss: 0.0948 - mse: 0.0948 - val_loss: 0.1307 - val_mse: 0.1307 - 16ms/epoch - 16ms/step\n",
      "Epoch 191/500\n",
      "1/1 - 0s - loss: 0.0942 - mse: 0.0942 - val_loss: 0.1299 - val_mse: 0.1299 - 17ms/epoch - 17ms/step\n",
      "Epoch 192/500\n",
      "1/1 - 0s - loss: 0.0936 - mse: 0.0936 - val_loss: 0.1292 - val_mse: 0.1292 - 18ms/epoch - 18ms/step\n",
      "Epoch 193/500\n",
      "1/1 - 0s - loss: 0.0929 - mse: 0.0929 - val_loss: 0.1284 - val_mse: 0.1284 - 17ms/epoch - 17ms/step\n",
      "Epoch 194/500\n",
      "1/1 - 0s - loss: 0.0923 - mse: 0.0923 - val_loss: 0.1277 - val_mse: 0.1277 - 17ms/epoch - 17ms/step\n",
      "Epoch 195/500\n",
      "1/1 - 0s - loss: 0.0917 - mse: 0.0917 - val_loss: 0.1270 - val_mse: 0.1270 - 17ms/epoch - 17ms/step\n",
      "Epoch 196/500\n",
      "1/1 - 0s - loss: 0.0911 - mse: 0.0911 - val_loss: 0.1262 - val_mse: 0.1262 - 16ms/epoch - 16ms/step\n",
      "Epoch 197/500\n",
      "1/1 - 0s - loss: 0.0905 - mse: 0.0905 - val_loss: 0.1255 - val_mse: 0.1255 - 16ms/epoch - 16ms/step\n",
      "Epoch 198/500\n",
      "1/1 - 0s - loss: 0.0899 - mse: 0.0899 - val_loss: 0.1248 - val_mse: 0.1248 - 16ms/epoch - 16ms/step\n",
      "Epoch 199/500\n",
      "1/1 - 0s - loss: 0.0893 - mse: 0.0893 - val_loss: 0.1241 - val_mse: 0.1241 - 16ms/epoch - 16ms/step\n",
      "Epoch 200/500\n",
      "1/1 - 0s - loss: 0.0887 - mse: 0.0887 - val_loss: 0.1234 - val_mse: 0.1234 - 16ms/epoch - 16ms/step\n",
      "Epoch 201/500\n",
      "1/1 - 0s - loss: 0.0881 - mse: 0.0881 - val_loss: 0.1227 - val_mse: 0.1227 - 16ms/epoch - 16ms/step\n",
      "Epoch 202/500\n",
      "1/1 - 0s - loss: 0.0876 - mse: 0.0876 - val_loss: 0.1220 - val_mse: 0.1220 - 16ms/epoch - 16ms/step\n",
      "Epoch 203/500\n",
      "1/1 - 0s - loss: 0.0870 - mse: 0.0870 - val_loss: 0.1214 - val_mse: 0.1214 - 16ms/epoch - 16ms/step\n",
      "Epoch 204/500\n",
      "1/1 - 0s - loss: 0.0864 - mse: 0.0864 - val_loss: 0.1207 - val_mse: 0.1207 - 16ms/epoch - 16ms/step\n",
      "Epoch 205/500\n",
      "1/1 - 0s - loss: 0.0859 - mse: 0.0859 - val_loss: 0.1200 - val_mse: 0.1200 - 16ms/epoch - 16ms/step\n",
      "Epoch 206/500\n",
      "1/1 - 0s - loss: 0.0853 - mse: 0.0853 - val_loss: 0.1194 - val_mse: 0.1194 - 17ms/epoch - 17ms/step\n",
      "Epoch 207/500\n",
      "1/1 - 0s - loss: 0.0848 - mse: 0.0848 - val_loss: 0.1187 - val_mse: 0.1187 - 16ms/epoch - 16ms/step\n",
      "Epoch 208/500\n",
      "1/1 - 0s - loss: 0.0842 - mse: 0.0842 - val_loss: 0.1181 - val_mse: 0.1181 - 15ms/epoch - 15ms/step\n",
      "Epoch 209/500\n",
      "1/1 - 0s - loss: 0.0837 - mse: 0.0837 - val_loss: 0.1174 - val_mse: 0.1174 - 15ms/epoch - 15ms/step\n",
      "Epoch 210/500\n",
      "1/1 - 0s - loss: 0.0832 - mse: 0.0832 - val_loss: 0.1168 - val_mse: 0.1168 - 16ms/epoch - 16ms/step\n",
      "Epoch 211/500\n",
      "1/1 - 0s - loss: 0.0826 - mse: 0.0826 - val_loss: 0.1162 - val_mse: 0.1162 - 16ms/epoch - 16ms/step\n",
      "Epoch 212/500\n",
      "1/1 - 0s - loss: 0.0821 - mse: 0.0821 - val_loss: 0.1156 - val_mse: 0.1156 - 16ms/epoch - 16ms/step\n",
      "Epoch 213/500\n",
      "1/1 - 0s - loss: 0.0816 - mse: 0.0816 - val_loss: 0.1149 - val_mse: 0.1149 - 15ms/epoch - 15ms/step\n",
      "Epoch 214/500\n",
      "1/1 - 0s - loss: 0.0811 - mse: 0.0811 - val_loss: 0.1143 - val_mse: 0.1143 - 15ms/epoch - 15ms/step\n",
      "Epoch 215/500\n",
      "1/1 - 0s - loss: 0.0806 - mse: 0.0806 - val_loss: 0.1137 - val_mse: 0.1137 - 16ms/epoch - 16ms/step\n",
      "Epoch 216/500\n",
      "1/1 - 0s - loss: 0.0801 - mse: 0.0801 - val_loss: 0.1131 - val_mse: 0.1131 - 16ms/epoch - 16ms/step\n",
      "Epoch 217/500\n",
      "1/1 - 0s - loss: 0.0796 - mse: 0.0796 - val_loss: 0.1125 - val_mse: 0.1125 - 16ms/epoch - 16ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 218/500\n",
      "1/1 - 0s - loss: 0.0791 - mse: 0.0791 - val_loss: 0.1119 - val_mse: 0.1119 - 16ms/epoch - 16ms/step\n",
      "Epoch 219/500\n",
      "1/1 - 0s - loss: 0.0786 - mse: 0.0786 - val_loss: 0.1114 - val_mse: 0.1114 - 17ms/epoch - 17ms/step\n",
      "Epoch 220/500\n",
      "1/1 - 0s - loss: 0.0781 - mse: 0.0781 - val_loss: 0.1108 - val_mse: 0.1108 - 17ms/epoch - 17ms/step\n",
      "Epoch 221/500\n",
      "1/1 - 0s - loss: 0.0777 - mse: 0.0777 - val_loss: 0.1102 - val_mse: 0.1102 - 18ms/epoch - 18ms/step\n",
      "Epoch 222/500\n",
      "1/1 - 0s - loss: 0.0772 - mse: 0.0772 - val_loss: 0.1096 - val_mse: 0.1096 - 17ms/epoch - 17ms/step\n",
      "Epoch 223/500\n",
      "1/1 - 0s - loss: 0.0767 - mse: 0.0767 - val_loss: 0.1091 - val_mse: 0.1091 - 17ms/epoch - 17ms/step\n",
      "Epoch 224/500\n",
      "1/1 - 0s - loss: 0.0762 - mse: 0.0762 - val_loss: 0.1085 - val_mse: 0.1085 - 16ms/epoch - 16ms/step\n",
      "Epoch 225/500\n",
      "1/1 - 0s - loss: 0.0758 - mse: 0.0758 - val_loss: 0.1080 - val_mse: 0.1080 - 17ms/epoch - 17ms/step\n",
      "Epoch 226/500\n",
      "1/1 - 0s - loss: 0.0753 - mse: 0.0753 - val_loss: 0.1074 - val_mse: 0.1074 - 17ms/epoch - 17ms/step\n",
      "Epoch 227/500\n",
      "1/1 - 0s - loss: 0.0749 - mse: 0.0749 - val_loss: 0.1069 - val_mse: 0.1069 - 16ms/epoch - 16ms/step\n",
      "Epoch 228/500\n",
      "1/1 - 0s - loss: 0.0744 - mse: 0.0744 - val_loss: 0.1064 - val_mse: 0.1064 - 16ms/epoch - 16ms/step\n",
      "Epoch 229/500\n",
      "1/1 - 0s - loss: 0.0740 - mse: 0.0740 - val_loss: 0.1058 - val_mse: 0.1058 - 17ms/epoch - 17ms/step\n",
      "Epoch 230/500\n",
      "1/1 - 0s - loss: 0.0735 - mse: 0.0735 - val_loss: 0.1053 - val_mse: 0.1053 - 16ms/epoch - 16ms/step\n",
      "Epoch 231/500\n",
      "1/1 - 0s - loss: 0.0731 - mse: 0.0731 - val_loss: 0.1048 - val_mse: 0.1048 - 15ms/epoch - 15ms/step\n",
      "Epoch 232/500\n",
      "1/1 - 0s - loss: 0.0727 - mse: 0.0727 - val_loss: 0.1043 - val_mse: 0.1043 - 15ms/epoch - 15ms/step\n",
      "Epoch 233/500\n",
      "1/1 - 0s - loss: 0.0722 - mse: 0.0722 - val_loss: 0.1037 - val_mse: 0.1037 - 15ms/epoch - 15ms/step\n",
      "Epoch 234/500\n",
      "1/1 - 0s - loss: 0.0718 - mse: 0.0718 - val_loss: 0.1032 - val_mse: 0.1032 - 15ms/epoch - 15ms/step\n",
      "Epoch 235/500\n",
      "1/1 - 0s - loss: 0.0714 - mse: 0.0714 - val_loss: 0.1027 - val_mse: 0.1027 - 16ms/epoch - 16ms/step\n",
      "Epoch 236/500\n",
      "1/1 - 0s - loss: 0.0710 - mse: 0.0710 - val_loss: 0.1022 - val_mse: 0.1022 - 16ms/epoch - 16ms/step\n",
      "Epoch 237/500\n",
      "1/1 - 0s - loss: 0.0706 - mse: 0.0706 - val_loss: 0.1017 - val_mse: 0.1017 - 16ms/epoch - 16ms/step\n",
      "Epoch 238/500\n",
      "1/1 - 0s - loss: 0.0701 - mse: 0.0701 - val_loss: 0.1012 - val_mse: 0.1012 - 15ms/epoch - 15ms/step\n",
      "Epoch 239/500\n",
      "1/1 - 0s - loss: 0.0697 - mse: 0.0697 - val_loss: 0.1007 - val_mse: 0.1007 - 15ms/epoch - 15ms/step\n",
      "Epoch 240/500\n",
      "1/1 - 0s - loss: 0.0693 - mse: 0.0693 - val_loss: 0.1003 - val_mse: 0.1003 - 15ms/epoch - 15ms/step\n",
      "Epoch 241/500\n",
      "1/1 - 0s - loss: 0.0689 - mse: 0.0689 - val_loss: 0.0998 - val_mse: 0.0998 - 15ms/epoch - 15ms/step\n",
      "Epoch 242/500\n",
      "1/1 - 0s - loss: 0.0685 - mse: 0.0685 - val_loss: 0.0993 - val_mse: 0.0993 - 15ms/epoch - 15ms/step\n",
      "Epoch 243/500\n",
      "1/1 - 0s - loss: 0.0681 - mse: 0.0681 - val_loss: 0.0988 - val_mse: 0.0988 - 15ms/epoch - 15ms/step\n",
      "Epoch 244/500\n",
      "1/1 - 0s - loss: 0.0677 - mse: 0.0677 - val_loss: 0.0984 - val_mse: 0.0984 - 15ms/epoch - 15ms/step\n",
      "Epoch 245/500\n",
      "1/1 - 0s - loss: 0.0674 - mse: 0.0674 - val_loss: 0.0979 - val_mse: 0.0979 - 16ms/epoch - 16ms/step\n",
      "Epoch 246/500\n",
      "1/1 - 0s - loss: 0.0670 - mse: 0.0670 - val_loss: 0.0974 - val_mse: 0.0974 - 16ms/epoch - 16ms/step\n",
      "Epoch 247/500\n",
      "1/1 - 0s - loss: 0.0666 - mse: 0.0666 - val_loss: 0.0970 - val_mse: 0.0970 - 17ms/epoch - 17ms/step\n",
      "Epoch 248/500\n",
      "1/1 - 0s - loss: 0.0662 - mse: 0.0662 - val_loss: 0.0965 - val_mse: 0.0965 - 17ms/epoch - 17ms/step\n",
      "Epoch 249/500\n",
      "1/1 - 0s - loss: 0.0658 - mse: 0.0658 - val_loss: 0.0961 - val_mse: 0.0961 - 17ms/epoch - 17ms/step\n",
      "Epoch 250/500\n",
      "1/1 - 0s - loss: 0.0655 - mse: 0.0655 - val_loss: 0.0956 - val_mse: 0.0956 - 17ms/epoch - 17ms/step\n",
      "Epoch 251/500\n",
      "1/1 - 0s - loss: 0.0651 - mse: 0.0651 - val_loss: 0.0952 - val_mse: 0.0952 - 16ms/epoch - 16ms/step\n",
      "Epoch 252/500\n",
      "1/1 - 0s - loss: 0.0647 - mse: 0.0647 - val_loss: 0.0948 - val_mse: 0.0948 - 16ms/epoch - 16ms/step\n",
      "Epoch 253/500\n",
      "1/1 - 0s - loss: 0.0644 - mse: 0.0644 - val_loss: 0.0943 - val_mse: 0.0943 - 16ms/epoch - 16ms/step\n",
      "Epoch 254/500\n",
      "1/1 - 0s - loss: 0.0640 - mse: 0.0640 - val_loss: 0.0939 - val_mse: 0.0939 - 17ms/epoch - 17ms/step\n",
      "Epoch 255/500\n",
      "1/1 - 0s - loss: 0.0637 - mse: 0.0637 - val_loss: 0.0935 - val_mse: 0.0935 - 16ms/epoch - 16ms/step\n",
      "Epoch 256/500\n",
      "1/1 - 0s - loss: 0.0633 - mse: 0.0633 - val_loss: 0.0931 - val_mse: 0.0931 - 16ms/epoch - 16ms/step\n",
      "Epoch 257/500\n",
      "1/1 - 0s - loss: 0.0630 - mse: 0.0630 - val_loss: 0.0926 - val_mse: 0.0926 - 16ms/epoch - 16ms/step\n",
      "Epoch 258/500\n",
      "1/1 - 0s - loss: 0.0626 - mse: 0.0626 - val_loss: 0.0922 - val_mse: 0.0922 - 16ms/epoch - 16ms/step\n",
      "Epoch 259/500\n",
      "1/1 - 0s - loss: 0.0623 - mse: 0.0623 - val_loss: 0.0918 - val_mse: 0.0918 - 16ms/epoch - 16ms/step\n",
      "Epoch 260/500\n",
      "1/1 - 0s - loss: 0.0619 - mse: 0.0619 - val_loss: 0.0914 - val_mse: 0.0914 - 16ms/epoch - 16ms/step\n",
      "Epoch 261/500\n",
      "1/1 - 0s - loss: 0.0616 - mse: 0.0616 - val_loss: 0.0910 - val_mse: 0.0910 - 23ms/epoch - 23ms/step\n",
      "Epoch 262/500\n",
      "1/1 - 0s - loss: 0.0612 - mse: 0.0612 - val_loss: 0.0906 - val_mse: 0.0906 - 15ms/epoch - 15ms/step\n",
      "Epoch 263/500\n",
      "1/1 - 0s - loss: 0.0609 - mse: 0.0609 - val_loss: 0.0902 - val_mse: 0.0902 - 12ms/epoch - 12ms/step\n",
      "Epoch 264/500\n",
      "1/1 - 0s - loss: 0.0606 - mse: 0.0606 - val_loss: 0.0898 - val_mse: 0.0898 - 14ms/epoch - 14ms/step\n",
      "Epoch 265/500\n",
      "1/1 - 0s - loss: 0.0603 - mse: 0.0603 - val_loss: 0.0894 - val_mse: 0.0894 - 14ms/epoch - 14ms/step\n",
      "Epoch 266/500\n",
      "1/1 - 0s - loss: 0.0599 - mse: 0.0599 - val_loss: 0.0890 - val_mse: 0.0890 - 15ms/epoch - 15ms/step\n",
      "Epoch 267/500\n",
      "1/1 - 0s - loss: 0.0596 - mse: 0.0596 - val_loss: 0.0886 - val_mse: 0.0886 - 16ms/epoch - 16ms/step\n",
      "Epoch 268/500\n",
      "1/1 - 0s - loss: 0.0593 - mse: 0.0593 - val_loss: 0.0882 - val_mse: 0.0882 - 15ms/epoch - 15ms/step\n",
      "Epoch 269/500\n",
      "1/1 - 0s - loss: 0.0590 - mse: 0.0590 - val_loss: 0.0878 - val_mse: 0.0878 - 15ms/epoch - 15ms/step\n",
      "Epoch 270/500\n",
      "1/1 - 0s - loss: 0.0587 - mse: 0.0587 - val_loss: 0.0875 - val_mse: 0.0875 - 17ms/epoch - 17ms/step\n",
      "Epoch 271/500\n",
      "1/1 - 0s - loss: 0.0583 - mse: 0.0583 - val_loss: 0.0871 - val_mse: 0.0871 - 16ms/epoch - 16ms/step\n",
      "Epoch 272/500\n",
      "1/1 - 0s - loss: 0.0580 - mse: 0.0580 - val_loss: 0.0867 - val_mse: 0.0867 - 15ms/epoch - 15ms/step\n",
      "Epoch 273/500\n",
      "1/1 - 0s - loss: 0.0577 - mse: 0.0577 - val_loss: 0.0863 - val_mse: 0.0863 - 14ms/epoch - 14ms/step\n",
      "Epoch 274/500\n",
      "1/1 - 0s - loss: 0.0574 - mse: 0.0574 - val_loss: 0.0860 - val_mse: 0.0860 - 14ms/epoch - 14ms/step\n",
      "Epoch 275/500\n",
      "1/1 - 0s - loss: 0.0571 - mse: 0.0571 - val_loss: 0.0856 - val_mse: 0.0856 - 15ms/epoch - 15ms/step\n",
      "Epoch 276/500\n",
      "1/1 - 0s - loss: 0.0568 - mse: 0.0568 - val_loss: 0.0852 - val_mse: 0.0852 - 15ms/epoch - 15ms/step\n",
      "Epoch 277/500\n",
      "1/1 - 0s - loss: 0.0565 - mse: 0.0565 - val_loss: 0.0849 - val_mse: 0.0849 - 15ms/epoch - 15ms/step\n",
      "Epoch 278/500\n",
      "1/1 - 0s - loss: 0.0562 - mse: 0.0562 - val_loss: 0.0845 - val_mse: 0.0845 - 15ms/epoch - 15ms/step\n",
      "Epoch 279/500\n",
      "1/1 - 0s - loss: 0.0559 - mse: 0.0559 - val_loss: 0.0842 - val_mse: 0.0842 - 15ms/epoch - 15ms/step\n",
      "Epoch 280/500\n",
      "1/1 - 0s - loss: 0.0556 - mse: 0.0556 - val_loss: 0.0838 - val_mse: 0.0838 - 15ms/epoch - 15ms/step\n",
      "Epoch 281/500\n",
      "1/1 - 0s - loss: 0.0553 - mse: 0.0553 - val_loss: 0.0835 - val_mse: 0.0835 - 15ms/epoch - 15ms/step\n",
      "Epoch 282/500\n",
      "1/1 - 0s - loss: 0.0551 - mse: 0.0551 - val_loss: 0.0831 - val_mse: 0.0831 - 15ms/epoch - 15ms/step\n",
      "Epoch 283/500\n",
      "1/1 - 0s - loss: 0.0548 - mse: 0.0548 - val_loss: 0.0828 - val_mse: 0.0828 - 15ms/epoch - 15ms/step\n",
      "Epoch 284/500\n",
      "1/1 - 0s - loss: 0.0545 - mse: 0.0545 - val_loss: 0.0824 - val_mse: 0.0824 - 15ms/epoch - 15ms/step\n",
      "Epoch 285/500\n",
      "1/1 - 0s - loss: 0.0542 - mse: 0.0542 - val_loss: 0.0821 - val_mse: 0.0821 - 16ms/epoch - 16ms/step\n",
      "Epoch 286/500\n",
      "1/1 - 0s - loss: 0.0539 - mse: 0.0539 - val_loss: 0.0817 - val_mse: 0.0817 - 14ms/epoch - 14ms/step\n",
      "Epoch 287/500\n",
      "1/1 - 0s - loss: 0.0536 - mse: 0.0536 - val_loss: 0.0814 - val_mse: 0.0814 - 15ms/epoch - 15ms/step\n",
      "Epoch 288/500\n",
      "1/1 - 0s - loss: 0.0534 - mse: 0.0534 - val_loss: 0.0811 - val_mse: 0.0811 - 15ms/epoch - 15ms/step\n",
      "Epoch 289/500\n",
      "1/1 - 0s - loss: 0.0531 - mse: 0.0531 - val_loss: 0.0807 - val_mse: 0.0807 - 15ms/epoch - 15ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 290/500\n",
      "1/1 - 0s - loss: 0.0528 - mse: 0.0528 - val_loss: 0.0804 - val_mse: 0.0804 - 15ms/epoch - 15ms/step\n",
      "Epoch 291/500\n",
      "1/1 - 0s - loss: 0.0526 - mse: 0.0526 - val_loss: 0.0801 - val_mse: 0.0801 - 16ms/epoch - 16ms/step\n",
      "Epoch 292/500\n",
      "1/1 - 0s - loss: 0.0523 - mse: 0.0523 - val_loss: 0.0798 - val_mse: 0.0798 - 15ms/epoch - 15ms/step\n",
      "Epoch 293/500\n",
      "1/1 - 0s - loss: 0.0520 - mse: 0.0520 - val_loss: 0.0794 - val_mse: 0.0794 - 14ms/epoch - 14ms/step\n",
      "Epoch 294/500\n",
      "1/1 - 0s - loss: 0.0518 - mse: 0.0518 - val_loss: 0.0791 - val_mse: 0.0791 - 14ms/epoch - 14ms/step\n",
      "Epoch 295/500\n",
      "1/1 - 0s - loss: 0.0515 - mse: 0.0515 - val_loss: 0.0788 - val_mse: 0.0788 - 14ms/epoch - 14ms/step\n",
      "Epoch 296/500\n",
      "1/1 - 0s - loss: 0.0512 - mse: 0.0512 - val_loss: 0.0785 - val_mse: 0.0785 - 15ms/epoch - 15ms/step\n",
      "Epoch 297/500\n",
      "1/1 - 0s - loss: 0.0510 - mse: 0.0510 - val_loss: 0.0782 - val_mse: 0.0782 - 15ms/epoch - 15ms/step\n",
      "Epoch 298/500\n",
      "1/1 - 0s - loss: 0.0507 - mse: 0.0507 - val_loss: 0.0778 - val_mse: 0.0778 - 15ms/epoch - 15ms/step\n",
      "Epoch 299/500\n",
      "1/1 - 0s - loss: 0.0505 - mse: 0.0505 - val_loss: 0.0775 - val_mse: 0.0775 - 15ms/epoch - 15ms/step\n",
      "Epoch 300/500\n",
      "1/1 - 0s - loss: 0.0502 - mse: 0.0502 - val_loss: 0.0772 - val_mse: 0.0772 - 15ms/epoch - 15ms/step\n",
      "Epoch 301/500\n",
      "1/1 - 0s - loss: 0.0500 - mse: 0.0500 - val_loss: 0.0769 - val_mse: 0.0769 - 15ms/epoch - 15ms/step\n",
      "Epoch 302/500\n",
      "1/1 - 0s - loss: 0.0497 - mse: 0.0497 - val_loss: 0.0766 - val_mse: 0.0766 - 16ms/epoch - 16ms/step\n",
      "Epoch 303/500\n",
      "1/1 - 0s - loss: 0.0495 - mse: 0.0495 - val_loss: 0.0763 - val_mse: 0.0763 - 16ms/epoch - 16ms/step\n",
      "Epoch 304/500\n",
      "1/1 - 0s - loss: 0.0492 - mse: 0.0492 - val_loss: 0.0760 - val_mse: 0.0760 - 16ms/epoch - 16ms/step\n",
      "Epoch 305/500\n",
      "1/1 - 0s - loss: 0.0490 - mse: 0.0490 - val_loss: 0.0757 - val_mse: 0.0757 - 15ms/epoch - 15ms/step\n",
      "Epoch 306/500\n",
      "1/1 - 0s - loss: 0.0487 - mse: 0.0487 - val_loss: 0.0754 - val_mse: 0.0754 - 15ms/epoch - 15ms/step\n",
      "Epoch 307/500\n",
      "1/1 - 0s - loss: 0.0485 - mse: 0.0485 - val_loss: 0.0751 - val_mse: 0.0751 - 15ms/epoch - 15ms/step\n",
      "Epoch 308/500\n",
      "1/1 - 0s - loss: 0.0483 - mse: 0.0483 - val_loss: 0.0748 - val_mse: 0.0748 - 16ms/epoch - 16ms/step\n",
      "Epoch 309/500\n",
      "1/1 - 0s - loss: 0.0480 - mse: 0.0480 - val_loss: 0.0745 - val_mse: 0.0745 - 15ms/epoch - 15ms/step\n",
      "Epoch 310/500\n",
      "1/1 - 0s - loss: 0.0478 - mse: 0.0478 - val_loss: 0.0742 - val_mse: 0.0742 - 15ms/epoch - 15ms/step\n",
      "Epoch 311/500\n",
      "1/1 - 0s - loss: 0.0476 - mse: 0.0476 - val_loss: 0.0740 - val_mse: 0.0740 - 15ms/epoch - 15ms/step\n",
      "Epoch 312/500\n",
      "1/1 - 0s - loss: 0.0473 - mse: 0.0473 - val_loss: 0.0737 - val_mse: 0.0737 - 15ms/epoch - 15ms/step\n",
      "Epoch 313/500\n",
      "1/1 - 0s - loss: 0.0471 - mse: 0.0471 - val_loss: 0.0734 - val_mse: 0.0734 - 15ms/epoch - 15ms/step\n",
      "Epoch 314/500\n",
      "1/1 - 0s - loss: 0.0469 - mse: 0.0469 - val_loss: 0.0731 - val_mse: 0.0731 - 16ms/epoch - 16ms/step\n",
      "Epoch 315/500\n",
      "1/1 - 0s - loss: 0.0466 - mse: 0.0466 - val_loss: 0.0728 - val_mse: 0.0728 - 16ms/epoch - 16ms/step\n",
      "Epoch 316/500\n",
      "1/1 - 0s - loss: 0.0464 - mse: 0.0464 - val_loss: 0.0725 - val_mse: 0.0725 - 15ms/epoch - 15ms/step\n",
      "Epoch 317/500\n",
      "1/1 - 0s - loss: 0.0462 - mse: 0.0462 - val_loss: 0.0723 - val_mse: 0.0723 - 15ms/epoch - 15ms/step\n",
      "Epoch 318/500\n",
      "1/1 - 0s - loss: 0.0460 - mse: 0.0460 - val_loss: 0.0720 - val_mse: 0.0720 - 15ms/epoch - 15ms/step\n",
      "Epoch 319/500\n",
      "1/1 - 0s - loss: 0.0458 - mse: 0.0458 - val_loss: 0.0717 - val_mse: 0.0717 - 15ms/epoch - 15ms/step\n",
      "Epoch 320/500\n",
      "1/1 - 0s - loss: 0.0455 - mse: 0.0455 - val_loss: 0.0714 - val_mse: 0.0714 - 16ms/epoch - 16ms/step\n",
      "Epoch 321/500\n",
      "1/1 - 0s - loss: 0.0453 - mse: 0.0453 - val_loss: 0.0712 - val_mse: 0.0712 - 16ms/epoch - 16ms/step\n",
      "Epoch 322/500\n",
      "1/1 - 0s - loss: 0.0451 - mse: 0.0451 - val_loss: 0.0709 - val_mse: 0.0709 - 15ms/epoch - 15ms/step\n",
      "Epoch 323/500\n",
      "1/1 - 0s - loss: 0.0449 - mse: 0.0449 - val_loss: 0.0706 - val_mse: 0.0706 - 15ms/epoch - 15ms/step\n",
      "Epoch 324/500\n",
      "1/1 - 0s - loss: 0.0447 - mse: 0.0447 - val_loss: 0.0704 - val_mse: 0.0704 - 15ms/epoch - 15ms/step\n",
      "Epoch 325/500\n",
      "1/1 - 0s - loss: 0.0445 - mse: 0.0445 - val_loss: 0.0701 - val_mse: 0.0701 - 15ms/epoch - 15ms/step\n",
      "Epoch 326/500\n",
      "1/1 - 0s - loss: 0.0442 - mse: 0.0442 - val_loss: 0.0698 - val_mse: 0.0698 - 15ms/epoch - 15ms/step\n",
      "Epoch 327/500\n",
      "1/1 - 0s - loss: 0.0440 - mse: 0.0440 - val_loss: 0.0696 - val_mse: 0.0696 - 16ms/epoch - 16ms/step\n",
      "Epoch 328/500\n",
      "1/1 - 0s - loss: 0.0438 - mse: 0.0438 - val_loss: 0.0693 - val_mse: 0.0693 - 16ms/epoch - 16ms/step\n",
      "Epoch 329/500\n",
      "1/1 - 0s - loss: 0.0436 - mse: 0.0436 - val_loss: 0.0691 - val_mse: 0.0691 - 15ms/epoch - 15ms/step\n",
      "Epoch 330/500\n",
      "1/1 - 0s - loss: 0.0434 - mse: 0.0434 - val_loss: 0.0688 - val_mse: 0.0688 - 16ms/epoch - 16ms/step\n",
      "Epoch 331/500\n",
      "1/1 - 0s - loss: 0.0432 - mse: 0.0432 - val_loss: 0.0685 - val_mse: 0.0685 - 16ms/epoch - 16ms/step\n",
      "Epoch 332/500\n",
      "1/1 - 0s - loss: 0.0430 - mse: 0.0430 - val_loss: 0.0683 - val_mse: 0.0683 - 16ms/epoch - 16ms/step\n",
      "Epoch 333/500\n",
      "1/1 - 0s - loss: 0.0428 - mse: 0.0428 - val_loss: 0.0680 - val_mse: 0.0680 - 15ms/epoch - 15ms/step\n",
      "Epoch 334/500\n",
      "1/1 - 0s - loss: 0.0426 - mse: 0.0426 - val_loss: 0.0678 - val_mse: 0.0678 - 16ms/epoch - 16ms/step\n",
      "Epoch 335/500\n",
      "1/1 - 0s - loss: 0.0424 - mse: 0.0424 - val_loss: 0.0675 - val_mse: 0.0675 - 15ms/epoch - 15ms/step\n",
      "Epoch 336/500\n",
      "1/1 - 0s - loss: 0.0422 - mse: 0.0422 - val_loss: 0.0673 - val_mse: 0.0673 - 15ms/epoch - 15ms/step\n",
      "Epoch 337/500\n",
      "1/1 - 0s - loss: 0.0420 - mse: 0.0420 - val_loss: 0.0670 - val_mse: 0.0670 - 16ms/epoch - 16ms/step\n",
      "Epoch 338/500\n",
      "1/1 - 0s - loss: 0.0418 - mse: 0.0418 - val_loss: 0.0668 - val_mse: 0.0668 - 15ms/epoch - 15ms/step\n",
      "Epoch 339/500\n",
      "1/1 - 0s - loss: 0.0416 - mse: 0.0416 - val_loss: 0.0665 - val_mse: 0.0665 - 15ms/epoch - 15ms/step\n",
      "Epoch 340/500\n",
      "1/1 - 0s - loss: 0.0414 - mse: 0.0414 - val_loss: 0.0663 - val_mse: 0.0663 - 14ms/epoch - 14ms/step\n",
      "Epoch 341/500\n",
      "1/1 - 0s - loss: 0.0412 - mse: 0.0412 - val_loss: 0.0660 - val_mse: 0.0660 - 15ms/epoch - 15ms/step\n",
      "Epoch 342/500\n",
      "1/1 - 0s - loss: 0.0411 - mse: 0.0411 - val_loss: 0.0658 - val_mse: 0.0658 - 14ms/epoch - 14ms/step\n",
      "Epoch 343/500\n",
      "1/1 - 0s - loss: 0.0409 - mse: 0.0409 - val_loss: 0.0656 - val_mse: 0.0656 - 16ms/epoch - 16ms/step\n",
      "Epoch 344/500\n",
      "1/1 - 0s - loss: 0.0407 - mse: 0.0407 - val_loss: 0.0653 - val_mse: 0.0653 - 15ms/epoch - 15ms/step\n",
      "Epoch 345/500\n",
      "1/1 - 0s - loss: 0.0405 - mse: 0.0405 - val_loss: 0.0651 - val_mse: 0.0651 - 15ms/epoch - 15ms/step\n",
      "Epoch 346/500\n",
      "1/1 - 0s - loss: 0.0403 - mse: 0.0403 - val_loss: 0.0648 - val_mse: 0.0648 - 15ms/epoch - 15ms/step\n",
      "Epoch 347/500\n",
      "1/1 - 0s - loss: 0.0401 - mse: 0.0401 - val_loss: 0.0646 - val_mse: 0.0646 - 15ms/epoch - 15ms/step\n",
      "Epoch 348/500\n",
      "1/1 - 0s - loss: 0.0399 - mse: 0.0399 - val_loss: 0.0644 - val_mse: 0.0644 - 15ms/epoch - 15ms/step\n",
      "Epoch 349/500\n",
      "1/1 - 0s - loss: 0.0398 - mse: 0.0398 - val_loss: 0.0641 - val_mse: 0.0641 - 15ms/epoch - 15ms/step\n",
      "Epoch 350/500\n",
      "1/1 - 0s - loss: 0.0396 - mse: 0.0396 - val_loss: 0.0639 - val_mse: 0.0639 - 15ms/epoch - 15ms/step\n",
      "Epoch 351/500\n",
      "1/1 - 0s - loss: 0.0394 - mse: 0.0394 - val_loss: 0.0637 - val_mse: 0.0637 - 15ms/epoch - 15ms/step\n",
      "Epoch 352/500\n",
      "1/1 - 0s - loss: 0.0392 - mse: 0.0392 - val_loss: 0.0634 - val_mse: 0.0634 - 15ms/epoch - 15ms/step\n",
      "Epoch 353/500\n",
      "1/1 - 0s - loss: 0.0390 - mse: 0.0390 - val_loss: 0.0632 - val_mse: 0.0632 - 17ms/epoch - 17ms/step\n",
      "Epoch 354/500\n",
      "1/1 - 0s - loss: 0.0389 - mse: 0.0389 - val_loss: 0.0630 - val_mse: 0.0630 - 13ms/epoch - 13ms/step\n",
      "Epoch 355/500\n",
      "1/1 - 0s - loss: 0.0387 - mse: 0.0387 - val_loss: 0.0628 - val_mse: 0.0628 - 15ms/epoch - 15ms/step\n",
      "Epoch 356/500\n",
      "1/1 - 0s - loss: 0.0385 - mse: 0.0385 - val_loss: 0.0625 - val_mse: 0.0625 - 18ms/epoch - 18ms/step\n",
      "Epoch 357/500\n",
      "1/1 - 0s - loss: 0.0383 - mse: 0.0383 - val_loss: 0.0623 - val_mse: 0.0623 - 14ms/epoch - 14ms/step\n",
      "Epoch 358/500\n",
      "1/1 - 0s - loss: 0.0382 - mse: 0.0382 - val_loss: 0.0621 - val_mse: 0.0621 - 17ms/epoch - 17ms/step\n",
      "Epoch 359/500\n",
      "1/1 - 0s - loss: 0.0380 - mse: 0.0380 - val_loss: 0.0619 - val_mse: 0.0619 - 17ms/epoch - 17ms/step\n",
      "Epoch 360/500\n",
      "1/1 - 0s - loss: 0.0378 - mse: 0.0378 - val_loss: 0.0616 - val_mse: 0.0616 - 15ms/epoch - 15ms/step\n",
      "Epoch 361/500\n",
      "1/1 - 0s - loss: 0.0376 - mse: 0.0376 - val_loss: 0.0614 - val_mse: 0.0614 - 14ms/epoch - 14ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 362/500\n",
      "1/1 - 0s - loss: 0.0375 - mse: 0.0375 - val_loss: 0.0612 - val_mse: 0.0612 - 15ms/epoch - 15ms/step\n",
      "Epoch 363/500\n",
      "1/1 - 0s - loss: 0.0373 - mse: 0.0373 - val_loss: 0.0610 - val_mse: 0.0610 - 16ms/epoch - 16ms/step\n",
      "Epoch 364/500\n",
      "1/1 - 0s - loss: 0.0371 - mse: 0.0371 - val_loss: 0.0608 - val_mse: 0.0608 - 15ms/epoch - 15ms/step\n",
      "Epoch 365/500\n",
      "1/1 - 0s - loss: 0.0370 - mse: 0.0370 - val_loss: 0.0606 - val_mse: 0.0606 - 14ms/epoch - 14ms/step\n",
      "Epoch 366/500\n",
      "1/1 - 0s - loss: 0.0368 - mse: 0.0368 - val_loss: 0.0603 - val_mse: 0.0603 - 22ms/epoch - 22ms/step\n",
      "Epoch 367/500\n",
      "1/1 - 0s - loss: 0.0367 - mse: 0.0367 - val_loss: 0.0601 - val_mse: 0.0601 - 15ms/epoch - 15ms/step\n",
      "Epoch 368/500\n",
      "1/1 - 0s - loss: 0.0365 - mse: 0.0365 - val_loss: 0.0599 - val_mse: 0.0599 - 14ms/epoch - 14ms/step\n",
      "Epoch 369/500\n",
      "1/1 - 0s - loss: 0.0363 - mse: 0.0363 - val_loss: 0.0597 - val_mse: 0.0597 - 14ms/epoch - 14ms/step\n",
      "Epoch 370/500\n",
      "1/1 - 0s - loss: 0.0362 - mse: 0.0362 - val_loss: 0.0595 - val_mse: 0.0595 - 15ms/epoch - 15ms/step\n",
      "Epoch 371/500\n",
      "1/1 - 0s - loss: 0.0360 - mse: 0.0360 - val_loss: 0.0593 - val_mse: 0.0593 - 15ms/epoch - 15ms/step\n",
      "Epoch 372/500\n",
      "1/1 - 0s - loss: 0.0358 - mse: 0.0358 - val_loss: 0.0591 - val_mse: 0.0591 - 15ms/epoch - 15ms/step\n",
      "Epoch 373/500\n",
      "1/1 - 0s - loss: 0.0357 - mse: 0.0357 - val_loss: 0.0589 - val_mse: 0.0589 - 15ms/epoch - 15ms/step\n",
      "Epoch 374/500\n",
      "1/1 - 0s - loss: 0.0355 - mse: 0.0355 - val_loss: 0.0586 - val_mse: 0.0586 - 14ms/epoch - 14ms/step\n",
      "Epoch 375/500\n",
      "1/1 - 0s - loss: 0.0354 - mse: 0.0354 - val_loss: 0.0584 - val_mse: 0.0584 - 14ms/epoch - 14ms/step\n",
      "Epoch 376/500\n",
      "1/1 - 0s - loss: 0.0352 - mse: 0.0352 - val_loss: 0.0582 - val_mse: 0.0582 - 15ms/epoch - 15ms/step\n",
      "Epoch 377/500\n",
      "1/1 - 0s - loss: 0.0351 - mse: 0.0351 - val_loss: 0.0580 - val_mse: 0.0580 - 14ms/epoch - 14ms/step\n",
      "Epoch 378/500\n",
      "1/1 - 0s - loss: 0.0349 - mse: 0.0349 - val_loss: 0.0578 - val_mse: 0.0578 - 14ms/epoch - 14ms/step\n",
      "Epoch 379/500\n",
      "1/1 - 0s - loss: 0.0348 - mse: 0.0348 - val_loss: 0.0576 - val_mse: 0.0576 - 15ms/epoch - 15ms/step\n",
      "Epoch 380/500\n",
      "1/1 - 0s - loss: 0.0346 - mse: 0.0346 - val_loss: 0.0574 - val_mse: 0.0574 - 14ms/epoch - 14ms/step\n",
      "Epoch 381/500\n",
      "1/1 - 0s - loss: 0.0344 - mse: 0.0344 - val_loss: 0.0572 - val_mse: 0.0572 - 14ms/epoch - 14ms/step\n",
      "Epoch 382/500\n",
      "1/1 - 0s - loss: 0.0343 - mse: 0.0343 - val_loss: 0.0570 - val_mse: 0.0570 - 13ms/epoch - 13ms/step\n",
      "Epoch 383/500\n",
      "1/1 - 0s - loss: 0.0341 - mse: 0.0341 - val_loss: 0.0568 - val_mse: 0.0568 - 14ms/epoch - 14ms/step\n",
      "Epoch 384/500\n",
      "1/1 - 0s - loss: 0.0340 - mse: 0.0340 - val_loss: 0.0566 - val_mse: 0.0566 - 14ms/epoch - 14ms/step\n",
      "Epoch 385/500\n",
      "1/1 - 0s - loss: 0.0339 - mse: 0.0339 - val_loss: 0.0564 - val_mse: 0.0564 - 15ms/epoch - 15ms/step\n",
      "Epoch 386/500\n",
      "1/1 - 0s - loss: 0.0337 - mse: 0.0337 - val_loss: 0.0562 - val_mse: 0.0562 - 14ms/epoch - 14ms/step\n",
      "Epoch 387/500\n",
      "1/1 - 0s - loss: 0.0336 - mse: 0.0336 - val_loss: 0.0560 - val_mse: 0.0560 - 15ms/epoch - 15ms/step\n",
      "Epoch 388/500\n",
      "1/1 - 0s - loss: 0.0334 - mse: 0.0334 - val_loss: 0.0558 - val_mse: 0.0558 - 14ms/epoch - 14ms/step\n",
      "Epoch 389/500\n",
      "1/1 - 0s - loss: 0.0333 - mse: 0.0333 - val_loss: 0.0556 - val_mse: 0.0556 - 14ms/epoch - 14ms/step\n",
      "Epoch 390/500\n",
      "1/1 - 0s - loss: 0.0331 - mse: 0.0331 - val_loss: 0.0554 - val_mse: 0.0554 - 15ms/epoch - 15ms/step\n",
      "Epoch 391/500\n",
      "1/1 - 0s - loss: 0.0330 - mse: 0.0330 - val_loss: 0.0553 - val_mse: 0.0553 - 15ms/epoch - 15ms/step\n",
      "Epoch 392/500\n",
      "1/1 - 0s - loss: 0.0328 - mse: 0.0328 - val_loss: 0.0551 - val_mse: 0.0551 - 15ms/epoch - 15ms/step\n",
      "Epoch 393/500\n",
      "1/1 - 0s - loss: 0.0327 - mse: 0.0327 - val_loss: 0.0549 - val_mse: 0.0549 - 15ms/epoch - 15ms/step\n",
      "Epoch 394/500\n",
      "1/1 - 0s - loss: 0.0326 - mse: 0.0326 - val_loss: 0.0547 - val_mse: 0.0547 - 15ms/epoch - 15ms/step\n",
      "Epoch 395/500\n",
      "1/1 - 0s - loss: 0.0324 - mse: 0.0324 - val_loss: 0.0545 - val_mse: 0.0545 - 14ms/epoch - 14ms/step\n",
      "Epoch 396/500\n",
      "1/1 - 0s - loss: 0.0323 - mse: 0.0323 - val_loss: 0.0543 - val_mse: 0.0543 - 13ms/epoch - 13ms/step\n",
      "Epoch 397/500\n",
      "1/1 - 0s - loss: 0.0321 - mse: 0.0321 - val_loss: 0.0541 - val_mse: 0.0541 - 14ms/epoch - 14ms/step\n",
      "Epoch 398/500\n",
      "1/1 - 0s - loss: 0.0320 - mse: 0.0320 - val_loss: 0.0539 - val_mse: 0.0539 - 14ms/epoch - 14ms/step\n",
      "Epoch 399/500\n",
      "1/1 - 0s - loss: 0.0319 - mse: 0.0319 - val_loss: 0.0537 - val_mse: 0.0537 - 15ms/epoch - 15ms/step\n",
      "Epoch 400/500\n",
      "1/1 - 0s - loss: 0.0317 - mse: 0.0317 - val_loss: 0.0536 - val_mse: 0.0536 - 14ms/epoch - 14ms/step\n",
      "Epoch 401/500\n",
      "1/1 - 0s - loss: 0.0316 - mse: 0.0316 - val_loss: 0.0534 - val_mse: 0.0534 - 14ms/epoch - 14ms/step\n",
      "Epoch 402/500\n",
      "1/1 - 0s - loss: 0.0314 - mse: 0.0314 - val_loss: 0.0532 - val_mse: 0.0532 - 14ms/epoch - 14ms/step\n",
      "Epoch 403/500\n",
      "1/1 - 0s - loss: 0.0313 - mse: 0.0313 - val_loss: 0.0530 - val_mse: 0.0530 - 14ms/epoch - 14ms/step\n",
      "Epoch 404/500\n",
      "1/1 - 0s - loss: 0.0312 - mse: 0.0312 - val_loss: 0.0528 - val_mse: 0.0528 - 15ms/epoch - 15ms/step\n",
      "Epoch 405/500\n",
      "1/1 - 0s - loss: 0.0310 - mse: 0.0310 - val_loss: 0.0526 - val_mse: 0.0526 - 15ms/epoch - 15ms/step\n",
      "Epoch 406/500\n",
      "1/1 - 0s - loss: 0.0309 - mse: 0.0309 - val_loss: 0.0525 - val_mse: 0.0525 - 14ms/epoch - 14ms/step\n",
      "Epoch 407/500\n",
      "1/1 - 0s - loss: 0.0308 - mse: 0.0308 - val_loss: 0.0523 - val_mse: 0.0523 - 14ms/epoch - 14ms/step\n",
      "Epoch 408/500\n",
      "1/1 - 0s - loss: 0.0306 - mse: 0.0306 - val_loss: 0.0521 - val_mse: 0.0521 - 15ms/epoch - 15ms/step\n",
      "Epoch 409/500\n",
      "1/1 - 0s - loss: 0.0305 - mse: 0.0305 - val_loss: 0.0519 - val_mse: 0.0519 - 14ms/epoch - 14ms/step\n",
      "Epoch 410/500\n",
      "1/1 - 0s - loss: 0.0304 - mse: 0.0304 - val_loss: 0.0517 - val_mse: 0.0517 - 14ms/epoch - 14ms/step\n",
      "Epoch 411/500\n",
      "1/1 - 0s - loss: 0.0303 - mse: 0.0303 - val_loss: 0.0516 - val_mse: 0.0516 - 14ms/epoch - 14ms/step\n",
      "Epoch 412/500\n",
      "1/1 - 0s - loss: 0.0301 - mse: 0.0301 - val_loss: 0.0514 - val_mse: 0.0514 - 15ms/epoch - 15ms/step\n",
      "Epoch 413/500\n",
      "1/1 - 0s - loss: 0.0300 - mse: 0.0300 - val_loss: 0.0512 - val_mse: 0.0512 - 15ms/epoch - 15ms/step\n",
      "Epoch 414/500\n",
      "1/1 - 0s - loss: 0.0299 - mse: 0.0299 - val_loss: 0.0510 - val_mse: 0.0510 - 15ms/epoch - 15ms/step\n",
      "Epoch 415/500\n",
      "1/1 - 0s - loss: 0.0297 - mse: 0.0297 - val_loss: 0.0509 - val_mse: 0.0509 - 15ms/epoch - 15ms/step\n",
      "Epoch 416/500\n",
      "1/1 - 0s - loss: 0.0296 - mse: 0.0296 - val_loss: 0.0507 - val_mse: 0.0507 - 15ms/epoch - 15ms/step\n",
      "Epoch 417/500\n",
      "1/1 - 0s - loss: 0.0295 - mse: 0.0295 - val_loss: 0.0505 - val_mse: 0.0505 - 16ms/epoch - 16ms/step\n",
      "Epoch 418/500\n",
      "1/1 - 0s - loss: 0.0294 - mse: 0.0294 - val_loss: 0.0503 - val_mse: 0.0503 - 15ms/epoch - 15ms/step\n",
      "Epoch 419/500\n",
      "1/1 - 0s - loss: 0.0292 - mse: 0.0292 - val_loss: 0.0502 - val_mse: 0.0502 - 16ms/epoch - 16ms/step\n",
      "Epoch 420/500\n",
      "1/1 - 0s - loss: 0.0291 - mse: 0.0291 - val_loss: 0.0500 - val_mse: 0.0500 - 15ms/epoch - 15ms/step\n",
      "Epoch 421/500\n",
      "1/1 - 0s - loss: 0.0290 - mse: 0.0290 - val_loss: 0.0498 - val_mse: 0.0498 - 16ms/epoch - 16ms/step\n",
      "Epoch 422/500\n",
      "1/1 - 0s - loss: 0.0289 - mse: 0.0289 - val_loss: 0.0497 - val_mse: 0.0497 - 15ms/epoch - 15ms/step\n",
      "Epoch 423/500\n",
      "1/1 - 0s - loss: 0.0288 - mse: 0.0288 - val_loss: 0.0495 - val_mse: 0.0495 - 16ms/epoch - 16ms/step\n",
      "Epoch 424/500\n",
      "1/1 - 0s - loss: 0.0286 - mse: 0.0286 - val_loss: 0.0493 - val_mse: 0.0493 - 15ms/epoch - 15ms/step\n",
      "Epoch 425/500\n",
      "1/1 - 0s - loss: 0.0285 - mse: 0.0285 - val_loss: 0.0492 - val_mse: 0.0492 - 16ms/epoch - 16ms/step\n",
      "Epoch 426/500\n",
      "1/1 - 0s - loss: 0.0284 - mse: 0.0284 - val_loss: 0.0490 - val_mse: 0.0490 - 16ms/epoch - 16ms/step\n",
      "Epoch 427/500\n",
      "1/1 - 0s - loss: 0.0283 - mse: 0.0283 - val_loss: 0.0488 - val_mse: 0.0488 - 15ms/epoch - 15ms/step\n",
      "Epoch 428/500\n",
      "1/1 - 0s - loss: 0.0282 - mse: 0.0282 - val_loss: 0.0487 - val_mse: 0.0487 - 15ms/epoch - 15ms/step\n",
      "Epoch 429/500\n",
      "1/1 - 0s - loss: 0.0280 - mse: 0.0280 - val_loss: 0.0485 - val_mse: 0.0485 - 15ms/epoch - 15ms/step\n",
      "Epoch 430/500\n",
      "1/1 - 0s - loss: 0.0279 - mse: 0.0279 - val_loss: 0.0483 - val_mse: 0.0483 - 15ms/epoch - 15ms/step\n",
      "Epoch 431/500\n",
      "1/1 - 0s - loss: 0.0278 - mse: 0.0278 - val_loss: 0.0482 - val_mse: 0.0482 - 15ms/epoch - 15ms/step\n",
      "Epoch 432/500\n",
      "1/1 - 0s - loss: 0.0277 - mse: 0.0277 - val_loss: 0.0480 - val_mse: 0.0480 - 16ms/epoch - 16ms/step\n",
      "Epoch 433/500\n",
      "1/1 - 0s - loss: 0.0276 - mse: 0.0276 - val_loss: 0.0478 - val_mse: 0.0478 - 15ms/epoch - 15ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 434/500\n",
      "1/1 - 0s - loss: 0.0275 - mse: 0.0275 - val_loss: 0.0477 - val_mse: 0.0477 - 15ms/epoch - 15ms/step\n",
      "Epoch 435/500\n",
      "1/1 - 0s - loss: 0.0273 - mse: 0.0273 - val_loss: 0.0475 - val_mse: 0.0475 - 15ms/epoch - 15ms/step\n",
      "Epoch 436/500\n",
      "1/1 - 0s - loss: 0.0272 - mse: 0.0272 - val_loss: 0.0473 - val_mse: 0.0473 - 15ms/epoch - 15ms/step\n",
      "Epoch 437/500\n",
      "1/1 - 0s - loss: 0.0271 - mse: 0.0271 - val_loss: 0.0472 - val_mse: 0.0472 - 15ms/epoch - 15ms/step\n",
      "Epoch 438/500\n",
      "1/1 - 0s - loss: 0.0270 - mse: 0.0270 - val_loss: 0.0470 - val_mse: 0.0470 - 15ms/epoch - 15ms/step\n",
      "Epoch 439/500\n",
      "1/1 - 0s - loss: 0.0269 - mse: 0.0269 - val_loss: 0.0469 - val_mse: 0.0469 - 14ms/epoch - 14ms/step\n",
      "Epoch 440/500\n",
      "1/1 - 0s - loss: 0.0268 - mse: 0.0268 - val_loss: 0.0467 - val_mse: 0.0467 - 15ms/epoch - 15ms/step\n",
      "Epoch 441/500\n",
      "1/1 - 0s - loss: 0.0267 - mse: 0.0267 - val_loss: 0.0466 - val_mse: 0.0466 - 16ms/epoch - 16ms/step\n",
      "Epoch 442/500\n",
      "1/1 - 0s - loss: 0.0266 - mse: 0.0266 - val_loss: 0.0464 - val_mse: 0.0464 - 15ms/epoch - 15ms/step\n",
      "Epoch 443/500\n",
      "1/1 - 0s - loss: 0.0264 - mse: 0.0264 - val_loss: 0.0462 - val_mse: 0.0462 - 15ms/epoch - 15ms/step\n",
      "Epoch 444/500\n",
      "1/1 - 0s - loss: 0.0263 - mse: 0.0263 - val_loss: 0.0461 - val_mse: 0.0461 - 15ms/epoch - 15ms/step\n",
      "Epoch 445/500\n",
      "1/1 - 0s - loss: 0.0262 - mse: 0.0262 - val_loss: 0.0459 - val_mse: 0.0459 - 15ms/epoch - 15ms/step\n",
      "Epoch 446/500\n",
      "1/1 - 0s - loss: 0.0261 - mse: 0.0261 - val_loss: 0.0458 - val_mse: 0.0458 - 15ms/epoch - 15ms/step\n",
      "Epoch 447/500\n",
      "1/1 - 0s - loss: 0.0260 - mse: 0.0260 - val_loss: 0.0456 - val_mse: 0.0456 - 15ms/epoch - 15ms/step\n",
      "Epoch 448/500\n",
      "1/1 - 0s - loss: 0.0259 - mse: 0.0259 - val_loss: 0.0455 - val_mse: 0.0455 - 15ms/epoch - 15ms/step\n",
      "Epoch 449/500\n",
      "1/1 - 0s - loss: 0.0258 - mse: 0.0258 - val_loss: 0.0453 - val_mse: 0.0453 - 15ms/epoch - 15ms/step\n",
      "Epoch 450/500\n",
      "1/1 - 0s - loss: 0.0257 - mse: 0.0257 - val_loss: 0.0452 - val_mse: 0.0452 - 15ms/epoch - 15ms/step\n",
      "Epoch 451/500\n",
      "1/1 - 0s - loss: 0.0256 - mse: 0.0256 - val_loss: 0.0450 - val_mse: 0.0450 - 15ms/epoch - 15ms/step\n",
      "Epoch 452/500\n",
      "1/1 - 0s - loss: 0.0255 - mse: 0.0255 - val_loss: 0.0449 - val_mse: 0.0449 - 16ms/epoch - 16ms/step\n",
      "Epoch 453/500\n",
      "1/1 - 0s - loss: 0.0254 - mse: 0.0254 - val_loss: 0.0447 - val_mse: 0.0447 - 15ms/epoch - 15ms/step\n",
      "Epoch 454/500\n",
      "1/1 - 0s - loss: 0.0253 - mse: 0.0253 - val_loss: 0.0446 - val_mse: 0.0446 - 16ms/epoch - 16ms/step\n",
      "Epoch 455/500\n",
      "1/1 - 0s - loss: 0.0252 - mse: 0.0252 - val_loss: 0.0444 - val_mse: 0.0444 - 15ms/epoch - 15ms/step\n",
      "Epoch 456/500\n",
      "1/1 - 0s - loss: 0.0251 - mse: 0.0251 - val_loss: 0.0443 - val_mse: 0.0443 - 15ms/epoch - 15ms/step\n",
      "Epoch 457/500\n",
      "1/1 - 0s - loss: 0.0250 - mse: 0.0250 - val_loss: 0.0441 - val_mse: 0.0441 - 15ms/epoch - 15ms/step\n",
      "Epoch 458/500\n",
      "1/1 - 0s - loss: 0.0248 - mse: 0.0248 - val_loss: 0.0440 - val_mse: 0.0440 - 15ms/epoch - 15ms/step\n",
      "Epoch 459/500\n",
      "1/1 - 0s - loss: 0.0247 - mse: 0.0247 - val_loss: 0.0438 - val_mse: 0.0438 - 15ms/epoch - 15ms/step\n",
      "Epoch 460/500\n",
      "1/1 - 0s - loss: 0.0246 - mse: 0.0246 - val_loss: 0.0437 - val_mse: 0.0437 - 15ms/epoch - 15ms/step\n",
      "Epoch 461/500\n",
      "1/1 - 0s - loss: 0.0245 - mse: 0.0245 - val_loss: 0.0435 - val_mse: 0.0435 - 15ms/epoch - 15ms/step\n",
      "Epoch 462/500\n",
      "1/1 - 0s - loss: 0.0244 - mse: 0.0244 - val_loss: 0.0434 - val_mse: 0.0434 - 15ms/epoch - 15ms/step\n",
      "Epoch 463/500\n",
      "1/1 - 0s - loss: 0.0243 - mse: 0.0243 - val_loss: 0.0432 - val_mse: 0.0432 - 15ms/epoch - 15ms/step\n",
      "Epoch 464/500\n",
      "1/1 - 0s - loss: 0.0242 - mse: 0.0242 - val_loss: 0.0431 - val_mse: 0.0431 - 15ms/epoch - 15ms/step\n",
      "Epoch 465/500\n",
      "1/1 - 0s - loss: 0.0241 - mse: 0.0241 - val_loss: 0.0429 - val_mse: 0.0429 - 14ms/epoch - 14ms/step\n",
      "Epoch 466/500\n",
      "1/1 - 0s - loss: 0.0240 - mse: 0.0240 - val_loss: 0.0428 - val_mse: 0.0428 - 14ms/epoch - 14ms/step\n",
      "Epoch 467/500\n",
      "1/1 - 0s - loss: 0.0239 - mse: 0.0239 - val_loss: 0.0427 - val_mse: 0.0427 - 13ms/epoch - 13ms/step\n",
      "Epoch 468/500\n",
      "1/1 - 0s - loss: 0.0238 - mse: 0.0238 - val_loss: 0.0425 - val_mse: 0.0425 - 14ms/epoch - 14ms/step\n",
      "Epoch 469/500\n",
      "1/1 - 0s - loss: 0.0237 - mse: 0.0237 - val_loss: 0.0424 - val_mse: 0.0424 - 14ms/epoch - 14ms/step\n",
      "Epoch 470/500\n",
      "1/1 - 0s - loss: 0.0236 - mse: 0.0236 - val_loss: 0.0422 - val_mse: 0.0422 - 15ms/epoch - 15ms/step\n",
      "Epoch 471/500\n",
      "1/1 - 0s - loss: 0.0236 - mse: 0.0236 - val_loss: 0.0421 - val_mse: 0.0421 - 14ms/epoch - 14ms/step\n",
      "Epoch 472/500\n",
      "1/1 - 0s - loss: 0.0235 - mse: 0.0235 - val_loss: 0.0419 - val_mse: 0.0419 - 14ms/epoch - 14ms/step\n",
      "Epoch 473/500\n",
      "1/1 - 0s - loss: 0.0234 - mse: 0.0234 - val_loss: 0.0418 - val_mse: 0.0418 - 15ms/epoch - 15ms/step\n",
      "Epoch 474/500\n",
      "1/1 - 0s - loss: 0.0233 - mse: 0.0233 - val_loss: 0.0417 - val_mse: 0.0417 - 16ms/epoch - 16ms/step\n",
      "Epoch 475/500\n",
      "1/1 - 0s - loss: 0.0232 - mse: 0.0232 - val_loss: 0.0415 - val_mse: 0.0415 - 15ms/epoch - 15ms/step\n",
      "Epoch 476/500\n",
      "1/1 - 0s - loss: 0.0231 - mse: 0.0231 - val_loss: 0.0414 - val_mse: 0.0414 - 15ms/epoch - 15ms/step\n",
      "Epoch 477/500\n",
      "1/1 - 0s - loss: 0.0230 - mse: 0.0230 - val_loss: 0.0412 - val_mse: 0.0412 - 15ms/epoch - 15ms/step\n",
      "Epoch 478/500\n",
      "1/1 - 0s - loss: 0.0229 - mse: 0.0229 - val_loss: 0.0411 - val_mse: 0.0411 - 15ms/epoch - 15ms/step\n",
      "Epoch 479/500\n",
      "1/1 - 0s - loss: 0.0228 - mse: 0.0228 - val_loss: 0.0410 - val_mse: 0.0410 - 15ms/epoch - 15ms/step\n",
      "Epoch 480/500\n",
      "1/1 - 0s - loss: 0.0227 - mse: 0.0227 - val_loss: 0.0408 - val_mse: 0.0408 - 15ms/epoch - 15ms/step\n",
      "Epoch 481/500\n",
      "1/1 - 0s - loss: 0.0226 - mse: 0.0226 - val_loss: 0.0407 - val_mse: 0.0407 - 16ms/epoch - 16ms/step\n",
      "Epoch 482/500\n",
      "1/1 - 0s - loss: 0.0225 - mse: 0.0225 - val_loss: 0.0406 - val_mse: 0.0406 - 17ms/epoch - 17ms/step\n",
      "Epoch 483/500\n",
      "1/1 - 0s - loss: 0.0224 - mse: 0.0224 - val_loss: 0.0404 - val_mse: 0.0404 - 16ms/epoch - 16ms/step\n",
      "Epoch 484/500\n",
      "1/1 - 0s - loss: 0.0223 - mse: 0.0223 - val_loss: 0.0403 - val_mse: 0.0403 - 15ms/epoch - 15ms/step\n",
      "Epoch 485/500\n",
      "1/1 - 0s - loss: 0.0222 - mse: 0.0222 - val_loss: 0.0402 - val_mse: 0.0402 - 16ms/epoch - 16ms/step\n",
      "Epoch 486/500\n",
      "1/1 - 0s - loss: 0.0221 - mse: 0.0221 - val_loss: 0.0400 - val_mse: 0.0400 - 15ms/epoch - 15ms/step\n",
      "Epoch 487/500\n",
      "1/1 - 0s - loss: 0.0221 - mse: 0.0221 - val_loss: 0.0399 - val_mse: 0.0399 - 17ms/epoch - 17ms/step\n",
      "Epoch 488/500\n",
      "1/1 - 0s - loss: 0.0220 - mse: 0.0220 - val_loss: 0.0398 - val_mse: 0.0398 - 14ms/epoch - 14ms/step\n",
      "Epoch 489/500\n",
      "1/1 - 0s - loss: 0.0219 - mse: 0.0219 - val_loss: 0.0396 - val_mse: 0.0396 - 17ms/epoch - 17ms/step\n",
      "Epoch 490/500\n",
      "1/1 - 0s - loss: 0.0218 - mse: 0.0218 - val_loss: 0.0395 - val_mse: 0.0395 - 21ms/epoch - 21ms/step\n",
      "Epoch 491/500\n",
      "1/1 - 0s - loss: 0.0217 - mse: 0.0217 - val_loss: 0.0394 - val_mse: 0.0394 - 14ms/epoch - 14ms/step\n",
      "Epoch 492/500\n",
      "1/1 - 0s - loss: 0.0216 - mse: 0.0216 - val_loss: 0.0392 - val_mse: 0.0392 - 13ms/epoch - 13ms/step\n",
      "Epoch 493/500\n",
      "1/1 - 0s - loss: 0.0215 - mse: 0.0215 - val_loss: 0.0391 - val_mse: 0.0391 - 16ms/epoch - 16ms/step\n",
      "Epoch 494/500\n",
      "1/1 - 0s - loss: 0.0214 - mse: 0.0214 - val_loss: 0.0390 - val_mse: 0.0390 - 14ms/epoch - 14ms/step\n",
      "Epoch 495/500\n",
      "1/1 - 0s - loss: 0.0213 - mse: 0.0213 - val_loss: 0.0388 - val_mse: 0.0388 - 23ms/epoch - 23ms/step\n",
      "Epoch 496/500\n",
      "1/1 - 0s - loss: 0.0213 - mse: 0.0213 - val_loss: 0.0387 - val_mse: 0.0387 - 15ms/epoch - 15ms/step\n",
      "Epoch 497/500\n",
      "1/1 - 0s - loss: 0.0212 - mse: 0.0212 - val_loss: 0.0386 - val_mse: 0.0386 - 13ms/epoch - 13ms/step\n",
      "Epoch 498/500\n",
      "1/1 - 0s - loss: 0.0211 - mse: 0.0211 - val_loss: 0.0385 - val_mse: 0.0385 - 13ms/epoch - 13ms/step\n",
      "Epoch 499/500\n",
      "1/1 - 0s - loss: 0.0210 - mse: 0.0210 - val_loss: 0.0383 - val_mse: 0.0383 - 14ms/epoch - 14ms/step\n",
      "Epoch 500/500\n",
      "1/1 - 0s - loss: 0.0209 - mse: 0.0209 - val_loss: 0.0382 - val_mse: 0.0382 - 15ms/epoch - 15ms/step\n",
      "8.85773515701294\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": 11,
   "id": "81f35c9a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1/1 [==============================] - 0s 13ms/step - loss: 0.0286 - mse: 0.0286\n",
      "[0.028626099228858948, 0.028626099228858948]\n",
      "8.85773515701294\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": 12,
   "id": "ef7b115a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0286 - mse: 0.0286\n",
      "[0.028626099228858948, 0.028626099228858948]\n",
      "8.85773515701294\n"
     ]
    }
   ],
   "source": [
    "#use the TARGET 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": "markdown",
   "id": "e569d35c",
   "metadata": {},
   "source": [
    "# construct the NN after feature transformation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "eecdb17c",
   "metadata": {},
   "outputs": [],
   "source": [
    "model = load_model(\"pretrained_model.h5\")\n",
    "X_train_S = np.load('source_input_data.npy')\n",
    "y_train_S = np.load('source_output_data.npy')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "4687c4cf",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "71/71 [==============================] - 0s 663us/step - loss: 7.2417e-04 - mse: 7.2417e-04\n",
      "1/1 [==============================] - 0s 9ms/step - loss: 2.2139 - mse: 2.2139\n",
      "72/72 [==============================] - 0s 631us/step - loss: 0.0068 - mse: 0.0068\n"
     ]
    }
   ],
   "source": [
    "#combine source and target for training\n",
    "#first 640 target, 3995 source\n",
    "RNN_input_final_Train = np.concatenate((X_train, X_train_S), axis=0) \n",
    "RNN_output_final_Train = np.concatenate((y_train, y_train_S), axis=0)\n",
    "\n",
    "NN_S = model.predict(X_train_S)\n",
    "\n",
    "#performance of the pre-trained model on train data\n",
    "loss_and_metrics = model.evaluate(X_train_S, y_train_S, batch_size=256)\n",
    "loss_and_metrics = model.evaluate(X_train, y_train, batch_size=256)\n",
    "\n",
    "loss_and_metrics = model.evaluate(RNN_input_final_Train, RNN_output_final_Train, batch_size=256)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "f2c61d08",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Step 2: Freeze the original model's weights\n",
    "for layer in model.layers:\n",
    "    layer.trainable = False\n",
    "\n",
    "# Step 3: Create new layers\n",
    "input_layer = Input(shape=(None, 4))  # Replace input_dim with your actual input feature dimension\n",
    "new_input_layer = Dense(8, activation='linear', use_bias=False)  # New front layer\n",
    "new_input_layer1 = Dense(8, activation='linear', use_bias=False)  # New front layer\n",
    "new_input_layer2 = Dense(4, activation='linear', use_bias=False)  # New front layer\n",
    "\n",
    "# Connect the frozen original model\n",
    "x = model(new_input_layer2(new_input_layer1(new_input_layer(input_layer))))\n",
    "\n",
    "# Add new output layer\n",
    "new_output_layer = Dense(4, activation='linear', use_bias=False)  # Replace output_dim with your desired final output size\n",
    "new_output_layer1 = Dense(4, activation='linear', use_bias=False)  # Replace output_dim with your desired final output size\n",
    "new_output_layer2 = Dense(3, activation='linear', use_bias=False)  # Replace output_dim with your desired final output size\n",
    "\n",
    "output = new_output_layer2(new_output_layer1(new_output_layer(x)))\n",
    "# Step 4: Assemble final model\n",
    "final_model = Model(inputs=input_layer, outputs=output)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "e9a742b1",
   "metadata": {},
   "outputs": [],
   "source": [
    "#assign parameters\n",
    "# Define A: 4x8 matrix [I_4 | 0]\n",
    "A = np.array([\n",
    "    [1, 0, 0, 0, 0, 0, 0, 0],\n",
    "    [0, 1, 0, 0, 0, 0, 0, 0],\n",
    "    [0, 0, 1, 0, 0, 0, 0, 0],\n",
    "    [0, 0, 0, 1, 0, 0, 0, 0]\n",
    "], dtype=np.float32)\n",
    "\n",
    "# Define B: 8x8 identity matrix\n",
    "B = np.array(np.eye(8), dtype=np.float32)\n",
    "\n",
    "# Define C: 8x4 matrix [I_4; 0]\n",
    "C = np.array([\n",
    "    [1, 0, 0, 0],\n",
    "    [0, 1, 0, 0],\n",
    "    [0, 0, 1, 0],\n",
    "    [0, 0, 0, 1],\n",
    "    [0, 0, 0, 0],\n",
    "    [0, 0, 0, 0],\n",
    "    [0, 0, 0, 0],\n",
    "    [0, 0, 0, 0]\n",
    "], dtype=np.float32)\n",
    "\n",
    "new_input_layer.set_weights([A])\n",
    "new_input_layer1.set_weights([B])\n",
    "new_input_layer2.set_weights([C])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "id": "a5792001",
   "metadata": {},
   "outputs": [],
   "source": [
    "# A: 3x4 matrix [I_2 | 0]\n",
    "Ao = np.array([\n",
    "    [1, 0, 0, 0],\n",
    "    [0, 1, 0, 0],\n",
    "    [0, 0, 1, 0]\n",
    "], dtype=np.float32)\n",
    "\n",
    "# B: 4x4 identity\n",
    "Bo = np.array(np.eye(4), dtype=np.float32)\n",
    "\n",
    "# C: 4x3 matrix [I_2; 0]\n",
    "Co = np.array([\n",
    "    [1, 0, 0],\n",
    "    [0, 1, 0],\n",
    "    [0, 0, 1],\n",
    "    [0, 0, 0]\n",
    "], dtype=np.float32)\n",
    "\n",
    "new_output_layer.set_weights([Ao])\n",
    "new_output_layer1.set_weights([Bo])\n",
    "new_output_layer2.set_weights([Co])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "4b514281",
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "# Step 5: Custom loss function\n",
    "def custom_loss(y_true, y_pred):\n",
    "    Num = 50 #number of training target data\n",
    "    NN_out = final_model(RNN_input_final_Train) #[[t1,ca1,cb1],[t2,ca2,cb2]]\n",
    "    \n",
    "    #first term\n",
    "    loss11 =  tf.math.reduce_mean((NN_out[:Num,:,:]-RNN_output_final_Train[:Num,:,:])**2) # prediction on target\n",
    "    loss12 =  tf.math.reduce_mean((NN_out[Num:,:,:]-RNN_output_final_Train[Num:,:,:])**2) # prediction on source\n",
    "    \n",
    "    loss1 = abs(loss11 - loss12) \n",
    "    \n",
    "    #second term\n",
    "    \n",
    "    loss2 =  tf.math.reduce_mean((NN_out[Num:,:,:]- NN_S)**2) # prediction error for h and h^* on source\n",
    "    \n",
    "    #last term\n",
    "    max_abs_input = tf.reduce_max(tf.abs(input_layer_weights))\n",
    "    max_abs_output = tf.reduce_max(tf.abs(output_layer_weights))\n",
    "    loss3 =  max_abs_input * max_abs_output\n",
    "    \n",
    "    #weight\n",
    "    a = 0\n",
    "    b = 0.01\n",
    "    c = 0.01\n",
    "    \n",
    "    loss = 1.0*loss11+a*loss1+b*loss2+c*loss3#100*loss11+a*loss1+b*loss2+c*loss3\n",
    "    \n",
    "    return loss  # you can modify this to include regularization if needed"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "91d741df",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model: \"model\"\n",
      "_________________________________________________________________\n",
      " Layer (type)                Output Shape              Param #   \n",
      "=================================================================\n",
      " input_1 (InputLayer)        [(None, None, 4)]         0         \n",
      "                                                                 \n",
      " dense_2 (Dense)             (None, None, 8)           32        \n",
      "                                                                 \n",
      " dense_3 (Dense)             (None, None, 8)           64        \n",
      "                                                                 \n",
      " dense_4 (Dense)             (None, None, 4)           32        \n",
      "                                                                 \n",
      " sequential (Sequential)     (None, 5, 3)              563       \n",
      "                                                                 \n",
      " dense_5 (Dense)             (None, 5, 4)              12        \n",
      "                                                                 \n",
      " dense_6 (Dense)             (None, 5, 4)              16        \n",
      "                                                                 \n",
      " dense_7 (Dense)             (None, 5, 3)              12        \n",
      "                                                                 \n",
      "=================================================================\n",
      "Total params: 731\n",
      "Trainable params: 168\n",
      "Non-trainable params: 563\n",
      "_________________________________________________________________\n",
      "None\n"
     ]
    }
   ],
   "source": [
    "# Step 6: Compile\n",
    "#final_model.compile(optimizer='adam', loss=custom_loss, metrics=['mse'])\n",
    "final_model.compile(optimizer='adam', loss=custom_loss, metrics=['mse'])\n",
    "print(final_model.summary())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "a2d89c02",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iteration :0     Target train: tf.Tensor(2.2138896, shape=(), dtype=float32)\n",
      "1/1 - 1s - loss: 2.2239 - mse: 2.0083 - val_loss: 2.1834 - val_mse: 2.7444 - 1s/epoch - 1s/step\n",
      "iteration :1     Target train: tf.Tensor(2.1733816, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 2.1834 - mse: 1.9728 - val_loss: 2.1437 - val_mse: 2.6914 - 48ms/epoch - 48ms/step\n",
      "iteration :2     Target train: tf.Tensor(2.1336899, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 2.1437 - mse: 1.9377 - val_loss: 2.1047 - val_mse: 2.6401 - 49ms/epoch - 49ms/step\n",
      "iteration :3     Target train: tf.Tensor(2.094722, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 2.1047 - mse: 1.9031 - val_loss: 2.0663 - val_mse: 2.5902 - 49ms/epoch - 49ms/step\n",
      "iteration :4     Target train: tf.Tensor(2.0563607, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 2.0663 - mse: 1.8688 - val_loss: 2.0284 - val_mse: 2.5417 - 49ms/epoch - 49ms/step\n",
      "iteration :5     Target train: tf.Tensor(2.018439, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 2.0284 - mse: 1.8346 - val_loss: 1.9907 - val_mse: 2.4947 - 51ms/epoch - 51ms/step\n",
      "iteration :6     Target train: tf.Tensor(1.9807459, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.9907 - mse: 1.8002 - val_loss: 1.9530 - val_mse: 2.4492 - 55ms/epoch - 55ms/step\n",
      "iteration :7     Target train: tf.Tensor(1.9430577, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.9530 - mse: 1.7652 - val_loss: 1.9151 - val_mse: 2.4053 - 50ms/epoch - 50ms/step\n",
      "iteration :8     Target train: tf.Tensor(1.9051974, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.9151 - mse: 1.7295 - val_loss: 1.8771 - val_mse: 2.3629 - 69ms/epoch - 69ms/step\n",
      "iteration :9     Target train: tf.Tensor(1.8672007, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.8771 - mse: 1.6930 - val_loss: 1.8394 - val_mse: 2.3220 - 83ms/epoch - 83ms/step\n",
      "iteration :10     Target train: tf.Tensor(1.8294997, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.8394 - mse: 1.6565 - val_loss: 1.8028 - val_mse: 2.2824 - 58ms/epoch - 58ms/step\n",
      "iteration :11     Target train: tf.Tensor(1.7928983, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.8028 - mse: 1.6209 - val_loss: 1.7682 - val_mse: 2.2442 - 48ms/epoch - 48ms/step\n",
      "iteration :12     Target train: tf.Tensor(1.7582227, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.7682 - mse: 1.5875 - val_loss: 1.7359 - val_mse: 2.2072 - 50ms/epoch - 50ms/step\n",
      "iteration :13     Target train: tf.Tensor(1.7259074, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.7359 - mse: 1.5568 - val_loss: 1.7059 - val_mse: 2.1715 - 51ms/epoch - 51ms/step\n",
      "iteration :14     Target train: tf.Tensor(1.695898, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.7059 - mse: 1.5288 - val_loss: 1.6779 - val_mse: 2.1370 - 53ms/epoch - 53ms/step\n",
      "iteration :15     Target train: tf.Tensor(1.6678636, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.6779 - mse: 1.5030 - val_loss: 1.6514 - val_mse: 2.1037 - 47ms/epoch - 47ms/step\n",
      "iteration :16     Target train: tf.Tensor(1.6414301, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.6514 - mse: 1.4790 - val_loss: 1.6263 - val_mse: 2.0714 - 52ms/epoch - 52ms/step\n",
      "iteration :17     Target train: tf.Tensor(1.6162952, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.6263 - mse: 1.4564 - val_loss: 1.6023 - val_mse: 2.0402 - 51ms/epoch - 51ms/step\n",
      "iteration :18     Target train: tf.Tensor(1.5922459, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.6023 - mse: 1.4348 - val_loss: 1.5792 - val_mse: 2.0100 - 47ms/epoch - 47ms/step\n",
      "iteration :19     Target train: tf.Tensor(1.5691408, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.5792 - mse: 1.4142 - val_loss: 1.5570 - val_mse: 1.9808 - 56ms/epoch - 56ms/step\n",
      "iteration :20     Target train: tf.Tensor(1.5468843, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.5570 - mse: 1.3944 - val_loss: 1.5355 - val_mse: 1.9525 - 74ms/epoch - 74ms/step\n",
      "iteration :21     Target train: tf.Tensor(1.5254102, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.5355 - mse: 1.3753 - val_loss: 1.5148 - val_mse: 1.9251 - 62ms/epoch - 62ms/step\n",
      "iteration :22     Target train: tf.Tensor(1.5046685, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.5148 - mse: 1.3569 - val_loss: 1.4948 - val_mse: 1.8986 - 53ms/epoch - 53ms/step\n",
      "iteration :23     Target train: tf.Tensor(1.4846203, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.4948 - mse: 1.3392 - val_loss: 1.4754 - val_mse: 1.8730 - 52ms/epoch - 52ms/step\n",
      "iteration :24     Target train: tf.Tensor(1.4652323, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.4754 - mse: 1.3220 - val_loss: 1.4567 - val_mse: 1.8481 - 58ms/epoch - 58ms/step\n",
      "iteration :25     Target train: tf.Tensor(1.4464741, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.4567 - mse: 1.3054 - val_loss: 1.4385 - val_mse: 1.8241 - 52ms/epoch - 52ms/step\n",
      "iteration :26     Target train: tf.Tensor(1.4283192, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.4385 - mse: 1.2893 - val_loss: 1.4210 - val_mse: 1.8008 - 75ms/epoch - 75ms/step\n",
      "iteration :27     Target train: tf.Tensor(1.4107416, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.4210 - mse: 1.2737 - val_loss: 1.4040 - val_mse: 1.7782 - 52ms/epoch - 52ms/step\n",
      "iteration :28     Target train: tf.Tensor(1.3937168, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.4040 - mse: 1.2586 - val_loss: 1.3875 - val_mse: 1.7563 - 55ms/epoch - 55ms/step\n",
      "iteration :29     Target train: tf.Tensor(1.3772215, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.3875 - mse: 1.2440 - val_loss: 1.3715 - val_mse: 1.7351 - 48ms/epoch - 48ms/step\n",
      "iteration :30     Target train: tf.Tensor(1.3612334, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.3715 - mse: 1.2299 - val_loss: 1.3561 - val_mse: 1.7145 - 52ms/epoch - 52ms/step\n",
      "iteration :31     Target train: tf.Tensor(1.3457304, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.3561 - mse: 1.2161 - val_loss: 1.3411 - val_mse: 1.6946 - 57ms/epoch - 57ms/step\n",
      "iteration :32     Target train: tf.Tensor(1.3306922, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.3411 - mse: 1.2028 - val_loss: 1.3265 - val_mse: 1.6753 - 58ms/epoch - 58ms/step\n",
      "iteration :33     Target train: tf.Tensor(1.3160979, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.3265 - mse: 1.1899 - val_loss: 1.3124 - val_mse: 1.6566 - 73ms/epoch - 73ms/step\n",
      "iteration :34     Target train: tf.Tensor(1.3019285, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.3124 - mse: 1.1773 - val_loss: 1.2986 - val_mse: 1.6384 - 52ms/epoch - 52ms/step\n",
      "iteration :35     Target train: tf.Tensor(1.2881649, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.2986 - mse: 1.1651 - val_loss: 1.2853 - val_mse: 1.6208 - 51ms/epoch - 51ms/step\n",
      "iteration :36     Target train: tf.Tensor(1.2747881, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.2853 - mse: 1.1532 - val_loss: 1.2723 - val_mse: 1.6037 - 53ms/epoch - 53ms/step\n",
      "iteration :37     Target train: tf.Tensor(1.261781, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.2723 - mse: 1.1417 - val_loss: 1.2597 - val_mse: 1.5871 - 53ms/epoch - 53ms/step\n",
      "iteration :38     Target train: tf.Tensor(1.2491255, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.2597 - mse: 1.1304 - val_loss: 1.2474 - val_mse: 1.5710 - 53ms/epoch - 53ms/step\n",
      "iteration :39     Target train: tf.Tensor(1.2368046, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.2474 - mse: 1.1194 - val_loss: 1.2354 - val_mse: 1.5553 - 56ms/epoch - 56ms/step\n",
      "iteration :40     Target train: tf.Tensor(1.2248012, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.2354 - mse: 1.1087 - val_loss: 1.2237 - val_mse: 1.5401 - 56ms/epoch - 56ms/step\n",
      "iteration :41     Target train: tf.Tensor(1.2130985, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.2237 - mse: 1.0982 - val_loss: 1.2123 - val_mse: 1.5253 - 50ms/epoch - 50ms/step\n",
      "iteration :42     Target train: tf.Tensor(1.2016797, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.2123 - mse: 1.0880 - val_loss: 1.2012 - val_mse: 1.5110 - 50ms/epoch - 50ms/step\n",
      "iteration :43     Target train: tf.Tensor(1.1905282, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.2012 - mse: 1.0779 - val_loss: 1.1904 - val_mse: 1.4971 - 50ms/epoch - 50ms/step\n",
      "iteration :44     Target train: tf.Tensor(1.1796263, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.1904 - mse: 1.0681 - val_loss: 1.1797 - val_mse: 1.4835 - 58ms/epoch - 58ms/step\n",
      "iteration :45     Target train: tf.Tensor(1.1689569, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.1797 - mse: 1.0584 - val_loss: 1.1693 - val_mse: 1.4703 - 55ms/epoch - 55ms/step\n",
      "iteration :46     Target train: tf.Tensor(1.1585015, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.1693 - mse: 1.0489 - val_loss: 1.1591 - val_mse: 1.4575 - 53ms/epoch - 53ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iteration :47     Target train: tf.Tensor(1.1482413, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.1591 - mse: 1.0396 - val_loss: 1.1490 - val_mse: 1.4450 - 55ms/epoch - 55ms/step\n",
      "iteration :48     Target train: tf.Tensor(1.1381563, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.1490 - mse: 1.0303 - val_loss: 1.1391 - val_mse: 1.4329 - 61ms/epoch - 61ms/step\n",
      "iteration :49     Target train: tf.Tensor(1.1282251, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.1391 - mse: 1.0212 - val_loss: 1.1293 - val_mse: 1.4211 - 52ms/epoch - 52ms/step\n",
      "iteration :50     Target train: tf.Tensor(1.1184257, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.1293 - mse: 1.0121 - val_loss: 1.1197 - val_mse: 1.4096 - 47ms/epoch - 47ms/step\n",
      "iteration :51     Target train: tf.Tensor(1.1087345, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.1197 - mse: 1.0030 - val_loss: 1.1101 - val_mse: 1.3984 - 52ms/epoch - 52ms/step\n",
      "iteration :52     Target train: tf.Tensor(1.0991279, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.1101 - mse: 0.9940 - val_loss: 1.1006 - val_mse: 1.3875 - 50ms/epoch - 50ms/step\n",
      "iteration :53     Target train: tf.Tensor(1.0895834, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.1006 - mse: 0.9849 - val_loss: 1.0911 - val_mse: 1.3769 - 51ms/epoch - 51ms/step\n",
      "iteration :54     Target train: tf.Tensor(1.0800813, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.0911 - mse: 0.9758 - val_loss: 1.0817 - val_mse: 1.3666 - 54ms/epoch - 54ms/step\n",
      "iteration :55     Target train: tf.Tensor(1.0706095, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.0817 - mse: 0.9666 - val_loss: 1.0723 - val_mse: 1.3566 - 54ms/epoch - 54ms/step\n",
      "iteration :56     Target train: tf.Tensor(1.0611681, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.0723 - mse: 0.9574 - val_loss: 1.0629 - val_mse: 1.3468 - 53ms/epoch - 53ms/step\n",
      "iteration :57     Target train: tf.Tensor(1.0517753, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.0629 - mse: 0.9481 - val_loss: 1.0536 - val_mse: 1.3373 - 51ms/epoch - 51ms/step\n",
      "iteration :58     Target train: tf.Tensor(1.0424724, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.0536 - mse: 0.9389 - val_loss: 1.0445 - val_mse: 1.3280 - 51ms/epoch - 51ms/step\n",
      "iteration :59     Target train: tf.Tensor(1.0333215, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.0445 - mse: 0.9298 - val_loss: 1.0356 - val_mse: 1.3190 - 79ms/epoch - 79ms/step\n",
      "iteration :60     Target train: tf.Tensor(1.0244006, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.0356 - mse: 0.9209 - val_loss: 1.0270 - val_mse: 1.3102 - 75ms/epoch - 75ms/step\n",
      "iteration :61     Target train: tf.Tensor(1.0157864, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.0270 - mse: 0.9123 - val_loss: 1.0188 - val_mse: 1.3016 - 62ms/epoch - 62ms/step\n",
      "iteration :62     Target train: tf.Tensor(1.0075399, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.0188 - mse: 0.9042 - val_loss: 1.0110 - val_mse: 1.2933 - 50ms/epoch - 50ms/step\n",
      "iteration :63     Target train: tf.Tensor(0.9996944, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.0110 - mse: 0.8965 - val_loss: 1.0036 - val_mse: 1.2851 - 51ms/epoch - 51ms/step\n",
      "iteration :64     Target train: tf.Tensor(0.9922539, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.0036 - mse: 0.8894 - val_loss: 0.9965 - val_mse: 1.2772 - 76ms/epoch - 76ms/step\n",
      "iteration :65     Target train: tf.Tensor(0.98519915, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.9965 - mse: 0.8826 - val_loss: 0.9899 - val_mse: 1.2694 - 81ms/epoch - 81ms/step\n",
      "iteration :66     Target train: tf.Tensor(0.9784965, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.9899 - mse: 0.8763 - val_loss: 0.9835 - val_mse: 1.2617 - 66ms/epoch - 66ms/step\n",
      "iteration :67     Target train: tf.Tensor(0.9721065, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.9835 - mse: 0.8703 - val_loss: 0.9774 - val_mse: 1.2543 - 82ms/epoch - 82ms/step\n",
      "iteration :68     Target train: tf.Tensor(0.96599, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.9774 - mse: 0.8647 - val_loss: 0.9716 - val_mse: 1.2470 - 62ms/epoch - 62ms/step\n",
      "iteration :69     Target train: tf.Tensor(0.96011114, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.9716 - mse: 0.8593 - val_loss: 0.9659 - val_mse: 1.2398 - 54ms/epoch - 54ms/step\n",
      "iteration :70     Target train: tf.Tensor(0.95443946, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.9659 - mse: 0.8542 - val_loss: 0.9604 - val_mse: 1.2328 - 52ms/epoch - 52ms/step\n",
      "iteration :71     Target train: tf.Tensor(0.9489488, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.9604 - mse: 0.8492 - val_loss: 0.9551 - val_mse: 1.2259 - 52ms/epoch - 52ms/step\n",
      "iteration :72     Target train: tf.Tensor(0.94361794, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.9551 - mse: 0.8445 - val_loss: 0.9500 - val_mse: 1.2191 - 55ms/epoch - 55ms/step\n",
      "iteration :73     Target train: tf.Tensor(0.93842936, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.9500 - mse: 0.8398 - val_loss: 0.9449 - val_mse: 1.2124 - 53ms/epoch - 53ms/step\n",
      "iteration :74     Target train: tf.Tensor(0.93336904, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.9449 - mse: 0.8353 - val_loss: 0.9400 - val_mse: 1.2059 - 55ms/epoch - 55ms/step\n",
      "iteration :75     Target train: tf.Tensor(0.92842543, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.9400 - mse: 0.8309 - val_loss: 0.9352 - val_mse: 1.1994 - 54ms/epoch - 54ms/step\n",
      "iteration :76     Target train: tf.Tensor(0.92358905, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.9352 - mse: 0.8267 - val_loss: 0.9305 - val_mse: 1.1931 - 56ms/epoch - 56ms/step\n",
      "iteration :77     Target train: tf.Tensor(0.9188519, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.9305 - mse: 0.8225 - val_loss: 0.9259 - val_mse: 1.1869 - 57ms/epoch - 57ms/step\n",
      "iteration :78     Target train: tf.Tensor(0.91420746, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.9259 - mse: 0.8184 - val_loss: 0.9213 - val_mse: 1.1808 - 53ms/epoch - 53ms/step\n",
      "iteration :79     Target train: tf.Tensor(0.9096499, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.9213 - mse: 0.8144 - val_loss: 0.9169 - val_mse: 1.1748 - 54ms/epoch - 54ms/step\n",
      "iteration :80     Target train: tf.Tensor(0.90517586, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.9169 - mse: 0.8105 - val_loss: 0.9125 - val_mse: 1.1688 - 53ms/epoch - 53ms/step\n",
      "iteration :81     Target train: tf.Tensor(0.90078074, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.9125 - mse: 0.8066 - val_loss: 0.9082 - val_mse: 1.1630 - 51ms/epoch - 51ms/step\n",
      "iteration :82     Target train: tf.Tensor(0.8964612, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.9082 - mse: 0.8028 - val_loss: 0.9040 - val_mse: 1.1573 - 58ms/epoch - 58ms/step\n",
      "iteration :83     Target train: tf.Tensor(0.89221364, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.9040 - mse: 0.7991 - val_loss: 0.8999 - val_mse: 1.1516 - 58ms/epoch - 58ms/step\n",
      "iteration :84     Target train: tf.Tensor(0.8880354, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.8999 - mse: 0.7954 - val_loss: 0.8958 - val_mse: 1.1460 - 54ms/epoch - 54ms/step\n",
      "iteration :85     Target train: tf.Tensor(0.8839236, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.8958 - mse: 0.7918 - val_loss: 0.8918 - val_mse: 1.1406 - 50ms/epoch - 50ms/step\n",
      "iteration :86     Target train: tf.Tensor(0.87987596, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.8918 - mse: 0.7883 - val_loss: 0.8878 - val_mse: 1.1352 - 48ms/epoch - 48ms/step\n",
      "iteration :87     Target train: tf.Tensor(0.8758902, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.8878 - mse: 0.7848 - val_loss: 0.8839 - val_mse: 1.1298 - 66ms/epoch - 66ms/step\n",
      "iteration :88     Target train: tf.Tensor(0.8719643, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.8839 - mse: 0.7814 - val_loss: 0.8801 - val_mse: 1.1246 - 50ms/epoch - 50ms/step\n",
      "iteration :89     Target train: tf.Tensor(0.8680962, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.8801 - mse: 0.7780 - val_loss: 0.8763 - val_mse: 1.1194 - 58ms/epoch - 58ms/step\n",
      "iteration :90     Target train: tf.Tensor(0.8642843, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.8763 - mse: 0.7747 - val_loss: 0.8726 - val_mse: 1.1143 - 52ms/epoch - 52ms/step\n",
      "iteration :91     Target train: tf.Tensor(0.8605266, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.8726 - mse: 0.7714 - val_loss: 0.8689 - val_mse: 1.1092 - 52ms/epoch - 52ms/step\n",
      "iteration :92     Target train: tf.Tensor(0.8568216, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.8689 - mse: 0.7681 - val_loss: 0.8653 - val_mse: 1.1043 - 54ms/epoch - 54ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iteration :93     Target train: tf.Tensor(0.8531677, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.8653 - mse: 0.7649 - val_loss: 0.8617 - val_mse: 1.0994 - 48ms/epoch - 48ms/step\n",
      "iteration :94     Target train: tf.Tensor(0.8495635, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.8617 - mse: 0.7618 - val_loss: 0.8582 - val_mse: 1.0945 - 52ms/epoch - 52ms/step\n",
      "iteration :95     Target train: tf.Tensor(0.84600747, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.8582 - mse: 0.7587 - val_loss: 0.8547 - val_mse: 1.0897 - 68ms/epoch - 68ms/step\n",
      "iteration :96     Target train: tf.Tensor(0.8424982, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.8547 - mse: 0.7556 - val_loss: 0.8512 - val_mse: 1.0850 - 55ms/epoch - 55ms/step\n",
      "iteration :97     Target train: tf.Tensor(0.8390345, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.8512 - mse: 0.7526 - val_loss: 0.8479 - val_mse: 1.0803 - 52ms/epoch - 52ms/step\n",
      "iteration :98     Target train: tf.Tensor(0.83561474, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.8479 - mse: 0.7496 - val_loss: 0.8445 - val_mse: 1.0757 - 53ms/epoch - 53ms/step\n",
      "iteration :99     Target train: tf.Tensor(0.832238, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.8445 - mse: 0.7467 - val_loss: 0.8412 - val_mse: 1.0712 - 56ms/epoch - 56ms/step\n",
      "iteration :100     Target train: tf.Tensor(0.8289029, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.8412 - mse: 0.7438 - val_loss: 0.8379 - val_mse: 1.0667 - 56ms/epoch - 56ms/step\n",
      "iteration :101     Target train: tf.Tensor(0.8256085, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.8379 - mse: 0.7409 - val_loss: 0.8347 - val_mse: 1.0622 - 55ms/epoch - 55ms/step\n",
      "iteration :102     Target train: tf.Tensor(0.82235336, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.8347 - mse: 0.7381 - val_loss: 0.8315 - val_mse: 1.0578 - 53ms/epoch - 53ms/step\n",
      "iteration :103     Target train: tf.Tensor(0.81913656, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.8315 - mse: 0.7353 - val_loss: 0.8284 - val_mse: 1.0535 - 49ms/epoch - 49ms/step\n",
      "iteration :104     Target train: tf.Tensor(0.8159568, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.8284 - mse: 0.7325 - val_loss: 0.8253 - val_mse: 1.0492 - 52ms/epoch - 52ms/step\n",
      "iteration :105     Target train: tf.Tensor(0.8128134, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.8253 - mse: 0.7298 - val_loss: 0.8222 - val_mse: 1.0449 - 56ms/epoch - 56ms/step\n",
      "iteration :106     Target train: tf.Tensor(0.809705, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.8222 - mse: 0.7271 - val_loss: 0.8191 - val_mse: 1.0407 - 51ms/epoch - 51ms/step\n",
      "iteration :107     Target train: tf.Tensor(0.8066308, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.8191 - mse: 0.7244 - val_loss: 0.8161 - val_mse: 1.0365 - 57ms/epoch - 57ms/step\n",
      "iteration :108     Target train: tf.Tensor(0.80358976, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.8161 - mse: 0.7217 - val_loss: 0.8131 - val_mse: 1.0324 - 51ms/epoch - 51ms/step\n",
      "iteration :109     Target train: tf.Tensor(0.8005812, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.8131 - mse: 0.7191 - val_loss: 0.8102 - val_mse: 1.0283 - 48ms/epoch - 48ms/step\n",
      "iteration :110     Target train: tf.Tensor(0.79760385, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.8102 - mse: 0.7165 - val_loss: 0.8073 - val_mse: 1.0243 - 53ms/epoch - 53ms/step\n",
      "iteration :111     Target train: tf.Tensor(0.7946573, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.8073 - mse: 0.7140 - val_loss: 0.8044 - val_mse: 1.0203 - 57ms/epoch - 57ms/step\n",
      "iteration :112     Target train: tf.Tensor(0.7917403, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.8044 - mse: 0.7115 - val_loss: 0.8015 - val_mse: 1.0163 - 48ms/epoch - 48ms/step\n",
      "iteration :113     Target train: tf.Tensor(0.7888522, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.8015 - mse: 0.7089 - val_loss: 0.7987 - val_mse: 1.0124 - 61ms/epoch - 61ms/step\n",
      "iteration :114     Target train: tf.Tensor(0.7859923, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.7987 - mse: 0.7065 - val_loss: 0.7959 - val_mse: 1.0085 - 49ms/epoch - 49ms/step\n",
      "iteration :115     Target train: tf.Tensor(0.78315973, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.7959 - mse: 0.7040 - val_loss: 0.7931 - val_mse: 1.0046 - 48ms/epoch - 48ms/step\n",
      "iteration :116     Target train: tf.Tensor(0.78035384, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.7931 - mse: 0.7016 - val_loss: 0.7904 - val_mse: 1.0008 - 52ms/epoch - 52ms/step\n",
      "iteration :117     Target train: tf.Tensor(0.7775738, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.7904 - mse: 0.6992 - val_loss: 0.7876 - val_mse: 0.9970 - 69ms/epoch - 69ms/step\n",
      "iteration :118     Target train: tf.Tensor(0.7748191, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.7876 - mse: 0.6968 - val_loss: 0.7849 - val_mse: 0.9932 - 55ms/epoch - 55ms/step\n",
      "iteration :119     Target train: tf.Tensor(0.772089, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.7849 - mse: 0.6944 - val_loss: 0.7822 - val_mse: 0.9895 - 56ms/epoch - 56ms/step\n",
      "iteration :120     Target train: tf.Tensor(0.7693827, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.7822 - mse: 0.6921 - val_loss: 0.7796 - val_mse: 0.9858 - 56ms/epoch - 56ms/step\n",
      "iteration :121     Target train: tf.Tensor(0.76669997, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.7796 - mse: 0.6897 - val_loss: 0.7770 - val_mse: 0.9821 - 54ms/epoch - 54ms/step\n",
      "iteration :122     Target train: tf.Tensor(0.7640399, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.7770 - mse: 0.6874 - val_loss: 0.7743 - val_mse: 0.9785 - 53ms/epoch - 53ms/step\n",
      "iteration :123     Target train: tf.Tensor(0.7614021, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.7743 - mse: 0.6851 - val_loss: 0.7718 - val_mse: 0.9748 - 56ms/epoch - 56ms/step\n",
      "iteration :124     Target train: tf.Tensor(0.75878596, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.7718 - mse: 0.6829 - val_loss: 0.7692 - val_mse: 0.9713 - 68ms/epoch - 68ms/step\n",
      "iteration :125     Target train: tf.Tensor(0.7561909, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.7692 - mse: 0.6806 - val_loss: 0.7666 - val_mse: 0.9677 - 56ms/epoch - 56ms/step\n",
      "iteration :126     Target train: tf.Tensor(0.7536165, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.7666 - mse: 0.6784 - val_loss: 0.7641 - val_mse: 0.9642 - 49ms/epoch - 49ms/step\n",
      "iteration :127     Target train: tf.Tensor(0.7510624, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.7641 - mse: 0.6762 - val_loss: 0.7616 - val_mse: 0.9607 - 58ms/epoch - 58ms/step\n",
      "iteration :128     Target train: tf.Tensor(0.7485279, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.7616 - mse: 0.6740 - val_loss: 0.7591 - val_mse: 0.9572 - 55ms/epoch - 55ms/step\n",
      "iteration :129     Target train: tf.Tensor(0.7460126, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.7591 - mse: 0.6718 - val_loss: 0.7567 - val_mse: 0.9537 - 57ms/epoch - 57ms/step\n",
      "iteration :130     Target train: tf.Tensor(0.7435161, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.7567 - mse: 0.6697 - val_loss: 0.7542 - val_mse: 0.9503 - 54ms/epoch - 54ms/step\n",
      "iteration :131     Target train: tf.Tensor(0.74103826, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.7542 - mse: 0.6675 - val_loss: 0.7518 - val_mse: 0.9469 - 49ms/epoch - 49ms/step\n",
      "iteration :132     Target train: tf.Tensor(0.7385782, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.7518 - mse: 0.6654 - val_loss: 0.7494 - val_mse: 0.9435 - 51ms/epoch - 51ms/step\n",
      "iteration :133     Target train: tf.Tensor(0.7361359, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.7494 - mse: 0.6633 - val_loss: 0.7470 - val_mse: 0.9402 - 52ms/epoch - 52ms/step\n",
      "iteration :134     Target train: tf.Tensor(0.7337109, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.7470 - mse: 0.6612 - val_loss: 0.7446 - val_mse: 0.9368 - 49ms/epoch - 49ms/step\n",
      "iteration :135     Target train: tf.Tensor(0.7313029, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.7446 - mse: 0.6591 - val_loss: 0.7422 - val_mse: 0.9335 - 57ms/epoch - 57ms/step\n",
      "iteration :136     Target train: tf.Tensor(0.72891146, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.7422 - mse: 0.6570 - val_loss: 0.7399 - val_mse: 0.9302 - 53ms/epoch - 53ms/step\n",
      "iteration :137     Target train: tf.Tensor(0.7265362, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.7399 - mse: 0.6550 - val_loss: 0.7375 - val_mse: 0.9270 - 58ms/epoch - 58ms/step\n",
      "iteration :138     Target train: tf.Tensor(0.7241772, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.7375 - mse: 0.6529 - val_loss: 0.7352 - val_mse: 0.9237 - 55ms/epoch - 55ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iteration :139     Target train: tf.Tensor(0.72183377, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.7352 - mse: 0.6509 - val_loss: 0.7329 - val_mse: 0.9205 - 54ms/epoch - 54ms/step\n",
      "iteration :140     Target train: tf.Tensor(0.71950567, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.7329 - mse: 0.6489 - val_loss: 0.7306 - val_mse: 0.9173 - 52ms/epoch - 52ms/step\n",
      "iteration :141     Target train: tf.Tensor(0.71719295, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.7306 - mse: 0.6469 - val_loss: 0.7284 - val_mse: 0.9141 - 64ms/epoch - 64ms/step\n",
      "iteration :142     Target train: tf.Tensor(0.71489495, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.7284 - mse: 0.6449 - val_loss: 0.7261 - val_mse: 0.9110 - 55ms/epoch - 55ms/step\n",
      "iteration :143     Target train: tf.Tensor(0.7126118, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.7261 - mse: 0.6429 - val_loss: 0.7239 - val_mse: 0.9078 - 53ms/epoch - 53ms/step\n",
      "iteration :144     Target train: tf.Tensor(0.7103429, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.7239 - mse: 0.6410 - val_loss: 0.7216 - val_mse: 0.9047 - 52ms/epoch - 52ms/step\n",
      "iteration :145     Target train: tf.Tensor(0.7080884, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.7216 - mse: 0.6390 - val_loss: 0.7194 - val_mse: 0.9016 - 55ms/epoch - 55ms/step\n",
      "iteration :146     Target train: tf.Tensor(0.70584774, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.7194 - mse: 0.6371 - val_loss: 0.7172 - val_mse: 0.8985 - 61ms/epoch - 61ms/step\n",
      "iteration :147     Target train: tf.Tensor(0.7036211, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.7172 - mse: 0.6351 - val_loss: 0.7150 - val_mse: 0.8954 - 48ms/epoch - 48ms/step\n",
      "iteration :148     Target train: tf.Tensor(0.7014078, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.7150 - mse: 0.6332 - val_loss: 0.7129 - val_mse: 0.8924 - 51ms/epoch - 51ms/step\n",
      "iteration :149     Target train: tf.Tensor(0.6992081, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.7129 - mse: 0.6313 - val_loss: 0.7107 - val_mse: 0.8894 - 59ms/epoch - 59ms/step\n",
      "iteration :150     Target train: tf.Tensor(0.69702154, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.7107 - mse: 0.6294 - val_loss: 0.7086 - val_mse: 0.8864 - 50ms/epoch - 50ms/step\n",
      "iteration :151     Target train: tf.Tensor(0.69484806, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.7086 - mse: 0.6276 - val_loss: 0.7064 - val_mse: 0.8834 - 47ms/epoch - 47ms/step\n",
      "iteration :152     Target train: tf.Tensor(0.6926877, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.7064 - mse: 0.6257 - val_loss: 0.7043 - val_mse: 0.8804 - 52ms/epoch - 52ms/step\n",
      "iteration :153     Target train: tf.Tensor(0.69053996, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.7043 - mse: 0.6238 - val_loss: 0.7022 - val_mse: 0.8774 - 51ms/epoch - 51ms/step\n",
      "iteration :154     Target train: tf.Tensor(0.6884048, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.7022 - mse: 0.6220 - val_loss: 0.7001 - val_mse: 0.8745 - 74ms/epoch - 74ms/step\n",
      "iteration :155     Target train: tf.Tensor(0.68628216, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.7001 - mse: 0.6202 - val_loss: 0.6980 - val_mse: 0.8716 - 63ms/epoch - 63ms/step\n",
      "iteration :156     Target train: tf.Tensor(0.68417186, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6980 - mse: 0.6183 - val_loss: 0.6959 - val_mse: 0.8687 - 59ms/epoch - 59ms/step\n",
      "iteration :157     Target train: tf.Tensor(0.68207383, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6959 - mse: 0.6165 - val_loss: 0.6939 - val_mse: 0.8658 - 54ms/epoch - 54ms/step\n",
      "iteration :158     Target train: tf.Tensor(0.6799879, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6939 - mse: 0.6147 - val_loss: 0.6918 - val_mse: 0.8629 - 56ms/epoch - 56ms/step\n",
      "iteration :159     Target train: tf.Tensor(0.6779139, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6918 - mse: 0.6129 - val_loss: 0.6898 - val_mse: 0.8601 - 59ms/epoch - 59ms/step\n",
      "iteration :160     Target train: tf.Tensor(0.6758518, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6898 - mse: 0.6111 - val_loss: 0.6878 - val_mse: 0.8572 - 54ms/epoch - 54ms/step\n",
      "iteration :161     Target train: tf.Tensor(0.67380154, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6878 - mse: 0.6094 - val_loss: 0.6858 - val_mse: 0.8544 - 55ms/epoch - 55ms/step\n",
      "iteration :162     Target train: tf.Tensor(0.6717629, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6858 - mse: 0.6076 - val_loss: 0.6838 - val_mse: 0.8516 - 52ms/epoch - 52ms/step\n",
      "iteration :163     Target train: tf.Tensor(0.66973585, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6838 - mse: 0.6058 - val_loss: 0.6818 - val_mse: 0.8488 - 47ms/epoch - 47ms/step\n",
      "iteration :164     Target train: tf.Tensor(0.6677202, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6818 - mse: 0.6041 - val_loss: 0.6798 - val_mse: 0.8461 - 52ms/epoch - 52ms/step\n",
      "iteration :165     Target train: tf.Tensor(0.6657161, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6798 - mse: 0.6023 - val_loss: 0.6778 - val_mse: 0.8433 - 56ms/epoch - 56ms/step\n",
      "iteration :166     Target train: tf.Tensor(0.6637233, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6778 - mse: 0.6006 - val_loss: 0.6759 - val_mse: 0.8406 - 52ms/epoch - 52ms/step\n",
      "iteration :167     Target train: tf.Tensor(0.6617417, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6759 - mse: 0.5989 - val_loss: 0.6739 - val_mse: 0.8379 - 50ms/epoch - 50ms/step\n",
      "iteration :168     Target train: tf.Tensor(0.6597712, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6739 - mse: 0.5972 - val_loss: 0.6720 - val_mse: 0.8352 - 54ms/epoch - 54ms/step\n",
      "iteration :169     Target train: tf.Tensor(0.65781194, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6720 - mse: 0.5955 - val_loss: 0.6701 - val_mse: 0.8325 - 52ms/epoch - 52ms/step\n",
      "iteration :170     Target train: tf.Tensor(0.65586364, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6701 - mse: 0.5938 - val_loss: 0.6682 - val_mse: 0.8298 - 48ms/epoch - 48ms/step\n",
      "iteration :171     Target train: tf.Tensor(0.6539264, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6682 - mse: 0.5921 - val_loss: 0.6663 - val_mse: 0.8271 - 53ms/epoch - 53ms/step\n",
      "iteration :172     Target train: tf.Tensor(0.652, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6663 - mse: 0.5905 - val_loss: 0.6644 - val_mse: 0.8245 - 46ms/epoch - 46ms/step\n",
      "iteration :173     Target train: tf.Tensor(0.6500844, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6644 - mse: 0.5888 - val_loss: 0.6625 - val_mse: 0.8219 - 48ms/epoch - 48ms/step\n",
      "iteration :174     Target train: tf.Tensor(0.6481797, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6625 - mse: 0.5871 - val_loss: 0.6606 - val_mse: 0.8193 - 59ms/epoch - 59ms/step\n",
      "iteration :175     Target train: tf.Tensor(0.6462857, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6606 - mse: 0.5855 - val_loss: 0.6588 - val_mse: 0.8167 - 53ms/epoch - 53ms/step\n",
      "iteration :176     Target train: tf.Tensor(0.6444024, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6588 - mse: 0.5839 - val_loss: 0.6569 - val_mse: 0.8141 - 51ms/epoch - 51ms/step\n",
      "iteration :177     Target train: tf.Tensor(0.6425297, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6569 - mse: 0.5822 - val_loss: 0.6551 - val_mse: 0.8116 - 58ms/epoch - 58ms/step\n",
      "iteration :178     Target train: tf.Tensor(0.6406677, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6551 - mse: 0.5806 - val_loss: 0.6532 - val_mse: 0.8090 - 50ms/epoch - 50ms/step\n",
      "iteration :179     Target train: tf.Tensor(0.6388162, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6532 - mse: 0.5790 - val_loss: 0.6514 - val_mse: 0.8065 - 55ms/epoch - 55ms/step\n",
      "iteration :180     Target train: tf.Tensor(0.6369753, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6514 - mse: 0.5774 - val_loss: 0.6496 - val_mse: 0.8040 - 51ms/epoch - 51ms/step\n",
      "iteration :181     Target train: tf.Tensor(0.6351447, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6496 - mse: 0.5758 - val_loss: 0.6478 - val_mse: 0.8015 - 46ms/epoch - 46ms/step\n",
      "iteration :182     Target train: tf.Tensor(0.6333247, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6478 - mse: 0.5742 - val_loss: 0.6460 - val_mse: 0.7990 - 55ms/epoch - 55ms/step\n",
      "iteration :183     Target train: tf.Tensor(0.6315149, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6460 - mse: 0.5727 - val_loss: 0.6443 - val_mse: 0.7965 - 55ms/epoch - 55ms/step\n",
      "iteration :184     Target train: tf.Tensor(0.6297157, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6443 - mse: 0.5711 - val_loss: 0.6425 - val_mse: 0.7941 - 61ms/epoch - 61ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iteration :185     Target train: tf.Tensor(0.62792665, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6425 - mse: 0.5696 - val_loss: 0.6408 - val_mse: 0.7916 - 55ms/epoch - 55ms/step\n",
      "iteration :186     Target train: tf.Tensor(0.6261479, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6408 - mse: 0.5680 - val_loss: 0.6390 - val_mse: 0.7892 - 55ms/epoch - 55ms/step\n",
      "iteration :187     Target train: tf.Tensor(0.62437946, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6390 - mse: 0.5665 - val_loss: 0.6373 - val_mse: 0.7868 - 55ms/epoch - 55ms/step\n",
      "iteration :188     Target train: tf.Tensor(0.6226211, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6373 - mse: 0.5649 - val_loss: 0.6356 - val_mse: 0.7844 - 59ms/epoch - 59ms/step\n",
      "iteration :189     Target train: tf.Tensor(0.6208731, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6356 - mse: 0.5634 - val_loss: 0.6338 - val_mse: 0.7821 - 54ms/epoch - 54ms/step\n",
      "iteration :190     Target train: tf.Tensor(0.6191352, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6338 - mse: 0.5619 - val_loss: 0.6321 - val_mse: 0.7797 - 58ms/epoch - 58ms/step\n",
      "iteration :191     Target train: tf.Tensor(0.6174073, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6321 - mse: 0.5604 - val_loss: 0.6305 - val_mse: 0.7774 - 59ms/epoch - 59ms/step\n",
      "iteration :192     Target train: tf.Tensor(0.6156896, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6305 - mse: 0.5589 - val_loss: 0.6288 - val_mse: 0.7750 - 51ms/epoch - 51ms/step\n",
      "iteration :193     Target train: tf.Tensor(0.6139818, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6288 - mse: 0.5574 - val_loss: 0.6271 - val_mse: 0.7727 - 63ms/epoch - 63ms/step\n",
      "iteration :194     Target train: tf.Tensor(0.61228406, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6271 - mse: 0.5559 - val_loss: 0.6254 - val_mse: 0.7704 - 53ms/epoch - 53ms/step\n",
      "iteration :195     Target train: tf.Tensor(0.61059624, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6254 - mse: 0.5544 - val_loss: 0.6238 - val_mse: 0.7682 - 49ms/epoch - 49ms/step\n",
      "iteration :196     Target train: tf.Tensor(0.6089184, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6238 - mse: 0.5530 - val_loss: 0.6221 - val_mse: 0.7659 - 53ms/epoch - 53ms/step\n",
      "iteration :197     Target train: tf.Tensor(0.6072504, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6221 - mse: 0.5515 - val_loss: 0.6205 - val_mse: 0.7636 - 53ms/epoch - 53ms/step\n",
      "iteration :198     Target train: tf.Tensor(0.6055923, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6205 - mse: 0.5501 - val_loss: 0.6189 - val_mse: 0.7614 - 53ms/epoch - 53ms/step\n",
      "iteration :199     Target train: tf.Tensor(0.60394394, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6189 - mse: 0.5486 - val_loss: 0.6173 - val_mse: 0.7592 - 56ms/epoch - 56ms/step\n",
      "iteration :200     Target train: tf.Tensor(0.60230535, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6173 - mse: 0.5472 - val_loss: 0.6157 - val_mse: 0.7570 - 50ms/epoch - 50ms/step\n",
      "iteration :201     Target train: tf.Tensor(0.60067654, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6157 - mse: 0.5458 - val_loss: 0.6141 - val_mse: 0.7548 - 54ms/epoch - 54ms/step\n",
      "iteration :202     Target train: tf.Tensor(0.5990573, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6141 - mse: 0.5443 - val_loss: 0.6125 - val_mse: 0.7526 - 52ms/epoch - 52ms/step\n",
      "iteration :203     Target train: tf.Tensor(0.5974477, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6125 - mse: 0.5429 - val_loss: 0.6109 - val_mse: 0.7505 - 55ms/epoch - 55ms/step\n",
      "iteration :204     Target train: tf.Tensor(0.5958477, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6109 - mse: 0.5415 - val_loss: 0.6093 - val_mse: 0.7483 - 47ms/epoch - 47ms/step\n",
      "iteration :205     Target train: tf.Tensor(0.59425724, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6093 - mse: 0.5401 - val_loss: 0.6078 - val_mse: 0.7462 - 63ms/epoch - 63ms/step\n",
      "iteration :206     Target train: tf.Tensor(0.5926762, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6078 - mse: 0.5387 - val_loss: 0.6062 - val_mse: 0.7441 - 56ms/epoch - 56ms/step\n",
      "iteration :207     Target train: tf.Tensor(0.5911046, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6062 - mse: 0.5373 - val_loss: 0.6047 - val_mse: 0.7420 - 55ms/epoch - 55ms/step\n",
      "iteration :208     Target train: tf.Tensor(0.5895424, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6047 - mse: 0.5360 - val_loss: 0.6032 - val_mse: 0.7400 - 57ms/epoch - 57ms/step\n",
      "iteration :209     Target train: tf.Tensor(0.5879895, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6032 - mse: 0.5346 - val_loss: 0.6016 - val_mse: 0.7379 - 57ms/epoch - 57ms/step\n",
      "iteration :210     Target train: tf.Tensor(0.58644587, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6016 - mse: 0.5332 - val_loss: 0.6001 - val_mse: 0.7359 - 56ms/epoch - 56ms/step\n",
      "iteration :211     Target train: tf.Tensor(0.58491135, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6001 - mse: 0.5319 - val_loss: 0.5986 - val_mse: 0.7338 - 55ms/epoch - 55ms/step\n",
      "iteration :212     Target train: tf.Tensor(0.58338606, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5986 - mse: 0.5305 - val_loss: 0.5971 - val_mse: 0.7318 - 54ms/epoch - 54ms/step\n",
      "iteration :213     Target train: tf.Tensor(0.5818697, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5971 - mse: 0.5292 - val_loss: 0.5956 - val_mse: 0.7298 - 49ms/epoch - 49ms/step\n",
      "iteration :214     Target train: tf.Tensor(0.5803625, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5956 - mse: 0.5279 - val_loss: 0.5942 - val_mse: 0.7278 - 52ms/epoch - 52ms/step\n",
      "iteration :215     Target train: tf.Tensor(0.57886416, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5942 - mse: 0.5265 - val_loss: 0.5927 - val_mse: 0.7259 - 53ms/epoch - 53ms/step\n",
      "iteration :216     Target train: tf.Tensor(0.5773747, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5927 - mse: 0.5252 - val_loss: 0.5912 - val_mse: 0.7239 - 65ms/epoch - 65ms/step\n",
      "iteration :217     Target train: tf.Tensor(0.57589406, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5912 - mse: 0.5239 - val_loss: 0.5898 - val_mse: 0.7220 - 176ms/epoch - 176ms/step\n",
      "iteration :218     Target train: tf.Tensor(0.5744222, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5898 - mse: 0.5226 - val_loss: 0.5884 - val_mse: 0.7201 - 54ms/epoch - 54ms/step\n",
      "iteration :219     Target train: tf.Tensor(0.5729589, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5884 - mse: 0.5213 - val_loss: 0.5869 - val_mse: 0.7182 - 63ms/epoch - 63ms/step\n",
      "iteration :220     Target train: tf.Tensor(0.5715042, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5869 - mse: 0.5200 - val_loss: 0.5855 - val_mse: 0.7163 - 59ms/epoch - 59ms/step\n",
      "iteration :221     Target train: tf.Tensor(0.570058, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5855 - mse: 0.5187 - val_loss: 0.5841 - val_mse: 0.7144 - 55ms/epoch - 55ms/step\n",
      "iteration :222     Target train: tf.Tensor(0.5686204, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5841 - mse: 0.5174 - val_loss: 0.5827 - val_mse: 0.7125 - 53ms/epoch - 53ms/step\n",
      "iteration :223     Target train: tf.Tensor(0.56719106, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5827 - mse: 0.5161 - val_loss: 0.5813 - val_mse: 0.7107 - 65ms/epoch - 65ms/step\n",
      "iteration :224     Target train: tf.Tensor(0.56577003, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5813 - mse: 0.5148 - val_loss: 0.5799 - val_mse: 0.7089 - 48ms/epoch - 48ms/step\n",
      "iteration :225     Target train: tf.Tensor(0.5643573, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5799 - mse: 0.5136 - val_loss: 0.5785 - val_mse: 0.7071 - 54ms/epoch - 54ms/step\n",
      "iteration :226     Target train: tf.Tensor(0.5629527, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5785 - mse: 0.5123 - val_loss: 0.5771 - val_mse: 0.7053 - 55ms/epoch - 55ms/step\n",
      "iteration :227     Target train: tf.Tensor(0.5615562, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5771 - mse: 0.5111 - val_loss: 0.5758 - val_mse: 0.7035 - 50ms/epoch - 50ms/step\n",
      "iteration :228     Target train: tf.Tensor(0.56016773, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5758 - mse: 0.5098 - val_loss: 0.5744 - val_mse: 0.7017 - 52ms/epoch - 52ms/step\n",
      "iteration :229     Target train: tf.Tensor(0.5587872, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5744 - mse: 0.5086 - val_loss: 0.5730 - val_mse: 0.7000 - 58ms/epoch - 58ms/step\n",
      "iteration :230     Target train: tf.Tensor(0.55741465, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5730 - mse: 0.5073 - val_loss: 0.5717 - val_mse: 0.6983 - 58ms/epoch - 58ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iteration :231     Target train: tf.Tensor(0.55605006, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5717 - mse: 0.5061 - val_loss: 0.5704 - val_mse: 0.6965 - 74ms/epoch - 74ms/step\n",
      "iteration :232     Target train: tf.Tensor(0.5546931, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5704 - mse: 0.5049 - val_loss: 0.5690 - val_mse: 0.6948 - 85ms/epoch - 85ms/step\n",
      "iteration :233     Target train: tf.Tensor(0.553344, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5690 - mse: 0.5036 - val_loss: 0.5677 - val_mse: 0.6931 - 56ms/epoch - 56ms/step\n",
      "iteration :234     Target train: tf.Tensor(0.55200267, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5677 - mse: 0.5024 - val_loss: 0.5664 - val_mse: 0.6915 - 56ms/epoch - 56ms/step\n",
      "iteration :235     Target train: tf.Tensor(0.550669, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5664 - mse: 0.5012 - val_loss: 0.5651 - val_mse: 0.6898 - 50ms/epoch - 50ms/step\n",
      "iteration :236     Target train: tf.Tensor(0.5493429, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5651 - mse: 0.5000 - val_loss: 0.5638 - val_mse: 0.6882 - 47ms/epoch - 47ms/step\n",
      "iteration :237     Target train: tf.Tensor(0.5480244, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5638 - mse: 0.4988 - val_loss: 0.5625 - val_mse: 0.6865 - 58ms/epoch - 58ms/step\n",
      "iteration :238     Target train: tf.Tensor(0.54671365, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5625 - mse: 0.4976 - val_loss: 0.5612 - val_mse: 0.6849 - 52ms/epoch - 52ms/step\n",
      "iteration :239     Target train: tf.Tensor(0.54541045, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5612 - mse: 0.4964 - val_loss: 0.5599 - val_mse: 0.6833 - 48ms/epoch - 48ms/step\n",
      "iteration :240     Target train: tf.Tensor(0.54411477, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5599 - mse: 0.4952 - val_loss: 0.5587 - val_mse: 0.6817 - 70ms/epoch - 70ms/step\n",
      "iteration :241     Target train: tf.Tensor(0.5428267, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5587 - mse: 0.4940 - val_loss: 0.5574 - val_mse: 0.6802 - 89ms/epoch - 89ms/step\n",
      "iteration :242     Target train: tf.Tensor(0.54154634, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5574 - mse: 0.4928 - val_loss: 0.5561 - val_mse: 0.6786 - 66ms/epoch - 66ms/step\n",
      "iteration :243     Target train: tf.Tensor(0.5402736, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5561 - mse: 0.4917 - val_loss: 0.5549 - val_mse: 0.6770 - 63ms/epoch - 63ms/step\n",
      "iteration :244     Target train: tf.Tensor(0.5390084, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5549 - mse: 0.4905 - val_loss: 0.5537 - val_mse: 0.6755 - 56ms/epoch - 56ms/step\n",
      "iteration :245     Target train: tf.Tensor(0.5377509, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5537 - mse: 0.4893 - val_loss: 0.5524 - val_mse: 0.6740 - 55ms/epoch - 55ms/step\n",
      "iteration :246     Target train: tf.Tensor(0.5365012, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5524 - mse: 0.4882 - val_loss: 0.5512 - val_mse: 0.6725 - 61ms/epoch - 61ms/step\n",
      "iteration :247     Target train: tf.Tensor(0.5352593, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5512 - mse: 0.4870 - val_loss: 0.5500 - val_mse: 0.6710 - 59ms/epoch - 59ms/step\n",
      "iteration :248     Target train: tf.Tensor(0.5340253, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5500 - mse: 0.4859 - val_loss: 0.5488 - val_mse: 0.6695 - 59ms/epoch - 59ms/step\n",
      "iteration :249     Target train: tf.Tensor(0.5327991, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5488 - mse: 0.4848 - val_loss: 0.5476 - val_mse: 0.6681 - 53ms/epoch - 53ms/step\n",
      "iteration :250     Target train: tf.Tensor(0.531581, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5476 - mse: 0.4836 - val_loss: 0.5464 - val_mse: 0.6666 - 64ms/epoch - 64ms/step\n",
      "iteration :251     Target train: tf.Tensor(0.53037095, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5464 - mse: 0.4825 - val_loss: 0.5452 - val_mse: 0.6652 - 60ms/epoch - 60ms/step\n",
      "iteration :252     Target train: tf.Tensor(0.5291691, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5452 - mse: 0.4814 - val_loss: 0.5440 - val_mse: 0.6638 - 53ms/epoch - 53ms/step\n",
      "iteration :253     Target train: tf.Tensor(0.5279755, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5440 - mse: 0.4803 - val_loss: 0.5428 - val_mse: 0.6623 - 53ms/epoch - 53ms/step\n",
      "iteration :254     Target train: tf.Tensor(0.5267904, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5428 - mse: 0.4792 - val_loss: 0.5417 - val_mse: 0.6609 - 51ms/epoch - 51ms/step\n",
      "iteration :255     Target train: tf.Tensor(0.52561367, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5417 - mse: 0.4781 - val_loss: 0.5405 - val_mse: 0.6596 - 59ms/epoch - 59ms/step\n",
      "iteration :256     Target train: tf.Tensor(0.52444553, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5405 - mse: 0.4770 - val_loss: 0.5394 - val_mse: 0.6582 - 56ms/epoch - 56ms/step\n",
      "iteration :257     Target train: tf.Tensor(0.52328616, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5394 - mse: 0.4759 - val_loss: 0.5382 - val_mse: 0.6568 - 54ms/epoch - 54ms/step\n",
      "iteration :258     Target train: tf.Tensor(0.5221356, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5382 - mse: 0.4748 - val_loss: 0.5371 - val_mse: 0.6555 - 52ms/epoch - 52ms/step\n",
      "iteration :259     Target train: tf.Tensor(0.520994, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5371 - mse: 0.4737 - val_loss: 0.5360 - val_mse: 0.6541 - 52ms/epoch - 52ms/step\n",
      "iteration :260     Target train: tf.Tensor(0.5198615, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5360 - mse: 0.4727 - val_loss: 0.5349 - val_mse: 0.6528 - 58ms/epoch - 58ms/step\n",
      "iteration :261     Target train: tf.Tensor(0.5187382, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5349 - mse: 0.4716 - val_loss: 0.5338 - val_mse: 0.6515 - 75ms/epoch - 75ms/step\n",
      "iteration :262     Target train: tf.Tensor(0.5176242, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5338 - mse: 0.4706 - val_loss: 0.5327 - val_mse: 0.6502 - 54ms/epoch - 54ms/step\n",
      "iteration :263     Target train: tf.Tensor(0.51651967, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5327 - mse: 0.4695 - val_loss: 0.5316 - val_mse: 0.6489 - 63ms/epoch - 63ms/step\n",
      "iteration :264     Target train: tf.Tensor(0.51542467, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5316 - mse: 0.4685 - val_loss: 0.5305 - val_mse: 0.6477 - 60ms/epoch - 60ms/step\n",
      "iteration :265     Target train: tf.Tensor(0.5143392, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5305 - mse: 0.4675 - val_loss: 0.5295 - val_mse: 0.6464 - 58ms/epoch - 58ms/step\n",
      "iteration :266     Target train: tf.Tensor(0.5132635, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5295 - mse: 0.4665 - val_loss: 0.5284 - val_mse: 0.6451 - 51ms/epoch - 51ms/step\n",
      "iteration :267     Target train: tf.Tensor(0.51219773, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5284 - mse: 0.4655 - val_loss: 0.5274 - val_mse: 0.6439 - 54ms/epoch - 54ms/step\n",
      "iteration :268     Target train: tf.Tensor(0.5111418, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5274 - mse: 0.4645 - val_loss: 0.5264 - val_mse: 0.6427 - 50ms/epoch - 50ms/step\n",
      "iteration :269     Target train: tf.Tensor(0.5100957, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5264 - mse: 0.4635 - val_loss: 0.5253 - val_mse: 0.6415 - 50ms/epoch - 50ms/step\n",
      "iteration :270     Target train: tf.Tensor(0.5090598, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5253 - mse: 0.4625 - val_loss: 0.5243 - val_mse: 0.6402 - 58ms/epoch - 58ms/step\n",
      "iteration :271     Target train: tf.Tensor(0.508034, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5243 - mse: 0.4616 - val_loss: 0.5233 - val_mse: 0.6391 - 47ms/epoch - 47ms/step\n",
      "iteration :272     Target train: tf.Tensor(0.5070184, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5233 - mse: 0.4606 - val_loss: 0.5223 - val_mse: 0.6379 - 59ms/epoch - 59ms/step\n",
      "iteration :273     Target train: tf.Tensor(0.5060129, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5223 - mse: 0.4597 - val_loss: 0.5213 - val_mse: 0.6367 - 52ms/epoch - 52ms/step\n",
      "iteration :274     Target train: tf.Tensor(0.5050177, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5213 - mse: 0.4588 - val_loss: 0.5204 - val_mse: 0.6355 - 52ms/epoch - 52ms/step\n",
      "iteration :275     Target train: tf.Tensor(0.50403273, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5204 - mse: 0.4578 - val_loss: 0.5194 - val_mse: 0.6344 - 56ms/epoch - 56ms/step\n",
      "iteration :276     Target train: tf.Tensor(0.50305796, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5194 - mse: 0.4569 - val_loss: 0.5184 - val_mse: 0.6332 - 61ms/epoch - 61ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iteration :277     Target train: tf.Tensor(0.5020934, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5184 - mse: 0.4560 - val_loss: 0.5175 - val_mse: 0.6321 - 64ms/epoch - 64ms/step\n",
      "iteration :278     Target train: tf.Tensor(0.5011391, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5175 - mse: 0.4551 - val_loss: 0.5166 - val_mse: 0.6310 - 54ms/epoch - 54ms/step\n",
      "iteration :279     Target train: tf.Tensor(0.5001951, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5166 - mse: 0.4542 - val_loss: 0.5156 - val_mse: 0.6299 - 52ms/epoch - 52ms/step\n",
      "iteration :280     Target train: tf.Tensor(0.49926123, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5156 - mse: 0.4534 - val_loss: 0.5147 - val_mse: 0.6288 - 54ms/epoch - 54ms/step\n",
      "iteration :281     Target train: tf.Tensor(0.49833748, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5147 - mse: 0.4525 - val_loss: 0.5138 - val_mse: 0.6277 - 53ms/epoch - 53ms/step\n",
      "iteration :282     Target train: tf.Tensor(0.49742386, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5138 - mse: 0.4517 - val_loss: 0.5129 - val_mse: 0.6266 - 53ms/epoch - 53ms/step\n",
      "iteration :283     Target train: tf.Tensor(0.49652025, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5129 - mse: 0.4508 - val_loss: 0.5121 - val_mse: 0.6256 - 49ms/epoch - 49ms/step\n",
      "iteration :284     Target train: tf.Tensor(0.49562666, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5121 - mse: 0.4500 - val_loss: 0.5112 - val_mse: 0.6245 - 49ms/epoch - 49ms/step\n",
      "iteration :285     Target train: tf.Tensor(0.49474293, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5112 - mse: 0.4492 - val_loss: 0.5103 - val_mse: 0.6235 - 63ms/epoch - 63ms/step\n",
      "iteration :286     Target train: tf.Tensor(0.493869, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5103 - mse: 0.4483 - val_loss: 0.5095 - val_mse: 0.6224 - 52ms/epoch - 52ms/step\n",
      "iteration :287     Target train: tf.Tensor(0.49300492, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5095 - mse: 0.4475 - val_loss: 0.5086 - val_mse: 0.6214 - 51ms/epoch - 51ms/step\n",
      "iteration :288     Target train: tf.Tensor(0.4921504, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5086 - mse: 0.4467 - val_loss: 0.5078 - val_mse: 0.6204 - 67ms/epoch - 67ms/step\n",
      "iteration :289     Target train: tf.Tensor(0.49130547, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5078 - mse: 0.4460 - val_loss: 0.5070 - val_mse: 0.6194 - 46ms/epoch - 46ms/step\n",
      "iteration :290     Target train: tf.Tensor(0.49047002, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5070 - mse: 0.4452 - val_loss: 0.5062 - val_mse: 0.6184 - 48ms/epoch - 48ms/step\n",
      "iteration :291     Target train: tf.Tensor(0.48964393, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5062 - mse: 0.4444 - val_loss: 0.5053 - val_mse: 0.6174 - 56ms/epoch - 56ms/step\n",
      "iteration :292     Target train: tf.Tensor(0.48882714, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5053 - mse: 0.4437 - val_loss: 0.5045 - val_mse: 0.6164 - 52ms/epoch - 52ms/step\n",
      "iteration :293     Target train: tf.Tensor(0.48801944, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5045 - mse: 0.4429 - val_loss: 0.5038 - val_mse: 0.6154 - 48ms/epoch - 48ms/step\n",
      "iteration :294     Target train: tf.Tensor(0.48722085, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5038 - mse: 0.4422 - val_loss: 0.5030 - val_mse: 0.6145 - 55ms/epoch - 55ms/step\n",
      "iteration :295     Target train: tf.Tensor(0.48643112, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5030 - mse: 0.4414 - val_loss: 0.5022 - val_mse: 0.6135 - 52ms/epoch - 52ms/step\n",
      "iteration :296     Target train: tf.Tensor(0.48565027, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5022 - mse: 0.4407 - val_loss: 0.5015 - val_mse: 0.6126 - 54ms/epoch - 54ms/step\n",
      "iteration :297     Target train: tf.Tensor(0.48487842, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5015 - mse: 0.4400 - val_loss: 0.5007 - val_mse: 0.6117 - 48ms/epoch - 48ms/step\n",
      "iteration :298     Target train: tf.Tensor(0.4841154, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5007 - mse: 0.4393 - val_loss: 0.5000 - val_mse: 0.6107 - 72ms/epoch - 72ms/step\n",
      "iteration :299     Target train: tf.Tensor(0.48336112, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5000 - mse: 0.4386 - val_loss: 0.4992 - val_mse: 0.6098 - 56ms/epoch - 56ms/step\n",
      "iteration :300     Target train: tf.Tensor(0.48261535, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4992 - mse: 0.4379 - val_loss: 0.4985 - val_mse: 0.6089 - 59ms/epoch - 59ms/step\n",
      "iteration :301     Target train: tf.Tensor(0.481878, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4985 - mse: 0.4372 - val_loss: 0.4978 - val_mse: 0.6080 - 51ms/epoch - 51ms/step\n",
      "iteration :302     Target train: tf.Tensor(0.48114896, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4978 - mse: 0.4366 - val_loss: 0.4971 - val_mse: 0.6071 - 56ms/epoch - 56ms/step\n",
      "iteration :303     Target train: tf.Tensor(0.480428, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4971 - mse: 0.4359 - val_loss: 0.4964 - val_mse: 0.6062 - 50ms/epoch - 50ms/step\n",
      "iteration :304     Target train: tf.Tensor(0.47971502, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4964 - mse: 0.4353 - val_loss: 0.4957 - val_mse: 0.6054 - 55ms/epoch - 55ms/step\n",
      "iteration :305     Target train: tf.Tensor(0.4790099, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4957 - mse: 0.4346 - val_loss: 0.4950 - val_mse: 0.6045 - 52ms/epoch - 52ms/step\n",
      "iteration :306     Target train: tf.Tensor(0.47831258, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4950 - mse: 0.4340 - val_loss: 0.4944 - val_mse: 0.6036 - 57ms/epoch - 57ms/step\n",
      "iteration :307     Target train: tf.Tensor(0.47762296, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4944 - mse: 0.4333 - val_loss: 0.4937 - val_mse: 0.6028 - 54ms/epoch - 54ms/step\n",
      "iteration :308     Target train: tf.Tensor(0.4769411, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4937 - mse: 0.4327 - val_loss: 0.4930 - val_mse: 0.6020 - 52ms/epoch - 52ms/step\n",
      "iteration :309     Target train: tf.Tensor(0.4762668, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4930 - mse: 0.4321 - val_loss: 0.4924 - val_mse: 0.6011 - 54ms/epoch - 54ms/step\n",
      "iteration :310     Target train: tf.Tensor(0.47559988, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4924 - mse: 0.4315 - val_loss: 0.4918 - val_mse: 0.6003 - 52ms/epoch - 52ms/step\n",
      "iteration :311     Target train: tf.Tensor(0.4749403, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4918 - mse: 0.4309 - val_loss: 0.4911 - val_mse: 0.5995 - 52ms/epoch - 52ms/step\n",
      "iteration :312     Target train: tf.Tensor(0.47428793, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4911 - mse: 0.4303 - val_loss: 0.4905 - val_mse: 0.5987 - 48ms/epoch - 48ms/step\n",
      "iteration :313     Target train: tf.Tensor(0.47364253, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4905 - mse: 0.4297 - val_loss: 0.4899 - val_mse: 0.5979 - 53ms/epoch - 53ms/step\n",
      "iteration :314     Target train: tf.Tensor(0.47300416, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4899 - mse: 0.4291 - val_loss: 0.4893 - val_mse: 0.5971 - 55ms/epoch - 55ms/step\n",
      "iteration :315     Target train: tf.Tensor(0.4723726, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4893 - mse: 0.4286 - val_loss: 0.4887 - val_mse: 0.5963 - 48ms/epoch - 48ms/step\n",
      "iteration :316     Target train: tf.Tensor(0.47174773, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4887 - mse: 0.4280 - val_loss: 0.4881 - val_mse: 0.5955 - 50ms/epoch - 50ms/step\n",
      "iteration :317     Target train: tf.Tensor(0.47112948, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4881 - mse: 0.4274 - val_loss: 0.4875 - val_mse: 0.5947 - 53ms/epoch - 53ms/step\n",
      "iteration :318     Target train: tf.Tensor(0.47051778, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4875 - mse: 0.4269 - val_loss: 0.4869 - val_mse: 0.5940 - 46ms/epoch - 46ms/step\n",
      "iteration :319     Target train: tf.Tensor(0.46991247, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4869 - mse: 0.4263 - val_loss: 0.4863 - val_mse: 0.5932 - 51ms/epoch - 51ms/step\n",
      "iteration :320     Target train: tf.Tensor(0.46931344, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4863 - mse: 0.4258 - val_loss: 0.4857 - val_mse: 0.5925 - 60ms/epoch - 60ms/step\n",
      "iteration :321     Target train: tf.Tensor(0.4687206, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4857 - mse: 0.4252 - val_loss: 0.4851 - val_mse: 0.5917 - 52ms/epoch - 52ms/step\n",
      "iteration :322     Target train: tf.Tensor(0.4681339, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4851 - mse: 0.4247 - val_loss: 0.4846 - val_mse: 0.5910 - 53ms/epoch - 53ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iteration :323     Target train: tf.Tensor(0.46755323, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4846 - mse: 0.4242 - val_loss: 0.4840 - val_mse: 0.5902 - 51ms/epoch - 51ms/step\n",
      "iteration :324     Target train: tf.Tensor(0.46697834, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4840 - mse: 0.4237 - val_loss: 0.4835 - val_mse: 0.5895 - 56ms/epoch - 56ms/step\n",
      "iteration :325     Target train: tf.Tensor(0.46640936, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4835 - mse: 0.4232 - val_loss: 0.4829 - val_mse: 0.5888 - 48ms/epoch - 48ms/step\n",
      "iteration :326     Target train: tf.Tensor(0.46584606, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4829 - mse: 0.4226 - val_loss: 0.4824 - val_mse: 0.5881 - 53ms/epoch - 53ms/step\n",
      "iteration :327     Target train: tf.Tensor(0.46528846, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4824 - mse: 0.4221 - val_loss: 0.4818 - val_mse: 0.5874 - 50ms/epoch - 50ms/step\n",
      "iteration :328     Target train: tf.Tensor(0.46473628, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4818 - mse: 0.4216 - val_loss: 0.4813 - val_mse: 0.5867 - 50ms/epoch - 50ms/step\n",
      "iteration :329     Target train: tf.Tensor(0.46418962, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4813 - mse: 0.4211 - val_loss: 0.4808 - val_mse: 0.5860 - 56ms/epoch - 56ms/step\n",
      "iteration :330     Target train: tf.Tensor(0.46364832, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4808 - mse: 0.4207 - val_loss: 0.4803 - val_mse: 0.5853 - 60ms/epoch - 60ms/step\n",
      "iteration :331     Target train: tf.Tensor(0.46311235, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4803 - mse: 0.4202 - val_loss: 0.4797 - val_mse: 0.5846 - 57ms/epoch - 57ms/step\n",
      "iteration :332     Target train: tf.Tensor(0.46258152, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4797 - mse: 0.4197 - val_loss: 0.4792 - val_mse: 0.5840 - 53ms/epoch - 53ms/step\n",
      "iteration :333     Target train: tf.Tensor(0.46205583, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4792 - mse: 0.4192 - val_loss: 0.4787 - val_mse: 0.5833 - 59ms/epoch - 59ms/step\n",
      "iteration :334     Target train: tf.Tensor(0.46153513, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4787 - mse: 0.4188 - val_loss: 0.4782 - val_mse: 0.5826 - 52ms/epoch - 52ms/step\n",
      "iteration :335     Target train: tf.Tensor(0.46101937, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4782 - mse: 0.4183 - val_loss: 0.4777 - val_mse: 0.5820 - 60ms/epoch - 60ms/step\n",
      "iteration :336     Target train: tf.Tensor(0.46050867, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4777 - mse: 0.4178 - val_loss: 0.4772 - val_mse: 0.5813 - 52ms/epoch - 52ms/step\n",
      "iteration :337     Target train: tf.Tensor(0.46000263, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4772 - mse: 0.4174 - val_loss: 0.4767 - val_mse: 0.5807 - 64ms/epoch - 64ms/step\n",
      "iteration :338     Target train: tf.Tensor(0.45950142, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4767 - mse: 0.4169 - val_loss: 0.4763 - val_mse: 0.5800 - 53ms/epoch - 53ms/step\n",
      "iteration :339     Target train: tf.Tensor(0.45900488, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4763 - mse: 0.4165 - val_loss: 0.4758 - val_mse: 0.5794 - 67ms/epoch - 67ms/step\n",
      "iteration :340     Target train: tf.Tensor(0.45851293, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4758 - mse: 0.4160 - val_loss: 0.4753 - val_mse: 0.5788 - 49ms/epoch - 49ms/step\n",
      "iteration :341     Target train: tf.Tensor(0.4580255, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4753 - mse: 0.4156 - val_loss: 0.4748 - val_mse: 0.5781 - 52ms/epoch - 52ms/step\n",
      "iteration :342     Target train: tf.Tensor(0.45754257, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4748 - mse: 0.4152 - val_loss: 0.4744 - val_mse: 0.5775 - 62ms/epoch - 62ms/step\n",
      "iteration :343     Target train: tf.Tensor(0.45706403, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4744 - mse: 0.4147 - val_loss: 0.4739 - val_mse: 0.5769 - 54ms/epoch - 54ms/step\n",
      "iteration :344     Target train: tf.Tensor(0.4565898, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4739 - mse: 0.4143 - val_loss: 0.4734 - val_mse: 0.5763 - 55ms/epoch - 55ms/step\n",
      "iteration :345     Target train: tf.Tensor(0.45611992, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4734 - mse: 0.4139 - val_loss: 0.4730 - val_mse: 0.5757 - 50ms/epoch - 50ms/step\n",
      "iteration :346     Target train: tf.Tensor(0.4556542, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4730 - mse: 0.4135 - val_loss: 0.4725 - val_mse: 0.5751 - 47ms/epoch - 47ms/step\n",
      "iteration :347     Target train: tf.Tensor(0.45519263, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4725 - mse: 0.4131 - val_loss: 0.4721 - val_mse: 0.5745 - 52ms/epoch - 52ms/step\n",
      "iteration :348     Target train: tf.Tensor(0.4547352, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4721 - mse: 0.4127 - val_loss: 0.4717 - val_mse: 0.5739 - 56ms/epoch - 56ms/step\n",
      "iteration :349     Target train: tf.Tensor(0.45428178, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4717 - mse: 0.4123 - val_loss: 0.4712 - val_mse: 0.5733 - 51ms/epoch - 51ms/step\n",
      "iteration :350     Target train: tf.Tensor(0.45383233, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4712 - mse: 0.4119 - val_loss: 0.4708 - val_mse: 0.5727 - 52ms/epoch - 52ms/step\n",
      "iteration :351     Target train: tf.Tensor(0.45338675, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4708 - mse: 0.4115 - val_loss: 0.4704 - val_mse: 0.5721 - 53ms/epoch - 53ms/step\n",
      "iteration :352     Target train: tf.Tensor(0.45294514, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4704 - mse: 0.4111 - val_loss: 0.4699 - val_mse: 0.5715 - 60ms/epoch - 60ms/step\n",
      "iteration :353     Target train: tf.Tensor(0.4525073, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4699 - mse: 0.4107 - val_loss: 0.4695 - val_mse: 0.5709 - 64ms/epoch - 64ms/step\n",
      "iteration :354     Target train: tf.Tensor(0.45207316, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4695 - mse: 0.4103 - val_loss: 0.4691 - val_mse: 0.5704 - 59ms/epoch - 59ms/step\n",
      "iteration :355     Target train: tf.Tensor(0.45164278, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4691 - mse: 0.4099 - val_loss: 0.4687 - val_mse: 0.5698 - 60ms/epoch - 60ms/step\n",
      "iteration :356     Target train: tf.Tensor(0.45121607, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4687 - mse: 0.4096 - val_loss: 0.4683 - val_mse: 0.5692 - 60ms/epoch - 60ms/step\n",
      "iteration :357     Target train: tf.Tensor(0.45079288, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4683 - mse: 0.4092 - val_loss: 0.4679 - val_mse: 0.5687 - 55ms/epoch - 55ms/step\n",
      "iteration :358     Target train: tf.Tensor(0.45037332, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4679 - mse: 0.4088 - val_loss: 0.4675 - val_mse: 0.5681 - 58ms/epoch - 58ms/step\n",
      "iteration :359     Target train: tf.Tensor(0.4499572, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4675 - mse: 0.4085 - val_loss: 0.4671 - val_mse: 0.5675 - 58ms/epoch - 58ms/step\n",
      "iteration :360     Target train: tf.Tensor(0.4495446, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4671 - mse: 0.4081 - val_loss: 0.4667 - val_mse: 0.5670 - 55ms/epoch - 55ms/step\n",
      "iteration :361     Target train: tf.Tensor(0.44913524, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4667 - mse: 0.4077 - val_loss: 0.4663 - val_mse: 0.5664 - 53ms/epoch - 53ms/step\n",
      "iteration :362     Target train: tf.Tensor(0.44872937, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4663 - mse: 0.4074 - val_loss: 0.4659 - val_mse: 0.5659 - 51ms/epoch - 51ms/step\n",
      "iteration :363     Target train: tf.Tensor(0.44832686, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4659 - mse: 0.4070 - val_loss: 0.4655 - val_mse: 0.5653 - 49ms/epoch - 49ms/step\n",
      "iteration :364     Target train: tf.Tensor(0.4479275, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4655 - mse: 0.4067 - val_loss: 0.4651 - val_mse: 0.5648 - 67ms/epoch - 67ms/step\n",
      "iteration :365     Target train: tf.Tensor(0.4475314, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4651 - mse: 0.4063 - val_loss: 0.4647 - val_mse: 0.5642 - 53ms/epoch - 53ms/step\n",
      "iteration :366     Target train: tf.Tensor(0.44713852, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4647 - mse: 0.4060 - val_loss: 0.4643 - val_mse: 0.5637 - 54ms/epoch - 54ms/step\n",
      "iteration :367     Target train: tf.Tensor(0.4467487, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4643 - mse: 0.4057 - val_loss: 0.4640 - val_mse: 0.5631 - 48ms/epoch - 48ms/step\n",
      "iteration :368     Target train: tf.Tensor(0.446362, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4640 - mse: 0.4053 - val_loss: 0.4636 - val_mse: 0.5626 - 62ms/epoch - 62ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iteration :369     Target train: tf.Tensor(0.44597828, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4636 - mse: 0.4050 - val_loss: 0.4632 - val_mse: 0.5621 - 52ms/epoch - 52ms/step\n",
      "iteration :370     Target train: tf.Tensor(0.44559753, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4632 - mse: 0.4047 - val_loss: 0.4628 - val_mse: 0.5615 - 55ms/epoch - 55ms/step\n",
      "iteration :371     Target train: tf.Tensor(0.44521984, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4628 - mse: 0.4044 - val_loss: 0.4625 - val_mse: 0.5610 - 62ms/epoch - 62ms/step\n",
      "iteration :372     Target train: tf.Tensor(0.44484502, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4625 - mse: 0.4040 - val_loss: 0.4621 - val_mse: 0.5605 - 60ms/epoch - 60ms/step\n",
      "iteration :373     Target train: tf.Tensor(0.44447312, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4621 - mse: 0.4037 - val_loss: 0.4618 - val_mse: 0.5599 - 51ms/epoch - 51ms/step\n",
      "iteration :374     Target train: tf.Tensor(0.44410396, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4618 - mse: 0.4034 - val_loss: 0.4614 - val_mse: 0.5594 - 48ms/epoch - 48ms/step\n",
      "iteration :375     Target train: tf.Tensor(0.44373763, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4614 - mse: 0.4031 - val_loss: 0.4610 - val_mse: 0.5589 - 57ms/epoch - 57ms/step\n",
      "iteration :376     Target train: tf.Tensor(0.44337407, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4610 - mse: 0.4028 - val_loss: 0.4607 - val_mse: 0.5584 - 52ms/epoch - 52ms/step\n",
      "iteration :377     Target train: tf.Tensor(0.44301322, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4607 - mse: 0.4025 - val_loss: 0.4603 - val_mse: 0.5578 - 56ms/epoch - 56ms/step\n",
      "iteration :378     Target train: tf.Tensor(0.44265503, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4603 - mse: 0.4022 - val_loss: 0.4600 - val_mse: 0.5573 - 56ms/epoch - 56ms/step\n",
      "iteration :379     Target train: tf.Tensor(0.44229957, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4600 - mse: 0.4019 - val_loss: 0.4597 - val_mse: 0.5568 - 49ms/epoch - 49ms/step\n",
      "iteration :380     Target train: tf.Tensor(0.44194657, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4597 - mse: 0.4016 - val_loss: 0.4593 - val_mse: 0.5563 - 48ms/epoch - 48ms/step\n",
      "iteration :381     Target train: tf.Tensor(0.44159624, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4593 - mse: 0.4013 - val_loss: 0.4590 - val_mse: 0.5558 - 60ms/epoch - 60ms/step\n",
      "iteration :382     Target train: tf.Tensor(0.44124833, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4590 - mse: 0.4010 - val_loss: 0.4586 - val_mse: 0.5553 - 53ms/epoch - 53ms/step\n",
      "iteration :383     Target train: tf.Tensor(0.440903, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4586 - mse: 0.4007 - val_loss: 0.4583 - val_mse: 0.5548 - 49ms/epoch - 49ms/step\n",
      "iteration :384     Target train: tf.Tensor(0.44056013, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4583 - mse: 0.4004 - val_loss: 0.4580 - val_mse: 0.5542 - 67ms/epoch - 67ms/step\n",
      "iteration :385     Target train: tf.Tensor(0.4402197, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4580 - mse: 0.4002 - val_loss: 0.4576 - val_mse: 0.5537 - 63ms/epoch - 63ms/step\n",
      "iteration :386     Target train: tf.Tensor(0.4398815, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4576 - mse: 0.3999 - val_loss: 0.4573 - val_mse: 0.5532 - 55ms/epoch - 55ms/step\n",
      "iteration :387     Target train: tf.Tensor(0.4395458, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4573 - mse: 0.3996 - val_loss: 0.4570 - val_mse: 0.5527 - 56ms/epoch - 56ms/step\n",
      "iteration :388     Target train: tf.Tensor(0.43921244, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4570 - mse: 0.3993 - val_loss: 0.4567 - val_mse: 0.5522 - 58ms/epoch - 58ms/step\n",
      "iteration :389     Target train: tf.Tensor(0.4388813, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4567 - mse: 0.3991 - val_loss: 0.4564 - val_mse: 0.5517 - 56ms/epoch - 56ms/step\n",
      "iteration :390     Target train: tf.Tensor(0.43855244, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4564 - mse: 0.3988 - val_loss: 0.4560 - val_mse: 0.5512 - 71ms/epoch - 71ms/step\n",
      "iteration :391     Target train: tf.Tensor(0.43822578, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4560 - mse: 0.3985 - val_loss: 0.4557 - val_mse: 0.5507 - 53ms/epoch - 53ms/step\n",
      "iteration :392     Target train: tf.Tensor(0.4379013, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4557 - mse: 0.3983 - val_loss: 0.4554 - val_mse: 0.5502 - 55ms/epoch - 55ms/step\n",
      "iteration :393     Target train: tf.Tensor(0.43757907, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4554 - mse: 0.3980 - val_loss: 0.4551 - val_mse: 0.5497 - 50ms/epoch - 50ms/step\n",
      "iteration :394     Target train: tf.Tensor(0.43725887, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4551 - mse: 0.3977 - val_loss: 0.4548 - val_mse: 0.5492 - 66ms/epoch - 66ms/step\n",
      "iteration :395     Target train: tf.Tensor(0.43694076, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4548 - mse: 0.3975 - val_loss: 0.4545 - val_mse: 0.5487 - 53ms/epoch - 53ms/step\n",
      "iteration :396     Target train: tf.Tensor(0.43662483, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4545 - mse: 0.3972 - val_loss: 0.4542 - val_mse: 0.5483 - 55ms/epoch - 55ms/step\n",
      "iteration :397     Target train: tf.Tensor(0.43631083, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4542 - mse: 0.3970 - val_loss: 0.4539 - val_mse: 0.5478 - 53ms/epoch - 53ms/step\n",
      "iteration :398     Target train: tf.Tensor(0.43599886, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4539 - mse: 0.3967 - val_loss: 0.4536 - val_mse: 0.5473 - 61ms/epoch - 61ms/step\n",
      "iteration :399     Target train: tf.Tensor(0.43568885, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4536 - mse: 0.3965 - val_loss: 0.4533 - val_mse: 0.5468 - 71ms/epoch - 71ms/step\n",
      "iteration :400     Target train: tf.Tensor(0.43538082, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4533 - mse: 0.3962 - val_loss: 0.4530 - val_mse: 0.5463 - 55ms/epoch - 55ms/step\n",
      "iteration :401     Target train: tf.Tensor(0.43507472, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4530 - mse: 0.3960 - val_loss: 0.4527 - val_mse: 0.5458 - 52ms/epoch - 52ms/step\n",
      "iteration :402     Target train: tf.Tensor(0.43477046, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4527 - mse: 0.3958 - val_loss: 0.4524 - val_mse: 0.5453 - 55ms/epoch - 55ms/step\n",
      "iteration :403     Target train: tf.Tensor(0.4344681, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4524 - mse: 0.3955 - val_loss: 0.4521 - val_mse: 0.5448 - 52ms/epoch - 52ms/step\n",
      "iteration :404     Target train: tf.Tensor(0.4341676, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4521 - mse: 0.3953 - val_loss: 0.4518 - val_mse: 0.5444 - 52ms/epoch - 52ms/step\n",
      "iteration :405     Target train: tf.Tensor(0.43386886, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4518 - mse: 0.3950 - val_loss: 0.4515 - val_mse: 0.5439 - 54ms/epoch - 54ms/step\n",
      "iteration :406     Target train: tf.Tensor(0.43357193, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4515 - mse: 0.3948 - val_loss: 0.4512 - val_mse: 0.5434 - 53ms/epoch - 53ms/step\n",
      "iteration :407     Target train: tf.Tensor(0.43327674, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4512 - mse: 0.3946 - val_loss: 0.4509 - val_mse: 0.5429 - 53ms/epoch - 53ms/step\n",
      "iteration :408     Target train: tf.Tensor(0.43298325, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4509 - mse: 0.3944 - val_loss: 0.4507 - val_mse: 0.5424 - 50ms/epoch - 50ms/step\n",
      "iteration :409     Target train: tf.Tensor(0.4326915, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4507 - mse: 0.3941 - val_loss: 0.4504 - val_mse: 0.5420 - 48ms/epoch - 48ms/step\n",
      "iteration :410     Target train: tf.Tensor(0.43240142, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4504 - mse: 0.3939 - val_loss: 0.4501 - val_mse: 0.5415 - 56ms/epoch - 56ms/step\n",
      "iteration :411     Target train: tf.Tensor(0.432113, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4501 - mse: 0.3937 - val_loss: 0.4498 - val_mse: 0.5410 - 65ms/epoch - 65ms/step\n",
      "iteration :412     Target train: tf.Tensor(0.43182617, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4498 - mse: 0.3935 - val_loss: 0.4495 - val_mse: 0.5405 - 59ms/epoch - 59ms/step\n",
      "iteration :413     Target train: tf.Tensor(0.43154103, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4495 - mse: 0.3933 - val_loss: 0.4493 - val_mse: 0.5400 - 55ms/epoch - 55ms/step\n",
      "iteration :414     Target train: tf.Tensor(0.4312574, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4493 - mse: 0.3930 - val_loss: 0.4490 - val_mse: 0.5396 - 58ms/epoch - 58ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iteration :415     Target train: tf.Tensor(0.43097535, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4490 - mse: 0.3928 - val_loss: 0.4487 - val_mse: 0.5391 - 58ms/epoch - 58ms/step\n",
      "iteration :416     Target train: tf.Tensor(0.43069482, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4487 - mse: 0.3926 - val_loss: 0.4484 - val_mse: 0.5386 - 55ms/epoch - 55ms/step\n",
      "iteration :417     Target train: tf.Tensor(0.4304159, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4484 - mse: 0.3924 - val_loss: 0.4482 - val_mse: 0.5382 - 57ms/epoch - 57ms/step\n",
      "iteration :418     Target train: tf.Tensor(0.43013832, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4482 - mse: 0.3922 - val_loss: 0.4479 - val_mse: 0.5377 - 57ms/epoch - 57ms/step\n",
      "iteration :419     Target train: tf.Tensor(0.4298623, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4479 - mse: 0.3920 - val_loss: 0.4476 - val_mse: 0.5372 - 56ms/epoch - 56ms/step\n",
      "iteration :420     Target train: tf.Tensor(0.4295877, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4476 - mse: 0.3918 - val_loss: 0.4474 - val_mse: 0.5367 - 51ms/epoch - 51ms/step\n",
      "iteration :421     Target train: tf.Tensor(0.4293145, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4474 - mse: 0.3916 - val_loss: 0.4471 - val_mse: 0.5363 - 49ms/epoch - 49ms/step\n",
      "iteration :422     Target train: tf.Tensor(0.42904276, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4471 - mse: 0.3914 - val_loss: 0.4469 - val_mse: 0.5358 - 55ms/epoch - 55ms/step\n",
      "iteration :423     Target train: tf.Tensor(0.4287724, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4469 - mse: 0.3912 - val_loss: 0.4466 - val_mse: 0.5353 - 51ms/epoch - 51ms/step\n",
      "iteration :424     Target train: tf.Tensor(0.42850333, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4466 - mse: 0.3910 - val_loss: 0.4463 - val_mse: 0.5349 - 60ms/epoch - 60ms/step\n",
      "iteration :425     Target train: tf.Tensor(0.42823565, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4463 - mse: 0.3908 - val_loss: 0.4461 - val_mse: 0.5344 - 54ms/epoch - 54ms/step\n",
      "iteration :426     Target train: tf.Tensor(0.42796928, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4461 - mse: 0.3906 - val_loss: 0.4458 - val_mse: 0.5340 - 61ms/epoch - 61ms/step\n",
      "iteration :427     Target train: tf.Tensor(0.4277042, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4458 - mse: 0.3904 - val_loss: 0.4456 - val_mse: 0.5335 - 50ms/epoch - 50ms/step\n",
      "iteration :428     Target train: tf.Tensor(0.42744038, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4456 - mse: 0.3902 - val_loss: 0.4453 - val_mse: 0.5330 - 50ms/epoch - 50ms/step\n",
      "iteration :429     Target train: tf.Tensor(0.42717785, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4453 - mse: 0.3900 - val_loss: 0.4450 - val_mse: 0.5326 - 53ms/epoch - 53ms/step\n",
      "iteration :430     Target train: tf.Tensor(0.42691663, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4450 - mse: 0.3898 - val_loss: 0.4448 - val_mse: 0.5321 - 55ms/epoch - 55ms/step\n",
      "iteration :431     Target train: tf.Tensor(0.42665654, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4448 - mse: 0.3896 - val_loss: 0.4445 - val_mse: 0.5316 - 60ms/epoch - 60ms/step\n",
      "iteration :432     Target train: tf.Tensor(0.42639774, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4445 - mse: 0.3894 - val_loss: 0.4443 - val_mse: 0.5312 - 59ms/epoch - 59ms/step\n",
      "iteration :433     Target train: tf.Tensor(0.42614007, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4443 - mse: 0.3892 - val_loss: 0.4440 - val_mse: 0.5307 - 54ms/epoch - 54ms/step\n",
      "iteration :434     Target train: tf.Tensor(0.42588353, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4440 - mse: 0.3890 - val_loss: 0.4438 - val_mse: 0.5303 - 54ms/epoch - 54ms/step\n",
      "iteration :435     Target train: tf.Tensor(0.42562822, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4438 - mse: 0.3889 - val_loss: 0.4436 - val_mse: 0.5298 - 55ms/epoch - 55ms/step\n",
      "iteration :436     Target train: tf.Tensor(0.42537397, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4436 - mse: 0.3887 - val_loss: 0.4433 - val_mse: 0.5293 - 61ms/epoch - 61ms/step\n",
      "iteration :437     Target train: tf.Tensor(0.42512092, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4433 - mse: 0.3885 - val_loss: 0.4431 - val_mse: 0.5289 - 50ms/epoch - 50ms/step\n",
      "iteration :438     Target train: tf.Tensor(0.42486888, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4431 - mse: 0.3883 - val_loss: 0.4428 - val_mse: 0.5284 - 54ms/epoch - 54ms/step\n",
      "iteration :439     Target train: tf.Tensor(0.42461804, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4428 - mse: 0.3881 - val_loss: 0.4426 - val_mse: 0.5280 - 54ms/epoch - 54ms/step\n",
      "iteration :440     Target train: tf.Tensor(0.42436823, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4426 - mse: 0.3880 - val_loss: 0.4423 - val_mse: 0.5275 - 53ms/epoch - 53ms/step\n",
      "iteration :441     Target train: tf.Tensor(0.42411947, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4423 - mse: 0.3878 - val_loss: 0.4421 - val_mse: 0.5271 - 50ms/epoch - 50ms/step\n",
      "iteration :442     Target train: tf.Tensor(0.42387176, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4421 - mse: 0.3876 - val_loss: 0.4419 - val_mse: 0.5266 - 48ms/epoch - 48ms/step\n",
      "iteration :443     Target train: tf.Tensor(0.423625, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4419 - mse: 0.3874 - val_loss: 0.4416 - val_mse: 0.5262 - 57ms/epoch - 57ms/step\n",
      "iteration :444     Target train: tf.Tensor(0.4233793, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4416 - mse: 0.3873 - val_loss: 0.4414 - val_mse: 0.5257 - 53ms/epoch - 53ms/step\n",
      "iteration :445     Target train: tf.Tensor(0.42313465, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4414 - mse: 0.3871 - val_loss: 0.4411 - val_mse: 0.5252 - 59ms/epoch - 59ms/step\n",
      "iteration :446     Target train: tf.Tensor(0.4228909, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4411 - mse: 0.3869 - val_loss: 0.4409 - val_mse: 0.5248 - 53ms/epoch - 53ms/step\n",
      "iteration :447     Target train: tf.Tensor(0.42264816, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4409 - mse: 0.3868 - val_loss: 0.4407 - val_mse: 0.5243 - 58ms/epoch - 58ms/step\n",
      "iteration :448     Target train: tf.Tensor(0.42240635, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4407 - mse: 0.3866 - val_loss: 0.4404 - val_mse: 0.5239 - 50ms/epoch - 50ms/step\n",
      "iteration :449     Target train: tf.Tensor(0.42216548, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4404 - mse: 0.3864 - val_loss: 0.4402 - val_mse: 0.5234 - 67ms/epoch - 67ms/step\n",
      "iteration :450     Target train: tf.Tensor(0.42192554, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4402 - mse: 0.3863 - val_loss: 0.4400 - val_mse: 0.5230 - 49ms/epoch - 49ms/step\n",
      "iteration :451     Target train: tf.Tensor(0.42168656, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4400 - mse: 0.3861 - val_loss: 0.4397 - val_mse: 0.5225 - 58ms/epoch - 58ms/step\n",
      "iteration :452     Target train: tf.Tensor(0.4214484, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4397 - mse: 0.3859 - val_loss: 0.4395 - val_mse: 0.5221 - 50ms/epoch - 50ms/step\n",
      "iteration :453     Target train: tf.Tensor(0.42121118, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4395 - mse: 0.3858 - val_loss: 0.4393 - val_mse: 0.5216 - 68ms/epoch - 68ms/step\n",
      "iteration :454     Target train: tf.Tensor(0.42097482, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4393 - mse: 0.3856 - val_loss: 0.4391 - val_mse: 0.5212 - 49ms/epoch - 49ms/step\n",
      "iteration :455     Target train: tf.Tensor(0.4207392, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4391 - mse: 0.3854 - val_loss: 0.4388 - val_mse: 0.5207 - 51ms/epoch - 51ms/step\n",
      "iteration :456     Target train: tf.Tensor(0.4205046, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4388 - mse: 0.3853 - val_loss: 0.4386 - val_mse: 0.5203 - 66ms/epoch - 66ms/step\n",
      "iteration :457     Target train: tf.Tensor(0.4202707, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4386 - mse: 0.3851 - val_loss: 0.4384 - val_mse: 0.5198 - 58ms/epoch - 58ms/step\n",
      "iteration :458     Target train: tf.Tensor(0.4200377, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4384 - mse: 0.3850 - val_loss: 0.4381 - val_mse: 0.5194 - 57ms/epoch - 57ms/step\n",
      "iteration :459     Target train: tf.Tensor(0.4198055, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4381 - mse: 0.3848 - val_loss: 0.4379 - val_mse: 0.5190 - 53ms/epoch - 53ms/step\n",
      "iteration :460     Target train: tf.Tensor(0.41957408, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4379 - mse: 0.3847 - val_loss: 0.4377 - val_mse: 0.5185 - 58ms/epoch - 58ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iteration :461     Target train: tf.Tensor(0.41934347, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4377 - mse: 0.3845 - val_loss: 0.4375 - val_mse: 0.5181 - 55ms/epoch - 55ms/step\n",
      "iteration :462     Target train: tf.Tensor(0.4191136, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4375 - mse: 0.3843 - val_loss: 0.4373 - val_mse: 0.5176 - 59ms/epoch - 59ms/step\n",
      "iteration :463     Target train: tf.Tensor(0.41888452, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4373 - mse: 0.3842 - val_loss: 0.4370 - val_mse: 0.5172 - 55ms/epoch - 55ms/step\n",
      "iteration :464     Target train: tf.Tensor(0.4186562, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4370 - mse: 0.3840 - val_loss: 0.4368 - val_mse: 0.5167 - 60ms/epoch - 60ms/step\n",
      "iteration :465     Target train: tf.Tensor(0.41842863, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4368 - mse: 0.3839 - val_loss: 0.4366 - val_mse: 0.5163 - 49ms/epoch - 49ms/step\n",
      "iteration :466     Target train: tf.Tensor(0.41820177, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4366 - mse: 0.3837 - val_loss: 0.4364 - val_mse: 0.5158 - 59ms/epoch - 59ms/step\n",
      "iteration :467     Target train: tf.Tensor(0.4179757, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4364 - mse: 0.3836 - val_loss: 0.4362 - val_mse: 0.5154 - 66ms/epoch - 66ms/step\n",
      "iteration :468     Target train: tf.Tensor(0.41775033, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4362 - mse: 0.3834 - val_loss: 0.4359 - val_mse: 0.5150 - 53ms/epoch - 53ms/step\n",
      "iteration :469     Target train: tf.Tensor(0.4175256, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4359 - mse: 0.3833 - val_loss: 0.4357 - val_mse: 0.5145 - 53ms/epoch - 53ms/step\n",
      "iteration :470     Target train: tf.Tensor(0.4173016, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4357 - mse: 0.3831 - val_loss: 0.4355 - val_mse: 0.5141 - 47ms/epoch - 47ms/step\n",
      "iteration :471     Target train: tf.Tensor(0.41707826, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4355 - mse: 0.3830 - val_loss: 0.4353 - val_mse: 0.5136 - 54ms/epoch - 54ms/step\n",
      "iteration :472     Target train: tf.Tensor(0.41685563, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4353 - mse: 0.3829 - val_loss: 0.4351 - val_mse: 0.5132 - 53ms/epoch - 53ms/step\n",
      "iteration :473     Target train: tf.Tensor(0.41663364, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4351 - mse: 0.3827 - val_loss: 0.4349 - val_mse: 0.5127 - 60ms/epoch - 60ms/step\n",
      "iteration :474     Target train: tf.Tensor(0.41641232, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4349 - mse: 0.3826 - val_loss: 0.4346 - val_mse: 0.5123 - 57ms/epoch - 57ms/step\n",
      "iteration :475     Target train: tf.Tensor(0.41619164, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4346 - mse: 0.3824 - val_loss: 0.4344 - val_mse: 0.5119 - 59ms/epoch - 59ms/step\n",
      "iteration :476     Target train: tf.Tensor(0.41597167, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4344 - mse: 0.3823 - val_loss: 0.4342 - val_mse: 0.5114 - 56ms/epoch - 56ms/step\n",
      "iteration :477     Target train: tf.Tensor(0.41575223, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4342 - mse: 0.3821 - val_loss: 0.4340 - val_mse: 0.5110 - 63ms/epoch - 63ms/step\n",
      "iteration :478     Target train: tf.Tensor(0.41553354, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4340 - mse: 0.3820 - val_loss: 0.4338 - val_mse: 0.5105 - 60ms/epoch - 60ms/step\n",
      "iteration :479     Target train: tf.Tensor(0.41531536, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4338 - mse: 0.3819 - val_loss: 0.4336 - val_mse: 0.5101 - 59ms/epoch - 59ms/step\n",
      "iteration :480     Target train: tf.Tensor(0.41509783, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4336 - mse: 0.3817 - val_loss: 0.4334 - val_mse: 0.5097 - 57ms/epoch - 57ms/step\n",
      "iteration :481     Target train: tf.Tensor(0.41488087, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4334 - mse: 0.3816 - val_loss: 0.4332 - val_mse: 0.5092 - 55ms/epoch - 55ms/step\n",
      "iteration :482     Target train: tf.Tensor(0.4146645, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4332 - mse: 0.3814 - val_loss: 0.4330 - val_mse: 0.5088 - 52ms/epoch - 52ms/step\n",
      "iteration :483     Target train: tf.Tensor(0.41444874, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4330 - mse: 0.3813 - val_loss: 0.4327 - val_mse: 0.5083 - 58ms/epoch - 58ms/step\n",
      "iteration :484     Target train: tf.Tensor(0.41423357, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4327 - mse: 0.3812 - val_loss: 0.4325 - val_mse: 0.5079 - 60ms/epoch - 60ms/step\n",
      "iteration :485     Target train: tf.Tensor(0.414019, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4325 - mse: 0.3810 - val_loss: 0.4323 - val_mse: 0.5075 - 58ms/epoch - 58ms/step\n",
      "iteration :486     Target train: tf.Tensor(0.41380492, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4323 - mse: 0.3809 - val_loss: 0.4321 - val_mse: 0.5070 - 54ms/epoch - 54ms/step\n",
      "iteration :487     Target train: tf.Tensor(0.41359144, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4321 - mse: 0.3808 - val_loss: 0.4319 - val_mse: 0.5066 - 50ms/epoch - 50ms/step\n",
      "iteration :488     Target train: tf.Tensor(0.41337842, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4319 - mse: 0.3806 - val_loss: 0.4317 - val_mse: 0.5062 - 51ms/epoch - 51ms/step\n",
      "iteration :489     Target train: tf.Tensor(0.41316605, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4317 - mse: 0.3805 - val_loss: 0.4315 - val_mse: 0.5057 - 55ms/epoch - 55ms/step\n",
      "iteration :490     Target train: tf.Tensor(0.41295418, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4315 - mse: 0.3804 - val_loss: 0.4313 - val_mse: 0.5053 - 70ms/epoch - 70ms/step\n",
      "iteration :491     Target train: tf.Tensor(0.41274288, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4313 - mse: 0.3802 - val_loss: 0.4311 - val_mse: 0.5048 - 51ms/epoch - 51ms/step\n",
      "iteration :492     Target train: tf.Tensor(0.41253203, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4311 - mse: 0.3801 - val_loss: 0.4309 - val_mse: 0.5044 - 50ms/epoch - 50ms/step\n",
      "iteration :493     Target train: tf.Tensor(0.41232178, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4309 - mse: 0.3800 - val_loss: 0.4307 - val_mse: 0.5040 - 49ms/epoch - 49ms/step\n",
      "iteration :494     Target train: tf.Tensor(0.41211197, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4307 - mse: 0.3798 - val_loss: 0.4305 - val_mse: 0.5035 - 56ms/epoch - 56ms/step\n",
      "iteration :495     Target train: tf.Tensor(0.41190264, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4305 - mse: 0.3797 - val_loss: 0.4303 - val_mse: 0.5031 - 58ms/epoch - 58ms/step\n",
      "iteration :496     Target train: tf.Tensor(0.4116939, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4303 - mse: 0.3796 - val_loss: 0.4301 - val_mse: 0.5027 - 61ms/epoch - 61ms/step\n",
      "iteration :497     Target train: tf.Tensor(0.41148558, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4301 - mse: 0.3794 - val_loss: 0.4299 - val_mse: 0.5022 - 59ms/epoch - 59ms/step\n",
      "iteration :498     Target train: tf.Tensor(0.41127783, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4299 - mse: 0.3793 - val_loss: 0.4297 - val_mse: 0.5018 - 57ms/epoch - 57ms/step\n",
      "iteration :499     Target train: tf.Tensor(0.41107047, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4297 - mse: 0.3792 - val_loss: 0.4295 - val_mse: 0.5014 - 63ms/epoch - 63ms/step\n",
      "55.49064493179321\n"
     ]
    }
   ],
   "source": [
    "t0 = time.time()\n",
    "for i in range(500):\n",
    "    Num = 50 #number of training target data\n",
    "     # Access the layers\n",
    "    input_layer_weights = final_model.layers[1].trainable_weights[0]  # weight matrix only\n",
    "    output_layer_weights = final_model.layers[-1].trainable_weights[0]\n",
    "    \n",
    "    #prediction performance on the target training set\n",
    "    NN_out = final_model(RNN_input_final_Train) \n",
    "    loss11 =  tf.math.reduce_mean((NN_out[:Num,:,:]-RNN_output_final_Train[:Num,:,:])**2) # prediction on target\n",
    "    print(\"iteration :\" + str(i) + \"     Target train: \" + str(loss11))\n",
    "    \n",
    "    #history = final_model.fit(RNN_input_final_Train, RNN_output_final_Train, epochs=1, batch_size=256, validation_split=0.25, verbose=2)\n",
    "    history = final_model.fit(X_train, y_train, epochs=1, batch_size=256, validation_split=0.25, verbose=2)\n",
    "    i += 1\n",
    "\n",
    "t1 = time.time()\n",
    "print(t1 - t0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "8f14a2c7",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Target train:  tf.Tensor(0.4108637, shape=(), dtype=float32)\n",
      "Target test:  tf.Tensor(0.45025823, shape=(), dtype=float32)\n"
     ]
    }
   ],
   "source": [
    "#prediction performance on the target training set\n",
    "NN_out = final_model(RNN_input_final_Train) \n",
    "loss11 =  tf.math.reduce_mean((NN_out[:Num,:,:]-RNN_output_final_Train[:Num,:,:])**2) # prediction on target\n",
    "print(\"Target train: \", loss11)\n",
    "\n",
    "#prediction performance on the target testing set\n",
    "NN_out = final_model(X_test) \n",
    "loss11 =  tf.math.reduce_mean((NN_out-y_test)**2) # prediction on target\n",
    "print(\"Target test: \", loss11)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "21ca0c99",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a8016b92",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "id": "647daff1",
   "metadata": {},
   "source": [
    "# combine the parameters and refine the model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "523000d4",
   "metadata": {},
   "outputs": [],
   "source": [
    "#calculate the input layers\n",
    "# Get first layer\n",
    "layer_I1 = final_model.layers[1]\n",
    "# Get weights\n",
    "weights_I1 = layer_I1.get_weights()\n",
    "\n",
    "# Get first layer\n",
    "layer_I2 = final_model.layers[2]\n",
    "# Get weights\n",
    "weights_I2 = layer_I2.get_weights()\n",
    "\n",
    "# Get first layer\n",
    "layer_I3 = final_model.layers[3]\n",
    "# Get weights\n",
    "weights_I3 = layer_I3.get_weights()\n",
    "\n",
    "# print(\"Weights (kernel_I1):\\n\", weights_I1)\n",
    "# print(\"Weights (kernel_I2):\\n\", weights_I2)\n",
    "# print(\"Weights (kernel_I3):\\n\", weights_I3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "b90b3b96",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Weights (kernel_P1):\n",
      " [array([[ 1.0391197 , -0.15593553,  0.08256879,  0.        ],\n",
      "       [ 0.03548376,  0.84459263,  0.08187562,  0.        ],\n",
      "       [ 0.02989147,  0.19371283,  1.0426505 ,  0.        ]],\n",
      "      dtype=float32)]\n",
      "Weights (kernel_P2):\n",
      " [array([[ 0.99965686, -0.1645801 ,  0.10338968,  0.        ],\n",
      "       [-0.00541863,  0.8761845 ,  0.10520536,  0.        ],\n",
      "       [ 0.06198535,  0.18854924,  1.0209529 ,  0.        ],\n",
      "       [ 0.        ,  0.        ,  0.        ,  1.        ]],\n",
      "      dtype=float32)]\n",
      "Weights (kernel_P3):\n",
      " [array([[ 0.93466806, -0.16885805,  0.12746486],\n",
      "       [-0.02617911,  0.90889484,  0.11546743],\n",
      "       [ 0.08724555,  0.18126705,  0.99220353],\n",
      "       [ 0.        ,  0.        ,  0.        ]], dtype=float32)]\n"
     ]
    }
   ],
   "source": [
    "#calculate the output layers\n",
    "# Get first layer\n",
    "layer_P1 = final_model.layers[-3]\n",
    "# Get weights\n",
    "weights_P1 = layer_P1.get_weights()\n",
    "\n",
    "# Get first layer\n",
    "layer_P2 = final_model.layers[-2]\n",
    "# Get weights\n",
    "weights_P2 = layer_P2.get_weights()\n",
    "\n",
    "# Get first layer\n",
    "layer_P3 = final_model.layers[-1]\n",
    "# Get weights\n",
    "weights_P3 = layer_P3.get_weights()\n",
    "\n",
    "print(\"Weights (kernel_P1):\\n\", weights_P1)\n",
    "print(\"Weights (kernel_P2):\\n\", weights_P2)\n",
    "print(\"Weights (kernel_P3):\\n\", weights_P3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "e2032c68",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Weights (kernel_I1):\n",
      " [[ 0.7926281   0.14916568 -0.10851387 -0.22752912  0.          0.\n",
      "   0.          0.        ]\n",
      " [-0.21404538  1.1044701  -0.07085827 -0.07753652  0.          0.\n",
      "   0.          0.        ]\n",
      " [-0.09994277  0.20313162  0.8543527  -0.21705554  0.          0.\n",
      "   0.          0.        ]\n",
      " [ 0.13956712 -0.0546584   0.09754648  1.0468787   0.          0.\n",
      "   0.          0.        ]]\n",
      "Weights (kernel_I2):\n",
      " [[ 0.8105775   0.03667956 -0.12156762 -0.04747374  0.          0.\n",
      "   0.          0.        ]\n",
      " [-0.24057941  1.0927567  -0.13542175  0.05155464  0.          0.\n",
      "   0.          0.        ]\n",
      " [-0.07179355  0.07506959  0.85817295 -0.11049461  0.          0.\n",
      "   0.          0.        ]\n",
      " [ 0.19364358 -0.10923319  0.13788216  1.0245957   0.          0.\n",
      "   0.          0.        ]\n",
      " [ 0.          0.          0.          0.          1.          0.\n",
      "   0.          0.        ]\n",
      " [ 0.          0.          0.          0.          0.          1.\n",
      "   0.          0.        ]\n",
      " [ 0.          0.          0.          0.          0.          0.\n",
      "   1.          0.        ]\n",
      " [ 0.          0.          0.          0.          0.          0.\n",
      "   0.          1.        ]]\n",
      "Weights (kernel_I3):\n",
      " [[ 0.8431676  -0.05372376 -0.11008354  0.11026154]\n",
      " [-0.26423422  1.0218049  -0.17595296  0.22670884]\n",
      " [-0.02235859 -0.01480498  0.8739995  -0.1049253 ]\n",
      " [ 0.21560206  0.14988527  0.16302921  0.7282373 ]\n",
      " [ 0.          0.          0.          0.        ]\n",
      " [ 0.          0.          0.          0.        ]\n",
      " [ 0.          0.          0.          0.        ]\n",
      " [ 0.          0.          0.          0.        ]]\n",
      "Weights (kernel_P1):\n",
      " [[ 1.0391197  -0.15593553  0.08256879  0.        ]\n",
      " [ 0.03548376  0.84459263  0.08187562  0.        ]\n",
      " [ 0.02989147  0.19371283  1.0426505   0.        ]]\n",
      "Weights (kernel_P2):\n",
      " [[ 0.99965686 -0.1645801   0.10338968  0.        ]\n",
      " [-0.00541863  0.8761845   0.10520536  0.        ]\n",
      " [ 0.06198535  0.18854924  1.0209529   0.        ]\n",
      " [ 0.          0.          0.          1.        ]]\n",
      "Weights (kernel_P3):\n",
      " [[ 0.93466806 -0.16885805  0.12746486]\n",
      " [-0.02617911  0.90889484  0.11546743]\n",
      " [ 0.08724555  0.18126705  0.99220353]\n",
      " [ 0.          0.          0.        ]]\n",
      "Weights Final input P:\n",
      " [[ 0.376975    0.14863133 -0.35113353 -0.04733028]\n",
      " [-0.69297916  1.2547715  -0.33329782  0.24020977]\n",
      " [-0.35796553  0.2699734   0.52386266 -0.24810915]\n",
      " [ 0.53622454 -0.0279584   0.3555298   0.7423342 ]]\n",
      "Weights Final output Q:\n",
      " [[ 0.9994151  -0.41009784  0.27340123]\n",
      " [ 0.02936113  0.7071728   0.26588365]\n",
      " [ 0.17281382  0.5099052   1.1331277 ]]\n"
     ]
    }
   ],
   "source": [
    "print(\"Weights (kernel_I1):\\n\", weights_I1[0])\n",
    "print(\"Weights (kernel_I2):\\n\", weights_I2[0])\n",
    "print(\"Weights (kernel_I3):\\n\", weights_I3[0])\n",
    "\n",
    "print(\"Weights (kernel_P1):\\n\", weights_P1[0])\n",
    "print(\"Weights (kernel_P2):\\n\", weights_P2[0])\n",
    "print(\"Weights (kernel_P3):\\n\", weights_P3[0])\n",
    "\n",
    "#calculate the transfromation matrix\n",
    "P = weights_I1[0]@weights_I2[0]@weights_I3[0]\n",
    "Q = weights_P1[0]@weights_P2[0]@weights_P3[0]\n",
    "\n",
    "print(\"Weights Final input P:\\n\", P)\n",
    "print(\"Weights Final output Q:\\n\", Q)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "63fb1c5d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "id": "c51eb080",
   "metadata": {},
   "source": [
    "# Refine the model and set the weight parameters"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "409049a8",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Step 2: Freeze the original model's weights\n",
    "for layer in model.layers:\n",
    "    layer.trainable = False\n",
    "\n",
    "# Step 3: Create new layers\n",
    "input_layer = Input(shape=(None, 4))  # Replace input_dim with your actual input feature dimension\n",
    "new_input_layer = Dense(4, activation='linear', use_bias=False)  # New front layer\n",
    "\n",
    "# Connect the frozen original model\n",
    "x = model(new_input_layer(input_layer))\n",
    "\n",
    "# Add new output layer\n",
    "new_output_layer = Dense(3, activation='linear', use_bias=False)  # Replace output_dim with your desired final output size\n",
    "\n",
    "output = new_output_layer(x)\n",
    "# Step 4: Assemble final model\n",
    "final_model_PQ = Model(inputs=input_layer, outputs=output)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "ea01d0d9",
   "metadata": {},
   "outputs": [],
   "source": [
    "#assign parameters\n",
    "W1 = np.array(P, dtype=np.float32)  # shape (input_dim, output_dim)\n",
    "W2 = np.array(Q, dtype=np.float32)  # shape (input_dim, output_dim)\n",
    "\n",
    "new_input_layer.set_weights([W1])\n",
    "new_output_layer.set_weights([W2])"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "cc27c3d2",
   "metadata": {},
   "source": [
    "# fine tune the model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "be147352",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model: \"model_1\"\n",
      "_________________________________________________________________\n",
      " Layer (type)                Output Shape              Param #   \n",
      "=================================================================\n",
      " input_2 (InputLayer)        [(None, None, 4)]         0         \n",
      "                                                                 \n",
      " dense_8 (Dense)             (None, None, 4)           16        \n",
      "                                                                 \n",
      " sequential (Sequential)     (None, 5, 3)              563       \n",
      "                                                                 \n",
      " dense_9 (Dense)             (None, 5, 3)              9         \n",
      "                                                                 \n",
      "=================================================================\n",
      "Total params: 588\n",
      "Trainable params: 588\n",
      "Non-trainable params: 0\n",
      "_________________________________________________________________\n",
      "None\n"
     ]
    }
   ],
   "source": [
    "# Step 1: ynFreeze the model's weights\n",
    "for layer in final_model.layers:\n",
    "    layer.trainable = True\n",
    "    \n",
    "# Step 2: Compile with mse as loss function\n",
    "final_model_PQ.compile(optimizer='adam', loss='mse', metrics=['mse'])\n",
    "print(final_model_PQ.summary())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "55fbdca2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/300\n",
      "1/1 - 1s - loss: 0.3791 - mse: 0.3791 - val_loss: 0.5055 - val_mse: 0.5055 - 895ms/epoch - 895ms/step\n",
      "Epoch 2/300\n",
      "1/1 - 0s - loss: 0.3709 - mse: 0.3709 - val_loss: 0.5046 - val_mse: 0.5046 - 16ms/epoch - 16ms/step\n",
      "Epoch 3/300\n",
      "1/1 - 0s - loss: 0.3649 - mse: 0.3649 - val_loss: 0.5016 - val_mse: 0.5016 - 14ms/epoch - 14ms/step\n",
      "Epoch 4/300\n",
      "1/1 - 0s - loss: 0.3587 - mse: 0.3587 - val_loss: 0.4990 - val_mse: 0.4990 - 17ms/epoch - 17ms/step\n",
      "Epoch 5/300\n",
      "1/1 - 0s - loss: 0.3543 - mse: 0.3543 - val_loss: 0.4974 - val_mse: 0.4974 - 19ms/epoch - 19ms/step\n",
      "Epoch 6/300\n",
      "1/1 - 0s - loss: 0.3504 - mse: 0.3504 - val_loss: 0.4964 - val_mse: 0.4964 - 17ms/epoch - 17ms/step\n",
      "Epoch 7/300\n",
      "1/1 - 0s - loss: 0.3464 - mse: 0.3464 - val_loss: 0.4960 - val_mse: 0.4960 - 18ms/epoch - 18ms/step\n",
      "Epoch 8/300\n",
      "1/1 - 0s - loss: 0.3425 - mse: 0.3425 - val_loss: 0.4962 - val_mse: 0.4962 - 18ms/epoch - 18ms/step\n",
      "Epoch 9/300\n",
      "1/1 - 0s - loss: 0.3393 - mse: 0.3393 - val_loss: 0.4965 - val_mse: 0.4965 - 21ms/epoch - 21ms/step\n",
      "Epoch 10/300\n",
      "1/1 - 0s - loss: 0.3366 - mse: 0.3366 - val_loss: 0.4962 - val_mse: 0.4962 - 19ms/epoch - 19ms/step\n",
      "Epoch 11/300\n",
      "1/1 - 0s - loss: 0.3339 - mse: 0.3339 - val_loss: 0.4953 - val_mse: 0.4953 - 18ms/epoch - 18ms/step\n",
      "Epoch 12/300\n",
      "1/1 - 0s - loss: 0.3311 - mse: 0.3311 - val_loss: 0.4940 - val_mse: 0.4940 - 14ms/epoch - 14ms/step\n",
      "Epoch 13/300\n",
      "1/1 - 0s - loss: 0.3285 - mse: 0.3285 - val_loss: 0.4929 - val_mse: 0.4929 - 16ms/epoch - 16ms/step\n",
      "Epoch 14/300\n",
      "1/1 - 0s - loss: 0.3261 - mse: 0.3261 - val_loss: 0.4922 - val_mse: 0.4922 - 15ms/epoch - 15ms/step\n",
      "Epoch 15/300\n",
      "1/1 - 0s - loss: 0.3240 - mse: 0.3240 - val_loss: 0.4918 - val_mse: 0.4918 - 17ms/epoch - 17ms/step\n",
      "Epoch 16/300\n",
      "1/1 - 0s - loss: 0.3219 - mse: 0.3219 - val_loss: 0.4918 - val_mse: 0.4918 - 14ms/epoch - 14ms/step\n",
      "Epoch 17/300\n",
      "1/1 - 0s - loss: 0.3198 - mse: 0.3198 - val_loss: 0.4920 - val_mse: 0.4920 - 15ms/epoch - 15ms/step\n",
      "Epoch 18/300\n",
      "1/1 - 0s - loss: 0.3178 - mse: 0.3178 - val_loss: 0.4923 - val_mse: 0.4923 - 16ms/epoch - 16ms/step\n",
      "Epoch 19/300\n",
      "1/1 - 0s - loss: 0.3161 - mse: 0.3161 - val_loss: 0.4924 - val_mse: 0.4924 - 17ms/epoch - 17ms/step\n",
      "Epoch 20/300\n",
      "1/1 - 0s - loss: 0.3144 - mse: 0.3144 - val_loss: 0.4923 - val_mse: 0.4923 - 14ms/epoch - 14ms/step\n",
      "Epoch 21/300\n",
      "1/1 - 0s - loss: 0.3128 - mse: 0.3128 - val_loss: 0.4920 - val_mse: 0.4920 - 16ms/epoch - 16ms/step\n",
      "Epoch 22/300\n",
      "1/1 - 0s - loss: 0.3112 - mse: 0.3112 - val_loss: 0.4916 - val_mse: 0.4916 - 16ms/epoch - 16ms/step\n",
      "Epoch 23/300\n",
      "1/1 - 0s - loss: 0.3096 - mse: 0.3096 - val_loss: 0.4914 - val_mse: 0.4914 - 17ms/epoch - 17ms/step\n",
      "Epoch 24/300\n",
      "1/1 - 0s - loss: 0.3082 - mse: 0.3082 - val_loss: 0.4914 - val_mse: 0.4914 - 18ms/epoch - 18ms/step\n",
      "Epoch 25/300\n",
      "1/1 - 0s - loss: 0.3069 - mse: 0.3069 - val_loss: 0.4916 - val_mse: 0.4916 - 15ms/epoch - 15ms/step\n",
      "Epoch 26/300\n",
      "1/1 - 0s - loss: 0.3057 - mse: 0.3057 - val_loss: 0.4920 - val_mse: 0.4920 - 15ms/epoch - 15ms/step\n",
      "Epoch 27/300\n",
      "1/1 - 0s - loss: 0.3044 - mse: 0.3044 - val_loss: 0.4926 - val_mse: 0.4926 - 14ms/epoch - 14ms/step\n",
      "Epoch 28/300\n",
      "1/1 - 0s - loss: 0.3032 - mse: 0.3032 - val_loss: 0.4933 - val_mse: 0.4933 - 17ms/epoch - 17ms/step\n",
      "Epoch 29/300\n",
      "1/1 - 0s - loss: 0.3021 - mse: 0.3021 - val_loss: 0.4939 - val_mse: 0.4939 - 17ms/epoch - 17ms/step\n",
      "Epoch 30/300\n",
      "1/1 - 0s - loss: 0.3011 - mse: 0.3011 - val_loss: 0.4943 - val_mse: 0.4943 - 17ms/epoch - 17ms/step\n",
      "Epoch 31/300\n",
      "1/1 - 0s - loss: 0.3001 - mse: 0.3001 - val_loss: 0.4945 - val_mse: 0.4945 - 17ms/epoch - 17ms/step\n",
      "Epoch 32/300\n",
      "1/1 - 0s - loss: 0.2991 - mse: 0.2991 - val_loss: 0.4948 - val_mse: 0.4948 - 21ms/epoch - 21ms/step\n",
      "Epoch 33/300\n",
      "1/1 - 0s - loss: 0.2981 - mse: 0.2981 - val_loss: 0.4950 - val_mse: 0.4950 - 19ms/epoch - 19ms/step\n",
      "Epoch 34/300\n",
      "1/1 - 0s - loss: 0.2972 - mse: 0.2972 - val_loss: 0.4954 - val_mse: 0.4954 - 18ms/epoch - 18ms/step\n",
      "Epoch 35/300\n",
      "1/1 - 0s - loss: 0.2963 - mse: 0.2963 - val_loss: 0.4958 - val_mse: 0.4958 - 14ms/epoch - 14ms/step\n",
      "Epoch 36/300\n",
      "1/1 - 0s - loss: 0.2954 - mse: 0.2954 - val_loss: 0.4962 - val_mse: 0.4962 - 17ms/epoch - 17ms/step\n",
      "Epoch 37/300\n",
      "1/1 - 0s - loss: 0.2946 - mse: 0.2946 - val_loss: 0.4966 - val_mse: 0.4966 - 13ms/epoch - 13ms/step\n",
      "Epoch 38/300\n",
      "1/1 - 0s - loss: 0.2937 - mse: 0.2937 - val_loss: 0.4970 - val_mse: 0.4970 - 16ms/epoch - 16ms/step\n",
      "Epoch 39/300\n",
      "1/1 - 0s - loss: 0.2929 - mse: 0.2929 - val_loss: 0.4973 - val_mse: 0.4973 - 15ms/epoch - 15ms/step\n",
      "Epoch 40/300\n",
      "1/1 - 0s - loss: 0.2921 - mse: 0.2921 - val_loss: 0.4975 - val_mse: 0.4975 - 16ms/epoch - 16ms/step\n",
      "Epoch 41/300\n",
      "1/1 - 0s - loss: 0.2913 - mse: 0.2913 - val_loss: 0.4977 - val_mse: 0.4977 - 16ms/epoch - 16ms/step\n",
      "Epoch 42/300\n",
      "1/1 - 0s - loss: 0.2906 - mse: 0.2906 - val_loss: 0.4978 - val_mse: 0.4978 - 17ms/epoch - 17ms/step\n",
      "Epoch 43/300\n",
      "1/1 - 0s - loss: 0.2898 - mse: 0.2898 - val_loss: 0.4980 - val_mse: 0.4980 - 18ms/epoch - 18ms/step\n",
      "Epoch 44/300\n",
      "1/1 - 0s - loss: 0.2891 - mse: 0.2891 - val_loss: 0.4983 - val_mse: 0.4983 - 19ms/epoch - 19ms/step\n",
      "Epoch 45/300\n",
      "1/1 - 0s - loss: 0.2884 - mse: 0.2884 - val_loss: 0.4987 - val_mse: 0.4987 - 23ms/epoch - 23ms/step\n",
      "Epoch 46/300\n",
      "1/1 - 0s - loss: 0.2876 - mse: 0.2876 - val_loss: 0.4990 - val_mse: 0.4990 - 20ms/epoch - 20ms/step\n",
      "Epoch 47/300\n",
      "1/1 - 0s - loss: 0.2869 - mse: 0.2869 - val_loss: 0.4994 - val_mse: 0.4994 - 16ms/epoch - 16ms/step\n",
      "Epoch 48/300\n",
      "1/1 - 0s - loss: 0.2862 - mse: 0.2862 - val_loss: 0.4997 - val_mse: 0.4997 - 18ms/epoch - 18ms/step\n",
      "Epoch 49/300\n",
      "1/1 - 0s - loss: 0.2855 - mse: 0.2855 - val_loss: 0.4998 - val_mse: 0.4998 - 18ms/epoch - 18ms/step\n",
      "Epoch 50/300\n",
      "1/1 - 0s - loss: 0.2849 - mse: 0.2849 - val_loss: 0.5000 - val_mse: 0.5000 - 22ms/epoch - 22ms/step\n",
      "Epoch 51/300\n",
      "1/1 - 0s - loss: 0.2842 - mse: 0.2842 - val_loss: 0.5001 - val_mse: 0.5001 - 19ms/epoch - 19ms/step\n",
      "Epoch 52/300\n",
      "1/1 - 0s - loss: 0.2835 - mse: 0.2835 - val_loss: 0.5002 - val_mse: 0.5002 - 16ms/epoch - 16ms/step\n",
      "Epoch 53/300\n",
      "1/1 - 0s - loss: 0.2828 - mse: 0.2828 - val_loss: 0.5003 - val_mse: 0.5003 - 18ms/epoch - 18ms/step\n",
      "Epoch 54/300\n",
      "1/1 - 0s - loss: 0.2821 - mse: 0.2821 - val_loss: 0.5004 - val_mse: 0.5004 - 19ms/epoch - 19ms/step\n",
      "Epoch 55/300\n",
      "1/1 - 0s - loss: 0.2815 - mse: 0.2815 - val_loss: 0.5004 - val_mse: 0.5004 - 24ms/epoch - 24ms/step\n",
      "Epoch 56/300\n",
      "1/1 - 0s - loss: 0.2808 - mse: 0.2808 - val_loss: 0.5005 - val_mse: 0.5005 - 18ms/epoch - 18ms/step\n",
      "Epoch 57/300\n",
      "1/1 - 0s - loss: 0.2801 - mse: 0.2801 - val_loss: 0.5004 - val_mse: 0.5004 - 14ms/epoch - 14ms/step\n",
      "Epoch 58/300\n",
      "1/1 - 0s - loss: 0.2794 - mse: 0.2794 - val_loss: 0.5004 - val_mse: 0.5004 - 16ms/epoch - 16ms/step\n",
      "Epoch 59/300\n",
      "1/1 - 0s - loss: 0.2787 - mse: 0.2787 - val_loss: 0.5002 - val_mse: 0.5002 - 15ms/epoch - 15ms/step\n",
      "Epoch 60/300\n",
      "1/1 - 0s - loss: 0.2780 - mse: 0.2780 - val_loss: 0.5001 - val_mse: 0.5001 - 17ms/epoch - 17ms/step\n",
      "Epoch 61/300\n",
      "1/1 - 0s - loss: 0.2773 - mse: 0.2773 - val_loss: 0.5000 - val_mse: 0.5000 - 17ms/epoch - 17ms/step\n",
      "Epoch 62/300\n",
      "1/1 - 0s - loss: 0.2766 - mse: 0.2766 - val_loss: 0.4998 - val_mse: 0.4998 - 17ms/epoch - 17ms/step\n",
      "Epoch 63/300\n",
      "1/1 - 0s - loss: 0.2758 - mse: 0.2758 - val_loss: 0.4996 - val_mse: 0.4996 - 17ms/epoch - 17ms/step\n",
      "Epoch 64/300\n",
      "1/1 - 0s - loss: 0.2751 - mse: 0.2751 - val_loss: 0.4994 - val_mse: 0.4994 - 17ms/epoch - 17ms/step\n",
      "Epoch 65/300\n",
      "1/1 - 0s - loss: 0.2743 - mse: 0.2743 - val_loss: 0.4992 - val_mse: 0.4992 - 19ms/epoch - 19ms/step\n",
      "Epoch 66/300\n",
      "1/1 - 0s - loss: 0.2735 - mse: 0.2735 - val_loss: 0.4988 - val_mse: 0.4988 - 26ms/epoch - 26ms/step\n",
      "Epoch 67/300\n",
      "1/1 - 0s - loss: 0.2727 - mse: 0.2727 - val_loss: 0.4985 - val_mse: 0.4985 - 18ms/epoch - 18ms/step\n",
      "Epoch 68/300\n",
      "1/1 - 0s - loss: 0.2719 - mse: 0.2719 - val_loss: 0.4981 - val_mse: 0.4981 - 18ms/epoch - 18ms/step\n",
      "Epoch 69/300\n",
      "1/1 - 0s - loss: 0.2710 - mse: 0.2710 - val_loss: 0.4976 - val_mse: 0.4976 - 15ms/epoch - 15ms/step\n",
      "Epoch 70/300\n",
      "1/1 - 0s - loss: 0.2701 - mse: 0.2701 - val_loss: 0.4972 - val_mse: 0.4972 - 20ms/epoch - 20ms/step\n",
      "Epoch 71/300\n",
      "1/1 - 0s - loss: 0.2692 - mse: 0.2692 - val_loss: 0.4967 - val_mse: 0.4967 - 17ms/epoch - 17ms/step\n",
      "Epoch 72/300\n",
      "1/1 - 0s - loss: 0.2683 - mse: 0.2683 - val_loss: 0.4961 - val_mse: 0.4961 - 17ms/epoch - 17ms/step\n",
      "Epoch 73/300\n",
      "1/1 - 0s - loss: 0.2673 - mse: 0.2673 - val_loss: 0.4956 - val_mse: 0.4956 - 14ms/epoch - 14ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 74/300\n",
      "1/1 - 0s - loss: 0.2663 - mse: 0.2663 - val_loss: 0.4949 - val_mse: 0.4949 - 16ms/epoch - 16ms/step\n",
      "Epoch 75/300\n",
      "1/1 - 0s - loss: 0.2653 - mse: 0.2653 - val_loss: 0.4942 - val_mse: 0.4942 - 15ms/epoch - 15ms/step\n",
      "Epoch 76/300\n",
      "1/1 - 0s - loss: 0.2642 - mse: 0.2642 - val_loss: 0.4934 - val_mse: 0.4934 - 16ms/epoch - 16ms/step\n",
      "Epoch 77/300\n",
      "1/1 - 0s - loss: 0.2631 - mse: 0.2631 - val_loss: 0.4926 - val_mse: 0.4926 - 16ms/epoch - 16ms/step\n",
      "Epoch 78/300\n",
      "1/1 - 0s - loss: 0.2619 - mse: 0.2619 - val_loss: 0.4918 - val_mse: 0.4918 - 16ms/epoch - 16ms/step\n",
      "Epoch 79/300\n",
      "1/1 - 0s - loss: 0.2607 - mse: 0.2607 - val_loss: 0.4908 - val_mse: 0.4908 - 15ms/epoch - 15ms/step\n",
      "Epoch 80/300\n",
      "1/1 - 0s - loss: 0.2595 - mse: 0.2595 - val_loss: 0.4898 - val_mse: 0.4898 - 15ms/epoch - 15ms/step\n",
      "Epoch 81/300\n",
      "1/1 - 0s - loss: 0.2581 - mse: 0.2581 - val_loss: 0.4887 - val_mse: 0.4887 - 15ms/epoch - 15ms/step\n",
      "Epoch 82/300\n",
      "1/1 - 0s - loss: 0.2567 - mse: 0.2567 - val_loss: 0.4875 - val_mse: 0.4875 - 17ms/epoch - 17ms/step\n",
      "Epoch 83/300\n",
      "1/1 - 0s - loss: 0.2553 - mse: 0.2553 - val_loss: 0.4862 - val_mse: 0.4862 - 16ms/epoch - 16ms/step\n",
      "Epoch 84/300\n",
      "1/1 - 0s - loss: 0.2538 - mse: 0.2538 - val_loss: 0.4848 - val_mse: 0.4848 - 16ms/epoch - 16ms/step\n",
      "Epoch 85/300\n",
      "1/1 - 0s - loss: 0.2522 - mse: 0.2522 - val_loss: 0.4833 - val_mse: 0.4833 - 17ms/epoch - 17ms/step\n",
      "Epoch 86/300\n",
      "1/1 - 0s - loss: 0.2505 - mse: 0.2505 - val_loss: 0.4817 - val_mse: 0.4817 - 18ms/epoch - 18ms/step\n",
      "Epoch 87/300\n",
      "1/1 - 0s - loss: 0.2488 - mse: 0.2488 - val_loss: 0.4799 - val_mse: 0.4799 - 18ms/epoch - 18ms/step\n",
      "Epoch 88/300\n",
      "1/1 - 0s - loss: 0.2469 - mse: 0.2469 - val_loss: 0.4780 - val_mse: 0.4780 - 20ms/epoch - 20ms/step\n",
      "Epoch 89/300\n",
      "1/1 - 0s - loss: 0.2450 - mse: 0.2450 - val_loss: 0.4760 - val_mse: 0.4760 - 20ms/epoch - 20ms/step\n",
      "Epoch 90/300\n",
      "1/1 - 0s - loss: 0.2429 - mse: 0.2429 - val_loss: 0.4738 - val_mse: 0.4738 - 17ms/epoch - 17ms/step\n",
      "Epoch 91/300\n",
      "1/1 - 0s - loss: 0.2408 - mse: 0.2408 - val_loss: 0.4714 - val_mse: 0.4714 - 17ms/epoch - 17ms/step\n",
      "Epoch 92/300\n",
      "1/1 - 0s - loss: 0.2385 - mse: 0.2385 - val_loss: 0.4688 - val_mse: 0.4688 - 14ms/epoch - 14ms/step\n",
      "Epoch 93/300\n",
      "1/1 - 0s - loss: 0.2361 - mse: 0.2361 - val_loss: 0.4661 - val_mse: 0.4661 - 15ms/epoch - 15ms/step\n",
      "Epoch 94/300\n",
      "1/1 - 0s - loss: 0.2336 - mse: 0.2336 - val_loss: 0.4631 - val_mse: 0.4631 - 15ms/epoch - 15ms/step\n",
      "Epoch 95/300\n",
      "1/1 - 0s - loss: 0.2309 - mse: 0.2309 - val_loss: 0.4598 - val_mse: 0.4598 - 17ms/epoch - 17ms/step\n",
      "Epoch 96/300\n",
      "1/1 - 0s - loss: 0.2281 - mse: 0.2281 - val_loss: 0.4563 - val_mse: 0.4563 - 16ms/epoch - 16ms/step\n",
      "Epoch 97/300\n",
      "1/1 - 0s - loss: 0.2251 - mse: 0.2251 - val_loss: 0.4525 - val_mse: 0.4525 - 16ms/epoch - 16ms/step\n",
      "Epoch 98/300\n",
      "1/1 - 0s - loss: 0.2220 - mse: 0.2220 - val_loss: 0.4484 - val_mse: 0.4484 - 17ms/epoch - 17ms/step\n",
      "Epoch 99/300\n",
      "1/1 - 0s - loss: 0.2188 - mse: 0.2188 - val_loss: 0.4440 - val_mse: 0.4440 - 18ms/epoch - 18ms/step\n",
      "Epoch 100/300\n",
      "1/1 - 0s - loss: 0.2154 - mse: 0.2154 - val_loss: 0.4392 - val_mse: 0.4392 - 19ms/epoch - 19ms/step\n",
      "Epoch 101/300\n",
      "1/1 - 0s - loss: 0.2118 - mse: 0.2118 - val_loss: 0.4341 - val_mse: 0.4341 - 19ms/epoch - 19ms/step\n",
      "Epoch 102/300\n",
      "1/1 - 0s - loss: 0.2081 - mse: 0.2081 - val_loss: 0.4286 - val_mse: 0.4286 - 17ms/epoch - 17ms/step\n",
      "Epoch 103/300\n",
      "1/1 - 0s - loss: 0.2043 - mse: 0.2043 - val_loss: 0.4228 - val_mse: 0.4228 - 17ms/epoch - 17ms/step\n",
      "Epoch 104/300\n",
      "1/1 - 0s - loss: 0.2004 - mse: 0.2004 - val_loss: 0.4166 - val_mse: 0.4166 - 16ms/epoch - 16ms/step\n",
      "Epoch 105/300\n",
      "1/1 - 0s - loss: 0.1963 - mse: 0.1963 - val_loss: 0.4100 - val_mse: 0.4100 - 16ms/epoch - 16ms/step\n",
      "Epoch 106/300\n",
      "1/1 - 0s - loss: 0.1921 - mse: 0.1921 - val_loss: 0.4030 - val_mse: 0.4030 - 16ms/epoch - 16ms/step\n",
      "Epoch 107/300\n",
      "1/1 - 0s - loss: 0.1878 - mse: 0.1878 - val_loss: 0.3956 - val_mse: 0.3956 - 14ms/epoch - 14ms/step\n",
      "Epoch 108/300\n",
      "1/1 - 0s - loss: 0.1834 - mse: 0.1834 - val_loss: 0.3879 - val_mse: 0.3879 - 15ms/epoch - 15ms/step\n",
      "Epoch 109/300\n",
      "1/1 - 0s - loss: 0.1789 - mse: 0.1789 - val_loss: 0.3799 - val_mse: 0.3799 - 15ms/epoch - 15ms/step\n",
      "Epoch 110/300\n",
      "1/1 - 0s - loss: 0.1744 - mse: 0.1744 - val_loss: 0.3715 - val_mse: 0.3715 - 17ms/epoch - 17ms/step\n",
      "Epoch 111/300\n",
      "1/1 - 0s - loss: 0.1698 - mse: 0.1698 - val_loss: 0.3628 - val_mse: 0.3628 - 17ms/epoch - 17ms/step\n",
      "Epoch 112/300\n",
      "1/1 - 0s - loss: 0.1652 - mse: 0.1652 - val_loss: 0.3538 - val_mse: 0.3538 - 16ms/epoch - 16ms/step\n",
      "Epoch 113/300\n",
      "1/1 - 0s - loss: 0.1606 - mse: 0.1606 - val_loss: 0.3446 - val_mse: 0.3446 - 17ms/epoch - 17ms/step\n",
      "Epoch 114/300\n",
      "1/1 - 0s - loss: 0.1560 - mse: 0.1560 - val_loss: 0.3352 - val_mse: 0.3352 - 16ms/epoch - 16ms/step\n",
      "Epoch 115/300\n",
      "1/1 - 0s - loss: 0.1513 - mse: 0.1513 - val_loss: 0.3256 - val_mse: 0.3256 - 17ms/epoch - 17ms/step\n",
      "Epoch 116/300\n",
      "1/1 - 0s - loss: 0.1467 - mse: 0.1467 - val_loss: 0.3158 - val_mse: 0.3158 - 18ms/epoch - 18ms/step\n",
      "Epoch 117/300\n",
      "1/1 - 0s - loss: 0.1421 - mse: 0.1421 - val_loss: 0.3060 - val_mse: 0.3060 - 19ms/epoch - 19ms/step\n",
      "Epoch 118/300\n",
      "1/1 - 0s - loss: 0.1375 - mse: 0.1375 - val_loss: 0.2961 - val_mse: 0.2961 - 18ms/epoch - 18ms/step\n",
      "Epoch 119/300\n",
      "1/1 - 0s - loss: 0.1330 - mse: 0.1330 - val_loss: 0.2861 - val_mse: 0.2861 - 17ms/epoch - 17ms/step\n",
      "Epoch 120/300\n",
      "1/1 - 0s - loss: 0.1285 - mse: 0.1285 - val_loss: 0.2762 - val_mse: 0.2762 - 17ms/epoch - 17ms/step\n",
      "Epoch 121/300\n",
      "1/1 - 0s - loss: 0.1241 - mse: 0.1241 - val_loss: 0.2662 - val_mse: 0.2662 - 16ms/epoch - 16ms/step\n",
      "Epoch 122/300\n",
      "1/1 - 0s - loss: 0.1197 - mse: 0.1197 - val_loss: 0.2563 - val_mse: 0.2563 - 16ms/epoch - 16ms/step\n",
      "Epoch 123/300\n",
      "1/1 - 0s - loss: 0.1155 - mse: 0.1155 - val_loss: 0.2466 - val_mse: 0.2466 - 16ms/epoch - 16ms/step\n",
      "Epoch 124/300\n",
      "1/1 - 0s - loss: 0.1114 - mse: 0.1114 - val_loss: 0.2369 - val_mse: 0.2369 - 16ms/epoch - 16ms/step\n",
      "Epoch 125/300\n",
      "1/1 - 0s - loss: 0.1074 - mse: 0.1074 - val_loss: 0.2275 - val_mse: 0.2275 - 17ms/epoch - 17ms/step\n",
      "Epoch 126/300\n",
      "1/1 - 0s - loss: 0.1036 - mse: 0.1036 - val_loss: 0.2182 - val_mse: 0.2182 - 18ms/epoch - 18ms/step\n",
      "Epoch 127/300\n",
      "1/1 - 0s - loss: 0.0999 - mse: 0.0999 - val_loss: 0.2093 - val_mse: 0.2093 - 20ms/epoch - 20ms/step\n",
      "Epoch 128/300\n",
      "1/1 - 0s - loss: 0.0964 - mse: 0.0964 - val_loss: 0.2006 - val_mse: 0.2006 - 19ms/epoch - 19ms/step\n",
      "Epoch 129/300\n",
      "1/1 - 0s - loss: 0.0931 - mse: 0.0931 - val_loss: 0.1922 - val_mse: 0.1922 - 16ms/epoch - 16ms/step\n",
      "Epoch 130/300\n",
      "1/1 - 0s - loss: 0.0899 - mse: 0.0899 - val_loss: 0.1842 - val_mse: 0.1842 - 16ms/epoch - 16ms/step\n",
      "Epoch 131/300\n",
      "1/1 - 0s - loss: 0.0869 - mse: 0.0869 - val_loss: 0.1766 - val_mse: 0.1766 - 17ms/epoch - 17ms/step\n",
      "Epoch 132/300\n",
      "1/1 - 0s - loss: 0.0840 - mse: 0.0840 - val_loss: 0.1693 - val_mse: 0.1693 - 17ms/epoch - 17ms/step\n",
      "Epoch 133/300\n",
      "1/1 - 0s - loss: 0.0813 - mse: 0.0813 - val_loss: 0.1624 - val_mse: 0.1624 - 17ms/epoch - 17ms/step\n",
      "Epoch 134/300\n",
      "1/1 - 0s - loss: 0.0788 - mse: 0.0788 - val_loss: 0.1559 - val_mse: 0.1559 - 17ms/epoch - 17ms/step\n",
      "Epoch 135/300\n",
      "1/1 - 0s - loss: 0.0765 - mse: 0.0765 - val_loss: 0.1498 - val_mse: 0.1498 - 17ms/epoch - 17ms/step\n",
      "Epoch 136/300\n",
      "1/1 - 0s - loss: 0.0742 - mse: 0.0742 - val_loss: 0.1440 - val_mse: 0.1440 - 19ms/epoch - 19ms/step\n",
      "Epoch 137/300\n",
      "1/1 - 0s - loss: 0.0721 - mse: 0.0721 - val_loss: 0.1386 - val_mse: 0.1386 - 20ms/epoch - 20ms/step\n",
      "Epoch 138/300\n",
      "1/1 - 0s - loss: 0.0701 - mse: 0.0701 - val_loss: 0.1336 - val_mse: 0.1336 - 17ms/epoch - 17ms/step\n",
      "Epoch 139/300\n",
      "1/1 - 0s - loss: 0.0682 - mse: 0.0682 - val_loss: 0.1289 - val_mse: 0.1289 - 17ms/epoch - 17ms/step\n",
      "Epoch 140/300\n",
      "1/1 - 0s - loss: 0.0665 - mse: 0.0665 - val_loss: 0.1245 - val_mse: 0.1245 - 17ms/epoch - 17ms/step\n",
      "Epoch 141/300\n",
      "1/1 - 0s - loss: 0.0648 - mse: 0.0648 - val_loss: 0.1205 - val_mse: 0.1205 - 17ms/epoch - 17ms/step\n",
      "Epoch 142/300\n",
      "1/1 - 0s - loss: 0.0631 - mse: 0.0631 - val_loss: 0.1168 - val_mse: 0.1168 - 17ms/epoch - 17ms/step\n",
      "Epoch 143/300\n",
      "1/1 - 0s - loss: 0.0616 - mse: 0.0616 - val_loss: 0.1133 - val_mse: 0.1133 - 19ms/epoch - 19ms/step\n",
      "Epoch 144/300\n",
      "1/1 - 0s - loss: 0.0601 - mse: 0.0601 - val_loss: 0.1101 - val_mse: 0.1101 - 22ms/epoch - 22ms/step\n",
      "Epoch 145/300\n",
      "1/1 - 0s - loss: 0.0586 - mse: 0.0586 - val_loss: 0.1072 - val_mse: 0.1072 - 17ms/epoch - 17ms/step\n",
      "Epoch 146/300\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1/1 - 0s - loss: 0.0572 - mse: 0.0572 - val_loss: 0.1045 - val_mse: 0.1045 - 17ms/epoch - 17ms/step\n",
      "Epoch 147/300\n",
      "1/1 - 0s - loss: 0.0559 - mse: 0.0559 - val_loss: 0.1020 - val_mse: 0.1020 - 17ms/epoch - 17ms/step\n",
      "Epoch 148/300\n",
      "1/1 - 0s - loss: 0.0546 - mse: 0.0546 - val_loss: 0.0997 - val_mse: 0.0997 - 19ms/epoch - 19ms/step\n",
      "Epoch 149/300\n",
      "1/1 - 0s - loss: 0.0533 - mse: 0.0533 - val_loss: 0.0975 - val_mse: 0.0975 - 22ms/epoch - 22ms/step\n",
      "Epoch 150/300\n",
      "1/1 - 0s - loss: 0.0520 - mse: 0.0520 - val_loss: 0.0955 - val_mse: 0.0955 - 18ms/epoch - 18ms/step\n",
      "Epoch 151/300\n",
      "1/1 - 0s - loss: 0.0508 - mse: 0.0508 - val_loss: 0.0937 - val_mse: 0.0937 - 17ms/epoch - 17ms/step\n",
      "Epoch 152/300\n",
      "1/1 - 0s - loss: 0.0497 - mse: 0.0497 - val_loss: 0.0920 - val_mse: 0.0920 - 17ms/epoch - 17ms/step\n",
      "Epoch 153/300\n",
      "1/1 - 0s - loss: 0.0485 - mse: 0.0485 - val_loss: 0.0903 - val_mse: 0.0903 - 16ms/epoch - 16ms/step\n",
      "Epoch 154/300\n",
      "1/1 - 0s - loss: 0.0474 - mse: 0.0474 - val_loss: 0.0888 - val_mse: 0.0888 - 16ms/epoch - 16ms/step\n",
      "Epoch 155/300\n",
      "1/1 - 0s - loss: 0.0463 - mse: 0.0463 - val_loss: 0.0874 - val_mse: 0.0874 - 17ms/epoch - 17ms/step\n",
      "Epoch 156/300\n",
      "1/1 - 0s - loss: 0.0453 - mse: 0.0453 - val_loss: 0.0860 - val_mse: 0.0860 - 18ms/epoch - 18ms/step\n",
      "Epoch 157/300\n",
      "1/1 - 0s - loss: 0.0443 - mse: 0.0443 - val_loss: 0.0848 - val_mse: 0.0848 - 20ms/epoch - 20ms/step\n",
      "Epoch 158/300\n",
      "1/1 - 0s - loss: 0.0433 - mse: 0.0433 - val_loss: 0.0835 - val_mse: 0.0835 - 18ms/epoch - 18ms/step\n",
      "Epoch 159/300\n",
      "1/1 - 0s - loss: 0.0423 - mse: 0.0423 - val_loss: 0.0823 - val_mse: 0.0823 - 17ms/epoch - 17ms/step\n",
      "Epoch 160/300\n",
      "1/1 - 0s - loss: 0.0414 - mse: 0.0414 - val_loss: 0.0812 - val_mse: 0.0812 - 16ms/epoch - 16ms/step\n",
      "Epoch 161/300\n",
      "1/1 - 0s - loss: 0.0405 - mse: 0.0405 - val_loss: 0.0801 - val_mse: 0.0801 - 17ms/epoch - 17ms/step\n",
      "Epoch 162/300\n",
      "1/1 - 0s - loss: 0.0397 - mse: 0.0397 - val_loss: 0.0790 - val_mse: 0.0790 - 16ms/epoch - 16ms/step\n",
      "Epoch 163/300\n",
      "1/1 - 0s - loss: 0.0388 - mse: 0.0388 - val_loss: 0.0779 - val_mse: 0.0779 - 16ms/epoch - 16ms/step\n",
      "Epoch 164/300\n",
      "1/1 - 0s - loss: 0.0381 - mse: 0.0381 - val_loss: 0.0768 - val_mse: 0.0768 - 16ms/epoch - 16ms/step\n",
      "Epoch 165/300\n",
      "1/1 - 0s - loss: 0.0373 - mse: 0.0373 - val_loss: 0.0757 - val_mse: 0.0757 - 16ms/epoch - 16ms/step\n",
      "Epoch 166/300\n",
      "1/1 - 0s - loss: 0.0366 - mse: 0.0366 - val_loss: 0.0747 - val_mse: 0.0747 - 17ms/epoch - 17ms/step\n",
      "Epoch 167/300\n",
      "1/1 - 0s - loss: 0.0358 - mse: 0.0358 - val_loss: 0.0736 - val_mse: 0.0736 - 18ms/epoch - 18ms/step\n",
      "Epoch 168/300\n",
      "1/1 - 0s - loss: 0.0352 - mse: 0.0352 - val_loss: 0.0725 - val_mse: 0.0725 - 19ms/epoch - 19ms/step\n",
      "Epoch 169/300\n",
      "1/1 - 0s - loss: 0.0345 - mse: 0.0345 - val_loss: 0.0714 - val_mse: 0.0714 - 19ms/epoch - 19ms/step\n",
      "Epoch 170/300\n",
      "1/1 - 0s - loss: 0.0339 - mse: 0.0339 - val_loss: 0.0704 - val_mse: 0.0704 - 17ms/epoch - 17ms/step\n",
      "Epoch 171/300\n",
      "1/1 - 0s - loss: 0.0332 - mse: 0.0332 - val_loss: 0.0693 - val_mse: 0.0693 - 16ms/epoch - 16ms/step\n",
      "Epoch 172/300\n",
      "1/1 - 0s - loss: 0.0326 - mse: 0.0326 - val_loss: 0.0682 - val_mse: 0.0682 - 16ms/epoch - 16ms/step\n",
      "Epoch 173/300\n",
      "1/1 - 0s - loss: 0.0321 - mse: 0.0321 - val_loss: 0.0672 - val_mse: 0.0672 - 16ms/epoch - 16ms/step\n",
      "Epoch 174/300\n",
      "1/1 - 0s - loss: 0.0315 - mse: 0.0315 - val_loss: 0.0661 - val_mse: 0.0661 - 16ms/epoch - 16ms/step\n",
      "Epoch 175/300\n",
      "1/1 - 0s - loss: 0.0309 - mse: 0.0309 - val_loss: 0.0650 - val_mse: 0.0650 - 15ms/epoch - 15ms/step\n",
      "Epoch 176/300\n",
      "1/1 - 0s - loss: 0.0304 - mse: 0.0304 - val_loss: 0.0640 - val_mse: 0.0640 - 16ms/epoch - 16ms/step\n",
      "Epoch 177/300\n",
      "1/1 - 0s - loss: 0.0299 - mse: 0.0299 - val_loss: 0.0630 - val_mse: 0.0630 - 17ms/epoch - 17ms/step\n",
      "Epoch 178/300\n",
      "1/1 - 0s - loss: 0.0294 - mse: 0.0294 - val_loss: 0.0619 - val_mse: 0.0619 - 17ms/epoch - 17ms/step\n",
      "Epoch 179/300\n",
      "1/1 - 0s - loss: 0.0289 - mse: 0.0289 - val_loss: 0.0609 - val_mse: 0.0609 - 29ms/epoch - 29ms/step\n",
      "Epoch 180/300\n",
      "1/1 - 0s - loss: 0.0284 - mse: 0.0284 - val_loss: 0.0600 - val_mse: 0.0600 - 16ms/epoch - 16ms/step\n",
      "Epoch 181/300\n",
      "1/1 - 0s - loss: 0.0280 - mse: 0.0280 - val_loss: 0.0590 - val_mse: 0.0590 - 16ms/epoch - 16ms/step\n",
      "Epoch 182/300\n",
      "1/1 - 0s - loss: 0.0275 - mse: 0.0275 - val_loss: 0.0581 - val_mse: 0.0581 - 17ms/epoch - 17ms/step\n",
      "Epoch 183/300\n",
      "1/1 - 0s - loss: 0.0271 - mse: 0.0271 - val_loss: 0.0572 - val_mse: 0.0572 - 18ms/epoch - 18ms/step\n",
      "Epoch 184/300\n",
      "1/1 - 0s - loss: 0.0267 - mse: 0.0267 - val_loss: 0.0563 - val_mse: 0.0563 - 20ms/epoch - 20ms/step\n",
      "Epoch 185/300\n",
      "1/1 - 0s - loss: 0.0263 - mse: 0.0263 - val_loss: 0.0554 - val_mse: 0.0554 - 19ms/epoch - 19ms/step\n",
      "Epoch 186/300\n",
      "1/1 - 0s - loss: 0.0259 - mse: 0.0259 - val_loss: 0.0546 - val_mse: 0.0546 - 17ms/epoch - 17ms/step\n",
      "Epoch 187/300\n",
      "1/1 - 0s - loss: 0.0255 - mse: 0.0255 - val_loss: 0.0538 - val_mse: 0.0538 - 17ms/epoch - 17ms/step\n",
      "Epoch 188/300\n",
      "1/1 - 0s - loss: 0.0251 - mse: 0.0251 - val_loss: 0.0530 - val_mse: 0.0530 - 14ms/epoch - 14ms/step\n",
      "Epoch 189/300\n",
      "1/1 - 0s - loss: 0.0248 - mse: 0.0248 - val_loss: 0.0523 - val_mse: 0.0523 - 15ms/epoch - 15ms/step\n",
      "Epoch 190/300\n",
      "1/1 - 0s - loss: 0.0244 - mse: 0.0244 - val_loss: 0.0516 - val_mse: 0.0516 - 16ms/epoch - 16ms/step\n",
      "Epoch 191/300\n",
      "1/1 - 0s - loss: 0.0241 - mse: 0.0241 - val_loss: 0.0509 - val_mse: 0.0509 - 16ms/epoch - 16ms/step\n",
      "Epoch 192/300\n",
      "1/1 - 0s - loss: 0.0237 - mse: 0.0237 - val_loss: 0.0502 - val_mse: 0.0502 - 17ms/epoch - 17ms/step\n",
      "Epoch 193/300\n",
      "1/1 - 0s - loss: 0.0234 - mse: 0.0234 - val_loss: 0.0496 - val_mse: 0.0496 - 14ms/epoch - 14ms/step\n",
      "Epoch 194/300\n",
      "1/1 - 0s - loss: 0.0230 - mse: 0.0230 - val_loss: 0.0490 - val_mse: 0.0490 - 15ms/epoch - 15ms/step\n",
      "Epoch 195/300\n",
      "1/1 - 0s - loss: 0.0227 - mse: 0.0227 - val_loss: 0.0484 - val_mse: 0.0484 - 15ms/epoch - 15ms/step\n",
      "Epoch 196/300\n",
      "1/1 - 0s - loss: 0.0224 - mse: 0.0224 - val_loss: 0.0478 - val_mse: 0.0478 - 17ms/epoch - 17ms/step\n",
      "Epoch 197/300\n",
      "1/1 - 0s - loss: 0.0221 - mse: 0.0221 - val_loss: 0.0472 - val_mse: 0.0472 - 17ms/epoch - 17ms/step\n",
      "Epoch 198/300\n",
      "1/1 - 0s - loss: 0.0218 - mse: 0.0218 - val_loss: 0.0467 - val_mse: 0.0467 - 17ms/epoch - 17ms/step\n",
      "Epoch 199/300\n",
      "1/1 - 0s - loss: 0.0215 - mse: 0.0215 - val_loss: 0.0461 - val_mse: 0.0461 - 17ms/epoch - 17ms/step\n",
      "Epoch 200/300\n",
      "1/1 - 0s - loss: 0.0212 - mse: 0.0212 - val_loss: 0.0456 - val_mse: 0.0456 - 18ms/epoch - 18ms/step\n",
      "Epoch 201/300\n",
      "1/1 - 0s - loss: 0.0209 - mse: 0.0209 - val_loss: 0.0451 - val_mse: 0.0451 - 20ms/epoch - 20ms/step\n",
      "Epoch 202/300\n",
      "1/1 - 0s - loss: 0.0206 - mse: 0.0206 - val_loss: 0.0447 - val_mse: 0.0447 - 19ms/epoch - 19ms/step\n",
      "Epoch 203/300\n",
      "1/1 - 0s - loss: 0.0203 - mse: 0.0203 - val_loss: 0.0442 - val_mse: 0.0442 - 17ms/epoch - 17ms/step\n",
      "Epoch 204/300\n",
      "1/1 - 0s - loss: 0.0200 - mse: 0.0200 - val_loss: 0.0437 - val_mse: 0.0437 - 17ms/epoch - 17ms/step\n",
      "Epoch 205/300\n",
      "1/1 - 0s - loss: 0.0198 - mse: 0.0198 - val_loss: 0.0433 - val_mse: 0.0433 - 16ms/epoch - 16ms/step\n",
      "Epoch 206/300\n",
      "1/1 - 0s - loss: 0.0195 - mse: 0.0195 - val_loss: 0.0428 - val_mse: 0.0428 - 17ms/epoch - 17ms/step\n",
      "Epoch 207/300\n",
      "1/1 - 0s - loss: 0.0192 - mse: 0.0192 - val_loss: 0.0424 - val_mse: 0.0424 - 18ms/epoch - 18ms/step\n",
      "Epoch 208/300\n",
      "1/1 - 0s - loss: 0.0190 - mse: 0.0190 - val_loss: 0.0419 - val_mse: 0.0419 - 23ms/epoch - 23ms/step\n",
      "Epoch 209/300\n",
      "1/1 - 0s - loss: 0.0187 - mse: 0.0187 - val_loss: 0.0415 - val_mse: 0.0415 - 17ms/epoch - 17ms/step\n",
      "Epoch 210/300\n",
      "1/1 - 0s - loss: 0.0184 - mse: 0.0184 - val_loss: 0.0411 - val_mse: 0.0411 - 17ms/epoch - 17ms/step\n",
      "Epoch 211/300\n",
      "1/1 - 0s - loss: 0.0182 - mse: 0.0182 - val_loss: 0.0406 - val_mse: 0.0406 - 14ms/epoch - 14ms/step\n",
      "Epoch 212/300\n",
      "1/1 - 0s - loss: 0.0179 - mse: 0.0179 - val_loss: 0.0402 - val_mse: 0.0402 - 16ms/epoch - 16ms/step\n",
      "Epoch 213/300\n",
      "1/1 - 0s - loss: 0.0177 - mse: 0.0177 - val_loss: 0.0398 - val_mse: 0.0398 - 15ms/epoch - 15ms/step\n",
      "Epoch 214/300\n",
      "1/1 - 0s - loss: 0.0175 - mse: 0.0175 - val_loss: 0.0394 - val_mse: 0.0394 - 17ms/epoch - 17ms/step\n",
      "Epoch 215/300\n",
      "1/1 - 0s - loss: 0.0172 - mse: 0.0172 - val_loss: 0.0390 - val_mse: 0.0390 - 17ms/epoch - 17ms/step\n",
      "Epoch 216/300\n",
      "1/1 - 0s - loss: 0.0170 - mse: 0.0170 - val_loss: 0.0386 - val_mse: 0.0386 - 14ms/epoch - 14ms/step\n",
      "Epoch 217/300\n",
      "1/1 - 0s - loss: 0.0168 - mse: 0.0168 - val_loss: 0.0382 - val_mse: 0.0382 - 16ms/epoch - 16ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 218/300\n",
      "1/1 - 0s - loss: 0.0165 - mse: 0.0165 - val_loss: 0.0378 - val_mse: 0.0378 - 15ms/epoch - 15ms/step\n",
      "Epoch 219/300\n",
      "1/1 - 0s - loss: 0.0163 - mse: 0.0163 - val_loss: 0.0374 - val_mse: 0.0374 - 16ms/epoch - 16ms/step\n",
      "Epoch 220/300\n",
      "1/1 - 0s - loss: 0.0161 - mse: 0.0161 - val_loss: 0.0370 - val_mse: 0.0370 - 16ms/epoch - 16ms/step\n",
      "Epoch 221/300\n",
      "1/1 - 0s - loss: 0.0159 - mse: 0.0159 - val_loss: 0.0367 - val_mse: 0.0367 - 16ms/epoch - 16ms/step\n",
      "Epoch 222/300\n",
      "1/1 - 0s - loss: 0.0156 - mse: 0.0156 - val_loss: 0.0363 - val_mse: 0.0363 - 15ms/epoch - 15ms/step\n",
      "Epoch 223/300\n",
      "1/1 - 0s - loss: 0.0154 - mse: 0.0154 - val_loss: 0.0359 - val_mse: 0.0359 - 15ms/epoch - 15ms/step\n",
      "Epoch 224/300\n",
      "1/1 - 0s - loss: 0.0152 - mse: 0.0152 - val_loss: 0.0355 - val_mse: 0.0355 - 16ms/epoch - 16ms/step\n",
      "Epoch 225/300\n",
      "1/1 - 0s - loss: 0.0150 - mse: 0.0150 - val_loss: 0.0352 - val_mse: 0.0352 - 17ms/epoch - 17ms/step\n",
      "Epoch 226/300\n",
      "1/1 - 0s - loss: 0.0148 - mse: 0.0148 - val_loss: 0.0348 - val_mse: 0.0348 - 16ms/epoch - 16ms/step\n",
      "Epoch 227/300\n",
      "1/1 - 0s - loss: 0.0146 - mse: 0.0146 - val_loss: 0.0345 - val_mse: 0.0345 - 17ms/epoch - 17ms/step\n",
      "Epoch 228/300\n",
      "1/1 - 0s - loss: 0.0144 - mse: 0.0144 - val_loss: 0.0341 - val_mse: 0.0341 - 15ms/epoch - 15ms/step\n",
      "Epoch 229/300\n",
      "1/1 - 0s - loss: 0.0142 - mse: 0.0142 - val_loss: 0.0338 - val_mse: 0.0338 - 15ms/epoch - 15ms/step\n",
      "Epoch 230/300\n",
      "1/1 - 0s - loss: 0.0140 - mse: 0.0140 - val_loss: 0.0334 - val_mse: 0.0334 - 15ms/epoch - 15ms/step\n",
      "Epoch 231/300\n",
      "1/1 - 0s - loss: 0.0138 - mse: 0.0138 - val_loss: 0.0331 - val_mse: 0.0331 - 17ms/epoch - 17ms/step\n",
      "Epoch 232/300\n",
      "1/1 - 0s - loss: 0.0136 - mse: 0.0136 - val_loss: 0.0328 - val_mse: 0.0328 - 17ms/epoch - 17ms/step\n",
      "Epoch 233/300\n",
      "1/1 - 0s - loss: 0.0134 - mse: 0.0134 - val_loss: 0.0324 - val_mse: 0.0324 - 16ms/epoch - 16ms/step\n",
      "Epoch 234/300\n",
      "1/1 - 0s - loss: 0.0133 - mse: 0.0133 - val_loss: 0.0321 - val_mse: 0.0321 - 16ms/epoch - 16ms/step\n",
      "Epoch 235/300\n",
      "1/1 - 0s - loss: 0.0131 - mse: 0.0131 - val_loss: 0.0318 - val_mse: 0.0318 - 17ms/epoch - 17ms/step\n",
      "Epoch 236/300\n",
      "1/1 - 0s - loss: 0.0129 - mse: 0.0129 - val_loss: 0.0315 - val_mse: 0.0315 - 13ms/epoch - 13ms/step\n",
      "Epoch 237/300\n",
      "1/1 - 0s - loss: 0.0127 - mse: 0.0127 - val_loss: 0.0311 - val_mse: 0.0311 - 15ms/epoch - 15ms/step\n",
      "Epoch 238/300\n",
      "1/1 - 0s - loss: 0.0125 - mse: 0.0125 - val_loss: 0.0308 - val_mse: 0.0308 - 15ms/epoch - 15ms/step\n",
      "Epoch 239/300\n",
      "1/1 - 0s - loss: 0.0124 - mse: 0.0124 - val_loss: 0.0305 - val_mse: 0.0305 - 16ms/epoch - 16ms/step\n",
      "Epoch 240/300\n",
      "1/1 - 0s - loss: 0.0122 - mse: 0.0122 - val_loss: 0.0302 - val_mse: 0.0302 - 18ms/epoch - 18ms/step\n",
      "Epoch 241/300\n",
      "1/1 - 0s - loss: 0.0120 - mse: 0.0120 - val_loss: 0.0299 - val_mse: 0.0299 - 14ms/epoch - 14ms/step\n",
      "Epoch 242/300\n",
      "1/1 - 0s - loss: 0.0119 - mse: 0.0119 - val_loss: 0.0296 - val_mse: 0.0296 - 15ms/epoch - 15ms/step\n",
      "Epoch 243/300\n",
      "1/1 - 0s - loss: 0.0117 - mse: 0.0117 - val_loss: 0.0293 - val_mse: 0.0293 - 15ms/epoch - 15ms/step\n",
      "Epoch 244/300\n",
      "1/1 - 0s - loss: 0.0115 - mse: 0.0115 - val_loss: 0.0291 - val_mse: 0.0291 - 16ms/epoch - 16ms/step\n",
      "Epoch 245/300\n",
      "1/1 - 0s - loss: 0.0114 - mse: 0.0114 - val_loss: 0.0288 - val_mse: 0.0288 - 16ms/epoch - 16ms/step\n",
      "Epoch 246/300\n",
      "1/1 - 0s - loss: 0.0112 - mse: 0.0112 - val_loss: 0.0285 - val_mse: 0.0285 - 16ms/epoch - 16ms/step\n",
      "Epoch 247/300\n",
      "1/1 - 0s - loss: 0.0111 - mse: 0.0111 - val_loss: 0.0282 - val_mse: 0.0282 - 16ms/epoch - 16ms/step\n",
      "Epoch 248/300\n",
      "1/1 - 0s - loss: 0.0109 - mse: 0.0109 - val_loss: 0.0279 - val_mse: 0.0279 - 14ms/epoch - 14ms/step\n",
      "Epoch 249/300\n",
      "1/1 - 0s - loss: 0.0108 - mse: 0.0108 - val_loss: 0.0277 - val_mse: 0.0277 - 16ms/epoch - 16ms/step\n",
      "Epoch 250/300\n",
      "1/1 - 0s - loss: 0.0106 - mse: 0.0106 - val_loss: 0.0274 - val_mse: 0.0274 - 15ms/epoch - 15ms/step\n",
      "Epoch 251/300\n",
      "1/1 - 0s - loss: 0.0105 - mse: 0.0105 - val_loss: 0.0271 - val_mse: 0.0271 - 16ms/epoch - 16ms/step\n",
      "Epoch 252/300\n",
      "1/1 - 0s - loss: 0.0103 - mse: 0.0103 - val_loss: 0.0269 - val_mse: 0.0269 - 16ms/epoch - 16ms/step\n",
      "Epoch 253/300\n",
      "1/1 - 0s - loss: 0.0102 - mse: 0.0102 - val_loss: 0.0266 - val_mse: 0.0266 - 17ms/epoch - 17ms/step\n",
      "Epoch 254/300\n",
      "1/1 - 0s - loss: 0.0101 - mse: 0.0101 - val_loss: 0.0264 - val_mse: 0.0264 - 16ms/epoch - 16ms/step\n",
      "Epoch 255/300\n",
      "1/1 - 0s - loss: 0.0099 - mse: 0.0099 - val_loss: 0.0261 - val_mse: 0.0261 - 16ms/epoch - 16ms/step\n",
      "Epoch 256/300\n",
      "1/1 - 0s - loss: 0.0098 - mse: 0.0098 - val_loss: 0.0259 - val_mse: 0.0259 - 18ms/epoch - 18ms/step\n",
      "Epoch 257/300\n",
      "1/1 - 0s - loss: 0.0097 - mse: 0.0097 - val_loss: 0.0256 - val_mse: 0.0256 - 19ms/epoch - 19ms/step\n",
      "Epoch 258/300\n",
      "1/1 - 0s - loss: 0.0095 - mse: 0.0095 - val_loss: 0.0254 - val_mse: 0.0254 - 17ms/epoch - 17ms/step\n",
      "Epoch 259/300\n",
      "1/1 - 0s - loss: 0.0094 - mse: 0.0094 - val_loss: 0.0251 - val_mse: 0.0251 - 16ms/epoch - 16ms/step\n",
      "Epoch 260/300\n",
      "1/1 - 0s - loss: 0.0093 - mse: 0.0093 - val_loss: 0.0249 - val_mse: 0.0249 - 16ms/epoch - 16ms/step\n",
      "Epoch 261/300\n",
      "1/1 - 0s - loss: 0.0091 - mse: 0.0091 - val_loss: 0.0247 - val_mse: 0.0247 - 16ms/epoch - 16ms/step\n",
      "Epoch 262/300\n",
      "1/1 - 0s - loss: 0.0090 - mse: 0.0090 - val_loss: 0.0244 - val_mse: 0.0244 - 17ms/epoch - 17ms/step\n",
      "Epoch 263/300\n",
      "1/1 - 0s - loss: 0.0089 - mse: 0.0089 - val_loss: 0.0242 - val_mse: 0.0242 - 16ms/epoch - 16ms/step\n",
      "Epoch 264/300\n",
      "1/1 - 0s - loss: 0.0088 - mse: 0.0088 - val_loss: 0.0240 - val_mse: 0.0240 - 16ms/epoch - 16ms/step\n",
      "Epoch 265/300\n",
      "1/1 - 0s - loss: 0.0087 - mse: 0.0087 - val_loss: 0.0238 - val_mse: 0.0238 - 16ms/epoch - 16ms/step\n",
      "Epoch 266/300\n",
      "1/1 - 0s - loss: 0.0085 - mse: 0.0085 - val_loss: 0.0236 - val_mse: 0.0236 - 16ms/epoch - 16ms/step\n",
      "Epoch 267/300\n",
      "1/1 - 0s - loss: 0.0084 - mse: 0.0084 - val_loss: 0.0233 - val_mse: 0.0233 - 15ms/epoch - 15ms/step\n",
      "Epoch 268/300\n",
      "1/1 - 0s - loss: 0.0083 - mse: 0.0083 - val_loss: 0.0231 - val_mse: 0.0231 - 15ms/epoch - 15ms/step\n",
      "Epoch 269/300\n",
      "1/1 - 0s - loss: 0.0082 - mse: 0.0082 - val_loss: 0.0229 - val_mse: 0.0229 - 15ms/epoch - 15ms/step\n",
      "Epoch 270/300\n",
      "1/1 - 0s - loss: 0.0081 - mse: 0.0081 - val_loss: 0.0227 - val_mse: 0.0227 - 16ms/epoch - 16ms/step\n",
      "Epoch 271/300\n",
      "1/1 - 0s - loss: 0.0080 - mse: 0.0080 - val_loss: 0.0225 - val_mse: 0.0225 - 16ms/epoch - 16ms/step\n",
      "Epoch 272/300\n",
      "1/1 - 0s - loss: 0.0079 - mse: 0.0079 - val_loss: 0.0223 - val_mse: 0.0223 - 16ms/epoch - 16ms/step\n",
      "Epoch 273/300\n",
      "1/1 - 0s - loss: 0.0078 - mse: 0.0078 - val_loss: 0.0221 - val_mse: 0.0221 - 16ms/epoch - 16ms/step\n",
      "Epoch 274/300\n",
      "1/1 - 0s - loss: 0.0077 - mse: 0.0077 - val_loss: 0.0219 - val_mse: 0.0219 - 16ms/epoch - 16ms/step\n",
      "Epoch 275/300\n",
      "1/1 - 0s - loss: 0.0076 - mse: 0.0076 - val_loss: 0.0217 - val_mse: 0.0217 - 16ms/epoch - 16ms/step\n",
      "Epoch 276/300\n",
      "1/1 - 0s - loss: 0.0075 - mse: 0.0075 - val_loss: 0.0216 - val_mse: 0.0216 - 16ms/epoch - 16ms/step\n",
      "Epoch 277/300\n",
      "1/1 - 0s - loss: 0.0074 - mse: 0.0074 - val_loss: 0.0214 - val_mse: 0.0214 - 16ms/epoch - 16ms/step\n",
      "Epoch 278/300\n",
      "1/1 - 0s - loss: 0.0073 - mse: 0.0073 - val_loss: 0.0212 - val_mse: 0.0212 - 16ms/epoch - 16ms/step\n",
      "Epoch 279/300\n",
      "1/1 - 0s - loss: 0.0072 - mse: 0.0072 - val_loss: 0.0210 - val_mse: 0.0210 - 15ms/epoch - 15ms/step\n",
      "Epoch 280/300\n",
      "1/1 - 0s - loss: 0.0071 - mse: 0.0071 - val_loss: 0.0208 - val_mse: 0.0208 - 16ms/epoch - 16ms/step\n",
      "Epoch 281/300\n",
      "1/1 - 0s - loss: 0.0070 - mse: 0.0070 - val_loss: 0.0207 - val_mse: 0.0207 - 16ms/epoch - 16ms/step\n",
      "Epoch 282/300\n",
      "1/1 - 0s - loss: 0.0069 - mse: 0.0069 - val_loss: 0.0205 - val_mse: 0.0205 - 16ms/epoch - 16ms/step\n",
      "Epoch 283/300\n",
      "1/1 - 0s - loss: 0.0069 - mse: 0.0069 - val_loss: 0.0203 - val_mse: 0.0203 - 16ms/epoch - 16ms/step\n",
      "Epoch 284/300\n",
      "1/1 - 0s - loss: 0.0068 - mse: 0.0068 - val_loss: 0.0202 - val_mse: 0.0202 - 16ms/epoch - 16ms/step\n",
      "Epoch 285/300\n",
      "1/1 - 0s - loss: 0.0067 - mse: 0.0067 - val_loss: 0.0200 - val_mse: 0.0200 - 16ms/epoch - 16ms/step\n",
      "Epoch 286/300\n",
      "1/1 - 0s - loss: 0.0066 - mse: 0.0066 - val_loss: 0.0198 - val_mse: 0.0198 - 15ms/epoch - 15ms/step\n",
      "Epoch 287/300\n",
      "1/1 - 0s - loss: 0.0065 - mse: 0.0065 - val_loss: 0.0197 - val_mse: 0.0197 - 16ms/epoch - 16ms/step\n",
      "Epoch 288/300\n",
      "1/1 - 0s - loss: 0.0064 - mse: 0.0064 - val_loss: 0.0195 - val_mse: 0.0195 - 16ms/epoch - 16ms/step\n",
      "Epoch 289/300\n",
      "1/1 - 0s - loss: 0.0064 - mse: 0.0064 - val_loss: 0.0194 - val_mse: 0.0194 - 16ms/epoch - 16ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 290/300\n",
      "1/1 - 0s - loss: 0.0063 - mse: 0.0063 - val_loss: 0.0192 - val_mse: 0.0192 - 16ms/epoch - 16ms/step\n",
      "Epoch 291/300\n",
      "1/1 - 0s - loss: 0.0062 - mse: 0.0062 - val_loss: 0.0191 - val_mse: 0.0191 - 15ms/epoch - 15ms/step\n",
      "Epoch 292/300\n",
      "1/1 - 0s - loss: 0.0061 - mse: 0.0061 - val_loss: 0.0189 - val_mse: 0.0189 - 15ms/epoch - 15ms/step\n",
      "Epoch 293/300\n",
      "1/1 - 0s - loss: 0.0061 - mse: 0.0061 - val_loss: 0.0188 - val_mse: 0.0188 - 15ms/epoch - 15ms/step\n",
      "Epoch 294/300\n",
      "1/1 - 0s - loss: 0.0060 - mse: 0.0060 - val_loss: 0.0186 - val_mse: 0.0186 - 24ms/epoch - 24ms/step\n",
      "Epoch 295/300\n",
      "1/1 - 0s - loss: 0.0059 - mse: 0.0059 - val_loss: 0.0185 - val_mse: 0.0185 - 17ms/epoch - 17ms/step\n",
      "Epoch 296/300\n",
      "1/1 - 0s - loss: 0.0058 - mse: 0.0058 - val_loss: 0.0183 - val_mse: 0.0183 - 16ms/epoch - 16ms/step\n",
      "Epoch 297/300\n",
      "1/1 - 0s - loss: 0.0058 - mse: 0.0058 - val_loss: 0.0182 - val_mse: 0.0182 - 17ms/epoch - 17ms/step\n",
      "Epoch 298/300\n",
      "1/1 - 0s - loss: 0.0057 - mse: 0.0057 - val_loss: 0.0181 - val_mse: 0.0181 - 16ms/epoch - 16ms/step\n",
      "Epoch 299/300\n",
      "1/1 - 0s - loss: 0.0056 - mse: 0.0056 - val_loss: 0.0179 - val_mse: 0.0179 - 16ms/epoch - 16ms/step\n",
      "Epoch 300/300\n",
      "1/1 - 0s - loss: 0.0056 - mse: 0.0056 - val_loss: 0.0178 - val_mse: 0.0178 - 15ms/epoch - 15ms/step\n",
      "6.276947498321533\n"
     ]
    }
   ],
   "source": [
    "t0 = time.time()\n",
    "history = final_model_PQ.fit(X_train, y_train, epochs=300, batch_size=256, validation_split=0.25, verbose=2)\n",
    "t1 = time.time()\n",
    "print(t1-t0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "388b3084",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0087 - mse: 0.0087\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0108 - mse: 0.0108\n"
     ]
    }
   ],
   "source": [
    "#performance of the pre-trained model on train data\n",
    "loss_and_metrics = final_model_PQ.evaluate(X_train, y_train, batch_size=256)\n",
    "loss_and_metrics = final_model_PQ.evaluate(X_test, y_test, batch_size=256)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f9ed7589",
   "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
}
