{
 "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": "d8e4402d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(10,)\n",
      "shape of x_deviation is (1000, 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, 10, endpoint=True)\n",
    "#the initial states are in real value\n",
    "T1_initial = np.linspace(-10, 10, 10, endpoint=True) + T1_s\n",
    "CA1_initial = np.linspace(-0.2, 0.2, 10, endpoint=True) + CA1_s\n",
    "CB1_initial = np.linspace(-0.2, 0.2, 10, 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 (10000, 1, 4)\n",
      "RNN_input shape is (10000, 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": "cdf611b1",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "RNN_output shape is (10000, 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": [
      "(500, 5, 4) (9500, 5, 4) (500, 5, 3) (9500, 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.95, 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": 9,
   "id": "25925acb",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/500\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-07-17 11:39:52.703308: E tensorflow/stream_executor/cuda/cuda_driver.cc:271] failed call to cuInit: CUDA_ERROR_NO_DEVICE: no CUDA-capable device is detected\n",
      "2025-07-17 11:39:52.703361: I tensorflow/stream_executor/cuda/cuda_diagnostics.cc:156] kernel driver does not appear to be running on this host (wulab2-System-Product-Name): /proc/driver/nvidia/version does not exist\n",
      "2025-07-17 11:39:52.704527: I tensorflow/core/platform/cpu_feature_guard.cc:151] This TensorFlow binary is optimized with oneAPI Deep Neural Network Library (oneDNN) to use the following CPU instructions in performance-critical operations:  AVX2 AVX512F FMA\n",
      "To enable them in other operations, rebuild TensorFlow with the appropriate compiler flags.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2/2 - 0s - loss: 1.2779 - mse: 1.2779 - val_loss: 1.2826 - val_mse: 1.2826 - 499ms/epoch - 250ms/step\n",
      "Epoch 2/500\n",
      "2/2 - 0s - loss: 1.2253 - mse: 1.2253 - val_loss: 1.2326 - val_mse: 1.2326 - 15ms/epoch - 8ms/step\n",
      "Epoch 3/500\n",
      "2/2 - 0s - loss: 1.1757 - mse: 1.1757 - val_loss: 1.1843 - val_mse: 1.1843 - 15ms/epoch - 8ms/step\n",
      "Epoch 4/500\n",
      "2/2 - 0s - loss: 1.1260 - mse: 1.1260 - val_loss: 1.1376 - val_mse: 1.1376 - 22ms/epoch - 11ms/step\n",
      "Epoch 5/500\n",
      "2/2 - 0s - loss: 1.0799 - mse: 1.0799 - val_loss: 1.0923 - val_mse: 1.0923 - 18ms/epoch - 9ms/step\n",
      "Epoch 6/500\n",
      "2/2 - 0s - loss: 1.0345 - mse: 1.0345 - val_loss: 1.0486 - val_mse: 1.0486 - 17ms/epoch - 8ms/step\n",
      "Epoch 7/500\n",
      "2/2 - 0s - loss: 0.9905 - mse: 0.9905 - val_loss: 1.0064 - val_mse: 1.0064 - 18ms/epoch - 9ms/step\n",
      "Epoch 8/500\n",
      "2/2 - 0s - loss: 0.9486 - mse: 0.9486 - val_loss: 0.9657 - val_mse: 0.9657 - 20ms/epoch - 10ms/step\n",
      "Epoch 9/500\n",
      "2/2 - 0s - loss: 0.9087 - mse: 0.9087 - val_loss: 0.9265 - val_mse: 0.9265 - 18ms/epoch - 9ms/step\n",
      "Epoch 10/500\n",
      "2/2 - 0s - loss: 0.8701 - mse: 0.8701 - val_loss: 0.8889 - val_mse: 0.8889 - 15ms/epoch - 7ms/step\n",
      "Epoch 11/500\n",
      "2/2 - 0s - loss: 0.8328 - mse: 0.8328 - val_loss: 0.8528 - val_mse: 0.8528 - 19ms/epoch - 9ms/step\n",
      "Epoch 12/500\n",
      "2/2 - 0s - loss: 0.7978 - mse: 0.7978 - val_loss: 0.8182 - val_mse: 0.8182 - 18ms/epoch - 9ms/step\n",
      "Epoch 13/500\n",
      "2/2 - 0s - loss: 0.7637 - mse: 0.7637 - val_loss: 0.7851 - val_mse: 0.7851 - 17ms/epoch - 8ms/step\n",
      "Epoch 14/500\n",
      "2/2 - 0s - loss: 0.7310 - mse: 0.7310 - val_loss: 0.7534 - val_mse: 0.7534 - 19ms/epoch - 9ms/step\n",
      "Epoch 15/500\n",
      "2/2 - 0s - loss: 0.7005 - mse: 0.7005 - val_loss: 0.7229 - val_mse: 0.7229 - 19ms/epoch - 9ms/step\n",
      "Epoch 16/500\n",
      "2/2 - 0s - loss: 0.6712 - mse: 0.6712 - val_loss: 0.6938 - val_mse: 0.6938 - 17ms/epoch - 8ms/step\n",
      "Epoch 17/500\n",
      "2/2 - 0s - loss: 0.6429 - mse: 0.6429 - val_loss: 0.6660 - val_mse: 0.6660 - 15ms/epoch - 7ms/step\n",
      "Epoch 18/500\n",
      "2/2 - 0s - loss: 0.6164 - mse: 0.6164 - val_loss: 0.6395 - val_mse: 0.6395 - 17ms/epoch - 9ms/step\n",
      "Epoch 19/500\n",
      "2/2 - 0s - loss: 0.5914 - mse: 0.5914 - val_loss: 0.6143 - val_mse: 0.6143 - 18ms/epoch - 9ms/step\n",
      "Epoch 20/500\n",
      "2/2 - 0s - loss: 0.5674 - mse: 0.5674 - val_loss: 0.5903 - val_mse: 0.5903 - 17ms/epoch - 9ms/step\n",
      "Epoch 21/500\n",
      "2/2 - 0s - loss: 0.5442 - mse: 0.5442 - val_loss: 0.5676 - val_mse: 0.5676 - 18ms/epoch - 9ms/step\n",
      "Epoch 22/500\n",
      "2/2 - 0s - loss: 0.5222 - mse: 0.5222 - val_loss: 0.5459 - val_mse: 0.5459 - 20ms/epoch - 10ms/step\n",
      "Epoch 23/500\n",
      "2/2 - 0s - loss: 0.5021 - mse: 0.5021 - val_loss: 0.5252 - val_mse: 0.5252 - 17ms/epoch - 9ms/step\n",
      "Epoch 24/500\n",
      "2/2 - 0s - loss: 0.4825 - mse: 0.4825 - val_loss: 0.5054 - val_mse: 0.5054 - 16ms/epoch - 8ms/step\n",
      "Epoch 25/500\n",
      "2/2 - 0s - loss: 0.4639 - mse: 0.4639 - val_loss: 0.4867 - val_mse: 0.4867 - 18ms/epoch - 9ms/step\n",
      "Epoch 26/500\n",
      "2/2 - 0s - loss: 0.4465 - mse: 0.4465 - val_loss: 0.4688 - val_mse: 0.4688 - 18ms/epoch - 9ms/step\n",
      "Epoch 27/500\n",
      "2/2 - 0s - loss: 0.4299 - mse: 0.4299 - val_loss: 0.4518 - val_mse: 0.4518 - 17ms/epoch - 9ms/step\n",
      "Epoch 28/500\n",
      "2/2 - 0s - loss: 0.4137 - mse: 0.4137 - val_loss: 0.4356 - val_mse: 0.4356 - 18ms/epoch - 9ms/step\n",
      "Epoch 29/500\n",
      "2/2 - 0s - loss: 0.3986 - mse: 0.3986 - val_loss: 0.4202 - val_mse: 0.4202 - 20ms/epoch - 10ms/step\n",
      "Epoch 30/500\n",
      "2/2 - 0s - loss: 0.3842 - mse: 0.3842 - val_loss: 0.4054 - val_mse: 0.4054 - 16ms/epoch - 8ms/step\n",
      "Epoch 31/500\n",
      "2/2 - 0s - loss: 0.3705 - mse: 0.3705 - val_loss: 0.3912 - val_mse: 0.3912 - 15ms/epoch - 7ms/step\n",
      "Epoch 32/500\n",
      "2/2 - 0s - loss: 0.3572 - mse: 0.3572 - val_loss: 0.3777 - val_mse: 0.3777 - 18ms/epoch - 9ms/step\n",
      "Epoch 33/500\n",
      "2/2 - 0s - loss: 0.3449 - mse: 0.3449 - val_loss: 0.3647 - val_mse: 0.3647 - 18ms/epoch - 9ms/step\n",
      "Epoch 34/500\n",
      "2/2 - 0s - loss: 0.3328 - mse: 0.3328 - val_loss: 0.3523 - val_mse: 0.3523 - 17ms/epoch - 8ms/step\n",
      "Epoch 35/500\n",
      "2/2 - 0s - loss: 0.3212 - mse: 0.3212 - val_loss: 0.3403 - val_mse: 0.3403 - 16ms/epoch - 8ms/step\n",
      "Epoch 36/500\n",
      "2/2 - 0s - loss: 0.3104 - mse: 0.3104 - val_loss: 0.3289 - val_mse: 0.3289 - 17ms/epoch - 8ms/step\n",
      "Epoch 37/500\n",
      "2/2 - 0s - loss: 0.2999 - mse: 0.2999 - val_loss: 0.3179 - val_mse: 0.3179 - 18ms/epoch - 9ms/step\n",
      "Epoch 38/500\n",
      "2/2 - 0s - loss: 0.2897 - mse: 0.2897 - val_loss: 0.3074 - val_mse: 0.3074 - 22ms/epoch - 11ms/step\n",
      "Epoch 39/500\n",
      "2/2 - 0s - loss: 0.2801 - mse: 0.2801 - val_loss: 0.2973 - val_mse: 0.2973 - 16ms/epoch - 8ms/step\n",
      "Epoch 40/500\n",
      "2/2 - 0s - loss: 0.2707 - mse: 0.2707 - val_loss: 0.2877 - val_mse: 0.2877 - 15ms/epoch - 7ms/step\n",
      "Epoch 41/500\n",
      "2/2 - 0s - loss: 0.2620 - mse: 0.2620 - val_loss: 0.2784 - val_mse: 0.2784 - 19ms/epoch - 9ms/step\n",
      "Epoch 42/500\n",
      "2/2 - 0s - loss: 0.2533 - mse: 0.2533 - val_loss: 0.2695 - val_mse: 0.2695 - 17ms/epoch - 8ms/step\n",
      "Epoch 43/500\n",
      "2/2 - 0s - loss: 0.2453 - mse: 0.2453 - val_loss: 0.2609 - val_mse: 0.2609 - 17ms/epoch - 8ms/step\n",
      "Epoch 44/500\n",
      "2/2 - 0s - loss: 0.2373 - mse: 0.2373 - val_loss: 0.2527 - val_mse: 0.2527 - 16ms/epoch - 8ms/step\n",
      "Epoch 45/500\n",
      "2/2 - 0s - loss: 0.2299 - mse: 0.2299 - val_loss: 0.2449 - val_mse: 0.2449 - 18ms/epoch - 9ms/step\n",
      "Epoch 46/500\n",
      "2/2 - 0s - loss: 0.2228 - mse: 0.2228 - val_loss: 0.2374 - val_mse: 0.2374 - 20ms/epoch - 10ms/step\n",
      "Epoch 47/500\n",
      "2/2 - 0s - loss: 0.2158 - mse: 0.2158 - val_loss: 0.2302 - val_mse: 0.2302 - 23ms/epoch - 11ms/step\n",
      "Epoch 48/500\n",
      "2/2 - 0s - loss: 0.2092 - mse: 0.2092 - val_loss: 0.2233 - val_mse: 0.2233 - 18ms/epoch - 9ms/step\n",
      "Epoch 49/500\n",
      "2/2 - 0s - loss: 0.2030 - mse: 0.2030 - val_loss: 0.2168 - val_mse: 0.2168 - 17ms/epoch - 8ms/step\n",
      "Epoch 50/500\n",
      "2/2 - 0s - loss: 0.1970 - mse: 0.1970 - val_loss: 0.2105 - val_mse: 0.2105 - 18ms/epoch - 9ms/step\n",
      "Epoch 51/500\n",
      "2/2 - 0s - loss: 0.1913 - mse: 0.1913 - val_loss: 0.2046 - val_mse: 0.2046 - 17ms/epoch - 8ms/step\n",
      "Epoch 52/500\n",
      "2/2 - 0s - loss: 0.1859 - mse: 0.1859 - val_loss: 0.1989 - val_mse: 0.1989 - 18ms/epoch - 9ms/step\n",
      "Epoch 53/500\n",
      "2/2 - 0s - loss: 0.1806 - mse: 0.1806 - val_loss: 0.1935 - val_mse: 0.1935 - 18ms/epoch - 9ms/step\n",
      "Epoch 54/500\n",
      "2/2 - 0s - loss: 0.1758 - mse: 0.1758 - val_loss: 0.1884 - val_mse: 0.1884 - 15ms/epoch - 7ms/step\n",
      "Epoch 55/500\n",
      "2/2 - 0s - loss: 0.1712 - mse: 0.1712 - val_loss: 0.1835 - val_mse: 0.1835 - 15ms/epoch - 7ms/step\n",
      "Epoch 56/500\n",
      "2/2 - 0s - loss: 0.1667 - mse: 0.1667 - val_loss: 0.1789 - val_mse: 0.1789 - 15ms/epoch - 8ms/step\n",
      "Epoch 57/500\n",
      "2/2 - 0s - loss: 0.1625 - mse: 0.1625 - val_loss: 0.1745 - val_mse: 0.1745 - 20ms/epoch - 10ms/step\n",
      "Epoch 58/500\n",
      "2/2 - 0s - loss: 0.1585 - mse: 0.1585 - val_loss: 0.1704 - val_mse: 0.1704 - 16ms/epoch - 8ms/step\n",
      "Epoch 59/500\n",
      "2/2 - 0s - loss: 0.1547 - mse: 0.1547 - val_loss: 0.1665 - val_mse: 0.1665 - 16ms/epoch - 8ms/step\n",
      "Epoch 60/500\n",
      "2/2 - 0s - loss: 0.1512 - mse: 0.1512 - val_loss: 0.1627 - val_mse: 0.1627 - 15ms/epoch - 7ms/step\n",
      "Epoch 61/500\n",
      "2/2 - 0s - loss: 0.1477 - mse: 0.1477 - val_loss: 0.1592 - val_mse: 0.1592 - 15ms/epoch - 8ms/step\n",
      "Epoch 62/500\n",
      "2/2 - 0s - loss: 0.1445 - mse: 0.1445 - val_loss: 0.1558 - val_mse: 0.1558 - 15ms/epoch - 8ms/step\n",
      "Epoch 63/500\n",
      "2/2 - 0s - loss: 0.1415 - mse: 0.1415 - val_loss: 0.1526 - val_mse: 0.1526 - 15ms/epoch - 8ms/step\n",
      "Epoch 64/500\n",
      "2/2 - 0s - loss: 0.1385 - mse: 0.1385 - val_loss: 0.1495 - val_mse: 0.1495 - 15ms/epoch - 8ms/step\n",
      "Epoch 65/500\n",
      "2/2 - 0s - loss: 0.1358 - mse: 0.1358 - val_loss: 0.1466 - val_mse: 0.1466 - 28ms/epoch - 14ms/step\n",
      "Epoch 66/500\n",
      "2/2 - 0s - loss: 0.1331 - mse: 0.1331 - val_loss: 0.1438 - val_mse: 0.1438 - 15ms/epoch - 7ms/step\n",
      "Epoch 67/500\n",
      "2/2 - 0s - loss: 0.1306 - mse: 0.1306 - val_loss: 0.1411 - val_mse: 0.1411 - 14ms/epoch - 7ms/step\n",
      "Epoch 68/500\n",
      "2/2 - 0s - loss: 0.1281 - mse: 0.1281 - val_loss: 0.1386 - val_mse: 0.1386 - 18ms/epoch - 9ms/step\n",
      "Epoch 69/500\n",
      "2/2 - 0s - loss: 0.1258 - mse: 0.1258 - val_loss: 0.1361 - val_mse: 0.1361 - 17ms/epoch - 9ms/step\n",
      "Epoch 70/500\n",
      "2/2 - 0s - loss: 0.1236 - mse: 0.1236 - val_loss: 0.1337 - val_mse: 0.1337 - 16ms/epoch - 8ms/step\n",
      "Epoch 71/500\n",
      "2/2 - 0s - loss: 0.1215 - mse: 0.1215 - val_loss: 0.1315 - val_mse: 0.1315 - 16ms/epoch - 8ms/step\n",
      "Epoch 72/500\n",
      "2/2 - 0s - loss: 0.1194 - mse: 0.1194 - val_loss: 0.1293 - val_mse: 0.1293 - 15ms/epoch - 8ms/step\n",
      "Epoch 73/500\n",
      "2/2 - 0s - loss: 0.1174 - mse: 0.1174 - val_loss: 0.1272 - val_mse: 0.1272 - 16ms/epoch - 8ms/step\n",
      "Epoch 74/500\n",
      "2/2 - 0s - loss: 0.1156 - mse: 0.1156 - val_loss: 0.1251 - val_mse: 0.1251 - 16ms/epoch - 8ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 75/500\n",
      "2/2 - 0s - loss: 0.1137 - mse: 0.1137 - val_loss: 0.1231 - val_mse: 0.1231 - 16ms/epoch - 8ms/step\n",
      "Epoch 76/500\n",
      "2/2 - 0s - loss: 0.1119 - mse: 0.1119 - val_loss: 0.1212 - val_mse: 0.1212 - 16ms/epoch - 8ms/step\n",
      "Epoch 77/500\n",
      "2/2 - 0s - loss: 0.1102 - mse: 0.1102 - val_loss: 0.1194 - val_mse: 0.1194 - 17ms/epoch - 8ms/step\n",
      "Epoch 78/500\n",
      "2/2 - 0s - loss: 0.1085 - mse: 0.1085 - val_loss: 0.1176 - val_mse: 0.1176 - 17ms/epoch - 8ms/step\n",
      "Epoch 79/500\n",
      "2/2 - 0s - loss: 0.1068 - mse: 0.1068 - val_loss: 0.1158 - val_mse: 0.1158 - 18ms/epoch - 9ms/step\n",
      "Epoch 80/500\n",
      "2/2 - 0s - loss: 0.1052 - mse: 0.1052 - val_loss: 0.1141 - val_mse: 0.1141 - 16ms/epoch - 8ms/step\n",
      "Epoch 81/500\n",
      "2/2 - 0s - loss: 0.1037 - mse: 0.1037 - val_loss: 0.1124 - val_mse: 0.1124 - 18ms/epoch - 9ms/step\n",
      "Epoch 82/500\n",
      "2/2 - 0s - loss: 0.1021 - mse: 0.1021 - val_loss: 0.1108 - val_mse: 0.1108 - 15ms/epoch - 7ms/step\n",
      "Epoch 83/500\n",
      "2/2 - 0s - loss: 0.1007 - mse: 0.1007 - val_loss: 0.1092 - val_mse: 0.1092 - 21ms/epoch - 11ms/step\n",
      "Epoch 84/500\n",
      "2/2 - 0s - loss: 0.0992 - mse: 0.0992 - val_loss: 0.1076 - val_mse: 0.1076 - 18ms/epoch - 9ms/step\n",
      "Epoch 85/500\n",
      "2/2 - 0s - loss: 0.0978 - mse: 0.0978 - val_loss: 0.1061 - val_mse: 0.1061 - 17ms/epoch - 8ms/step\n",
      "Epoch 86/500\n",
      "2/2 - 0s - loss: 0.0963 - mse: 0.0963 - val_loss: 0.1046 - val_mse: 0.1046 - 17ms/epoch - 8ms/step\n",
      "Epoch 87/500\n",
      "2/2 - 0s - loss: 0.0950 - mse: 0.0950 - val_loss: 0.1031 - val_mse: 0.1031 - 17ms/epoch - 9ms/step\n",
      "Epoch 88/500\n",
      "2/2 - 0s - loss: 0.0936 - mse: 0.0936 - val_loss: 0.1016 - val_mse: 0.1016 - 18ms/epoch - 9ms/step\n",
      "Epoch 89/500\n",
      "2/2 - 0s - loss: 0.0923 - mse: 0.0923 - val_loss: 0.1002 - val_mse: 0.1002 - 22ms/epoch - 11ms/step\n",
      "Epoch 90/500\n",
      "2/2 - 0s - loss: 0.0910 - mse: 0.0910 - val_loss: 0.0988 - val_mse: 0.0988 - 19ms/epoch - 9ms/step\n",
      "Epoch 91/500\n",
      "2/2 - 0s - loss: 0.0897 - mse: 0.0897 - val_loss: 0.0974 - val_mse: 0.0974 - 17ms/epoch - 8ms/step\n",
      "Epoch 92/500\n",
      "2/2 - 0s - loss: 0.0885 - mse: 0.0885 - val_loss: 0.0961 - val_mse: 0.0961 - 17ms/epoch - 9ms/step\n",
      "Epoch 93/500\n",
      "2/2 - 0s - loss: 0.0873 - mse: 0.0873 - val_loss: 0.0947 - val_mse: 0.0947 - 18ms/epoch - 9ms/step\n",
      "Epoch 94/500\n",
      "2/2 - 0s - loss: 0.0860 - mse: 0.0860 - val_loss: 0.0934 - val_mse: 0.0934 - 18ms/epoch - 9ms/step\n",
      "Epoch 95/500\n",
      "2/2 - 0s - loss: 0.0848 - mse: 0.0848 - val_loss: 0.0921 - val_mse: 0.0921 - 22ms/epoch - 11ms/step\n",
      "Epoch 96/500\n",
      "2/2 - 0s - loss: 0.0837 - mse: 0.0837 - val_loss: 0.0909 - val_mse: 0.0909 - 18ms/epoch - 9ms/step\n",
      "Epoch 97/500\n",
      "2/2 - 0s - loss: 0.0825 - mse: 0.0825 - val_loss: 0.0896 - val_mse: 0.0896 - 17ms/epoch - 8ms/step\n",
      "Epoch 98/500\n",
      "2/2 - 0s - loss: 0.0814 - mse: 0.0814 - val_loss: 0.0884 - val_mse: 0.0884 - 17ms/epoch - 9ms/step\n",
      "Epoch 99/500\n",
      "2/2 - 0s - loss: 0.0802 - mse: 0.0802 - val_loss: 0.0872 - val_mse: 0.0872 - 19ms/epoch - 9ms/step\n",
      "Epoch 100/500\n",
      "2/2 - 0s - loss: 0.0792 - mse: 0.0792 - val_loss: 0.0860 - val_mse: 0.0860 - 25ms/epoch - 12ms/step\n",
      "Epoch 101/500\n",
      "2/2 - 0s - loss: 0.0781 - mse: 0.0781 - val_loss: 0.0849 - val_mse: 0.0849 - 18ms/epoch - 9ms/step\n",
      "Epoch 102/500\n",
      "2/2 - 0s - loss: 0.0770 - mse: 0.0770 - val_loss: 0.0837 - val_mse: 0.0837 - 16ms/epoch - 8ms/step\n",
      "Epoch 103/500\n",
      "2/2 - 0s - loss: 0.0760 - mse: 0.0760 - val_loss: 0.0826 - val_mse: 0.0826 - 16ms/epoch - 8ms/step\n",
      "Epoch 104/500\n",
      "2/2 - 0s - loss: 0.0749 - mse: 0.0749 - val_loss: 0.0815 - val_mse: 0.0815 - 17ms/epoch - 9ms/step\n",
      "Epoch 105/500\n",
      "2/2 - 0s - loss: 0.0739 - mse: 0.0739 - val_loss: 0.0805 - val_mse: 0.0805 - 18ms/epoch - 9ms/step\n",
      "Epoch 106/500\n",
      "2/2 - 0s - loss: 0.0729 - mse: 0.0729 - val_loss: 0.0794 - val_mse: 0.0794 - 21ms/epoch - 11ms/step\n",
      "Epoch 107/500\n",
      "2/2 - 0s - loss: 0.0719 - mse: 0.0719 - val_loss: 0.0783 - val_mse: 0.0783 - 18ms/epoch - 9ms/step\n",
      "Epoch 108/500\n",
      "2/2 - 0s - loss: 0.0710 - mse: 0.0710 - val_loss: 0.0773 - val_mse: 0.0773 - 17ms/epoch - 9ms/step\n",
      "Epoch 109/500\n",
      "2/2 - 0s - loss: 0.0701 - mse: 0.0701 - val_loss: 0.0763 - val_mse: 0.0763 - 17ms/epoch - 8ms/step\n",
      "Epoch 110/500\n",
      "2/2 - 0s - loss: 0.0691 - mse: 0.0691 - val_loss: 0.0753 - val_mse: 0.0753 - 17ms/epoch - 8ms/step\n",
      "Epoch 111/500\n",
      "2/2 - 0s - loss: 0.0682 - mse: 0.0682 - val_loss: 0.0743 - val_mse: 0.0743 - 17ms/epoch - 8ms/step\n",
      "Epoch 112/500\n",
      "2/2 - 0s - loss: 0.0673 - mse: 0.0673 - val_loss: 0.0733 - val_mse: 0.0733 - 19ms/epoch - 9ms/step\n",
      "Epoch 113/500\n",
      "2/2 - 0s - loss: 0.0664 - mse: 0.0664 - val_loss: 0.0724 - val_mse: 0.0724 - 26ms/epoch - 13ms/step\n",
      "Epoch 114/500\n",
      "2/2 - 0s - loss: 0.0655 - mse: 0.0655 - val_loss: 0.0714 - val_mse: 0.0714 - 14ms/epoch - 7ms/step\n",
      "Epoch 115/500\n",
      "2/2 - 0s - loss: 0.0646 - mse: 0.0646 - val_loss: 0.0705 - val_mse: 0.0705 - 13ms/epoch - 7ms/step\n",
      "Epoch 116/500\n",
      "2/2 - 0s - loss: 0.0638 - mse: 0.0638 - val_loss: 0.0696 - val_mse: 0.0696 - 13ms/epoch - 7ms/step\n",
      "Epoch 117/500\n",
      "2/2 - 0s - loss: 0.0629 - mse: 0.0629 - val_loss: 0.0687 - val_mse: 0.0687 - 12ms/epoch - 6ms/step\n",
      "Epoch 118/500\n",
      "2/2 - 0s - loss: 0.0621 - mse: 0.0621 - val_loss: 0.0678 - val_mse: 0.0678 - 12ms/epoch - 6ms/step\n",
      "Epoch 119/500\n",
      "2/2 - 0s - loss: 0.0613 - mse: 0.0613 - val_loss: 0.0669 - val_mse: 0.0669 - 12ms/epoch - 6ms/step\n",
      "Epoch 120/500\n",
      "2/2 - 0s - loss: 0.0605 - mse: 0.0605 - val_loss: 0.0661 - val_mse: 0.0661 - 12ms/epoch - 6ms/step\n",
      "Epoch 121/500\n",
      "2/2 - 0s - loss: 0.0597 - mse: 0.0597 - val_loss: 0.0652 - val_mse: 0.0652 - 12ms/epoch - 6ms/step\n",
      "Epoch 122/500\n",
      "2/2 - 0s - loss: 0.0589 - mse: 0.0589 - val_loss: 0.0644 - val_mse: 0.0644 - 12ms/epoch - 6ms/step\n",
      "Epoch 123/500\n",
      "2/2 - 0s - loss: 0.0582 - mse: 0.0582 - val_loss: 0.0635 - val_mse: 0.0635 - 11ms/epoch - 6ms/step\n",
      "Epoch 124/500\n",
      "2/2 - 0s - loss: 0.0574 - mse: 0.0574 - val_loss: 0.0627 - val_mse: 0.0627 - 11ms/epoch - 6ms/step\n",
      "Epoch 125/500\n",
      "2/2 - 0s - loss: 0.0567 - mse: 0.0567 - val_loss: 0.0619 - val_mse: 0.0619 - 11ms/epoch - 6ms/step\n",
      "Epoch 126/500\n",
      "2/2 - 0s - loss: 0.0559 - mse: 0.0559 - val_loss: 0.0611 - val_mse: 0.0611 - 11ms/epoch - 6ms/step\n",
      "Epoch 127/500\n",
      "2/2 - 0s - loss: 0.0552 - mse: 0.0552 - val_loss: 0.0603 - val_mse: 0.0603 - 11ms/epoch - 6ms/step\n",
      "Epoch 128/500\n",
      "2/2 - 0s - loss: 0.0545 - mse: 0.0545 - val_loss: 0.0595 - val_mse: 0.0595 - 12ms/epoch - 6ms/step\n",
      "Epoch 129/500\n",
      "2/2 - 0s - loss: 0.0538 - mse: 0.0538 - val_loss: 0.0588 - val_mse: 0.0588 - 11ms/epoch - 6ms/step\n",
      "Epoch 130/500\n",
      "2/2 - 0s - loss: 0.0531 - mse: 0.0531 - val_loss: 0.0580 - val_mse: 0.0580 - 12ms/epoch - 6ms/step\n",
      "Epoch 131/500\n",
      "2/2 - 0s - loss: 0.0525 - mse: 0.0525 - val_loss: 0.0573 - val_mse: 0.0573 - 12ms/epoch - 6ms/step\n",
      "Epoch 132/500\n",
      "2/2 - 0s - loss: 0.0518 - mse: 0.0518 - val_loss: 0.0566 - val_mse: 0.0566 - 11ms/epoch - 6ms/step\n",
      "Epoch 133/500\n",
      "2/2 - 0s - loss: 0.0512 - mse: 0.0512 - val_loss: 0.0559 - val_mse: 0.0559 - 12ms/epoch - 6ms/step\n",
      "Epoch 134/500\n",
      "2/2 - 0s - loss: 0.0505 - mse: 0.0505 - val_loss: 0.0552 - val_mse: 0.0552 - 12ms/epoch - 6ms/step\n",
      "Epoch 135/500\n",
      "2/2 - 0s - loss: 0.0499 - mse: 0.0499 - val_loss: 0.0545 - val_mse: 0.0545 - 12ms/epoch - 6ms/step\n",
      "Epoch 136/500\n",
      "2/2 - 0s - loss: 0.0493 - mse: 0.0493 - val_loss: 0.0539 - val_mse: 0.0539 - 12ms/epoch - 6ms/step\n",
      "Epoch 137/500\n",
      "2/2 - 0s - loss: 0.0487 - mse: 0.0487 - val_loss: 0.0532 - val_mse: 0.0532 - 13ms/epoch - 6ms/step\n",
      "Epoch 138/500\n",
      "2/2 - 0s - loss: 0.0481 - mse: 0.0481 - val_loss: 0.0526 - val_mse: 0.0526 - 14ms/epoch - 7ms/step\n",
      "Epoch 139/500\n",
      "2/2 - 0s - loss: 0.0475 - mse: 0.0475 - val_loss: 0.0520 - val_mse: 0.0520 - 12ms/epoch - 6ms/step\n",
      "Epoch 140/500\n",
      "2/2 - 0s - loss: 0.0469 - mse: 0.0469 - val_loss: 0.0513 - val_mse: 0.0513 - 11ms/epoch - 6ms/step\n",
      "Epoch 141/500\n",
      "2/2 - 0s - loss: 0.0464 - mse: 0.0464 - val_loss: 0.0507 - val_mse: 0.0507 - 12ms/epoch - 6ms/step\n",
      "Epoch 142/500\n",
      "2/2 - 0s - loss: 0.0458 - mse: 0.0458 - val_loss: 0.0501 - val_mse: 0.0501 - 11ms/epoch - 6ms/step\n",
      "Epoch 143/500\n",
      "2/2 - 0s - loss: 0.0453 - mse: 0.0453 - val_loss: 0.0495 - val_mse: 0.0495 - 12ms/epoch - 6ms/step\n",
      "Epoch 144/500\n",
      "2/2 - 0s - loss: 0.0447 - mse: 0.0447 - val_loss: 0.0489 - val_mse: 0.0489 - 12ms/epoch - 6ms/step\n",
      "Epoch 145/500\n",
      "2/2 - 0s - loss: 0.0442 - mse: 0.0442 - val_loss: 0.0484 - val_mse: 0.0484 - 12ms/epoch - 6ms/step\n",
      "Epoch 146/500\n",
      "2/2 - 0s - loss: 0.0437 - mse: 0.0437 - val_loss: 0.0478 - val_mse: 0.0478 - 11ms/epoch - 6ms/step\n",
      "Epoch 147/500\n",
      "2/2 - 0s - loss: 0.0432 - mse: 0.0432 - val_loss: 0.0472 - val_mse: 0.0472 - 11ms/epoch - 6ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 148/500\n",
      "2/2 - 0s - loss: 0.0426 - mse: 0.0426 - val_loss: 0.0467 - val_mse: 0.0467 - 12ms/epoch - 6ms/step\n",
      "Epoch 149/500\n",
      "2/2 - 0s - loss: 0.0421 - mse: 0.0421 - val_loss: 0.0461 - val_mse: 0.0461 - 12ms/epoch - 6ms/step\n",
      "Epoch 150/500\n",
      "2/2 - 0s - loss: 0.0416 - mse: 0.0416 - val_loss: 0.0456 - val_mse: 0.0456 - 11ms/epoch - 6ms/step\n",
      "Epoch 151/500\n",
      "2/2 - 0s - loss: 0.0412 - mse: 0.0412 - val_loss: 0.0451 - val_mse: 0.0451 - 12ms/epoch - 6ms/step\n",
      "Epoch 152/500\n",
      "2/2 - 0s - loss: 0.0407 - mse: 0.0407 - val_loss: 0.0446 - val_mse: 0.0446 - 12ms/epoch - 6ms/step\n",
      "Epoch 153/500\n",
      "2/2 - 0s - loss: 0.0402 - mse: 0.0402 - val_loss: 0.0441 - val_mse: 0.0441 - 12ms/epoch - 6ms/step\n",
      "Epoch 154/500\n",
      "2/2 - 0s - loss: 0.0397 - mse: 0.0397 - val_loss: 0.0436 - val_mse: 0.0436 - 11ms/epoch - 6ms/step\n",
      "Epoch 155/500\n",
      "2/2 - 0s - loss: 0.0393 - mse: 0.0393 - val_loss: 0.0431 - val_mse: 0.0431 - 11ms/epoch - 6ms/step\n",
      "Epoch 156/500\n",
      "2/2 - 0s - loss: 0.0388 - mse: 0.0388 - val_loss: 0.0426 - val_mse: 0.0426 - 11ms/epoch - 6ms/step\n",
      "Epoch 157/500\n",
      "2/2 - 0s - loss: 0.0384 - mse: 0.0384 - val_loss: 0.0421 - val_mse: 0.0421 - 12ms/epoch - 6ms/step\n",
      "Epoch 158/500\n",
      "2/2 - 0s - loss: 0.0380 - mse: 0.0380 - val_loss: 0.0416 - val_mse: 0.0416 - 12ms/epoch - 6ms/step\n",
      "Epoch 159/500\n",
      "2/2 - 0s - loss: 0.0375 - mse: 0.0375 - val_loss: 0.0412 - val_mse: 0.0412 - 12ms/epoch - 6ms/step\n",
      "Epoch 160/500\n",
      "2/2 - 0s - loss: 0.0371 - mse: 0.0371 - val_loss: 0.0407 - val_mse: 0.0407 - 12ms/epoch - 6ms/step\n",
      "Epoch 161/500\n",
      "2/2 - 0s - loss: 0.0367 - mse: 0.0367 - val_loss: 0.0403 - val_mse: 0.0403 - 11ms/epoch - 6ms/step\n",
      "Epoch 162/500\n",
      "2/2 - 0s - loss: 0.0363 - mse: 0.0363 - val_loss: 0.0398 - val_mse: 0.0398 - 12ms/epoch - 6ms/step\n",
      "Epoch 163/500\n",
      "2/2 - 0s - loss: 0.0359 - mse: 0.0359 - val_loss: 0.0394 - val_mse: 0.0394 - 11ms/epoch - 6ms/step\n",
      "Epoch 164/500\n",
      "2/2 - 0s - loss: 0.0355 - mse: 0.0355 - val_loss: 0.0389 - val_mse: 0.0389 - 12ms/epoch - 6ms/step\n",
      "Epoch 165/500\n",
      "2/2 - 0s - loss: 0.0351 - mse: 0.0351 - val_loss: 0.0385 - val_mse: 0.0385 - 11ms/epoch - 6ms/step\n",
      "Epoch 166/500\n",
      "2/2 - 0s - loss: 0.0347 - mse: 0.0347 - val_loss: 0.0381 - val_mse: 0.0381 - 11ms/epoch - 6ms/step\n",
      "Epoch 167/500\n",
      "2/2 - 0s - loss: 0.0344 - mse: 0.0344 - val_loss: 0.0377 - val_mse: 0.0377 - 11ms/epoch - 6ms/step\n",
      "Epoch 168/500\n",
      "2/2 - 0s - loss: 0.0340 - mse: 0.0340 - val_loss: 0.0373 - val_mse: 0.0373 - 12ms/epoch - 6ms/step\n",
      "Epoch 169/500\n",
      "2/2 - 0s - loss: 0.0336 - mse: 0.0336 - val_loss: 0.0369 - val_mse: 0.0369 - 11ms/epoch - 6ms/step\n",
      "Epoch 170/500\n",
      "2/2 - 0s - loss: 0.0333 - mse: 0.0333 - val_loss: 0.0365 - val_mse: 0.0365 - 11ms/epoch - 6ms/step\n",
      "Epoch 171/500\n",
      "2/2 - 0s - loss: 0.0329 - mse: 0.0329 - val_loss: 0.0361 - val_mse: 0.0361 - 11ms/epoch - 6ms/step\n",
      "Epoch 172/500\n",
      "2/2 - 0s - loss: 0.0326 - mse: 0.0326 - val_loss: 0.0358 - val_mse: 0.0358 - 12ms/epoch - 6ms/step\n",
      "Epoch 173/500\n",
      "2/2 - 0s - loss: 0.0322 - mse: 0.0322 - val_loss: 0.0354 - val_mse: 0.0354 - 12ms/epoch - 6ms/step\n",
      "Epoch 174/500\n",
      "2/2 - 0s - loss: 0.0319 - mse: 0.0319 - val_loss: 0.0350 - val_mse: 0.0350 - 12ms/epoch - 6ms/step\n",
      "Epoch 175/500\n",
      "2/2 - 0s - loss: 0.0316 - mse: 0.0316 - val_loss: 0.0347 - val_mse: 0.0347 - 12ms/epoch - 6ms/step\n",
      "Epoch 176/500\n",
      "2/2 - 0s - loss: 0.0312 - mse: 0.0312 - val_loss: 0.0343 - val_mse: 0.0343 - 11ms/epoch - 6ms/step\n",
      "Epoch 177/500\n",
      "2/2 - 0s - loss: 0.0309 - mse: 0.0309 - val_loss: 0.0339 - val_mse: 0.0339 - 11ms/epoch - 6ms/step\n",
      "Epoch 178/500\n",
      "2/2 - 0s - loss: 0.0306 - mse: 0.0306 - val_loss: 0.0336 - val_mse: 0.0336 - 12ms/epoch - 6ms/step\n",
      "Epoch 179/500\n",
      "2/2 - 0s - loss: 0.0303 - mse: 0.0303 - val_loss: 0.0332 - val_mse: 0.0332 - 12ms/epoch - 6ms/step\n",
      "Epoch 180/500\n",
      "2/2 - 0s - loss: 0.0300 - mse: 0.0300 - val_loss: 0.0329 - val_mse: 0.0329 - 11ms/epoch - 6ms/step\n",
      "Epoch 181/500\n",
      "2/2 - 0s - loss: 0.0297 - mse: 0.0297 - val_loss: 0.0325 - val_mse: 0.0325 - 12ms/epoch - 6ms/step\n",
      "Epoch 182/500\n",
      "2/2 - 0s - loss: 0.0294 - mse: 0.0294 - val_loss: 0.0322 - val_mse: 0.0322 - 12ms/epoch - 6ms/step\n",
      "Epoch 183/500\n",
      "2/2 - 0s - loss: 0.0291 - mse: 0.0291 - val_loss: 0.0319 - val_mse: 0.0319 - 12ms/epoch - 6ms/step\n",
      "Epoch 184/500\n",
      "2/2 - 0s - loss: 0.0288 - mse: 0.0288 - val_loss: 0.0316 - val_mse: 0.0316 - 12ms/epoch - 6ms/step\n",
      "Epoch 185/500\n",
      "2/2 - 0s - loss: 0.0285 - mse: 0.0285 - val_loss: 0.0313 - val_mse: 0.0313 - 12ms/epoch - 6ms/step\n",
      "Epoch 186/500\n",
      "2/2 - 0s - loss: 0.0282 - mse: 0.0282 - val_loss: 0.0310 - val_mse: 0.0310 - 12ms/epoch - 6ms/step\n",
      "Epoch 187/500\n",
      "2/2 - 0s - loss: 0.0280 - mse: 0.0280 - val_loss: 0.0307 - val_mse: 0.0307 - 11ms/epoch - 6ms/step\n",
      "Epoch 188/500\n",
      "2/2 - 0s - loss: 0.0277 - mse: 0.0277 - val_loss: 0.0304 - val_mse: 0.0304 - 12ms/epoch - 6ms/step\n",
      "Epoch 189/500\n",
      "2/2 - 0s - loss: 0.0274 - mse: 0.0274 - val_loss: 0.0301 - val_mse: 0.0301 - 12ms/epoch - 6ms/step\n",
      "Epoch 190/500\n",
      "2/2 - 0s - loss: 0.0271 - mse: 0.0271 - val_loss: 0.0298 - val_mse: 0.0298 - 12ms/epoch - 6ms/step\n",
      "Epoch 191/500\n",
      "2/2 - 0s - loss: 0.0269 - mse: 0.0269 - val_loss: 0.0295 - val_mse: 0.0295 - 12ms/epoch - 6ms/step\n",
      "Epoch 192/500\n",
      "2/2 - 0s - loss: 0.0266 - mse: 0.0266 - val_loss: 0.0292 - val_mse: 0.0292 - 12ms/epoch - 6ms/step\n",
      "Epoch 193/500\n",
      "2/2 - 0s - loss: 0.0264 - mse: 0.0264 - val_loss: 0.0290 - val_mse: 0.0290 - 12ms/epoch - 6ms/step\n",
      "Epoch 194/500\n",
      "2/2 - 0s - loss: 0.0261 - mse: 0.0261 - val_loss: 0.0287 - val_mse: 0.0287 - 12ms/epoch - 6ms/step\n",
      "Epoch 195/500\n",
      "2/2 - 0s - loss: 0.0259 - mse: 0.0259 - val_loss: 0.0284 - val_mse: 0.0284 - 12ms/epoch - 6ms/step\n",
      "Epoch 196/500\n",
      "2/2 - 0s - loss: 0.0256 - mse: 0.0256 - val_loss: 0.0282 - val_mse: 0.0282 - 12ms/epoch - 6ms/step\n",
      "Epoch 197/500\n",
      "2/2 - 0s - loss: 0.0254 - mse: 0.0254 - val_loss: 0.0279 - val_mse: 0.0279 - 13ms/epoch - 6ms/step\n",
      "Epoch 198/500\n",
      "2/2 - 0s - loss: 0.0252 - mse: 0.0252 - val_loss: 0.0276 - val_mse: 0.0276 - 14ms/epoch - 7ms/step\n",
      "Epoch 199/500\n",
      "2/2 - 0s - loss: 0.0249 - mse: 0.0249 - val_loss: 0.0274 - val_mse: 0.0274 - 15ms/epoch - 8ms/step\n",
      "Epoch 200/500\n",
      "2/2 - 0s - loss: 0.0247 - mse: 0.0247 - val_loss: 0.0271 - val_mse: 0.0271 - 16ms/epoch - 8ms/step\n",
      "Epoch 201/500\n",
      "2/2 - 0s - loss: 0.0245 - mse: 0.0245 - val_loss: 0.0269 - val_mse: 0.0269 - 16ms/epoch - 8ms/step\n",
      "Epoch 202/500\n",
      "2/2 - 0s - loss: 0.0242 - mse: 0.0242 - val_loss: 0.0266 - val_mse: 0.0266 - 16ms/epoch - 8ms/step\n",
      "Epoch 203/500\n",
      "2/2 - 0s - loss: 0.0240 - mse: 0.0240 - val_loss: 0.0264 - val_mse: 0.0264 - 16ms/epoch - 8ms/step\n",
      "Epoch 204/500\n",
      "2/2 - 0s - loss: 0.0238 - mse: 0.0238 - val_loss: 0.0262 - val_mse: 0.0262 - 16ms/epoch - 8ms/step\n",
      "Epoch 205/500\n",
      "2/2 - 0s - loss: 0.0236 - mse: 0.0236 - val_loss: 0.0259 - val_mse: 0.0259 - 16ms/epoch - 8ms/step\n",
      "Epoch 206/500\n",
      "2/2 - 0s - loss: 0.0234 - mse: 0.0234 - val_loss: 0.0257 - val_mse: 0.0257 - 15ms/epoch - 8ms/step\n",
      "Epoch 207/500\n",
      "2/2 - 0s - loss: 0.0232 - mse: 0.0232 - val_loss: 0.0255 - val_mse: 0.0255 - 16ms/epoch - 8ms/step\n",
      "Epoch 208/500\n",
      "2/2 - 0s - loss: 0.0229 - mse: 0.0229 - val_loss: 0.0252 - val_mse: 0.0252 - 16ms/epoch - 8ms/step\n",
      "Epoch 209/500\n",
      "2/2 - 0s - loss: 0.0227 - mse: 0.0227 - val_loss: 0.0250 - val_mse: 0.0250 - 16ms/epoch - 8ms/step\n",
      "Epoch 210/500\n",
      "2/2 - 0s - loss: 0.0225 - mse: 0.0225 - val_loss: 0.0248 - val_mse: 0.0248 - 16ms/epoch - 8ms/step\n",
      "Epoch 211/500\n",
      "2/2 - 0s - loss: 0.0223 - mse: 0.0223 - val_loss: 0.0246 - val_mse: 0.0246 - 16ms/epoch - 8ms/step\n",
      "Epoch 212/500\n",
      "2/2 - 0s - loss: 0.0221 - mse: 0.0221 - val_loss: 0.0243 - val_mse: 0.0243 - 15ms/epoch - 8ms/step\n",
      "Epoch 213/500\n",
      "2/2 - 0s - loss: 0.0219 - mse: 0.0219 - val_loss: 0.0241 - val_mse: 0.0241 - 16ms/epoch - 8ms/step\n",
      "Epoch 214/500\n",
      "2/2 - 0s - loss: 0.0218 - mse: 0.0218 - val_loss: 0.0239 - val_mse: 0.0239 - 16ms/epoch - 8ms/step\n",
      "Epoch 215/500\n",
      "2/2 - 0s - loss: 0.0216 - mse: 0.0216 - val_loss: 0.0237 - val_mse: 0.0237 - 16ms/epoch - 8ms/step\n",
      "Epoch 216/500\n",
      "2/2 - 0s - loss: 0.0214 - mse: 0.0214 - val_loss: 0.0235 - val_mse: 0.0235 - 16ms/epoch - 8ms/step\n",
      "Epoch 217/500\n",
      "2/2 - 0s - loss: 0.0212 - mse: 0.0212 - val_loss: 0.0233 - val_mse: 0.0233 - 16ms/epoch - 8ms/step\n",
      "Epoch 218/500\n",
      "2/2 - 0s - loss: 0.0210 - mse: 0.0210 - val_loss: 0.0231 - val_mse: 0.0231 - 16ms/epoch - 8ms/step\n",
      "Epoch 219/500\n",
      "2/2 - 0s - loss: 0.0208 - mse: 0.0208 - val_loss: 0.0229 - val_mse: 0.0229 - 15ms/epoch - 7ms/step\n",
      "Epoch 220/500\n",
      "2/2 - 0s - loss: 0.0207 - mse: 0.0207 - val_loss: 0.0227 - val_mse: 0.0227 - 15ms/epoch - 7ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 221/500\n",
      "2/2 - 0s - loss: 0.0205 - mse: 0.0205 - val_loss: 0.0225 - val_mse: 0.0225 - 12ms/epoch - 6ms/step\n",
      "Epoch 222/500\n",
      "2/2 - 0s - loss: 0.0203 - mse: 0.0203 - val_loss: 0.0224 - val_mse: 0.0224 - 12ms/epoch - 6ms/step\n",
      "Epoch 223/500\n",
      "2/2 - 0s - loss: 0.0201 - mse: 0.0201 - val_loss: 0.0222 - val_mse: 0.0222 - 13ms/epoch - 6ms/step\n",
      "Epoch 224/500\n",
      "2/2 - 0s - loss: 0.0200 - mse: 0.0200 - val_loss: 0.0220 - val_mse: 0.0220 - 12ms/epoch - 6ms/step\n",
      "Epoch 225/500\n",
      "2/2 - 0s - loss: 0.0198 - mse: 0.0198 - val_loss: 0.0218 - val_mse: 0.0218 - 12ms/epoch - 6ms/step\n",
      "Epoch 226/500\n",
      "2/2 - 0s - loss: 0.0196 - mse: 0.0196 - val_loss: 0.0216 - val_mse: 0.0216 - 12ms/epoch - 6ms/step\n",
      "Epoch 227/500\n",
      "2/2 - 0s - loss: 0.0195 - mse: 0.0195 - val_loss: 0.0214 - val_mse: 0.0214 - 13ms/epoch - 6ms/step\n",
      "Epoch 228/500\n",
      "2/2 - 0s - loss: 0.0193 - mse: 0.0193 - val_loss: 0.0213 - val_mse: 0.0213 - 23ms/epoch - 11ms/step\n",
      "Epoch 229/500\n",
      "2/2 - 0s - loss: 0.0192 - mse: 0.0192 - val_loss: 0.0211 - val_mse: 0.0211 - 17ms/epoch - 8ms/step\n",
      "Epoch 230/500\n",
      "2/2 - 0s - loss: 0.0190 - mse: 0.0190 - val_loss: 0.0209 - val_mse: 0.0209 - 13ms/epoch - 7ms/step\n",
      "Epoch 231/500\n",
      "2/2 - 0s - loss: 0.0188 - mse: 0.0188 - val_loss: 0.0207 - val_mse: 0.0207 - 12ms/epoch - 6ms/step\n",
      "Epoch 232/500\n",
      "2/2 - 0s - loss: 0.0187 - mse: 0.0187 - val_loss: 0.0206 - val_mse: 0.0206 - 12ms/epoch - 6ms/step\n",
      "Epoch 233/500\n",
      "2/2 - 0s - loss: 0.0185 - mse: 0.0185 - val_loss: 0.0204 - val_mse: 0.0204 - 11ms/epoch - 6ms/step\n",
      "Epoch 234/500\n",
      "2/2 - 0s - loss: 0.0184 - mse: 0.0184 - val_loss: 0.0202 - val_mse: 0.0202 - 12ms/epoch - 6ms/step\n",
      "Epoch 235/500\n",
      "2/2 - 0s - loss: 0.0182 - mse: 0.0182 - val_loss: 0.0201 - val_mse: 0.0201 - 12ms/epoch - 6ms/step\n",
      "Epoch 236/500\n",
      "2/2 - 0s - loss: 0.0181 - mse: 0.0181 - val_loss: 0.0199 - val_mse: 0.0199 - 12ms/epoch - 6ms/step\n",
      "Epoch 237/500\n",
      "2/2 - 0s - loss: 0.0179 - mse: 0.0179 - val_loss: 0.0197 - val_mse: 0.0197 - 12ms/epoch - 6ms/step\n",
      "Epoch 238/500\n",
      "2/2 - 0s - loss: 0.0178 - mse: 0.0178 - val_loss: 0.0196 - val_mse: 0.0196 - 12ms/epoch - 6ms/step\n",
      "Epoch 239/500\n",
      "2/2 - 0s - loss: 0.0177 - mse: 0.0177 - val_loss: 0.0194 - val_mse: 0.0194 - 12ms/epoch - 6ms/step\n",
      "Epoch 240/500\n",
      "2/2 - 0s - loss: 0.0175 - mse: 0.0175 - val_loss: 0.0193 - val_mse: 0.0193 - 12ms/epoch - 6ms/step\n",
      "Epoch 241/500\n",
      "2/2 - 0s - loss: 0.0174 - mse: 0.0174 - val_loss: 0.0191 - val_mse: 0.0191 - 12ms/epoch - 6ms/step\n",
      "Epoch 242/500\n",
      "2/2 - 0s - loss: 0.0173 - mse: 0.0173 - val_loss: 0.0190 - val_mse: 0.0190 - 12ms/epoch - 6ms/step\n",
      "Epoch 243/500\n",
      "2/2 - 0s - loss: 0.0171 - mse: 0.0171 - val_loss: 0.0188 - val_mse: 0.0188 - 12ms/epoch - 6ms/step\n",
      "Epoch 244/500\n",
      "2/2 - 0s - loss: 0.0170 - mse: 0.0170 - val_loss: 0.0187 - val_mse: 0.0187 - 12ms/epoch - 6ms/step\n",
      "Epoch 245/500\n",
      "2/2 - 0s - loss: 0.0169 - mse: 0.0169 - val_loss: 0.0185 - val_mse: 0.0185 - 12ms/epoch - 6ms/step\n",
      "Epoch 246/500\n",
      "2/2 - 0s - loss: 0.0167 - mse: 0.0167 - val_loss: 0.0184 - val_mse: 0.0184 - 12ms/epoch - 6ms/step\n",
      "Epoch 247/500\n",
      "2/2 - 0s - loss: 0.0166 - mse: 0.0166 - val_loss: 0.0183 - val_mse: 0.0183 - 14ms/epoch - 7ms/step\n",
      "Epoch 248/500\n",
      "2/2 - 0s - loss: 0.0165 - mse: 0.0165 - val_loss: 0.0181 - val_mse: 0.0181 - 13ms/epoch - 6ms/step\n",
      "Epoch 249/500\n",
      "2/2 - 0s - loss: 0.0163 - mse: 0.0163 - val_loss: 0.0180 - val_mse: 0.0180 - 18ms/epoch - 9ms/step\n",
      "Epoch 250/500\n",
      "2/2 - 0s - loss: 0.0162 - mse: 0.0162 - val_loss: 0.0179 - val_mse: 0.0179 - 19ms/epoch - 10ms/step\n",
      "Epoch 251/500\n",
      "2/2 - 0s - loss: 0.0161 - mse: 0.0161 - val_loss: 0.0177 - val_mse: 0.0177 - 16ms/epoch - 8ms/step\n",
      "Epoch 252/500\n",
      "2/2 - 0s - loss: 0.0160 - mse: 0.0160 - val_loss: 0.0176 - val_mse: 0.0176 - 16ms/epoch - 8ms/step\n",
      "Epoch 253/500\n",
      "2/2 - 0s - loss: 0.0159 - mse: 0.0159 - val_loss: 0.0175 - val_mse: 0.0175 - 16ms/epoch - 8ms/step\n",
      "Epoch 254/500\n",
      "2/2 - 0s - loss: 0.0157 - mse: 0.0157 - val_loss: 0.0174 - val_mse: 0.0174 - 14ms/epoch - 7ms/step\n",
      "Epoch 255/500\n",
      "2/2 - 0s - loss: 0.0156 - mse: 0.0156 - val_loss: 0.0172 - val_mse: 0.0172 - 15ms/epoch - 8ms/step\n",
      "Epoch 256/500\n",
      "2/2 - 0s - loss: 0.0155 - mse: 0.0155 - val_loss: 0.0171 - val_mse: 0.0171 - 15ms/epoch - 8ms/step\n",
      "Epoch 257/500\n",
      "2/2 - 0s - loss: 0.0154 - mse: 0.0154 - val_loss: 0.0170 - val_mse: 0.0170 - 17ms/epoch - 9ms/step\n",
      "Epoch 258/500\n",
      "2/2 - 0s - loss: 0.0153 - mse: 0.0153 - val_loss: 0.0169 - val_mse: 0.0169 - 16ms/epoch - 8ms/step\n",
      "Epoch 259/500\n",
      "2/2 - 0s - loss: 0.0152 - mse: 0.0152 - val_loss: 0.0167 - val_mse: 0.0167 - 16ms/epoch - 8ms/step\n",
      "Epoch 260/500\n",
      "2/2 - 0s - loss: 0.0151 - mse: 0.0151 - val_loss: 0.0166 - val_mse: 0.0166 - 16ms/epoch - 8ms/step\n",
      "Epoch 261/500\n",
      "2/2 - 0s - loss: 0.0150 - mse: 0.0150 - val_loss: 0.0165 - val_mse: 0.0165 - 16ms/epoch - 8ms/step\n",
      "Epoch 262/500\n",
      "2/2 - 0s - loss: 0.0149 - mse: 0.0149 - val_loss: 0.0164 - val_mse: 0.0164 - 14ms/epoch - 7ms/step\n",
      "Epoch 263/500\n",
      "2/2 - 0s - loss: 0.0148 - mse: 0.0148 - val_loss: 0.0163 - val_mse: 0.0163 - 13ms/epoch - 7ms/step\n",
      "Epoch 264/500\n",
      "2/2 - 0s - loss: 0.0146 - mse: 0.0146 - val_loss: 0.0161 - val_mse: 0.0161 - 12ms/epoch - 6ms/step\n",
      "Epoch 265/500\n",
      "2/2 - 0s - loss: 0.0145 - mse: 0.0145 - val_loss: 0.0160 - val_mse: 0.0160 - 12ms/epoch - 6ms/step\n",
      "Epoch 266/500\n",
      "2/2 - 0s - loss: 0.0144 - mse: 0.0144 - val_loss: 0.0159 - val_mse: 0.0159 - 12ms/epoch - 6ms/step\n",
      "Epoch 267/500\n",
      "2/2 - 0s - loss: 0.0143 - mse: 0.0143 - val_loss: 0.0158 - val_mse: 0.0158 - 12ms/epoch - 6ms/step\n",
      "Epoch 268/500\n",
      "2/2 - 0s - loss: 0.0142 - mse: 0.0142 - val_loss: 0.0157 - val_mse: 0.0157 - 12ms/epoch - 6ms/step\n",
      "Epoch 269/500\n",
      "2/2 - 0s - loss: 0.0141 - mse: 0.0141 - val_loss: 0.0156 - val_mse: 0.0156 - 12ms/epoch - 6ms/step\n",
      "Epoch 270/500\n",
      "2/2 - 0s - loss: 0.0141 - mse: 0.0141 - val_loss: 0.0155 - val_mse: 0.0155 - 12ms/epoch - 6ms/step\n",
      "Epoch 271/500\n",
      "2/2 - 0s - loss: 0.0140 - mse: 0.0140 - val_loss: 0.0154 - val_mse: 0.0154 - 13ms/epoch - 7ms/step\n",
      "Epoch 272/500\n",
      "2/2 - 0s - loss: 0.0139 - mse: 0.0139 - val_loss: 0.0153 - val_mse: 0.0153 - 15ms/epoch - 7ms/step\n",
      "Epoch 273/500\n",
      "2/2 - 0s - loss: 0.0138 - mse: 0.0138 - val_loss: 0.0152 - val_mse: 0.0152 - 16ms/epoch - 8ms/step\n",
      "Epoch 274/500\n",
      "2/2 - 0s - loss: 0.0137 - mse: 0.0137 - val_loss: 0.0151 - val_mse: 0.0151 - 14ms/epoch - 7ms/step\n",
      "Epoch 275/500\n",
      "2/2 - 0s - loss: 0.0136 - mse: 0.0136 - val_loss: 0.0150 - val_mse: 0.0150 - 13ms/epoch - 6ms/step\n",
      "Epoch 276/500\n",
      "2/2 - 0s - loss: 0.0135 - mse: 0.0135 - val_loss: 0.0149 - val_mse: 0.0149 - 12ms/epoch - 6ms/step\n",
      "Epoch 277/500\n",
      "2/2 - 0s - loss: 0.0134 - mse: 0.0134 - val_loss: 0.0148 - val_mse: 0.0148 - 12ms/epoch - 6ms/step\n",
      "Epoch 278/500\n",
      "2/2 - 0s - loss: 0.0133 - mse: 0.0133 - val_loss: 0.0147 - val_mse: 0.0147 - 12ms/epoch - 6ms/step\n",
      "Epoch 279/500\n",
      "2/2 - 0s - loss: 0.0132 - mse: 0.0132 - val_loss: 0.0146 - val_mse: 0.0146 - 13ms/epoch - 6ms/step\n",
      "Epoch 280/500\n",
      "2/2 - 0s - loss: 0.0132 - mse: 0.0132 - val_loss: 0.0145 - val_mse: 0.0145 - 12ms/epoch - 6ms/step\n",
      "Epoch 281/500\n",
      "2/2 - 0s - loss: 0.0131 - mse: 0.0131 - val_loss: 0.0144 - val_mse: 0.0144 - 12ms/epoch - 6ms/step\n",
      "Epoch 282/500\n",
      "2/2 - 0s - loss: 0.0130 - mse: 0.0130 - val_loss: 0.0143 - val_mse: 0.0143 - 12ms/epoch - 6ms/step\n",
      "Epoch 283/500\n",
      "2/2 - 0s - loss: 0.0129 - mse: 0.0129 - val_loss: 0.0142 - val_mse: 0.0142 - 12ms/epoch - 6ms/step\n",
      "Epoch 284/500\n",
      "2/2 - 0s - loss: 0.0128 - mse: 0.0128 - val_loss: 0.0142 - val_mse: 0.0142 - 12ms/epoch - 6ms/step\n",
      "Epoch 285/500\n",
      "2/2 - 0s - loss: 0.0127 - mse: 0.0127 - val_loss: 0.0141 - val_mse: 0.0141 - 12ms/epoch - 6ms/step\n",
      "Epoch 286/500\n",
      "2/2 - 0s - loss: 0.0127 - mse: 0.0127 - val_loss: 0.0140 - val_mse: 0.0140 - 14ms/epoch - 7ms/step\n",
      "Epoch 287/500\n",
      "2/2 - 0s - loss: 0.0126 - mse: 0.0126 - val_loss: 0.0139 - val_mse: 0.0139 - 15ms/epoch - 7ms/step\n",
      "Epoch 288/500\n",
      "2/2 - 0s - loss: 0.0125 - mse: 0.0125 - val_loss: 0.0138 - val_mse: 0.0138 - 16ms/epoch - 8ms/step\n",
      "Epoch 289/500\n",
      "2/2 - 0s - loss: 0.0124 - mse: 0.0124 - val_loss: 0.0137 - val_mse: 0.0137 - 17ms/epoch - 8ms/step\n",
      "Epoch 290/500\n",
      "2/2 - 0s - loss: 0.0123 - mse: 0.0123 - val_loss: 0.0136 - val_mse: 0.0136 - 18ms/epoch - 9ms/step\n",
      "Epoch 291/500\n",
      "2/2 - 0s - loss: 0.0123 - mse: 0.0123 - val_loss: 0.0136 - val_mse: 0.0136 - 21ms/epoch - 10ms/step\n",
      "Epoch 292/500\n",
      "2/2 - 0s - loss: 0.0122 - mse: 0.0122 - val_loss: 0.0135 - val_mse: 0.0135 - 18ms/epoch - 9ms/step\n",
      "Epoch 293/500\n",
      "2/2 - 0s - loss: 0.0121 - mse: 0.0121 - val_loss: 0.0134 - val_mse: 0.0134 - 16ms/epoch - 8ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 294/500\n",
      "2/2 - 0s - loss: 0.0121 - mse: 0.0121 - val_loss: 0.0133 - val_mse: 0.0133 - 16ms/epoch - 8ms/step\n",
      "Epoch 295/500\n",
      "2/2 - 0s - loss: 0.0120 - mse: 0.0120 - val_loss: 0.0132 - val_mse: 0.0132 - 16ms/epoch - 8ms/step\n",
      "Epoch 296/500\n",
      "2/2 - 0s - loss: 0.0119 - mse: 0.0119 - val_loss: 0.0132 - val_mse: 0.0132 - 16ms/epoch - 8ms/step\n",
      "Epoch 297/500\n",
      "2/2 - 0s - loss: 0.0118 - mse: 0.0118 - val_loss: 0.0131 - val_mse: 0.0131 - 15ms/epoch - 8ms/step\n",
      "Epoch 298/500\n",
      "2/2 - 0s - loss: 0.0118 - mse: 0.0118 - val_loss: 0.0130 - val_mse: 0.0130 - 13ms/epoch - 6ms/step\n",
      "Epoch 299/500\n",
      "2/2 - 0s - loss: 0.0117 - mse: 0.0117 - val_loss: 0.0129 - val_mse: 0.0129 - 12ms/epoch - 6ms/step\n",
      "Epoch 300/500\n",
      "2/2 - 0s - loss: 0.0116 - mse: 0.0116 - val_loss: 0.0129 - val_mse: 0.0129 - 12ms/epoch - 6ms/step\n",
      "Epoch 301/500\n",
      "2/2 - 0s - loss: 0.0116 - mse: 0.0116 - val_loss: 0.0128 - val_mse: 0.0128 - 11ms/epoch - 6ms/step\n",
      "Epoch 302/500\n",
      "2/2 - 0s - loss: 0.0115 - mse: 0.0115 - val_loss: 0.0127 - val_mse: 0.0127 - 12ms/epoch - 6ms/step\n",
      "Epoch 303/500\n",
      "2/2 - 0s - loss: 0.0114 - mse: 0.0114 - val_loss: 0.0126 - val_mse: 0.0126 - 12ms/epoch - 6ms/step\n",
      "Epoch 304/500\n",
      "2/2 - 0s - loss: 0.0114 - mse: 0.0114 - val_loss: 0.0126 - val_mse: 0.0126 - 12ms/epoch - 6ms/step\n",
      "Epoch 305/500\n",
      "2/2 - 0s - loss: 0.0113 - mse: 0.0113 - val_loss: 0.0125 - val_mse: 0.0125 - 12ms/epoch - 6ms/step\n",
      "Epoch 306/500\n",
      "2/2 - 0s - loss: 0.0112 - mse: 0.0112 - val_loss: 0.0124 - val_mse: 0.0124 - 12ms/epoch - 6ms/step\n",
      "Epoch 307/500\n",
      "2/2 - 0s - loss: 0.0112 - mse: 0.0112 - val_loss: 0.0123 - val_mse: 0.0123 - 12ms/epoch - 6ms/step\n",
      "Epoch 308/500\n",
      "2/2 - 0s - loss: 0.0111 - mse: 0.0111 - val_loss: 0.0123 - val_mse: 0.0123 - 12ms/epoch - 6ms/step\n",
      "Epoch 309/500\n",
      "2/2 - 0s - loss: 0.0111 - mse: 0.0111 - val_loss: 0.0122 - val_mse: 0.0122 - 11ms/epoch - 6ms/step\n",
      "Epoch 310/500\n",
      "2/2 - 0s - loss: 0.0110 - mse: 0.0110 - val_loss: 0.0121 - val_mse: 0.0121 - 12ms/epoch - 6ms/step\n",
      "Epoch 311/500\n",
      "2/2 - 0s - loss: 0.0109 - mse: 0.0109 - val_loss: 0.0121 - val_mse: 0.0121 - 11ms/epoch - 6ms/step\n",
      "Epoch 312/500\n",
      "2/2 - 0s - loss: 0.0109 - mse: 0.0109 - val_loss: 0.0120 - val_mse: 0.0120 - 11ms/epoch - 6ms/step\n",
      "Epoch 313/500\n",
      "2/2 - 0s - loss: 0.0108 - mse: 0.0108 - val_loss: 0.0119 - val_mse: 0.0119 - 11ms/epoch - 6ms/step\n",
      "Epoch 314/500\n",
      "2/2 - 0s - loss: 0.0108 - mse: 0.0108 - val_loss: 0.0119 - val_mse: 0.0119 - 12ms/epoch - 6ms/step\n",
      "Epoch 315/500\n",
      "2/2 - 0s - loss: 0.0107 - mse: 0.0107 - val_loss: 0.0118 - val_mse: 0.0118 - 12ms/epoch - 6ms/step\n",
      "Epoch 316/500\n",
      "2/2 - 0s - loss: 0.0106 - mse: 0.0106 - val_loss: 0.0118 - val_mse: 0.0118 - 12ms/epoch - 6ms/step\n",
      "Epoch 317/500\n",
      "2/2 - 0s - loss: 0.0106 - mse: 0.0106 - val_loss: 0.0117 - val_mse: 0.0117 - 12ms/epoch - 6ms/step\n",
      "Epoch 318/500\n",
      "2/2 - 0s - loss: 0.0105 - mse: 0.0105 - val_loss: 0.0116 - val_mse: 0.0116 - 12ms/epoch - 6ms/step\n",
      "Epoch 319/500\n",
      "2/2 - 0s - loss: 0.0105 - mse: 0.0105 - val_loss: 0.0116 - val_mse: 0.0116 - 12ms/epoch - 6ms/step\n",
      "Epoch 320/500\n",
      "2/2 - 0s - loss: 0.0104 - mse: 0.0104 - val_loss: 0.0115 - val_mse: 0.0115 - 13ms/epoch - 6ms/step\n",
      "Epoch 321/500\n",
      "2/2 - 0s - loss: 0.0104 - mse: 0.0104 - val_loss: 0.0115 - val_mse: 0.0115 - 15ms/epoch - 8ms/step\n",
      "Epoch 322/500\n",
      "2/2 - 0s - loss: 0.0103 - mse: 0.0103 - val_loss: 0.0114 - val_mse: 0.0114 - 12ms/epoch - 6ms/step\n",
      "Epoch 323/500\n",
      "2/2 - 0s - loss: 0.0103 - mse: 0.0103 - val_loss: 0.0114 - val_mse: 0.0114 - 12ms/epoch - 6ms/step\n",
      "Epoch 324/500\n",
      "2/2 - 0s - loss: 0.0102 - mse: 0.0102 - val_loss: 0.0113 - val_mse: 0.0113 - 12ms/epoch - 6ms/step\n",
      "Epoch 325/500\n",
      "2/2 - 0s - loss: 0.0102 - mse: 0.0102 - val_loss: 0.0112 - val_mse: 0.0112 - 12ms/epoch - 6ms/step\n",
      "Epoch 326/500\n",
      "2/2 - 0s - loss: 0.0101 - mse: 0.0101 - val_loss: 0.0112 - val_mse: 0.0112 - 12ms/epoch - 6ms/step\n",
      "Epoch 327/500\n",
      "2/2 - 0s - loss: 0.0101 - mse: 0.0101 - val_loss: 0.0111 - val_mse: 0.0111 - 12ms/epoch - 6ms/step\n",
      "Epoch 328/500\n",
      "2/2 - 0s - loss: 0.0100 - mse: 0.0100 - val_loss: 0.0111 - val_mse: 0.0111 - 12ms/epoch - 6ms/step\n",
      "Epoch 329/500\n",
      "2/2 - 0s - loss: 0.0100 - mse: 0.0100 - val_loss: 0.0110 - val_mse: 0.0110 - 12ms/epoch - 6ms/step\n",
      "Epoch 330/500\n",
      "2/2 - 0s - loss: 0.0099 - mse: 0.0099 - val_loss: 0.0110 - val_mse: 0.0110 - 12ms/epoch - 6ms/step\n",
      "Epoch 331/500\n",
      "2/2 - 0s - loss: 0.0099 - mse: 0.0099 - val_loss: 0.0109 - val_mse: 0.0109 - 12ms/epoch - 6ms/step\n",
      "Epoch 332/500\n",
      "2/2 - 0s - loss: 0.0098 - mse: 0.0098 - val_loss: 0.0108 - val_mse: 0.0108 - 12ms/epoch - 6ms/step\n",
      "Epoch 333/500\n",
      "2/2 - 0s - loss: 0.0098 - mse: 0.0098 - val_loss: 0.0108 - val_mse: 0.0108 - 12ms/epoch - 6ms/step\n",
      "Epoch 334/500\n",
      "2/2 - 0s - loss: 0.0097 - mse: 0.0097 - val_loss: 0.0108 - val_mse: 0.0108 - 12ms/epoch - 6ms/step\n",
      "Epoch 335/500\n",
      "2/2 - 0s - loss: 0.0097 - mse: 0.0097 - val_loss: 0.0107 - val_mse: 0.0107 - 12ms/epoch - 6ms/step\n",
      "Epoch 336/500\n",
      "2/2 - 0s - loss: 0.0096 - mse: 0.0096 - val_loss: 0.0107 - val_mse: 0.0107 - 12ms/epoch - 6ms/step\n",
      "Epoch 337/500\n",
      "2/2 - 0s - loss: 0.0096 - mse: 0.0096 - val_loss: 0.0106 - val_mse: 0.0106 - 12ms/epoch - 6ms/step\n",
      "Epoch 338/500\n",
      "2/2 - 0s - loss: 0.0095 - mse: 0.0095 - val_loss: 0.0106 - val_mse: 0.0106 - 12ms/epoch - 6ms/step\n",
      "Epoch 339/500\n",
      "2/2 - 0s - loss: 0.0095 - mse: 0.0095 - val_loss: 0.0105 - val_mse: 0.0105 - 12ms/epoch - 6ms/step\n",
      "Epoch 340/500\n",
      "2/2 - 0s - loss: 0.0094 - mse: 0.0094 - val_loss: 0.0105 - val_mse: 0.0105 - 12ms/epoch - 6ms/step\n",
      "Epoch 341/500\n",
      "2/2 - 0s - loss: 0.0094 - mse: 0.0094 - val_loss: 0.0104 - val_mse: 0.0104 - 12ms/epoch - 6ms/step\n",
      "Epoch 342/500\n",
      "2/2 - 0s - loss: 0.0094 - mse: 0.0094 - val_loss: 0.0104 - val_mse: 0.0104 - 12ms/epoch - 6ms/step\n",
      "Epoch 343/500\n",
      "2/2 - 0s - loss: 0.0093 - mse: 0.0093 - val_loss: 0.0103 - val_mse: 0.0103 - 12ms/epoch - 6ms/step\n",
      "Epoch 344/500\n",
      "2/2 - 0s - loss: 0.0093 - mse: 0.0093 - val_loss: 0.0103 - val_mse: 0.0103 - 12ms/epoch - 6ms/step\n",
      "Epoch 345/500\n",
      "2/2 - 0s - loss: 0.0092 - mse: 0.0092 - val_loss: 0.0102 - val_mse: 0.0102 - 12ms/epoch - 6ms/step\n",
      "Epoch 346/500\n",
      "2/2 - 0s - loss: 0.0092 - mse: 0.0092 - val_loss: 0.0102 - val_mse: 0.0102 - 12ms/epoch - 6ms/step\n",
      "Epoch 347/500\n",
      "2/2 - 0s - loss: 0.0092 - mse: 0.0092 - val_loss: 0.0102 - val_mse: 0.0102 - 12ms/epoch - 6ms/step\n",
      "Epoch 348/500\n",
      "2/2 - 0s - loss: 0.0091 - mse: 0.0091 - val_loss: 0.0101 - val_mse: 0.0101 - 12ms/epoch - 6ms/step\n",
      "Epoch 349/500\n",
      "2/2 - 0s - loss: 0.0091 - mse: 0.0091 - val_loss: 0.0101 - val_mse: 0.0101 - 12ms/epoch - 6ms/step\n",
      "Epoch 350/500\n",
      "2/2 - 0s - loss: 0.0090 - mse: 0.0090 - val_loss: 0.0100 - val_mse: 0.0100 - 12ms/epoch - 6ms/step\n",
      "Epoch 351/500\n",
      "2/2 - 0s - loss: 0.0090 - mse: 0.0090 - val_loss: 0.0100 - val_mse: 0.0100 - 13ms/epoch - 6ms/step\n",
      "Epoch 352/500\n",
      "2/2 - 0s - loss: 0.0090 - mse: 0.0090 - val_loss: 0.0099 - val_mse: 0.0099 - 14ms/epoch - 7ms/step\n",
      "Epoch 353/500\n",
      "2/2 - 0s - loss: 0.0089 - mse: 0.0089 - val_loss: 0.0099 - val_mse: 0.0099 - 14ms/epoch - 7ms/step\n",
      "Epoch 354/500\n",
      "2/2 - 0s - loss: 0.0089 - mse: 0.0089 - val_loss: 0.0098 - val_mse: 0.0098 - 14ms/epoch - 7ms/step\n",
      "Epoch 355/500\n",
      "2/2 - 0s - loss: 0.0088 - mse: 0.0088 - val_loss: 0.0098 - val_mse: 0.0098 - 14ms/epoch - 7ms/step\n",
      "Epoch 356/500\n",
      "2/2 - 0s - loss: 0.0088 - mse: 0.0088 - val_loss: 0.0098 - val_mse: 0.0098 - 15ms/epoch - 7ms/step\n",
      "Epoch 357/500\n",
      "2/2 - 0s - loss: 0.0088 - mse: 0.0088 - val_loss: 0.0097 - val_mse: 0.0097 - 12ms/epoch - 6ms/step\n",
      "Epoch 358/500\n",
      "2/2 - 0s - loss: 0.0087 - mse: 0.0087 - val_loss: 0.0097 - val_mse: 0.0097 - 12ms/epoch - 6ms/step\n",
      "Epoch 359/500\n",
      "2/2 - 0s - loss: 0.0087 - mse: 0.0087 - val_loss: 0.0096 - val_mse: 0.0096 - 12ms/epoch - 6ms/step\n",
      "Epoch 360/500\n",
      "2/2 - 0s - loss: 0.0087 - mse: 0.0087 - val_loss: 0.0096 - val_mse: 0.0096 - 12ms/epoch - 6ms/step\n",
      "Epoch 361/500\n",
      "2/2 - 0s - loss: 0.0086 - mse: 0.0086 - val_loss: 0.0096 - val_mse: 0.0096 - 12ms/epoch - 6ms/step\n",
      "Epoch 362/500\n",
      "2/2 - 0s - loss: 0.0086 - mse: 0.0086 - val_loss: 0.0095 - val_mse: 0.0095 - 12ms/epoch - 6ms/step\n",
      "Epoch 363/500\n",
      "2/2 - 0s - loss: 0.0086 - mse: 0.0086 - val_loss: 0.0095 - val_mse: 0.0095 - 12ms/epoch - 6ms/step\n",
      "Epoch 364/500\n",
      "2/2 - 0s - loss: 0.0085 - mse: 0.0085 - val_loss: 0.0095 - val_mse: 0.0095 - 12ms/epoch - 6ms/step\n",
      "Epoch 365/500\n",
      "2/2 - 0s - loss: 0.0085 - mse: 0.0085 - val_loss: 0.0094 - val_mse: 0.0094 - 12ms/epoch - 6ms/step\n",
      "Epoch 366/500\n",
      "2/2 - 0s - loss: 0.0085 - mse: 0.0085 - val_loss: 0.0094 - val_mse: 0.0094 - 12ms/epoch - 6ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 367/500\n",
      "2/2 - 0s - loss: 0.0084 - mse: 0.0084 - val_loss: 0.0093 - val_mse: 0.0093 - 12ms/epoch - 6ms/step\n",
      "Epoch 368/500\n",
      "2/2 - 0s - loss: 0.0084 - mse: 0.0084 - val_loss: 0.0093 - val_mse: 0.0093 - 12ms/epoch - 6ms/step\n",
      "Epoch 369/500\n",
      "2/2 - 0s - loss: 0.0084 - mse: 0.0084 - val_loss: 0.0093 - val_mse: 0.0093 - 12ms/epoch - 6ms/step\n",
      "Epoch 370/500\n",
      "2/2 - 0s - loss: 0.0083 - mse: 0.0083 - val_loss: 0.0092 - val_mse: 0.0092 - 12ms/epoch - 6ms/step\n",
      "Epoch 371/500\n",
      "2/2 - 0s - loss: 0.0083 - mse: 0.0083 - val_loss: 0.0092 - val_mse: 0.0092 - 12ms/epoch - 6ms/step\n",
      "Epoch 372/500\n",
      "2/2 - 0s - loss: 0.0083 - mse: 0.0083 - val_loss: 0.0092 - val_mse: 0.0092 - 12ms/epoch - 6ms/step\n",
      "Epoch 373/500\n",
      "2/2 - 0s - loss: 0.0082 - mse: 0.0082 - val_loss: 0.0091 - val_mse: 0.0091 - 12ms/epoch - 6ms/step\n",
      "Epoch 374/500\n",
      "2/2 - 0s - loss: 0.0082 - mse: 0.0082 - val_loss: 0.0091 - val_mse: 0.0091 - 13ms/epoch - 6ms/step\n",
      "Epoch 375/500\n",
      "2/2 - 0s - loss: 0.0082 - mse: 0.0082 - val_loss: 0.0091 - val_mse: 0.0091 - 13ms/epoch - 6ms/step\n",
      "Epoch 376/500\n",
      "2/2 - 0s - loss: 0.0081 - mse: 0.0081 - val_loss: 0.0090 - val_mse: 0.0090 - 15ms/epoch - 7ms/step\n",
      "Epoch 377/500\n",
      "2/2 - 0s - loss: 0.0081 - mse: 0.0081 - val_loss: 0.0090 - val_mse: 0.0090 - 15ms/epoch - 7ms/step\n",
      "Epoch 378/500\n",
      "2/2 - 0s - loss: 0.0081 - mse: 0.0081 - val_loss: 0.0090 - val_mse: 0.0090 - 15ms/epoch - 7ms/step\n",
      "Epoch 379/500\n",
      "2/2 - 0s - loss: 0.0081 - mse: 0.0081 - val_loss: 0.0089 - val_mse: 0.0089 - 14ms/epoch - 7ms/step\n",
      "Epoch 380/500\n",
      "2/2 - 0s - loss: 0.0080 - mse: 0.0080 - val_loss: 0.0089 - val_mse: 0.0089 - 13ms/epoch - 7ms/step\n",
      "Epoch 381/500\n",
      "2/2 - 0s - loss: 0.0080 - mse: 0.0080 - val_loss: 0.0089 - val_mse: 0.0089 - 13ms/epoch - 7ms/step\n",
      "Epoch 382/500\n",
      "2/2 - 0s - loss: 0.0080 - mse: 0.0080 - val_loss: 0.0088 - val_mse: 0.0088 - 14ms/epoch - 7ms/step\n",
      "Epoch 383/500\n",
      "2/2 - 0s - loss: 0.0079 - mse: 0.0079 - val_loss: 0.0088 - val_mse: 0.0088 - 13ms/epoch - 6ms/step\n",
      "Epoch 384/500\n",
      "2/2 - 0s - loss: 0.0079 - mse: 0.0079 - val_loss: 0.0088 - val_mse: 0.0088 - 13ms/epoch - 6ms/step\n",
      "Epoch 385/500\n",
      "2/2 - 0s - loss: 0.0079 - mse: 0.0079 - val_loss: 0.0087 - val_mse: 0.0087 - 15ms/epoch - 7ms/step\n",
      "Epoch 386/500\n",
      "2/2 - 0s - loss: 0.0079 - mse: 0.0079 - val_loss: 0.0087 - val_mse: 0.0087 - 15ms/epoch - 7ms/step\n",
      "Epoch 387/500\n",
      "2/2 - 0s - loss: 0.0078 - mse: 0.0078 - val_loss: 0.0087 - val_mse: 0.0087 - 15ms/epoch - 8ms/step\n",
      "Epoch 388/500\n",
      "2/2 - 0s - loss: 0.0078 - mse: 0.0078 - val_loss: 0.0087 - val_mse: 0.0087 - 15ms/epoch - 7ms/step\n",
      "Epoch 389/500\n",
      "2/2 - 0s - loss: 0.0078 - mse: 0.0078 - val_loss: 0.0086 - val_mse: 0.0086 - 14ms/epoch - 7ms/step\n",
      "Epoch 390/500\n",
      "2/2 - 0s - loss: 0.0078 - mse: 0.0078 - val_loss: 0.0086 - val_mse: 0.0086 - 13ms/epoch - 6ms/step\n",
      "Epoch 391/500\n",
      "2/2 - 0s - loss: 0.0077 - mse: 0.0077 - val_loss: 0.0086 - val_mse: 0.0086 - 12ms/epoch - 6ms/step\n",
      "Epoch 392/500\n",
      "2/2 - 0s - loss: 0.0077 - mse: 0.0077 - val_loss: 0.0085 - val_mse: 0.0085 - 12ms/epoch - 6ms/step\n",
      "Epoch 393/500\n",
      "2/2 - 0s - loss: 0.0077 - mse: 0.0077 - val_loss: 0.0085 - val_mse: 0.0085 - 12ms/epoch - 6ms/step\n",
      "Epoch 394/500\n",
      "2/2 - 0s - loss: 0.0076 - mse: 0.0076 - val_loss: 0.0085 - val_mse: 0.0085 - 12ms/epoch - 6ms/step\n",
      "Epoch 395/500\n",
      "2/2 - 0s - loss: 0.0076 - mse: 0.0076 - val_loss: 0.0085 - val_mse: 0.0085 - 11ms/epoch - 6ms/step\n",
      "Epoch 396/500\n",
      "2/2 - 0s - loss: 0.0076 - mse: 0.0076 - val_loss: 0.0084 - val_mse: 0.0084 - 11ms/epoch - 6ms/step\n",
      "Epoch 397/500\n",
      "2/2 - 0s - loss: 0.0076 - mse: 0.0076 - val_loss: 0.0084 - val_mse: 0.0084 - 12ms/epoch - 6ms/step\n",
      "Epoch 398/500\n",
      "2/2 - 0s - loss: 0.0075 - mse: 0.0075 - val_loss: 0.0084 - val_mse: 0.0084 - 12ms/epoch - 6ms/step\n",
      "Epoch 399/500\n",
      "2/2 - 0s - loss: 0.0075 - mse: 0.0075 - val_loss: 0.0083 - val_mse: 0.0083 - 12ms/epoch - 6ms/step\n",
      "Epoch 400/500\n",
      "2/2 - 0s - loss: 0.0075 - mse: 0.0075 - val_loss: 0.0083 - val_mse: 0.0083 - 12ms/epoch - 6ms/step\n",
      "Epoch 401/500\n",
      "2/2 - 0s - loss: 0.0075 - mse: 0.0075 - val_loss: 0.0083 - val_mse: 0.0083 - 12ms/epoch - 6ms/step\n",
      "Epoch 402/500\n",
      "2/2 - 0s - loss: 0.0075 - mse: 0.0075 - val_loss: 0.0083 - val_mse: 0.0083 - 12ms/epoch - 6ms/step\n",
      "Epoch 403/500\n",
      "2/2 - 0s - loss: 0.0074 - mse: 0.0074 - val_loss: 0.0082 - val_mse: 0.0082 - 12ms/epoch - 6ms/step\n",
      "Epoch 404/500\n",
      "2/2 - 0s - loss: 0.0074 - mse: 0.0074 - val_loss: 0.0082 - val_mse: 0.0082 - 12ms/epoch - 6ms/step\n",
      "Epoch 405/500\n",
      "2/2 - 0s - loss: 0.0074 - mse: 0.0074 - val_loss: 0.0082 - val_mse: 0.0082 - 14ms/epoch - 7ms/step\n",
      "Epoch 406/500\n",
      "2/2 - 0s - loss: 0.0074 - mse: 0.0074 - val_loss: 0.0082 - val_mse: 0.0082 - 12ms/epoch - 6ms/step\n",
      "Epoch 407/500\n",
      "2/2 - 0s - loss: 0.0073 - mse: 0.0073 - val_loss: 0.0081 - val_mse: 0.0081 - 13ms/epoch - 7ms/step\n",
      "Epoch 408/500\n",
      "2/2 - 0s - loss: 0.0073 - mse: 0.0073 - val_loss: 0.0081 - val_mse: 0.0081 - 14ms/epoch - 7ms/step\n",
      "Epoch 409/500\n",
      "2/2 - 0s - loss: 0.0073 - mse: 0.0073 - val_loss: 0.0081 - val_mse: 0.0081 - 12ms/epoch - 6ms/step\n",
      "Epoch 410/500\n",
      "2/2 - 0s - loss: 0.0073 - mse: 0.0073 - val_loss: 0.0081 - val_mse: 0.0081 - 12ms/epoch - 6ms/step\n",
      "Epoch 411/500\n",
      "2/2 - 0s - loss: 0.0072 - mse: 0.0072 - val_loss: 0.0080 - val_mse: 0.0080 - 16ms/epoch - 8ms/step\n",
      "Epoch 412/500\n",
      "2/2 - 0s - loss: 0.0072 - mse: 0.0072 - val_loss: 0.0080 - val_mse: 0.0080 - 16ms/epoch - 8ms/step\n",
      "Epoch 413/500\n",
      "2/2 - 0s - loss: 0.0072 - mse: 0.0072 - val_loss: 0.0080 - val_mse: 0.0080 - 17ms/epoch - 8ms/step\n",
      "Epoch 414/500\n",
      "2/2 - 0s - loss: 0.0072 - mse: 0.0072 - val_loss: 0.0080 - val_mse: 0.0080 - 15ms/epoch - 8ms/step\n",
      "Epoch 415/500\n",
      "2/2 - 0s - loss: 0.0072 - mse: 0.0072 - val_loss: 0.0080 - val_mse: 0.0080 - 15ms/epoch - 7ms/step\n",
      "Epoch 416/500\n",
      "2/2 - 0s - loss: 0.0071 - mse: 0.0071 - val_loss: 0.0079 - val_mse: 0.0079 - 15ms/epoch - 8ms/step\n",
      "Epoch 417/500\n",
      "2/2 - 0s - loss: 0.0071 - mse: 0.0071 - val_loss: 0.0079 - val_mse: 0.0079 - 15ms/epoch - 8ms/step\n",
      "Epoch 418/500\n",
      "2/2 - 0s - loss: 0.0071 - mse: 0.0071 - val_loss: 0.0079 - val_mse: 0.0079 - 15ms/epoch - 8ms/step\n",
      "Epoch 419/500\n",
      "2/2 - 0s - loss: 0.0071 - mse: 0.0071 - val_loss: 0.0079 - val_mse: 0.0079 - 15ms/epoch - 8ms/step\n",
      "Epoch 420/500\n",
      "2/2 - 0s - loss: 0.0071 - mse: 0.0071 - val_loss: 0.0078 - val_mse: 0.0078 - 15ms/epoch - 7ms/step\n",
      "Epoch 421/500\n",
      "2/2 - 0s - loss: 0.0070 - mse: 0.0070 - val_loss: 0.0078 - val_mse: 0.0078 - 12ms/epoch - 6ms/step\n",
      "Epoch 422/500\n",
      "2/2 - 0s - loss: 0.0070 - mse: 0.0070 - val_loss: 0.0078 - val_mse: 0.0078 - 12ms/epoch - 6ms/step\n",
      "Epoch 423/500\n",
      "2/2 - 0s - loss: 0.0070 - mse: 0.0070 - val_loss: 0.0078 - val_mse: 0.0078 - 12ms/epoch - 6ms/step\n",
      "Epoch 424/500\n",
      "2/2 - 0s - loss: 0.0070 - mse: 0.0070 - val_loss: 0.0078 - val_mse: 0.0078 - 12ms/epoch - 6ms/step\n",
      "Epoch 425/500\n",
      "2/2 - 0s - loss: 0.0070 - mse: 0.0070 - val_loss: 0.0077 - val_mse: 0.0077 - 12ms/epoch - 6ms/step\n",
      "Epoch 426/500\n",
      "2/2 - 0s - loss: 0.0069 - mse: 0.0069 - val_loss: 0.0077 - val_mse: 0.0077 - 12ms/epoch - 6ms/step\n",
      "Epoch 427/500\n",
      "2/2 - 0s - loss: 0.0069 - mse: 0.0069 - val_loss: 0.0077 - val_mse: 0.0077 - 12ms/epoch - 6ms/step\n",
      "Epoch 428/500\n",
      "2/2 - 0s - loss: 0.0069 - mse: 0.0069 - val_loss: 0.0077 - val_mse: 0.0077 - 12ms/epoch - 6ms/step\n",
      "Epoch 429/500\n",
      "2/2 - 0s - loss: 0.0069 - mse: 0.0069 - val_loss: 0.0076 - val_mse: 0.0076 - 14ms/epoch - 7ms/step\n",
      "Epoch 430/500\n",
      "2/2 - 0s - loss: 0.0069 - mse: 0.0069 - val_loss: 0.0076 - val_mse: 0.0076 - 14ms/epoch - 7ms/step\n",
      "Epoch 431/500\n",
      "2/2 - 0s - loss: 0.0068 - mse: 0.0068 - val_loss: 0.0076 - val_mse: 0.0076 - 13ms/epoch - 7ms/step\n",
      "Epoch 432/500\n",
      "2/2 - 0s - loss: 0.0068 - mse: 0.0068 - val_loss: 0.0076 - val_mse: 0.0076 - 14ms/epoch - 7ms/step\n",
      "Epoch 433/500\n",
      "2/2 - 0s - loss: 0.0068 - mse: 0.0068 - val_loss: 0.0076 - val_mse: 0.0076 - 15ms/epoch - 7ms/step\n",
      "Epoch 434/500\n",
      "2/2 - 0s - loss: 0.0068 - mse: 0.0068 - val_loss: 0.0075 - val_mse: 0.0075 - 14ms/epoch - 7ms/step\n",
      "Epoch 435/500\n",
      "2/2 - 0s - loss: 0.0068 - mse: 0.0068 - val_loss: 0.0075 - val_mse: 0.0075 - 12ms/epoch - 6ms/step\n",
      "Epoch 436/500\n",
      "2/2 - 0s - loss: 0.0067 - mse: 0.0067 - val_loss: 0.0075 - val_mse: 0.0075 - 13ms/epoch - 7ms/step\n",
      "Epoch 437/500\n",
      "2/2 - 0s - loss: 0.0067 - mse: 0.0067 - val_loss: 0.0075 - val_mse: 0.0075 - 15ms/epoch - 7ms/step\n",
      "Epoch 438/500\n",
      "2/2 - 0s - loss: 0.0067 - mse: 0.0067 - val_loss: 0.0075 - val_mse: 0.0075 - 15ms/epoch - 7ms/step\n",
      "Epoch 439/500\n",
      "2/2 - 0s - loss: 0.0067 - mse: 0.0067 - val_loss: 0.0074 - val_mse: 0.0074 - 15ms/epoch - 8ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 440/500\n",
      "2/2 - 0s - loss: 0.0067 - mse: 0.0067 - val_loss: 0.0074 - val_mse: 0.0074 - 12ms/epoch - 6ms/step\n",
      "Epoch 441/500\n",
      "2/2 - 0s - loss: 0.0067 - mse: 0.0067 - val_loss: 0.0074 - val_mse: 0.0074 - 12ms/epoch - 6ms/step\n",
      "Epoch 442/500\n",
      "2/2 - 0s - loss: 0.0066 - mse: 0.0066 - val_loss: 0.0074 - val_mse: 0.0074 - 12ms/epoch - 6ms/step\n",
      "Epoch 443/500\n",
      "2/2 - 0s - loss: 0.0066 - mse: 0.0066 - val_loss: 0.0074 - val_mse: 0.0074 - 12ms/epoch - 6ms/step\n",
      "Epoch 444/500\n",
      "2/2 - 0s - loss: 0.0066 - mse: 0.0066 - val_loss: 0.0073 - val_mse: 0.0073 - 12ms/epoch - 6ms/step\n",
      "Epoch 445/500\n",
      "2/2 - 0s - loss: 0.0066 - mse: 0.0066 - val_loss: 0.0073 - val_mse: 0.0073 - 12ms/epoch - 6ms/step\n",
      "Epoch 446/500\n",
      "2/2 - 0s - loss: 0.0066 - mse: 0.0066 - val_loss: 0.0073 - val_mse: 0.0073 - 12ms/epoch - 6ms/step\n",
      "Epoch 447/500\n",
      "2/2 - 0s - loss: 0.0065 - mse: 0.0065 - val_loss: 0.0073 - val_mse: 0.0073 - 12ms/epoch - 6ms/step\n",
      "Epoch 448/500\n",
      "2/2 - 0s - loss: 0.0065 - mse: 0.0065 - val_loss: 0.0073 - val_mse: 0.0073 - 12ms/epoch - 6ms/step\n",
      "Epoch 449/500\n",
      "2/2 - 0s - loss: 0.0065 - mse: 0.0065 - val_loss: 0.0072 - val_mse: 0.0072 - 12ms/epoch - 6ms/step\n",
      "Epoch 450/500\n",
      "2/2 - 0s - loss: 0.0065 - mse: 0.0065 - val_loss: 0.0072 - val_mse: 0.0072 - 12ms/epoch - 6ms/step\n",
      "Epoch 451/500\n",
      "2/2 - 0s - loss: 0.0065 - mse: 0.0065 - val_loss: 0.0072 - val_mse: 0.0072 - 12ms/epoch - 6ms/step\n",
      "Epoch 452/500\n",
      "2/2 - 0s - loss: 0.0065 - mse: 0.0065 - val_loss: 0.0072 - val_mse: 0.0072 - 12ms/epoch - 6ms/step\n",
      "Epoch 453/500\n",
      "2/2 - 0s - loss: 0.0064 - mse: 0.0064 - val_loss: 0.0072 - val_mse: 0.0072 - 12ms/epoch - 6ms/step\n",
      "Epoch 454/500\n",
      "2/2 - 0s - loss: 0.0064 - mse: 0.0064 - val_loss: 0.0071 - val_mse: 0.0071 - 12ms/epoch - 6ms/step\n",
      "Epoch 455/500\n",
      "2/2 - 0s - loss: 0.0064 - mse: 0.0064 - val_loss: 0.0071 - val_mse: 0.0071 - 12ms/epoch - 6ms/step\n",
      "Epoch 456/500\n",
      "2/2 - 0s - loss: 0.0064 - mse: 0.0064 - val_loss: 0.0071 - val_mse: 0.0071 - 12ms/epoch - 6ms/step\n",
      "Epoch 457/500\n",
      "2/2 - 0s - loss: 0.0064 - mse: 0.0064 - val_loss: 0.0071 - val_mse: 0.0071 - 12ms/epoch - 6ms/step\n",
      "Epoch 458/500\n",
      "2/2 - 0s - loss: 0.0064 - mse: 0.0064 - val_loss: 0.0071 - val_mse: 0.0071 - 12ms/epoch - 6ms/step\n",
      "Epoch 459/500\n",
      "2/2 - 0s - loss: 0.0063 - mse: 0.0063 - val_loss: 0.0071 - val_mse: 0.0071 - 12ms/epoch - 6ms/step\n",
      "Epoch 460/500\n",
      "2/2 - 0s - loss: 0.0063 - mse: 0.0063 - val_loss: 0.0070 - val_mse: 0.0070 - 12ms/epoch - 6ms/step\n",
      "Epoch 461/500\n",
      "2/2 - 0s - loss: 0.0063 - mse: 0.0063 - val_loss: 0.0070 - val_mse: 0.0070 - 12ms/epoch - 6ms/step\n",
      "Epoch 462/500\n",
      "2/2 - 0s - loss: 0.0063 - mse: 0.0063 - val_loss: 0.0070 - val_mse: 0.0070 - 11ms/epoch - 6ms/step\n",
      "Epoch 463/500\n",
      "2/2 - 0s - loss: 0.0063 - mse: 0.0063 - val_loss: 0.0070 - val_mse: 0.0070 - 12ms/epoch - 6ms/step\n",
      "Epoch 464/500\n",
      "2/2 - 0s - loss: 0.0063 - mse: 0.0063 - val_loss: 0.0070 - val_mse: 0.0070 - 12ms/epoch - 6ms/step\n",
      "Epoch 465/500\n",
      "2/2 - 0s - loss: 0.0063 - mse: 0.0063 - val_loss: 0.0070 - val_mse: 0.0070 - 12ms/epoch - 6ms/step\n",
      "Epoch 466/500\n",
      "2/2 - 0s - loss: 0.0062 - mse: 0.0062 - val_loss: 0.0069 - val_mse: 0.0069 - 12ms/epoch - 6ms/step\n",
      "Epoch 467/500\n",
      "2/2 - 0s - loss: 0.0062 - mse: 0.0062 - val_loss: 0.0069 - val_mse: 0.0069 - 12ms/epoch - 6ms/step\n",
      "Epoch 468/500\n",
      "2/2 - 0s - loss: 0.0062 - mse: 0.0062 - val_loss: 0.0069 - val_mse: 0.0069 - 12ms/epoch - 6ms/step\n",
      "Epoch 469/500\n",
      "2/2 - 0s - loss: 0.0062 - mse: 0.0062 - val_loss: 0.0069 - val_mse: 0.0069 - 12ms/epoch - 6ms/step\n",
      "Epoch 470/500\n",
      "2/2 - 0s - loss: 0.0062 - mse: 0.0062 - val_loss: 0.0069 - val_mse: 0.0069 - 12ms/epoch - 6ms/step\n",
      "Epoch 471/500\n",
      "2/2 - 0s - loss: 0.0062 - mse: 0.0062 - val_loss: 0.0069 - val_mse: 0.0069 - 12ms/epoch - 6ms/step\n",
      "Epoch 472/500\n",
      "2/2 - 0s - loss: 0.0061 - mse: 0.0061 - val_loss: 0.0068 - val_mse: 0.0068 - 12ms/epoch - 6ms/step\n",
      "Epoch 473/500\n",
      "2/2 - 0s - loss: 0.0061 - mse: 0.0061 - val_loss: 0.0068 - val_mse: 0.0068 - 12ms/epoch - 6ms/step\n",
      "Epoch 474/500\n",
      "2/2 - 0s - loss: 0.0061 - mse: 0.0061 - val_loss: 0.0068 - val_mse: 0.0068 - 12ms/epoch - 6ms/step\n",
      "Epoch 475/500\n",
      "2/2 - 0s - loss: 0.0061 - mse: 0.0061 - val_loss: 0.0068 - val_mse: 0.0068 - 12ms/epoch - 6ms/step\n",
      "Epoch 476/500\n",
      "2/2 - 0s - loss: 0.0061 - mse: 0.0061 - val_loss: 0.0068 - val_mse: 0.0068 - 15ms/epoch - 7ms/step\n",
      "Epoch 477/500\n",
      "2/2 - 0s - loss: 0.0061 - mse: 0.0061 - val_loss: 0.0068 - val_mse: 0.0068 - 12ms/epoch - 6ms/step\n",
      "Epoch 478/500\n",
      "2/2 - 0s - loss: 0.0061 - mse: 0.0061 - val_loss: 0.0067 - val_mse: 0.0067 - 12ms/epoch - 6ms/step\n",
      "Epoch 479/500\n",
      "2/2 - 0s - loss: 0.0060 - mse: 0.0060 - val_loss: 0.0067 - val_mse: 0.0067 - 12ms/epoch - 6ms/step\n",
      "Epoch 480/500\n",
      "2/2 - 0s - loss: 0.0060 - mse: 0.0060 - val_loss: 0.0067 - val_mse: 0.0067 - 12ms/epoch - 6ms/step\n",
      "Epoch 481/500\n",
      "2/2 - 0s - loss: 0.0060 - mse: 0.0060 - val_loss: 0.0067 - val_mse: 0.0067 - 24ms/epoch - 12ms/step\n",
      "Epoch 482/500\n",
      "2/2 - 0s - loss: 0.0060 - mse: 0.0060 - val_loss: 0.0067 - val_mse: 0.0067 - 21ms/epoch - 10ms/step\n",
      "Epoch 483/500\n",
      "2/2 - 0s - loss: 0.0060 - mse: 0.0060 - val_loss: 0.0067 - val_mse: 0.0067 - 15ms/epoch - 8ms/step\n",
      "Epoch 484/500\n",
      "2/2 - 0s - loss: 0.0060 - mse: 0.0060 - val_loss: 0.0067 - val_mse: 0.0067 - 12ms/epoch - 6ms/step\n",
      "Epoch 485/500\n",
      "2/2 - 0s - loss: 0.0060 - mse: 0.0060 - val_loss: 0.0066 - val_mse: 0.0066 - 12ms/epoch - 6ms/step\n",
      "Epoch 486/500\n",
      "2/2 - 0s - loss: 0.0059 - mse: 0.0059 - val_loss: 0.0066 - val_mse: 0.0066 - 12ms/epoch - 6ms/step\n",
      "Epoch 487/500\n",
      "2/2 - 0s - loss: 0.0059 - mse: 0.0059 - val_loss: 0.0066 - val_mse: 0.0066 - 12ms/epoch - 6ms/step\n",
      "Epoch 488/500\n",
      "2/2 - 0s - loss: 0.0059 - mse: 0.0059 - val_loss: 0.0066 - val_mse: 0.0066 - 12ms/epoch - 6ms/step\n",
      "Epoch 489/500\n",
      "2/2 - 0s - loss: 0.0059 - mse: 0.0059 - val_loss: 0.0066 - val_mse: 0.0066 - 15ms/epoch - 8ms/step\n",
      "Epoch 490/500\n",
      "2/2 - 0s - loss: 0.0059 - mse: 0.0059 - val_loss: 0.0066 - val_mse: 0.0066 - 13ms/epoch - 7ms/step\n",
      "Epoch 491/500\n",
      "2/2 - 0s - loss: 0.0059 - mse: 0.0059 - val_loss: 0.0065 - val_mse: 0.0065 - 12ms/epoch - 6ms/step\n",
      "Epoch 492/500\n",
      "2/2 - 0s - loss: 0.0059 - mse: 0.0059 - val_loss: 0.0065 - val_mse: 0.0065 - 12ms/epoch - 6ms/step\n",
      "Epoch 493/500\n",
      "2/2 - 0s - loss: 0.0058 - mse: 0.0058 - val_loss: 0.0065 - val_mse: 0.0065 - 12ms/epoch - 6ms/step\n",
      "Epoch 494/500\n",
      "2/2 - 0s - loss: 0.0058 - mse: 0.0058 - val_loss: 0.0065 - val_mse: 0.0065 - 13ms/epoch - 6ms/step\n",
      "Epoch 495/500\n",
      "2/2 - 0s - loss: 0.0058 - mse: 0.0058 - val_loss: 0.0065 - val_mse: 0.0065 - 13ms/epoch - 6ms/step\n",
      "Epoch 496/500\n",
      "2/2 - 0s - loss: 0.0058 - mse: 0.0058 - val_loss: 0.0065 - val_mse: 0.0065 - 17ms/epoch - 8ms/step\n",
      "Epoch 497/500\n",
      "2/2 - 0s - loss: 0.0058 - mse: 0.0058 - val_loss: 0.0065 - val_mse: 0.0065 - 23ms/epoch - 12ms/step\n",
      "Epoch 498/500\n",
      "2/2 - 0s - loss: 0.0058 - mse: 0.0058 - val_loss: 0.0064 - val_mse: 0.0064 - 22ms/epoch - 11ms/step\n",
      "Epoch 499/500\n",
      "2/2 - 0s - loss: 0.0058 - mse: 0.0058 - val_loss: 0.0064 - val_mse: 0.0064 - 12ms/epoch - 6ms/step\n",
      "Epoch 500/500\n",
      "2/2 - 0s - loss: 0.0057 - mse: 0.0057 - val_loss: 0.0064 - val_mse: 0.0064 - 12ms/epoch - 6ms/step\n",
      "7.985640287399292\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": 10,
   "id": "81f35c9a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0059 - mse: 0.0059\n",
      "[0.005906948819756508, 0.005906949285417795]\n",
      "7.985640287399292\n"
     ]
    }
   ],
   "source": [
    "#use the SOURCE test data to evaluate the model\n",
    "loss_and_metrics = model.evaluate(X_train, y_train, batch_size=256)\n",
    "print(loss_and_metrics)\n",
    "\n",
    "print(t1-t0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "ef7b115a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "38/38 [==============================] - 0s 507us/step - loss: 0.0062 - mse: 0.0062\n",
      "[0.006179293617606163, 0.006179293151944876]\n",
      "7.985640287399292\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": 12,
   "id": "d659a2af",
   "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": 13,
   "id": "4687c4cf",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "71/71 [==============================] - 0s 529us/step - loss: 0.0014 - mse: 0.0014  \n",
      "2/2 [==============================] - 0s 1ms/step - loss: 2.0235 - mse: 2.0235\n",
      "73/73 [==============================] - 0s 511us/step - loss: 0.0556 - mse: 0.0556\n"
     ]
    }
   ],
   "source": [
    "#combine source and target for training\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": 14,
   "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) \n",
    "new_output_layer1 = Dense(4, activation='linear', use_bias=False) \n",
    "new_output_layer2 = Dense(3, activation='linear', use_bias=False)  \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": 15,
   "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": 16,
   "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": 17,
   "id": "4b514281",
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "# Step 5: Custom loss function\n",
    "def custom_loss(y_true, y_pred):\n",
    "    Num = 500 #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.0001\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": 18,
   "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_1 (Dense)             (None, None, 8)           32        \n",
      "                                                                 \n",
      " dense_2 (Dense)             (None, None, 8)           64        \n",
      "                                                                 \n",
      " dense_3 (Dense)             (None, None, 4)           32        \n",
      "                                                                 \n",
      " sequential (Sequential)     (None, 5, 3)              387       \n",
      "                                                                 \n",
      " dense_4 (Dense)             (None, 5, 4)              12        \n",
      "                                                                 \n",
      " dense_5 (Dense)             (None, 5, 4)              16        \n",
      "                                                                 \n",
      " dense_6 (Dense)             (None, 5, 3)              12        \n",
      "                                                                 \n",
      "=================================================================\n",
      "Total params: 555\n",
      "Trainable params: 168\n",
      "Non-trainable params: 387\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": 20,
   "id": "6bc7a420",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2/2 - 1s - loss: 2.0226 - mse: 1.9533 - val_loss: 1.9642 - val_mse: 2.1242 - 1s/epoch - 510ms/step\n",
      "iteration :1 Target train: tf.Tensor(1.9540325, shape=(), dtype=float32) loss1 tf.Tensor(1.9521213, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.001911318, shape=(), dtype=float32) loss2   tf.Tensor(0.00066552154, shape=(), dtype=float32) loss3  tf.Tensor(0.99600655, shape=(), dtype=float32) Target test: tf.Tensor(1.9927757, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 1.9536 - mse: 1.8867 - val_loss: 1.8980 - val_mse: 2.0540 - 57ms/epoch - 28ms/step\n",
      "iteration :2 Target train: tf.Tensor(1.8878218, shape=(), dtype=float32) loss1 tf.Tensor(1.8841289, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.003692824, shape=(), dtype=float32) loss2   tf.Tensor(0.0025910134, shape=(), dtype=float32) loss3  tf.Tensor(0.99203354, shape=(), dtype=float32) Target test: tf.Tensor(1.924996, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 1.8878 - mse: 1.8236 - val_loss: 1.8351 - val_mse: 1.9869 - 64ms/epoch - 32ms/step\n",
      "iteration :3 Target train: tf.Tensor(1.8249369, shape=(), dtype=float32) loss1 tf.Tensor(1.8183061, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.0066308333, shape=(), dtype=float32) loss2   tf.Tensor(0.0056661544, shape=(), dtype=float32) loss3  tf.Tensor(0.9880958, shape=(), dtype=float32) Target test: tf.Tensor(1.8606496, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 1.8255 - mse: 1.7609 - val_loss: 1.7754 - val_mse: 1.9228 - 56ms/epoch - 28ms/step\n",
      "iteration :4 Target train: tf.Tensor(1.7653176, shape=(), dtype=float32) loss1 tf.Tensor(1.7547055, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.0106120305, shape=(), dtype=float32) loss2   tf.Tensor(0.009777652, shape=(), dtype=float32) loss3  tf.Tensor(0.984205, shape=(), dtype=float32) Target test: tf.Tensor(1.7996807, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 1.7664 - mse: 1.7041 - val_loss: 1.7190 - val_mse: 1.8617 - 56ms/epoch - 28ms/step\n",
      "iteration :5 Target train: tf.Tensor(1.7088373, shape=(), dtype=float32) loss1 tf.Tensor(1.693316, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.015521231, shape=(), dtype=float32) loss2   tf.Tensor(0.014810478, shape=(), dtype=float32) loss3  tf.Tensor(0.9803794, shape=(), dtype=float32) Target test: tf.Tensor(1.7420114, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 1.7104 - mse: 1.6509 - val_loss: 1.6655 - val_mse: 1.8034 - 54ms/epoch - 27ms/step\n",
      "iteration :6 Target train: tf.Tensor(1.6553454, shape=(), dtype=float32) loss1 tf.Tensor(1.6341032, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.021242274, shape=(), dtype=float32) loss2   tf.Tensor(0.020648729, shape=(), dtype=float32) loss3  tf.Tensor(0.976622, shape=(), dtype=float32) Target test: tf.Tensor(1.6875396, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 1.6573 - mse: 1.5980 - val_loss: 1.6148 - val_mse: 1.7479 - 63ms/epoch - 31ms/step\n",
      "iteration :7 Target train: tf.Tensor(1.604688, shape=(), dtype=float32) loss1 tf.Tensor(1.577029, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.027659088, shape=(), dtype=float32) loss2   tf.Tensor(0.027176753, shape=(), dtype=float32) loss3  tf.Tensor(0.9729493, shape=(), dtype=float32) Target test: tf.Tensor(1.6361451, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 1.6071 - mse: 1.5498 - val_loss: 1.5669 - val_mse: 1.6949 - 59ms/epoch - 30ms/step\n",
      "iteration :8 Target train: tf.Tensor(1.55671, shape=(), dtype=float32) loss1 tf.Tensor(1.5220522, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.034657888, shape=(), dtype=float32) loss2   tf.Tensor(0.034281217, shape=(), dtype=float32) loss3  tf.Tensor(0.9693704, shape=(), dtype=float32) Target test: tf.Tensor(1.5876944, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 1.5596 - mse: 1.5031 - val_loss: 1.5215 - val_mse: 1.6444 - 56ms/epoch - 28ms/step\n",
      "iteration :9 Target train: tf.Tensor(1.5112649, shape=(), dtype=float32) loss1 tf.Tensor(1.4691343, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.042130638, shape=(), dtype=float32) loss2   tf.Tensor(0.04185444, shape=(), dtype=float32) loss3  tf.Tensor(0.9658832, shape=(), dtype=float32) Target test: tf.Tensor(1.5420471, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 1.5146 - mse: 1.4589 - val_loss: 1.4785 - val_mse: 1.5962 - 62ms/epoch - 31ms/step\n",
      "iteration :10 Target train: tf.Tensor(1.4682304, shape=(), dtype=float32) loss1 tf.Tensor(1.4182521, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.04997821, shape=(), dtype=float32) loss2   tf.Tensor(0.049797665, shape=(), dtype=float32) loss3  tf.Tensor(0.96250325, shape=(), dtype=float32) Target test: tf.Tensor(1.4990603, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 1.4720 - mse: 1.4199 - val_loss: 1.4378 - val_mse: 1.5502 - 61ms/epoch - 30ms/step\n",
      "iteration :11 Target train: tf.Tensor(1.4275208, shape=(), dtype=float32) loss1 tf.Tensor(1.3694072, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.058113568, shape=(), dtype=float32) loss2   tf.Tensor(0.058024023, shape=(), dtype=float32) loss3  tf.Tensor(0.95923376, shape=(), dtype=float32) Target test: tf.Tensor(1.4585956, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 1.4316 - mse: 1.3795 - val_loss: 1.3994 - val_mse: 1.5067 - 64ms/epoch - 32ms/step\n",
      "iteration :12 Target train: tf.Tensor(1.3890857, shape=(), dtype=float32) loss1 tf.Tensor(1.3226235, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.06646213, shape=(), dtype=float32) loss2   tf.Tensor(0.066459015, shape=(), dtype=float32) loss3  tf.Tensor(0.9560874, shape=(), dtype=float32) Target test: tf.Tensor(1.4205234, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 1.3936 - mse: 1.3447 - val_loss: 1.3633 - val_mse: 1.4656 - 56ms/epoch - 28ms/step\n",
      "iteration :13 Target train: tf.Tensor(1.3528867, shape=(), dtype=float32) loss1 tf.Tensor(1.2779269, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.0749598, shape=(), dtype=float32) loss2   tf.Tensor(0.07503875, shape=(), dtype=float32) loss3  tf.Tensor(0.95305085, shape=(), dtype=float32) Target test: tf.Tensor(1.3847202, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 1.3578 - mse: 1.3088 - val_loss: 1.3293 - val_mse: 1.4270 - 58ms/epoch - 29ms/step\n",
      "iteration :14 Target train: tf.Tensor(1.3188689, shape=(), dtype=float32) loss1 tf.Tensor(1.2353171, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.083551794, shape=(), dtype=float32) loss2   tf.Tensor(0.083708555, shape=(), dtype=float32) loss3  tf.Tensor(0.95014346, shape=(), dtype=float32) Target test: tf.Tensor(1.3510656, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 1.3242 - mse: 1.2776 - val_loss: 1.2975 - val_mse: 1.3909 - 54ms/epoch - 27ms/step\n",
      "iteration :15 Target train: tf.Tensor(1.2869452, shape=(), dtype=float32) loss1 tf.Tensor(1.1947546, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.092190586, shape=(), dtype=float32) loss2   tf.Tensor(0.092421085, shape=(), dtype=float32) loss3  tf.Tensor(0.94737154, shape=(), dtype=float32) Target test: tf.Tensor(1.3194416, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 1.2926 - mse: 1.2472 - val_loss: 1.2676 - val_mse: 1.3570 - 56ms/epoch - 28ms/step\n",
      "iteration :16 Target train: tf.Tensor(1.2569977, shape=(), dtype=float32) loss1 tf.Tensor(1.1561637, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.10083403, shape=(), dtype=float32) loss2   tf.Tensor(0.10113449, shape=(), dtype=float32) loss3  tf.Tensor(0.944743, shape=(), dtype=float32) Target test: tf.Tensor(1.2897271, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 1.2631 - mse: 1.2189 - val_loss: 1.2395 - val_mse: 1.3252 - 58ms/epoch - 29ms/step\n",
      "iteration :17 Target train: tf.Tensor(1.228894, shape=(), dtype=float32) loss1 tf.Tensor(1.1194485, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.10944543, shape=(), dtype=float32) loss2   tf.Tensor(0.1098124, shape=(), dtype=float32) loss3  tf.Tensor(0.9422646, shape=(), dtype=float32) Target test: tf.Tensor(1.2617983, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 1.2353 - mse: 1.1935 - val_loss: 1.2132 - val_mse: 1.2954 - 61ms/epoch - 31ms/step\n",
      "iteration :18 Target train: tf.Tensor(1.2025028, shape=(), dtype=float32) loss1 tf.Tensor(1.0845093, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.11799356, shape=(), dtype=float32) loss2   tf.Tensor(0.11842386, shape=(), dtype=float32) loss3  tf.Tensor(0.93993634, shape=(), dtype=float32) Target test: tf.Tensor(1.2355318, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 1.2092 - mse: 1.1674 - val_loss: 1.1885 - val_mse: 1.2675 - 56ms/epoch - 28ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iteration :19 Target train: tf.Tensor(1.1776993, shape=(), dtype=float32) loss1 tf.Tensor(1.051247, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.12645231, shape=(), dtype=float32) loss2   tf.Tensor(0.12694295, shape=(), dtype=float32) loss3  tf.Tensor(0.93776345, shape=(), dtype=float32) Target test: tf.Tensor(1.2108086, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 1.1847 - mse: 1.1440 - val_loss: 1.1652 - val_mse: 1.2412 - 56ms/epoch - 28ms/step\n",
      "iteration :20 Target train: tf.Tensor(1.1543622, shape=(), dtype=float32) loss1 tf.Tensor(1.0195618, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.1348005, shape=(), dtype=float32) loss2   tf.Tensor(0.13534872, shape=(), dtype=float32) loss3  tf.Tensor(0.93574935, shape=(), dtype=float32) Target test: tf.Tensor(1.1875136, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 1.1616 - mse: 1.1215 - val_loss: 1.1432 - val_mse: 1.2164 - 61ms/epoch - 30ms/step\n",
      "iteration :21 Target train: tf.Tensor(1.1323742, shape=(), dtype=float32) loss1 tf.Tensor(0.98935276, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.14302139, shape=(), dtype=float32) loss2   tf.Tensor(0.1436246, shape=(), dtype=float32) loss3  tf.Tensor(0.9338961, shape=(), dtype=float32) Target test: tf.Tensor(1.1655344, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 1.1399 - mse: 1.1016 - val_loss: 1.1226 - val_mse: 1.1931 - 56ms/epoch - 28ms/step\n",
      "iteration :22 Target train: tf.Tensor(1.111625, shape=(), dtype=float32) loss1 tf.Tensor(0.96052283, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.15110213, shape=(), dtype=float32) loss2   tf.Tensor(0.15175778, shape=(), dtype=float32) loss3  tf.Tensor(0.9322043, shape=(), dtype=float32) Target test: tf.Tensor(1.1447656, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 1.1194 - mse: 1.0809 - val_loss: 1.1030 - val_mse: 1.1711 - 58ms/epoch - 29ms/step\n",
      "iteration :23 Target train: tf.Tensor(1.0920138, shape=(), dtype=float32) loss1 tf.Tensor(0.93298066, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.15903318, shape=(), dtype=float32) loss2   tf.Tensor(0.15973884, shape=(), dtype=float32) loss3  tf.Tensor(0.93067336, shape=(), dtype=float32) Target test: tf.Tensor(1.1251087, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 1.1000 - mse: 1.0624 - val_loss: 1.0845 - val_mse: 1.1503 - 56ms/epoch - 28ms/step\n",
      "iteration :24 Target train: tf.Tensor(1.0734487, shape=(), dtype=float32) loss1 tf.Tensor(0.90664077, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.1668079, shape=(), dtype=float32) loss2   tf.Tensor(0.16756125, shape=(), dtype=float32) loss3  tf.Tensor(0.92930216, shape=(), dtype=float32) Target test: tf.Tensor(1.1064724, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 1.0817 - mse: 1.0448 - val_loss: 1.0670 - val_mse: 1.1307 - 55ms/epoch - 28ms/step\n",
      "iteration :25 Target train: tf.Tensor(1.0558425, shape=(), dtype=float32) loss1 tf.Tensor(0.8814204, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.17442212, shape=(), dtype=float32) loss2   tf.Tensor(0.17522089, shape=(), dtype=float32) loss3  tf.Tensor(0.92808884, shape=(), dtype=float32) Target test: tf.Tensor(1.0887705, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 1.0643 - mse: 1.0283 - val_loss: 1.0503 - val_mse: 1.1120 - 68ms/epoch - 34ms/step\n",
      "iteration :26 Target train: tf.Tensor(1.0391122, shape=(), dtype=float32) loss1 tf.Tensor(0.8572387, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.18187352, shape=(), dtype=float32) loss2   tf.Tensor(0.18271554, shape=(), dtype=float32) loss3  tf.Tensor(0.9270311, shape=(), dtype=float32) Target test: tf.Tensor(1.0719239, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 1.0477 - mse: 1.0123 - val_loss: 1.0344 - val_mse: 1.0942 - 57ms/epoch - 28ms/step\n",
      "iteration :27 Target train: tf.Tensor(1.0231788, shape=(), dtype=float32) loss1 tf.Tensor(0.8340175, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.1891613, shape=(), dtype=float32) loss2   tf.Tensor(0.19004449, shape=(), dtype=float32) loss3  tf.Tensor(0.9261257, shape=(), dtype=float32) Target test: tf.Tensor(1.0558593, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 1.0320 - mse: 0.9973 - val_loss: 1.0193 - val_mse: 1.0773 - 55ms/epoch - 27ms/step\n",
      "iteration :28 Target train: tf.Tensor(1.0079695, shape=(), dtype=float32) loss1 tf.Tensor(0.81168365, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.19628583, shape=(), dtype=float32) loss2   tf.Tensor(0.19720827, shape=(), dtype=float32) loss3  tf.Tensor(0.92536855, shape=(), dtype=float32) Target test: tf.Tensor(1.0405099, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 1.0170 - mse: 0.9826 - val_loss: 1.0048 - val_mse: 1.0611 - 68ms/epoch - 34ms/step\n",
      "iteration :29 Target train: tf.Tensor(0.99341744, shape=(), dtype=float32) loss1 tf.Tensor(0.79016894, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.2032485, shape=(), dtype=float32) loss2   tf.Tensor(0.20420836, shape=(), dtype=float32) loss3  tf.Tensor(0.924755, shape=(), dtype=float32) Target test: tf.Tensor(1.0258149, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 1.0026 - mse: 0.9690 - val_loss: 0.9909 - val_mse: 1.0456 - 59ms/epoch - 29ms/step\n",
      "iteration :30 Target train: tf.Tensor(0.979463, shape=(), dtype=float32) loss1 tf.Tensor(0.76941144, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.21005157, shape=(), dtype=float32) loss2   tf.Tensor(0.21104714, shape=(), dtype=float32) loss3  tf.Tensor(0.92427975, shape=(), dtype=float32) Target test: tf.Tensor(1.0117184, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.9888 - mse: 0.9553 - val_loss: 0.9775 - val_mse: 1.0307 - 60ms/epoch - 30ms/step\n",
      "iteration :31 Target train: tf.Tensor(0.9660525, shape=(), dtype=float32) loss1 tf.Tensor(0.74935436, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.21669808, shape=(), dtype=float32) loss2   tf.Tensor(0.2177278, shape=(), dtype=float32) loss3  tf.Tensor(0.92393726, shape=(), dtype=float32) Target test: tf.Tensor(0.9981702, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.9755 - mse: 0.9424 - val_loss: 0.9647 - val_mse: 1.0164 - 56ms/epoch - 28ms/step\n",
      "iteration :32 Target train: tf.Tensor(0.9531385, shape=(), dtype=float32) loss1 tf.Tensor(0.7299467, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.22319178, shape=(), dtype=float32) loss2   tf.Tensor(0.22425419, shape=(), dtype=float32) loss3  tf.Tensor(0.9237222, shape=(), dtype=float32) Target test: tf.Tensor(0.9851241, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.9627 - mse: 0.9300 - val_loss: 0.9523 - val_mse: 1.0025 - 60ms/epoch - 30ms/step\n",
      "iteration :33 Target train: tf.Tensor(0.9406787, shape=(), dtype=float32) loss1 tf.Tensor(0.7111417, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.22953704, shape=(), dtype=float32) loss2   tf.Tensor(0.2306308, shape=(), dtype=float32) loss3  tf.Tensor(0.92362934, shape=(), dtype=float32) Target test: tf.Tensor(0.9725388, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.9504 - mse: 0.9184 - val_loss: 0.9403 - val_mse: 0.9891 - 58ms/epoch - 29ms/step\n",
      "iteration :34 Target train: tf.Tensor(0.9286361, shape=(), dtype=float32) loss1 tf.Tensor(0.6928973, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.23573878, shape=(), dtype=float32) loss2   tf.Tensor(0.23686261, shape=(), dtype=float32) loss3  tf.Tensor(0.92365366, shape=(), dtype=float32) Target test: tf.Tensor(0.9603773, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.9385 - mse: 0.9068 - val_loss: 0.9287 - val_mse: 0.9762 - 55ms/epoch - 28ms/step\n",
      "iteration :35 Target train: tf.Tensor(0.9169769, shape=(), dtype=float32) loss1 tf.Tensor(0.6751746, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.24180236, shape=(), dtype=float32) loss2   tf.Tensor(0.24295512, shape=(), dtype=float32) loss3  tf.Tensor(0.9237906, shape=(), dtype=float32) Target test: tf.Tensor(0.9486055, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.9269 - mse: 0.8954 - val_loss: 0.9175 - val_mse: 0.9636 - 56ms/epoch - 28ms/step\n",
      "iteration :36 Target train: tf.Tensor(0.90567267, shape=(), dtype=float32) loss1 tf.Tensor(0.6579392, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.24773344, shape=(), dtype=float32) loss2   tf.Tensor(0.24891403, shape=(), dtype=float32) loss3  tf.Tensor(0.9240358, shape=(), dtype=float32) Target test: tf.Tensor(0.9371935, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.9157 - mse: 0.8849 - val_loss: 0.9066 - val_mse: 0.9514 - 67ms/epoch - 33ms/step\n",
      "iteration :37 Target train: tf.Tensor(0.89469665, shape=(), dtype=float32) loss1 tf.Tensor(0.64115864, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.253538, shape=(), dtype=float32) loss2   tf.Tensor(0.2547454, shape=(), dtype=float32) loss3  tf.Tensor(0.92438555, shape=(), dtype=float32) Target test: tf.Tensor(0.926114, shape=(), dtype=float32)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2/2 - 0s - loss: 0.9049 - mse: 0.8741 - val_loss: 0.8959 - val_mse: 0.9395 - 61ms/epoch - 31ms/step\n",
      "iteration :38 Target train: tf.Tensor(0.8840261, shape=(), dtype=float32) loss1 tf.Tensor(0.624804, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.25922206, shape=(), dtype=float32) loss2   tf.Tensor(0.26045528, shape=(), dtype=float32) loss3  tf.Tensor(0.9248364, shape=(), dtype=float32) Target test: tf.Tensor(0.91534245, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.8943 - mse: 0.8639 - val_loss: 0.8856 - val_mse: 0.9279 - 57ms/epoch - 29ms/step\n",
      "iteration :39 Target train: tf.Tensor(0.87364054, shape=(), dtype=float32) loss1 tf.Tensor(0.6088488, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.26479173, shape=(), dtype=float32) loss2   tf.Tensor(0.26604986, shape=(), dtype=float32) loss3  tf.Tensor(0.92538506, shape=(), dtype=float32) Target test: tf.Tensor(0.9048569, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.8840 - mse: 0.8540 - val_loss: 0.8756 - val_mse: 0.9166 - 59ms/epoch - 30ms/step\n",
      "iteration :40 Target train: tf.Tensor(0.8635218, shape=(), dtype=float32) loss1 tf.Tensor(0.5932689, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.2702529, shape=(), dtype=float32) loss2   tf.Tensor(0.2715351, shape=(), dtype=float32) loss3  tf.Tensor(0.92602867, shape=(), dtype=float32) Target test: tf.Tensor(0.8946376, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.8740 - mse: 0.8442 - val_loss: 0.8657 - val_mse: 0.9056 - 57ms/epoch - 29ms/step\n",
      "iteration :41 Target train: tf.Tensor(0.8536541, shape=(), dtype=float32) loss1 tf.Tensor(0.5780425, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.2756116, shape=(), dtype=float32) loss2   tf.Tensor(0.276917, shape=(), dtype=float32) loss3  tf.Tensor(0.92676437, shape=(), dtype=float32) Target test: tf.Tensor(0.88466686, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.8642 - mse: 0.8346 - val_loss: 0.8562 - val_mse: 0.8948 - 57ms/epoch - 28ms/step\n",
      "iteration :42 Target train: tf.Tensor(0.84402263, shape=(), dtype=float32) loss1 tf.Tensor(0.5631491, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.2808735, shape=(), dtype=float32) loss2   tf.Tensor(0.28220132, shape=(), dtype=float32) loss3  tf.Tensor(0.92758936, shape=(), dtype=float32) Target test: tf.Tensor(0.8749286, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.8547 - mse: 0.8256 - val_loss: 0.8468 - val_mse: 0.8843 - 76ms/epoch - 38ms/step\n",
      "iteration :43 Target train: tf.Tensor(0.8346146, shape=(), dtype=float32) loss1 tf.Tensor(0.5485705, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.2860441, shape=(), dtype=float32) loss2   tf.Tensor(0.28739363, shape=(), dtype=float32) loss3  tf.Tensor(0.9285013, shape=(), dtype=float32) Target test: tf.Tensor(0.8654084, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.8454 - mse: 0.8168 - val_loss: 0.8377 - val_mse: 0.8740 - 55ms/epoch - 28ms/step\n",
      "iteration :44 Target train: tf.Tensor(0.8254183, shape=(), dtype=float32) loss1 tf.Tensor(0.53428954, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.29112875, shape=(), dtype=float32) loss2   tf.Tensor(0.29249924, shape=(), dtype=float32) loss3  tf.Tensor(0.92949736, shape=(), dtype=float32) Target test: tf.Tensor(0.8560935, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.8363 - mse: 0.8077 - val_loss: 0.8288 - val_mse: 0.8639 - 58ms/epoch - 29ms/step\n",
      "iteration :45 Target train: tf.Tensor(0.81642336, shape=(), dtype=float32) loss1 tf.Tensor(0.52029085, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.2961325, shape=(), dtype=float32) loss2   tf.Tensor(0.29752335, shape=(), dtype=float32) loss3  tf.Tensor(0.9305751, shape=(), dtype=float32) Target test: tf.Tensor(0.8469723, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.8274 - mse: 0.7992 - val_loss: 0.8200 - val_mse: 0.8541 - 57ms/epoch - 29ms/step\n",
      "iteration :46 Target train: tf.Tensor(0.8076201, shape=(), dtype=float32) loss1 tf.Tensor(0.50655985, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.30106026, shape=(), dtype=float32) loss2   tf.Tensor(0.3024709, shape=(), dtype=float32) loss3  tf.Tensor(0.9317318, shape=(), dtype=float32) Target test: tf.Tensor(0.83803415, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.8186 - mse: 0.7910 - val_loss: 0.8115 - val_mse: 0.8444 - 58ms/epoch - 29ms/step\n",
      "iteration :47 Target train: tf.Tensor(0.7989996, shape=(), dtype=float32) loss1 tf.Tensor(0.49308288, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.30591673, shape=(), dtype=float32) loss2   tf.Tensor(0.30734655, shape=(), dtype=float32) loss3  tf.Tensor(0.932965, shape=(), dtype=float32) Target test: tf.Tensor(0.82926965, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.8101 - mse: 0.7825 - val_loss: 0.8031 - val_mse: 0.8350 - 67ms/epoch - 33ms/step\n",
      "iteration :48 Target train: tf.Tensor(0.790554, shape=(), dtype=float32) loss1 tf.Tensor(0.4798476, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.31070638, shape=(), dtype=float32) loss2   tf.Tensor(0.3121549, shape=(), dtype=float32) loss3  tf.Tensor(0.934272, shape=(), dtype=float32) Target test: tf.Tensor(0.8206702, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.8018 - mse: 0.7743 - val_loss: 0.7948 - val_mse: 0.8258 - 61ms/epoch - 30ms/step\n",
      "iteration :49 Target train: tf.Tensor(0.782276, shape=(), dtype=float32) loss1 tf.Tensor(0.4668425, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.31543347, shape=(), dtype=float32) loss2   tf.Tensor(0.31690022, shape=(), dtype=float32) loss3  tf.Tensor(0.9356502, shape=(), dtype=float32) Target test: tf.Tensor(0.81222796, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.7936 - mse: 0.7665 - val_loss: 0.7868 - val_mse: 0.8167 - 79ms/epoch - 40ms/step\n",
      "iteration :50 Target train: tf.Tensor(0.77415884, shape=(), dtype=float32) loss1 tf.Tensor(0.4540566, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.32010224, shape=(), dtype=float32) loss2   tf.Tensor(0.32158673, shape=(), dtype=float32) loss3  tf.Tensor(0.93709695, shape=(), dtype=float32) Target test: tf.Tensor(0.80393595, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.7855 - mse: 0.7587 - val_loss: 0.7789 - val_mse: 0.8078 - 73ms/epoch - 37ms/step\n",
      "iteration :51 Target train: tf.Tensor(0.76619667, shape=(), dtype=float32) loss1 tf.Tensor(0.4414801, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.32471657, shape=(), dtype=float32) loss2   tf.Tensor(0.32621837, shape=(), dtype=float32) loss3  tf.Tensor(0.9386096, shape=(), dtype=float32) Target test: tf.Tensor(0.795788, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.7777 - mse: 0.7512 - val_loss: 0.7711 - val_mse: 0.7991 - 57ms/epoch - 29ms/step\n",
      "iteration :52 Target train: tf.Tensor(0.7583838, shape=(), dtype=float32) loss1 tf.Tensor(0.42910355, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.32928026, shape=(), dtype=float32) loss2   tf.Tensor(0.330799, shape=(), dtype=float32) loss3  tf.Tensor(0.94018537, shape=(), dtype=float32) Target test: tf.Tensor(0.78777814, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.7699 - mse: 0.7437 - val_loss: 0.7635 - val_mse: 0.7906 - 85ms/epoch - 42ms/step\n",
      "iteration :53 Target train: tf.Tensor(0.7507151, shape=(), dtype=float32) loss1 tf.Tensor(0.41691807, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.333797, shape=(), dtype=float32) loss2   tf.Tensor(0.33533245, shape=(), dtype=float32) loss3  tf.Tensor(0.9418216, shape=(), dtype=float32) Target test: tf.Tensor(0.7799012, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.7623 - mse: 0.7362 - val_loss: 0.7561 - val_mse: 0.7822 - 59ms/epoch - 29ms/step\n",
      "iteration :54 Target train: tf.Tensor(0.7431861, shape=(), dtype=float32) loss1 tf.Tensor(0.4049158, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.3382703, shape=(), dtype=float32) loss2   tf.Tensor(0.33982214, shape=(), dtype=float32) loss3  tf.Tensor(0.9435154, shape=(), dtype=float32) Target test: tf.Tensor(0.77215254, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.7549 - mse: 0.7292 - val_loss: 0.7487 - val_mse: 0.7740 - 70ms/epoch - 35ms/step\n",
      "iteration :55 Target train: tf.Tensor(0.7357926, shape=(), dtype=float32) loss1 tf.Tensor(0.39308903, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.34270355, shape=(), dtype=float32) loss2   tf.Tensor(0.34427142, shape=(), dtype=float32) loss3  tf.Tensor(0.94526416, shape=(), dtype=float32) Target test: tf.Tensor(0.76452786, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.7476 - mse: 0.7220 - val_loss: 0.7415 - val_mse: 0.7660 - 74ms/epoch - 37ms/step\n",
      "iteration :56 Target train: tf.Tensor(0.7285305, shape=(), dtype=float32) loss1 tf.Tensor(0.3814306, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.34709993, shape=(), dtype=float32) loss2   tf.Tensor(0.3486836, shape=(), dtype=float32) loss3  tf.Tensor(0.9470649, shape=(), dtype=float32) Target test: tf.Tensor(0.7570235, shape=(), dtype=float32)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2/2 - 0s - loss: 0.7404 - mse: 0.7149 - val_loss: 0.7345 - val_mse: 0.7581 - 60ms/epoch - 30ms/step\n",
      "iteration :57 Target train: tf.Tensor(0.7213963, shape=(), dtype=float32) loss1 tf.Tensor(0.36993363, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.3514627, shape=(), dtype=float32) loss2   tf.Tensor(0.3530619, shape=(), dtype=float32) loss3  tf.Tensor(0.94891465, shape=(), dtype=float32) Target test: tf.Tensor(0.749636, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.7333 - mse: 0.7080 - val_loss: 0.7275 - val_mse: 0.7503 - 67ms/epoch - 33ms/step\n",
      "iteration :58 Target train: tf.Tensor(0.7143862, shape=(), dtype=float32) loss1 tf.Tensor(0.35859153, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.3557947, shape=(), dtype=float32) loss2   tf.Tensor(0.35740933, shape=(), dtype=float32) loss3  tf.Tensor(0.9508107, shape=(), dtype=float32) Target test: tf.Tensor(0.742362, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.7264 - mse: 0.7014 - val_loss: 0.7207 - val_mse: 0.7427 - 67ms/epoch - 34ms/step\n",
      "iteration :59 Target train: tf.Tensor(0.70749676, shape=(), dtype=float32) loss1 tf.Tensor(0.3473978, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.36009896, shape=(), dtype=float32) loss2   tf.Tensor(0.36172864, shape=(), dtype=float32) loss3  tf.Tensor(0.95275, shape=(), dtype=float32) Target test: tf.Tensor(0.7351989, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.7196 - mse: 0.6947 - val_loss: 0.7140 - val_mse: 0.7353 - 58ms/epoch - 29ms/step\n",
      "iteration :60 Target train: tf.Tensor(0.7007245, shape=(), dtype=float32) loss1 tf.Tensor(0.33634645, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.36437804, shape=(), dtype=float32) loss2   tf.Tensor(0.36602277, shape=(), dtype=float32) loss3  tf.Tensor(0.9547299, shape=(), dtype=float32) Target test: tf.Tensor(0.728144, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.7129 - mse: 0.6882 - val_loss: 0.7074 - val_mse: 0.7279 - 57ms/epoch - 28ms/step\n",
      "iteration :61 Target train: tf.Tensor(0.694066, shape=(), dtype=float32) loss1 tf.Tensor(0.32543123, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.36863476, shape=(), dtype=float32) loss2   tf.Tensor(0.37029424, shape=(), dtype=float32) loss3  tf.Tensor(0.9567473, shape=(), dtype=float32) Target test: tf.Tensor(0.7211949, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.7063 - mse: 0.6817 - val_loss: 0.7009 - val_mse: 0.7207 - 60ms/epoch - 30ms/step\n",
      "iteration :62 Target train: tf.Tensor(0.6875181, shape=(), dtype=float32) loss1 tf.Tensor(0.3146465, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.3728716, shape=(), dtype=float32) loss2   tf.Tensor(0.37454572, shape=(), dtype=float32) loss3  tf.Tensor(0.95879936, shape=(), dtype=float32) Target test: tf.Tensor(0.7143495, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.6999 - mse: 0.6753 - val_loss: 0.6945 - val_mse: 0.7136 - 101ms/epoch - 50ms/step\n",
      "iteration :63 Target train: tf.Tensor(0.6810774, shape=(), dtype=float32) loss1 tf.Tensor(0.30398646, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.37709096, shape=(), dtype=float32) loss2   tf.Tensor(0.37877956, shape=(), dtype=float32) loss3  tf.Tensor(0.96088314, shape=(), dtype=float32) Target test: tf.Tensor(0.7076056, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.6935 - mse: 0.6691 - val_loss: 0.6882 - val_mse: 0.7066 - 57ms/epoch - 28ms/step\n",
      "iteration :64 Target train: tf.Tensor(0.6747409, shape=(), dtype=float32) loss1 tf.Tensor(0.29344562, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.3812953, shape=(), dtype=float32) loss2   tf.Tensor(0.38299817, shape=(), dtype=float32) loss3  tf.Tensor(0.962996, shape=(), dtype=float32) Target test: tf.Tensor(0.7009615, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.6872 - mse: 0.6631 - val_loss: 0.6821 - val_mse: 0.6997 - 55ms/epoch - 28ms/step\n",
      "iteration :65 Target train: tf.Tensor(0.66850525, shape=(), dtype=float32) loss1 tf.Tensor(0.28301868, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.38548657, shape=(), dtype=float32) loss2   tf.Tensor(0.3872036, shape=(), dtype=float32) loss3  tf.Tensor(0.9651351, shape=(), dtype=float32) Target test: tf.Tensor(0.6944152, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.6811 - mse: 0.6571 - val_loss: 0.6760 - val_mse: 0.6929 - 72ms/epoch - 36ms/step\n",
      "iteration :66 Target train: tf.Tensor(0.6623682, shape=(), dtype=float32) loss1 tf.Tensor(0.27270108, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.3896671, shape=(), dtype=float32) loss2   tf.Tensor(0.3913981, shape=(), dtype=float32) loss3  tf.Tensor(0.9672977, shape=(), dtype=float32) Target test: tf.Tensor(0.68796545, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.6750 - mse: 0.6514 - val_loss: 0.6700 - val_mse: 0.6863 - 56ms/epoch - 28ms/step\n",
      "iteration :67 Target train: tf.Tensor(0.6563266, shape=(), dtype=float32) loss1 tf.Tensor(0.26248786, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.39383873, shape=(), dtype=float32) loss2   tf.Tensor(0.3955836, shape=(), dtype=float32) loss3  tf.Tensor(0.9694808, shape=(), dtype=float32) Target test: tf.Tensor(0.6816108, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.6691 - mse: 0.6456 - val_loss: 0.6641 - val_mse: 0.6797 - 57ms/epoch - 29ms/step\n",
      "iteration :68 Target train: tf.Tensor(0.6503782, shape=(), dtype=float32) loss1 tf.Tensor(0.25237495, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.39800328, shape=(), dtype=float32) loss2   tf.Tensor(0.3997619, shape=(), dtype=float32) loss3  tf.Tensor(0.971682, shape=(), dtype=float32) Target test: tf.Tensor(0.6753499, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.6632 - mse: 0.6396 - val_loss: 0.6583 - val_mse: 0.6732 - 56ms/epoch - 28ms/step\n",
      "iteration :69 Target train: tf.Tensor(0.6445213, shape=(), dtype=float32) loss1 tf.Tensor(0.24235883, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.40216246, shape=(), dtype=float32) loss2   tf.Tensor(0.40393457, shape=(), dtype=float32) loss3  tf.Tensor(0.9738986, shape=(), dtype=float32) Target test: tf.Tensor(0.6691818, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.6574 - mse: 0.6341 - val_loss: 0.6526 - val_mse: 0.6668 - 61ms/epoch - 31ms/step\n",
      "iteration :70 Target train: tf.Tensor(0.6387536, shape=(), dtype=float32) loss1 tf.Tensor(0.23243564, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.40631795, shape=(), dtype=float32) loss2   tf.Tensor(0.40810335, shape=(), dtype=float32) loss3  tf.Tensor(0.9761279, shape=(), dtype=float32) Target test: tf.Tensor(0.6631056, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.6517 - mse: 0.6284 - val_loss: 0.6470 - val_mse: 0.6605 - 93ms/epoch - 47ms/step\n",
      "iteration :71 Target train: tf.Tensor(0.6330735, shape=(), dtype=float32) loss1 tf.Tensor(0.22260249, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.41047102, shape=(), dtype=float32) loss2   tf.Tensor(0.4122696, shape=(), dtype=float32) loss3  tf.Tensor(0.9783672, shape=(), dtype=float32) Target test: tf.Tensor(0.65712065, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.6461 - mse: 0.6230 - val_loss: 0.6415 - val_mse: 0.6542 - 58ms/epoch - 29ms/step\n",
      "iteration :72 Target train: tf.Tensor(0.62747955, shape=(), dtype=float32) loss1 tf.Tensor(0.21285653, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.41462302, shape=(), dtype=float32) loss2   tf.Tensor(0.4164346, shape=(), dtype=float32) loss3  tf.Tensor(0.980614, shape=(), dtype=float32) Target test: tf.Tensor(0.65122646, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.6406 - mse: 0.6178 - val_loss: 0.6360 - val_mse: 0.6480 - 60ms/epoch - 30ms/step\n",
      "iteration :73 Target train: tf.Tensor(0.62197, shape=(), dtype=float32) loss1 tf.Tensor(0.20319471, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.4187753, shape=(), dtype=float32) loss2   tf.Tensor(0.42059955, shape=(), dtype=float32) loss3  tf.Tensor(0.98286587, shape=(), dtype=float32) Target test: tf.Tensor(0.6454226, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.6352 - mse: 0.6125 - val_loss: 0.6307 - val_mse: 0.6419 - 56ms/epoch - 28ms/step\n",
      "iteration :74 Target train: tf.Tensor(0.6165437, shape=(), dtype=float32) loss1 tf.Tensor(0.19361508, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.42292863, shape=(), dtype=float32) loss2   tf.Tensor(0.4247655, shape=(), dtype=float32) loss3  tf.Tensor(0.98512036, shape=(), dtype=float32) Target test: tf.Tensor(0.6397089, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.6298 - mse: 0.6074 - val_loss: 0.6254 - val_mse: 0.6358 - 55ms/epoch - 27ms/step\n",
      "iteration :75 Target train: tf.Tensor(0.61119884, shape=(), dtype=float32) loss1 tf.Tensor(0.18411452, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.42708433, shape=(), dtype=float32) loss2   tf.Tensor(0.42893347, shape=(), dtype=float32) loss3  tf.Tensor(0.98737484, shape=(), dtype=float32) Target test: tf.Tensor(0.6340851, shape=(), dtype=float32)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2/2 - 0s - loss: 0.6246 - mse: 0.6021 - val_loss: 0.6202 - val_mse: 0.6298 - 85ms/epoch - 42ms/step\n",
      "iteration :76 Target train: tf.Tensor(0.60593367, shape=(), dtype=float32) loss1 tf.Tensor(0.17469049, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.43124318, shape=(), dtype=float32) loss2   tf.Tensor(0.43310437, shape=(), dtype=float32) loss3  tf.Tensor(0.98962694, shape=(), dtype=float32) Target test: tf.Tensor(0.62855136, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.6194 - mse: 0.5972 - val_loss: 0.6151 - val_mse: 0.6238 - 80ms/epoch - 40ms/step\n",
      "iteration :77 Target train: tf.Tensor(0.6007465, shape=(), dtype=float32) loss1 tf.Tensor(0.16534054, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.43540597, shape=(), dtype=float32) loss2   tf.Tensor(0.4372791, shape=(), dtype=float32) loss3  tf.Tensor(0.99187464, shape=(), dtype=float32) Target test: tf.Tensor(0.6231075, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.6143 - mse: 0.5924 - val_loss: 0.6100 - val_mse: 0.6179 - 77ms/epoch - 39ms/step\n",
      "iteration :78 Target train: tf.Tensor(0.5956349, shape=(), dtype=float32) loss1 tf.Tensor(0.1560612, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.43957368, shape=(), dtype=float32) loss2   tf.Tensor(0.44145834, shape=(), dtype=float32) loss3  tf.Tensor(0.99411577, shape=(), dtype=float32) Target test: tf.Tensor(0.6177535, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.6092 - mse: 0.5874 - val_loss: 0.6050 - val_mse: 0.6120 - 62ms/epoch - 31ms/step\n",
      "iteration :79 Target train: tf.Tensor(0.59059685, shape=(), dtype=float32) loss1 tf.Tensor(0.1468499, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.44374695, shape=(), dtype=float32) loss2   tf.Tensor(0.44564292, shape=(), dtype=float32) loss3  tf.Tensor(0.99634826, shape=(), dtype=float32) Target test: tf.Tensor(0.61248934, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.6043 - mse: 0.5826 - val_loss: 0.6001 - val_mse: 0.6061 - 62ms/epoch - 31ms/step\n",
      "iteration :80 Target train: tf.Tensor(0.5856298, shape=(), dtype=float32) loss1 tf.Tensor(0.13770324, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.44792658, shape=(), dtype=float32) loss2   tf.Tensor(0.44983357, shape=(), dtype=float32) loss3  tf.Tensor(0.99857056, shape=(), dtype=float32) Target test: tf.Tensor(0.607315, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.5994 - mse: 0.5781 - val_loss: 0.5953 - val_mse: 0.6002 - 62ms/epoch - 31ms/step\n",
      "iteration :81 Target train: tf.Tensor(0.5807313, shape=(), dtype=float32) loss1 tf.Tensor(0.12861785, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.45211342, shape=(), dtype=float32) loss2   tf.Tensor(0.454031, shape=(), dtype=float32) loss3  tf.Tensor(1.0007807, shape=(), dtype=float32) Target test: tf.Tensor(0.6022304, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.5945 - mse: 0.5736 - val_loss: 0.5905 - val_mse: 0.5943 - 62ms/epoch - 31ms/step\n",
      "iteration :82 Target train: tf.Tensor(0.5758988, shape=(), dtype=float32) loss1 tf.Tensor(0.11959085, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.45630798, shape=(), dtype=float32) loss2   tf.Tensor(0.45823607, shape=(), dtype=float32) loss3  tf.Tensor(1.0029774, shape=(), dtype=float32) Target test: tf.Tensor(0.5972355, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.5898 - mse: 0.5692 - val_loss: 0.5858 - val_mse: 0.5885 - 63ms/epoch - 31ms/step\n",
      "iteration :83 Target train: tf.Tensor(0.57113004, shape=(), dtype=float32) loss1 tf.Tensor(0.11061886, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.46051118, shape=(), dtype=float32) loss2   tf.Tensor(0.46244925, shape=(), dtype=float32) loss3  tf.Tensor(1.0051595, shape=(), dtype=float32) Target test: tf.Tensor(0.59233004, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.5851 - mse: 0.5646 - val_loss: 0.5812 - val_mse: 0.5826 - 77ms/epoch - 38ms/step\n",
      "iteration :84 Target train: tf.Tensor(0.5664229, shape=(), dtype=float32) loss1 tf.Tensor(0.10169929, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.4647236, shape=(), dtype=float32) loss2   tf.Tensor(0.46667138, shape=(), dtype=float32) loss3  tf.Tensor(1.0073258, shape=(), dtype=float32) Target test: tf.Tensor(0.58751434, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.5804 - mse: 0.5603 - val_loss: 0.5766 - val_mse: 0.5768 - 97ms/epoch - 48ms/step\n",
      "iteration :85 Target train: tf.Tensor(0.56177586, shape=(), dtype=float32) loss1 tf.Tensor(0.09283006, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.4689458, shape=(), dtype=float32) loss2   tf.Tensor(0.4709029, shape=(), dtype=float32) loss3  tf.Tensor(1.0094754, shape=(), dtype=float32) Target test: tf.Tensor(0.5827883, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.5759 - mse: 0.5561 - val_loss: 0.5721 - val_mse: 0.5709 - 64ms/epoch - 32ms/step\n",
      "iteration :86 Target train: tf.Tensor(0.5571879, shape=(), dtype=float32) loss1 tf.Tensor(0.08400965, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.47317827, shape=(), dtype=float32) loss2   tf.Tensor(0.47514433, shape=(), dtype=float32) loss3  tf.Tensor(1.0116076, shape=(), dtype=float32) Target test: tf.Tensor(0.5781521, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.5714 - mse: 0.5519 - val_loss: 0.5676 - val_mse: 0.5651 - 61ms/epoch - 30ms/step\n",
      "iteration :87 Target train: tf.Tensor(0.55265874, shape=(), dtype=float32) loss1 tf.Tensor(0.075237244, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.4774215, shape=(), dtype=float32) loss2   tf.Tensor(0.47939613, shape=(), dtype=float32) loss3  tf.Tensor(1.013722, shape=(), dtype=float32) Target test: tf.Tensor(0.5736062, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.5669 - mse: 0.5479 - val_loss: 0.5632 - val_mse: 0.5592 - 59ms/epoch - 30ms/step\n",
      "iteration :88 Target train: tf.Tensor(0.54818857, shape=(), dtype=float32) loss1 tf.Tensor(0.06651294, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.48167562, shape=(), dtype=float32) loss2   tf.Tensor(0.48365846, shape=(), dtype=float32) loss3  tf.Tensor(1.0158176, shape=(), dtype=float32) Target test: tf.Tensor(0.56915104, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.5625 - mse: 0.5438 - val_loss: 0.5588 - val_mse: 0.5534 - 63ms/epoch - 31ms/step\n",
      "iteration :89 Target train: tf.Tensor(0.5437781, shape=(), dtype=float32) loss1 tf.Tensor(0.057837248, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.48594087, shape=(), dtype=float32) loss2   tf.Tensor(0.48793143, shape=(), dtype=float32) loss3  tf.Tensor(1.0178946, shape=(), dtype=float32) Target test: tf.Tensor(0.5647873, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.5582 - mse: 0.5400 - val_loss: 0.5546 - val_mse: 0.5477 - 63ms/epoch - 31ms/step\n",
      "iteration :90 Target train: tf.Tensor(0.5394293, shape=(), dtype=float32) loss1 tf.Tensor(0.049212128, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.49021718, shape=(), dtype=float32) loss2   tf.Tensor(0.49221498, shape=(), dtype=float32) loss3  tf.Tensor(1.0199522, shape=(), dtype=float32) Target test: tf.Tensor(0.5605161, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.5539 - mse: 0.5360 - val_loss: 0.5503 - val_mse: 0.5419 - 62ms/epoch - 31ms/step\n",
      "iteration :91 Target train: tf.Tensor(0.53514427, shape=(), dtype=float32) loss1 tf.Tensor(0.040640026, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.49450424, shape=(), dtype=float32) loss2   tf.Tensor(0.49650896, shape=(), dtype=float32) loss3  tf.Tensor(1.02199, shape=(), dtype=float32) Target test: tf.Tensor(0.5563385, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.5497 - mse: 0.5323 - val_loss: 0.5462 - val_mse: 0.5363 - 61ms/epoch - 30ms/step\n",
      "iteration :92 Target train: tf.Tensor(0.530926, shape=(), dtype=float32) loss1 tf.Tensor(0.032124102, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.4988019, shape=(), dtype=float32) loss2   tf.Tensor(0.50081295, shape=(), dtype=float32) loss3  tf.Tensor(1.0240074, shape=(), dtype=float32) Target test: tf.Tensor(0.5522556, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.5455 - mse: 0.5285 - val_loss: 0.5421 - val_mse: 0.5307 - 61ms/epoch - 31ms/step\n",
      "iteration :93 Target train: tf.Tensor(0.52677846, shape=(), dtype=float32) loss1 tf.Tensor(0.023668945, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.5031095, shape=(), dtype=float32) loss2   tf.Tensor(0.5051265, shape=(), dtype=float32) loss3  tf.Tensor(1.0260044, shape=(), dtype=float32) Target test: tf.Tensor(0.54826874, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.5415 - mse: 0.5249 - val_loss: 0.5381 - val_mse: 0.5252 - 85ms/epoch - 42ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iteration :94 Target train: tf.Tensor(0.5227069, shape=(), dtype=float32) loss1 tf.Tensor(0.015280664, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.50742626, shape=(), dtype=float32) loss2   tf.Tensor(0.5094488, shape=(), dtype=float32) loss3  tf.Tensor(1.02798, shape=(), dtype=float32) Target test: tf.Tensor(0.5443794, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.5375 - mse: 0.5213 - val_loss: 0.5342 - val_mse: 0.5198 - 73ms/epoch - 36ms/step\n",
      "iteration :95 Target train: tf.Tensor(0.5187182, shape=(), dtype=float32) loss1 tf.Tensor(0.00696671, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.5117515, shape=(), dtype=float32) loss2   tf.Tensor(0.51377904, shape=(), dtype=float32) loss3  tf.Tensor(1.0299333, shape=(), dtype=float32) Target test: tf.Tensor(0.5405893, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.5335 - mse: 0.5177 - val_loss: 0.5303 - val_mse: 0.5146 - 62ms/epoch - 31ms/step\n",
      "iteration :96 Target train: tf.Tensor(0.5148203, shape=(), dtype=float32) loss1 tf.Tensor(0.0012636185, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.5160839, shape=(), dtype=float32) loss2   tf.Tensor(0.51811594, shape=(), dtype=float32) loss3  tf.Tensor(1.0318629, shape=(), dtype=float32) Target test: tf.Tensor(0.5368999, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.5297 - mse: 0.5143 - val_loss: 0.5266 - val_mse: 0.5094 - 59ms/epoch - 29ms/step\n",
      "iteration :97 Target train: tf.Tensor(0.5110232, shape=(), dtype=float32) loss1 tf.Tensor(0.009398282, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.5204215, shape=(), dtype=float32) loss2   tf.Tensor(0.5224576, shape=(), dtype=float32) loss3  tf.Tensor(1.0337666, shape=(), dtype=float32) Target test: tf.Tensor(0.5333136, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.5260 - mse: 0.5111 - val_loss: 0.5230 - val_mse: 0.5045 - 59ms/epoch - 30ms/step\n",
      "iteration :98 Target train: tf.Tensor(0.507337, shape=(), dtype=float32) loss1 tf.Tensor(0.01742524, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.5247622, shape=(), dtype=float32) loss2   tf.Tensor(0.5268019, shape=(), dtype=float32) loss3  tf.Tensor(1.0356423, shape=(), dtype=float32) Target test: tf.Tensor(0.52983224, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.5224 - mse: 0.5078 - val_loss: 0.5195 - val_mse: 0.4997 - 62ms/epoch - 31ms/step\n",
      "iteration :99 Target train: tf.Tensor(0.50377136, shape=(), dtype=float32) loss1 tf.Tensor(0.025332391, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.52910376, shape=(), dtype=float32) loss2   tf.Tensor(0.53114647, shape=(), dtype=float32) loss3  tf.Tensor(1.0374863, shape=(), dtype=float32) Target test: tf.Tensor(0.5264579, shape=(), dtype=float32)\n",
      "2/2 - 0s - loss: 0.5189 - mse: 0.5047 - val_loss: 0.5161 - val_mse: 0.4952 - 59ms/epoch - 29ms/step\n",
      "iteration :100 Target train: tf.Tensor(0.50033504, shape=(), dtype=float32) loss1 tf.Tensor(0.033108234, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.5334433, shape=(), dtype=float32) loss2   tf.Tensor(0.53548867, shape=(), dtype=float32) loss3  tf.Tensor(1.0392947, shape=(), dtype=float32) Target test: tf.Tensor(0.52319264, shape=(), dtype=float32)\n"
     ]
    }
   ],
   "source": [
    "#print the detail for training process\n",
    "t0 = time.time()\n",
    "history_PQ = [] #collect data for figures\n",
    "for i in range(100):\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",
    "    history = final_model.fit(X_train, y_train, epochs=1, batch_size=256, validation_split=0.25, verbose=2)\n",
    "    i += 1\n",
    "    \n",
    "    Num = 500\n",
    "    #prediction performance on the target training set\n",
    "    NN_out = final_model(RNN_input_final_Train) \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",
    "    #prediction performance on the target testing set\n",
    "    NN_out = final_model(X_test) \n",
    "    loss_final =  tf.math.reduce_mean((NN_out-y_test)**2) # prediction on target\n",
    "    \n",
    "    history_PQ.append([loss11,loss1,loss2, loss3,loss_final])#target training, first_term, second, third, target test\n",
    "    \n",
    "    print(\"iteration :\" + str(i) + \" Target train: \" + str(loss11) + \" loss1 \" + str(loss1))\n",
    "    print(\"loss 12  \" + str(loss12) + \" loss2   \" + str(loss2) + \" loss3  \" + str(loss3)+ \" Target test: \" + str(loss_final))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "4b32fab3",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "from scipy.io import savemat\n",
    "history_PQ = np.array(history_PQ)  # shape: (num_epochs, 5)\n",
    "# Plot each variable\n",
    "plt.figure(figsize=(10, 6))\n",
    "for i in range(5):\n",
    "    plt.plot(history_PQ[:, i], label=f'Variable {i}')\n",
    "\n",
    "plt.xlabel('Epoch')\n",
    "plt.ylabel('Value')\n",
    "plt.title('Five Variables over Epochs')\n",
    "plt.legend()\n",
    "plt.grid(True)\n",
    "plt.tight_layout()\n",
    "plt.show()\n",
    "\n",
    "savemat('history_PQ.mat', {'value': history_PQ})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "8f14a2c7",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Target train:  tf.Tensor(0.50033504, shape=(), dtype=float32)\n",
      "Target test:  tf.Tensor(0.52319264, 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": 23,
   "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": 24,
   "id": "b90b3b96",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Weights (kernel_P1):\n",
      " [array([[ 1.0130728 , -0.10436038,  0.06267904,  0.        ],\n",
      "       [ 0.01307319,  0.8956399 ,  0.06267904,  0.        ],\n",
      "       [ 0.03976395,  0.12674078,  0.9608724 ,  0.        ]],\n",
      "      dtype=float32)]\n",
      "Weights (kernel_P2):\n",
      " [array([[ 0.99794054, -0.10185689,  0.06789407,  0.        ],\n",
      "       [-0.00736877,  0.90779084,  0.06760866,  0.        ],\n",
      "       [ 0.05661688,  0.1243645 ,  0.95127577,  0.        ],\n",
      "       [ 0.        ,  0.        ,  0.        ,  1.        ]],\n",
      "      dtype=float32)]\n",
      "Weights (kernel_P3):\n",
      " [array([[ 0.97295535, -0.0980657 ,  0.07237858],\n",
      "       [-0.02016502,  0.9201074 ,  0.06937293],\n",
      "       [ 0.07065751,  0.12235582,  0.9421826 ],\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": 25,
   "id": "e2032c68",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Weights (kernel_I1):\n",
      " [[ 0.8665027   0.15933904 -0.10878716 -0.20542975  0.          0.\n",
      "   0.          0.        ]\n",
      " [-0.13049118  1.0681834  -0.09791271 -0.11475112  0.          0.\n",
      "   0.          0.        ]\n",
      " [-0.11548394  0.20994197  0.88966715 -0.18210843  0.          0.\n",
      "   0.          0.        ]\n",
      " [ 0.11126662 -0.12318127  0.1095471   1.0238397   0.          0.\n",
      "   0.          0.        ]]\n",
      "Weights (kernel_I2):\n",
      " [[ 0.88152367  0.03741286 -0.09806947 -0.08641354  0.          0.\n",
      "   0.          0.        ]\n",
      " [-0.15385094  1.0604333  -0.12940544 -0.02869535  0.          0.\n",
      "   0.          0.        ]\n",
      " [-0.11141498  0.17513281  0.88961047 -0.09021913  0.          0.\n",
      "   0.          0.        ]\n",
      " [ 0.1371206  -0.11250312  0.14018048  0.97799474  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.9127533  -0.08792392 -0.06969923  0.12289807]\n",
      " [-0.17029081  0.98897606 -0.1532883   0.12408386]\n",
      " [-0.10177797  0.02587279  0.8953261   0.0783761 ]\n",
      " [ 0.14853446  0.01590346  0.15474765  0.8908408 ]\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.0130728  -0.10436038  0.06267904  0.        ]\n",
      " [ 0.01307319  0.8956399   0.06267904  0.        ]\n",
      " [ 0.03976395  0.12674078  0.9608724   0.        ]]\n",
      "Weights (kernel_P2):\n",
      " [[ 0.99794054 -0.10185689  0.06789407  0.        ]\n",
      " [-0.00736877  0.90779084  0.06760866  0.        ]\n",
      " [ 0.05661688  0.1243645   0.95127577  0.        ]\n",
      " [ 0.          0.          0.          1.        ]]\n",
      "Weights (kernel_P3):\n",
      " [[ 0.97295535 -0.0980657   0.07237858]\n",
      " [-0.02016502  0.9201074   0.06937293]\n",
      " [ 0.07065751  0.12235582  0.9421826 ]\n",
      " [ 0.          0.          0.        ]]\n",
      "Weights Final input P:\n",
      " [[ 0.60853374  0.12930395 -0.33074516 -0.14474809]\n",
      " [-0.44571093  1.128351   -0.37611791 -0.02278988]\n",
      " [-0.41699702  0.42831874  0.5897103  -0.1506182 ]\n",
      " [ 0.38302872 -0.21953562  0.38974404  0.89960074]]\n",
      "Weights Final output Q:\n",
      " [[ 1.000254   -0.2596593   0.17463116]\n",
      " [ 0.00175349  0.7678767   0.17164169]\n",
      " [ 0.15136348  0.31617075  0.89455605]]\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": 26,
   "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": 27,
   "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": 28,
   "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_7 (Dense)             (None, None, 4)           16        \n",
      "                                                                 \n",
      " sequential (Sequential)     (None, 5, 3)              387       \n",
      "                                                                 \n",
      " dense_8 (Dense)             (None, 5, 3)              9         \n",
      "                                                                 \n",
      "=================================================================\n",
      "Total params: 412\n",
      "Trainable params: 412\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": 29,
   "id": "55fbdca2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2/2 - 0s - loss: 0.4966 - mse: 0.4966 - val_loss: 0.4546 - val_mse: 0.4546 - 497ms/epoch - 249ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.4665 - mse: 0.4665\n",
      "38/38 [==============================] - 0s 687us/step - loss: 0.4913 - mse: 0.4913\n",
      "2/2 - 0s - loss: 0.4680 - mse: 0.4680 - val_loss: 0.4360 - val_mse: 0.4360 - 30ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.4509 - mse: 0.4509\n",
      "38/38 [==============================] - 0s 671us/step - loss: 0.4757 - mse: 0.4757\n",
      "2/2 - 0s - loss: 0.4540 - mse: 0.4540 - val_loss: 0.4236 - val_mse: 0.4236 - 28ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.4393 - mse: 0.4393\n",
      "38/38 [==============================] - 0s 623us/step - loss: 0.4634 - mse: 0.4634\n",
      "2/2 - 0s - loss: 0.4430 - mse: 0.4430 - val_loss: 0.4114 - val_mse: 0.4114 - 27ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.4275 - mse: 0.4275\n",
      "38/38 [==============================] - 0s 675us/step - loss: 0.4505 - mse: 0.4505\n",
      "2/2 - 0s - loss: 0.4310 - mse: 0.4310 - val_loss: 0.4001 - val_mse: 0.4001 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.4165 - mse: 0.4165\n",
      "38/38 [==============================] - 0s 629us/step - loss: 0.4385 - mse: 0.4385\n",
      "2/2 - 0s - loss: 0.4204 - mse: 0.4204 - val_loss: 0.3906 - val_mse: 0.3906 - 27ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.4073 - mse: 0.4073\n",
      "38/38 [==============================] - 0s 719us/step - loss: 0.4283 - mse: 0.4283\n",
      "2/2 - 0s - loss: 0.4117 - mse: 0.4117 - val_loss: 0.3835 - val_mse: 0.3835 - 28ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.4005 - mse: 0.4005\n",
      "38/38 [==============================] - 0s 687us/step - loss: 0.4207 - mse: 0.4207\n",
      "2/2 - 0s - loss: 0.4052 - mse: 0.4052 - val_loss: 0.3777 - val_mse: 0.3777 - 28ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.3950 - mse: 0.3950\n",
      "38/38 [==============================] - 0s 657us/step - loss: 0.4147 - mse: 0.4147\n",
      "2/2 - 0s - loss: 0.3999 - mse: 0.3999 - val_loss: 0.3724 - val_mse: 0.3724 - 27ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.3898 - mse: 0.3898\n",
      "38/38 [==============================] - 0s 678us/step - loss: 0.4094 - mse: 0.4094\n",
      "2/2 - 0s - loss: 0.3948 - mse: 0.3948 - val_loss: 0.3674 - val_mse: 0.3674 - 28ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.3849 - mse: 0.3849\n",
      "38/38 [==============================] - 0s 624us/step - loss: 0.4046 - mse: 0.4046\n",
      "2/2 - 0s - loss: 0.3899 - mse: 0.3899 - val_loss: 0.3624 - val_mse: 0.3624 - 27ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.3802 - mse: 0.3802\n",
      "38/38 [==============================] - 0s 644us/step - loss: 0.3999 - mse: 0.3999\n",
      "2/2 - 0s - loss: 0.3854 - mse: 0.3854 - val_loss: 0.3580 - val_mse: 0.3580 - 28ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.3759 - mse: 0.3759\n",
      "38/38 [==============================] - 0s 651us/step - loss: 0.3958 - mse: 0.3958\n",
      "2/2 - 0s - loss: 0.3812 - mse: 0.3812 - val_loss: 0.3539 - val_mse: 0.3539 - 34ms/epoch - 17ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.3720 - mse: 0.3720\n",
      "38/38 [==============================] - 0s 667us/step - loss: 0.3921 - mse: 0.3921\n",
      "2/2 - 0s - loss: 0.3775 - mse: 0.3775 - val_loss: 0.3501 - val_mse: 0.3501 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.3684 - mse: 0.3684\n",
      "38/38 [==============================] - 0s 555us/step - loss: 0.3886 - mse: 0.3886\n",
      "2/2 - 0s - loss: 0.3740 - mse: 0.3740 - val_loss: 0.3464 - val_mse: 0.3464 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.3649 - mse: 0.3649\n",
      "38/38 [==============================] - 0s 578us/step - loss: 0.3852 - mse: 0.3852\n",
      "2/2 - 0s - loss: 0.3705 - mse: 0.3705 - val_loss: 0.3429 - val_mse: 0.3429 - 29ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.3616 - mse: 0.3616\n",
      "38/38 [==============================] - 0s 668us/step - loss: 0.3821 - mse: 0.3821\n",
      "2/2 - 0s - loss: 0.3673 - mse: 0.3673 - val_loss: 0.3394 - val_mse: 0.3394 - 29ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.3584 - mse: 0.3584\n",
      "38/38 [==============================] - 0s 600us/step - loss: 0.3791 - mse: 0.3791\n",
      "2/2 - 0s - loss: 0.3642 - mse: 0.3642 - val_loss: 0.3362 - val_mse: 0.3362 - 31ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.3554 - mse: 0.3554\n",
      "38/38 [==============================] - 0s 581us/step - loss: 0.3763 - mse: 0.3763\n",
      "2/2 - 0s - loss: 0.3613 - mse: 0.3613 - val_loss: 0.3334 - val_mse: 0.3334 - 29ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.3528 - mse: 0.3528\n",
      "38/38 [==============================] - 0s 702us/step - loss: 0.3738 - mse: 0.3738\n",
      "2/2 - 0s - loss: 0.3589 - mse: 0.3589 - val_loss: 0.3307 - val_mse: 0.3307 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.3503 - mse: 0.3503\n",
      "38/38 [==============================] - 0s 618us/step - loss: 0.3715 - mse: 0.3715\n",
      "2/2 - 0s - loss: 0.3565 - mse: 0.3565 - val_loss: 0.3282 - val_mse: 0.3282 - 31ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.3479 - mse: 0.3479\n",
      "38/38 [==============================] - 0s 611us/step - loss: 0.3694 - mse: 0.3694\n",
      "2/2 - 0s - loss: 0.3542 - mse: 0.3542 - val_loss: 0.3259 - val_mse: 0.3259 - 27ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.3457 - mse: 0.3457\n",
      "38/38 [==============================] - 0s 658us/step - loss: 0.3673 - mse: 0.3673\n",
      "2/2 - 0s - loss: 0.3519 - mse: 0.3519 - val_loss: 0.3236 - val_mse: 0.3236 - 30ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.3435 - mse: 0.3435\n",
      "38/38 [==============================] - 0s 622us/step - loss: 0.3653 - mse: 0.3653\n",
      "2/2 - 0s - loss: 0.3498 - mse: 0.3498 - val_loss: 0.3214 - val_mse: 0.3214 - 32ms/epoch - 16ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.3414 - mse: 0.3414\n",
      "38/38 [==============================] - 0s 607us/step - loss: 0.3633 - mse: 0.3633\n",
      "2/2 - 0s - loss: 0.3477 - mse: 0.3477 - val_loss: 0.3192 - val_mse: 0.3192 - 30ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.3394 - mse: 0.3394\n",
      "38/38 [==============================] - 0s 636us/step - loss: 0.3614 - mse: 0.3614\n",
      "2/2 - 0s - loss: 0.3458 - mse: 0.3458 - val_loss: 0.3172 - val_mse: 0.3172 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.3374 - mse: 0.3374\n",
      "38/38 [==============================] - 0s 642us/step - loss: 0.3596 - mse: 0.3596\n",
      "2/2 - 0s - loss: 0.3439 - mse: 0.3439 - val_loss: 0.3152 - val_mse: 0.3152 - 27ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.3356 - mse: 0.3356\n",
      "38/38 [==============================] - 0s 670us/step - loss: 0.3579 - mse: 0.3579\n",
      "2/2 - 0s - loss: 0.3420 - mse: 0.3420 - val_loss: 0.3132 - val_mse: 0.3132 - 30ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.3337 - mse: 0.3337\n",
      "38/38 [==============================] - 0s 643us/step - loss: 0.3562 - mse: 0.3562\n",
      "2/2 - 0s - loss: 0.3403 - mse: 0.3403 - val_loss: 0.3113 - val_mse: 0.3113 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.3319 - mse: 0.3319\n",
      "38/38 [==============================] - 0s 620us/step - loss: 0.3545 - mse: 0.3545\n",
      "2/2 - 0s - loss: 0.3385 - mse: 0.3385 - val_loss: 0.3095 - val_mse: 0.3095 - 28ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.3301 - mse: 0.3301\n",
      "38/38 [==============================] - 0s 593us/step - loss: 0.3528 - mse: 0.3528\n",
      "2/2 - 0s - loss: 0.3368 - mse: 0.3368 - val_loss: 0.3077 - val_mse: 0.3077 - 27ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.3284 - mse: 0.3284\n",
      "38/38 [==============================] - 0s 748us/step - loss: 0.3513 - mse: 0.3513\n",
      "2/2 - 0s - loss: 0.3351 - mse: 0.3351 - val_loss: 0.3059 - val_mse: 0.3059 - 26ms/epoch - 13ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2/2 [==============================] - 0s 1ms/step - loss: 0.3267 - mse: 0.3267\n",
      "38/38 [==============================] - 0s 651us/step - loss: 0.3497 - mse: 0.3497\n",
      "2/2 - 0s - loss: 0.3333 - mse: 0.3333 - val_loss: 0.3041 - val_mse: 0.3041 - 32ms/epoch - 16ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.3250 - mse: 0.3250\n",
      "38/38 [==============================] - 0s 624us/step - loss: 0.3480 - mse: 0.3480\n",
      "2/2 - 0s - loss: 0.3316 - mse: 0.3316 - val_loss: 0.3022 - val_mse: 0.3022 - 25ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.3232 - mse: 0.3232\n",
      "38/38 [==============================] - 0s 596us/step - loss: 0.3463 - mse: 0.3463\n",
      "2/2 - 0s - loss: 0.3300 - mse: 0.3300 - val_loss: 0.3003 - val_mse: 0.3003 - 31ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.3215 - mse: 0.3215\n",
      "38/38 [==============================] - 0s 625us/step - loss: 0.3447 - mse: 0.3447\n",
      "2/2 - 0s - loss: 0.3283 - mse: 0.3283 - val_loss: 0.2985 - val_mse: 0.2985 - 27ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.3197 - mse: 0.3197\n",
      "38/38 [==============================] - 0s 629us/step - loss: 0.3430 - mse: 0.3430\n",
      "2/2 - 0s - loss: 0.3266 - mse: 0.3266 - val_loss: 0.2966 - val_mse: 0.2966 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.3179 - mse: 0.3179\n",
      "38/38 [==============================] - 0s 649us/step - loss: 0.3412 - mse: 0.3412\n",
      "2/2 - 0s - loss: 0.3247 - mse: 0.3247 - val_loss: 0.2948 - val_mse: 0.2948 - 27ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.3162 - mse: 0.3162\n",
      "38/38 [==============================] - 0s 601us/step - loss: 0.3394 - mse: 0.3394\n",
      "2/2 - 0s - loss: 0.3231 - mse: 0.3231 - val_loss: 0.2928 - val_mse: 0.2928 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.3143 - mse: 0.3143\n",
      "38/38 [==============================] - 0s 642us/step - loss: 0.3374 - mse: 0.3374\n",
      "2/2 - 0s - loss: 0.3212 - mse: 0.3212 - val_loss: 0.2909 - val_mse: 0.2909 - 27ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.3125 - mse: 0.3125\n",
      "38/38 [==============================] - 0s 609us/step - loss: 0.3355 - mse: 0.3355\n",
      "2/2 - 0s - loss: 0.3194 - mse: 0.3194 - val_loss: 0.2889 - val_mse: 0.2889 - 29ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.3106 - mse: 0.3106\n",
      "38/38 [==============================] - 0s 566us/step - loss: 0.3336 - mse: 0.3336\n",
      "2/2 - 0s - loss: 0.3175 - mse: 0.3175 - val_loss: 0.2869 - val_mse: 0.2869 - 31ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.3086 - mse: 0.3086\n",
      "38/38 [==============================] - 0s 586us/step - loss: 0.3316 - mse: 0.3316\n",
      "2/2 - 0s - loss: 0.3156 - mse: 0.3156 - val_loss: 0.2849 - val_mse: 0.2849 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.3067 - mse: 0.3067\n",
      "38/38 [==============================] - 0s 611us/step - loss: 0.3295 - mse: 0.3295\n",
      "2/2 - 0s - loss: 0.3135 - mse: 0.3135 - val_loss: 0.2829 - val_mse: 0.2829 - 27ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.3046 - mse: 0.3046\n",
      "38/38 [==============================] - 0s 699us/step - loss: 0.3274 - mse: 0.3274\n",
      "2/2 - 0s - loss: 0.3116 - mse: 0.3116 - val_loss: 0.2807 - val_mse: 0.2807 - 29ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.3024 - mse: 0.3024\n",
      "38/38 [==============================] - 0s 600us/step - loss: 0.3251 - mse: 0.3251\n",
      "2/2 - 0s - loss: 0.3093 - mse: 0.3093 - val_loss: 0.2784 - val_mse: 0.2784 - 28ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.3002 - mse: 0.3002\n",
      "38/38 [==============================] - 0s 718us/step - loss: 0.3228 - mse: 0.3228\n",
      "2/2 - 0s - loss: 0.3072 - mse: 0.3072 - val_loss: 0.2760 - val_mse: 0.2760 - 27ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.2979 - mse: 0.2979\n",
      "38/38 [==============================] - 0s 638us/step - loss: 0.3203 - mse: 0.3203\n",
      "2/2 - 0s - loss: 0.3048 - mse: 0.3048 - val_loss: 0.2736 - val_mse: 0.2736 - 28ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 3ms/step - loss: 0.2954 - mse: 0.2954\n",
      "38/38 [==============================] - 0s 585us/step - loss: 0.3177 - mse: 0.3177\n",
      "2/2 - 0s - loss: 0.3024 - mse: 0.3024 - val_loss: 0.2710 - val_mse: 0.2710 - 31ms/epoch - 16ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.2929 - mse: 0.2929\n",
      "38/38 [==============================] - 0s 591us/step - loss: 0.3150 - mse: 0.3150\n",
      "2/2 - 0s - loss: 0.2997 - mse: 0.2997 - val_loss: 0.2684 - val_mse: 0.2684 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.2902 - mse: 0.2902\n",
      "38/38 [==============================] - 0s 689us/step - loss: 0.3122 - mse: 0.3122\n",
      "2/2 - 0s - loss: 0.2971 - mse: 0.2971 - val_loss: 0.2655 - val_mse: 0.2655 - 32ms/epoch - 16ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.2873 - mse: 0.2873\n",
      "38/38 [==============================] - 0s 645us/step - loss: 0.3091 - mse: 0.3091\n",
      "2/2 - 0s - loss: 0.2941 - mse: 0.2941 - val_loss: 0.2624 - val_mse: 0.2624 - 29ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.2842 - mse: 0.2842\n",
      "38/38 [==============================] - 0s 621us/step - loss: 0.3058 - mse: 0.3058\n",
      "2/2 - 0s - loss: 0.2910 - mse: 0.2910 - val_loss: 0.2592 - val_mse: 0.2592 - 27ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.2810 - mse: 0.2810\n",
      "38/38 [==============================] - 0s 565us/step - loss: 0.3023 - mse: 0.3023\n",
      "2/2 - 0s - loss: 0.2878 - mse: 0.2878 - val_loss: 0.2557 - val_mse: 0.2557 - 28ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.2775 - mse: 0.2775\n",
      "38/38 [==============================] - 0s 600us/step - loss: 0.2986 - mse: 0.2986\n",
      "2/2 - 0s - loss: 0.2841 - mse: 0.2841 - val_loss: 0.2521 - val_mse: 0.2521 - 27ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.2739 - mse: 0.2739\n",
      "38/38 [==============================] - 0s 643us/step - loss: 0.2946 - mse: 0.2946\n",
      "2/2 - 0s - loss: 0.2805 - mse: 0.2805 - val_loss: 0.2483 - val_mse: 0.2483 - 27ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.2700 - mse: 0.2700\n",
      "38/38 [==============================] - 0s 619us/step - loss: 0.2904 - mse: 0.2904\n",
      "2/2 - 0s - loss: 0.2766 - mse: 0.2766 - val_loss: 0.2443 - val_mse: 0.2443 - 25ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.2658 - mse: 0.2658\n",
      "38/38 [==============================] - 0s 602us/step - loss: 0.2857 - mse: 0.2857\n",
      "2/2 - 0s - loss: 0.2723 - mse: 0.2723 - val_loss: 0.2400 - val_mse: 0.2400 - 25ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.2614 - mse: 0.2614\n",
      "38/38 [==============================] - 0s 618us/step - loss: 0.2807 - mse: 0.2807\n",
      "2/2 - 0s - loss: 0.2679 - mse: 0.2679 - val_loss: 0.2355 - val_mse: 0.2355 - 31ms/epoch - 16ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.2567 - mse: 0.2567\n",
      "38/38 [==============================] - 0s 579us/step - loss: 0.2753 - mse: 0.2753\n",
      "2/2 - 0s - loss: 0.2630 - mse: 0.2630 - val_loss: 0.2308 - val_mse: 0.2308 - 33ms/epoch - 16ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.2517 - mse: 0.2517\n",
      "38/38 [==============================] - 0s 634us/step - loss: 0.2696 - mse: 0.2696\n",
      "2/2 - 0s - loss: 0.2578 - mse: 0.2578 - val_loss: 0.2258 - val_mse: 0.2258 - 29ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.2464 - mse: 0.2464\n",
      "38/38 [==============================] - 0s 608us/step - loss: 0.2636 - mse: 0.2636\n",
      "2/2 - 0s - loss: 0.2523 - mse: 0.2523 - val_loss: 0.2206 - val_mse: 0.2206 - 31ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.2408 - mse: 0.2408\n",
      "38/38 [==============================] - 0s 602us/step - loss: 0.2572 - mse: 0.2572\n",
      "2/2 - 0s - loss: 0.2466 - mse: 0.2466 - val_loss: 0.2151 - val_mse: 0.2151 - 32ms/epoch - 16ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.2347 - mse: 0.2347\n",
      "38/38 [==============================] - 0s 651us/step - loss: 0.2504 - mse: 0.2504\n",
      "2/2 - 0s - loss: 0.2402 - mse: 0.2402 - val_loss: 0.2094 - val_mse: 0.2094 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.2282 - mse: 0.2282\n",
      "38/38 [==============================] - 0s 654us/step - loss: 0.2431 - mse: 0.2431\n",
      "2/2 - 0s - loss: 0.2334 - mse: 0.2334 - val_loss: 0.2035 - val_mse: 0.2035 - 28ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.2214 - mse: 0.2214\n",
      "38/38 [==============================] - 0s 738us/step - loss: 0.2355 - mse: 0.2355\n",
      "2/2 - 0s - loss: 0.2263 - mse: 0.2263 - val_loss: 0.1974 - val_mse: 0.1974 - 27ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.2143 - mse: 0.2143\n",
      "38/38 [==============================] - 0s 682us/step - loss: 0.2274 - mse: 0.2274\n",
      "2/2 - 0s - loss: 0.2189 - mse: 0.2189 - val_loss: 0.1911 - val_mse: 0.1911 - 28ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.2068 - mse: 0.2068\n",
      "38/38 [==============================] - 0s 651us/step - loss: 0.2191 - mse: 0.2191\n",
      "2/2 - 0s - loss: 0.2106 - mse: 0.2106 - val_loss: 0.1848 - val_mse: 0.1848 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.1991 - mse: 0.1991\n",
      "38/38 [==============================] - 0s 648us/step - loss: 0.2106 - mse: 0.2106\n",
      "2/2 - 0s - loss: 0.2026 - mse: 0.2026 - val_loss: 0.1784 - val_mse: 0.1784 - 30ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.1913 - mse: 0.1913\n",
      "38/38 [==============================] - 0s 599us/step - loss: 0.2019 - mse: 0.2019\n",
      "2/2 - 0s - loss: 0.1942 - mse: 0.1942 - val_loss: 0.1716 - val_mse: 0.1716 - 27ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.1832 - mse: 0.1832\n",
      "38/38 [==============================] - 0s 724us/step - loss: 0.1929 - mse: 0.1929\n",
      "2/2 - 0s - loss: 0.1859 - mse: 0.1859 - val_loss: 0.1648 - val_mse: 0.1648 - 30ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.1751 - mse: 0.1751\n",
      "38/38 [==============================] - 0s 587us/step - loss: 0.1839 - mse: 0.1839\n",
      "2/2 - 0s - loss: 0.1773 - mse: 0.1773 - val_loss: 0.1579 - val_mse: 0.1579 - 29ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.1671 - mse: 0.1671\n",
      "38/38 [==============================] - 0s 597us/step - loss: 0.1750 - mse: 0.1750\n",
      "2/2 - 0s - loss: 0.1685 - mse: 0.1685 - val_loss: 0.1510 - val_mse: 0.1510 - 27ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.1590 - mse: 0.1590\n",
      "38/38 [==============================] - 0s 703us/step - loss: 0.1662 - mse: 0.1662\n",
      "2/2 - 0s - loss: 0.1604 - mse: 0.1604 - val_loss: 0.1442 - val_mse: 0.1442 - 27ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.1510 - mse: 0.1510\n",
      "38/38 [==============================] - 0s 634us/step - loss: 0.1575 - mse: 0.1575\n",
      "2/2 - 0s - loss: 0.1522 - mse: 0.1522 - val_loss: 0.1376 - val_mse: 0.1376 - 27ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.1432 - mse: 0.1432\n",
      "38/38 [==============================] - 0s 603us/step - loss: 0.1492 - mse: 0.1492\n",
      "2/2 - 0s - loss: 0.1438 - mse: 0.1438 - val_loss: 0.1312 - val_mse: 0.1312 - 27ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.1358 - mse: 0.1358\n",
      "38/38 [==============================] - 0s 564us/step - loss: 0.1413 - mse: 0.1413\n",
      "2/2 - 0s - loss: 0.1362 - mse: 0.1362 - val_loss: 0.1252 - val_mse: 0.1252 - 27ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.1286 - mse: 0.1286\n",
      "38/38 [==============================] - 0s 617us/step - loss: 0.1337 - mse: 0.1337\n",
      "2/2 - 0s - loss: 0.1287 - mse: 0.1287 - val_loss: 0.1196 - val_mse: 0.1196 - 31ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.1220 - mse: 0.1220\n",
      "38/38 [==============================] - 0s 681us/step - loss: 0.1266 - mse: 0.1266\n",
      "2/2 - 0s - loss: 0.1214 - mse: 0.1214 - val_loss: 0.1144 - val_mse: 0.1144 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.1158 - mse: 0.1158\n",
      "38/38 [==============================] - 0s 619us/step - loss: 0.1201 - mse: 0.1201\n",
      "2/2 - 0s - loss: 0.1154 - mse: 0.1154 - val_loss: 0.1096 - val_mse: 0.1096 - 24ms/epoch - 12ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.1101 - mse: 0.1101\n",
      "38/38 [==============================] - 0s 584us/step - loss: 0.1142 - mse: 0.1142\n",
      "2/2 - 0s - loss: 0.1096 - mse: 0.1096 - val_loss: 0.1052 - val_mse: 0.1052 - 25ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.1049 - mse: 0.1049\n",
      "38/38 [==============================] - 0s 621us/step - loss: 0.1087 - mse: 0.1087\n",
      "2/2 - 0s - loss: 0.1041 - mse: 0.1041 - val_loss: 0.1011 - val_mse: 0.1011 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.1002 - mse: 0.1002\n",
      "38/38 [==============================] - 0s 641us/step - loss: 0.1038 - mse: 0.1038\n",
      "2/2 - 0s - loss: 0.0992 - mse: 0.0992 - val_loss: 0.0971 - val_mse: 0.0971 - 29ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0959 - mse: 0.0959\n",
      "38/38 [==============================] - 0s 563us/step - loss: 0.0993 - mse: 0.0993\n",
      "2/2 - 0s - loss: 0.0948 - mse: 0.0948 - val_loss: 0.0934 - val_mse: 0.0934 - 28ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0919 - mse: 0.0919\n",
      "38/38 [==============================] - 0s 694us/step - loss: 0.0951 - mse: 0.0951\n",
      "2/2 - 0s - loss: 0.0907 - mse: 0.0907 - val_loss: 0.0899 - val_mse: 0.0899 - 27ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0882 - mse: 0.0882\n",
      "38/38 [==============================] - 0s 733us/step - loss: 0.0913 - mse: 0.0913\n",
      "2/2 - 0s - loss: 0.0871 - mse: 0.0871 - val_loss: 0.0865 - val_mse: 0.0865 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0846 - mse: 0.0846\n",
      "38/38 [==============================] - 0s 598us/step - loss: 0.0876 - mse: 0.0876\n",
      "2/2 - 0s - loss: 0.0834 - mse: 0.0834 - val_loss: 0.0832 - val_mse: 0.0832 - 32ms/epoch - 16ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0813 - mse: 0.0813\n",
      "38/38 [==============================] - 0s 587us/step - loss: 0.0842 - mse: 0.0842\n",
      "2/2 - 0s - loss: 0.0801 - mse: 0.0801 - val_loss: 0.0800 - val_mse: 0.0800 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0781 - mse: 0.0781\n",
      "38/38 [==============================] - 0s 658us/step - loss: 0.0809 - mse: 0.0809\n",
      "2/2 - 0s - loss: 0.0770 - mse: 0.0770 - val_loss: 0.0768 - val_mse: 0.0768 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0750 - mse: 0.0750\n",
      "38/38 [==============================] - 0s 624us/step - loss: 0.0778 - mse: 0.0778\n",
      "2/2 - 0s - loss: 0.0740 - mse: 0.0740 - val_loss: 0.0738 - val_mse: 0.0738 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0721 - mse: 0.0721\n",
      "38/38 [==============================] - 0s 589us/step - loss: 0.0748 - mse: 0.0748\n",
      "2/2 - 0s - loss: 0.0711 - mse: 0.0711 - val_loss: 0.0709 - val_mse: 0.0709 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0694 - mse: 0.0694\n",
      "38/38 [==============================] - 0s 668us/step - loss: 0.0720 - mse: 0.0720\n",
      "2/2 - 0s - loss: 0.0684 - mse: 0.0684 - val_loss: 0.0681 - val_mse: 0.0681 - 27ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0667 - mse: 0.0667\n",
      "38/38 [==============================] - 0s 667us/step - loss: 0.0693 - mse: 0.0693\n",
      "2/2 - 0s - loss: 0.0659 - mse: 0.0659 - val_loss: 0.0654 - val_mse: 0.0654 - 30ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0642 - mse: 0.0642\n",
      "38/38 [==============================] - 0s 602us/step - loss: 0.0668 - mse: 0.0668\n",
      "2/2 - 0s - loss: 0.0634 - mse: 0.0634 - val_loss: 0.0630 - val_mse: 0.0630 - 28ms/epoch - 14ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0619 - mse: 0.0619\n",
      "38/38 [==============================] - 0s 684us/step - loss: 0.0644 - mse: 0.0644\n",
      "2/2 - 0s - loss: 0.0611 - mse: 0.0611 - val_loss: 0.0606 - val_mse: 0.0606 - 28ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0596 - mse: 0.0596\n",
      "38/38 [==============================] - 0s 567us/step - loss: 0.0622 - mse: 0.0622\n",
      "2/2 - 0s - loss: 0.0590 - mse: 0.0590 - val_loss: 0.0583 - val_mse: 0.0583 - 30ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 3ms/step - loss: 0.0575 - mse: 0.0575\n",
      "38/38 [==============================] - 0s 727us/step - loss: 0.0600 - mse: 0.0600\n",
      "2/2 - 0s - loss: 0.0569 - mse: 0.0569 - val_loss: 0.0562 - val_mse: 0.0562 - 28ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0555 - mse: 0.0555\n",
      "38/38 [==============================] - 0s 679us/step - loss: 0.0580 - mse: 0.0580\n",
      "2/2 - 0s - loss: 0.0549 - mse: 0.0549 - val_loss: 0.0542 - val_mse: 0.0542 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0536 - mse: 0.0536\n",
      "38/38 [==============================] - 0s 631us/step - loss: 0.0561 - mse: 0.0561\n",
      "2/2 - 0s - loss: 0.0531 - mse: 0.0531 - val_loss: 0.0522 - val_mse: 0.0522 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0517 - mse: 0.0517\n",
      "38/38 [==============================] - 0s 585us/step - loss: 0.0542 - mse: 0.0542\n",
      "2/2 - 0s - loss: 0.0513 - mse: 0.0513 - val_loss: 0.0505 - val_mse: 0.0505 - 27ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0500 - mse: 0.0500\n",
      "38/38 [==============================] - 0s 609us/step - loss: 0.0524 - mse: 0.0524\n",
      "2/2 - 0s - loss: 0.0496 - mse: 0.0496 - val_loss: 0.0488 - val_mse: 0.0488 - 28ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0484 - mse: 0.0484\n",
      "38/38 [==============================] - 0s 584us/step - loss: 0.0508 - mse: 0.0508\n",
      "2/2 - 0s - loss: 0.0480 - mse: 0.0480 - val_loss: 0.0472 - val_mse: 0.0472 - 27ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0468 - mse: 0.0468\n",
      "38/38 [==============================] - 0s 654us/step - loss: 0.0492 - mse: 0.0492\n",
      "2/2 - 0s - loss: 0.0465 - mse: 0.0465 - val_loss: 0.0457 - val_mse: 0.0457 - 27ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0453 - mse: 0.0453\n",
      "38/38 [==============================] - 0s 631us/step - loss: 0.0477 - mse: 0.0477\n",
      "2/2 - 0s - loss: 0.0450 - mse: 0.0450 - val_loss: 0.0442 - val_mse: 0.0442 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0439 - mse: 0.0439\n",
      "38/38 [==============================] - 0s 610us/step - loss: 0.0462 - mse: 0.0462\n",
      "2/2 - 0s - loss: 0.0435 - mse: 0.0435 - val_loss: 0.0428 - val_mse: 0.0428 - 31ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0425 - mse: 0.0425\n",
      "38/38 [==============================] - 0s 550us/step - loss: 0.0448 - mse: 0.0448\n",
      "2/2 - 0s - loss: 0.0422 - mse: 0.0422 - val_loss: 0.0414 - val_mse: 0.0414 - 31ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0411 - mse: 0.0411\n",
      "38/38 [==============================] - 0s 619us/step - loss: 0.0433 - mse: 0.0433\n",
      "2/2 - 0s - loss: 0.0408 - mse: 0.0408 - val_loss: 0.0401 - val_mse: 0.0401 - 27ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0398 - mse: 0.0398\n",
      "38/38 [==============================] - 0s 618us/step - loss: 0.0420 - mse: 0.0420\n",
      "2/2 - 0s - loss: 0.0395 - mse: 0.0395 - val_loss: 0.0390 - val_mse: 0.0390 - 27ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0387 - mse: 0.0387\n",
      "38/38 [==============================] - 0s 585us/step - loss: 0.0408 - mse: 0.0408\n",
      "2/2 - 0s - loss: 0.0384 - mse: 0.0384 - val_loss: 0.0377 - val_mse: 0.0377 - 25ms/epoch - 12ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0374 - mse: 0.0374\n",
      "38/38 [==============================] - 0s 658us/step - loss: 0.0395 - mse: 0.0395\n",
      "2/2 - 0s - loss: 0.0371 - mse: 0.0371 - val_loss: 0.0364 - val_mse: 0.0364 - 28ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0362 - mse: 0.0362\n",
      "38/38 [==============================] - 0s 614us/step - loss: 0.0382 - mse: 0.0382\n",
      "2/2 - 0s - loss: 0.0360 - mse: 0.0360 - val_loss: 0.0353 - val_mse: 0.0353 - 25ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0351 - mse: 0.0351\n",
      "38/38 [==============================] - 0s 581us/step - loss: 0.0371 - mse: 0.0371\n",
      "2/2 - 0s - loss: 0.0349 - mse: 0.0349 - val_loss: 0.0343 - val_mse: 0.0343 - 27ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0340 - mse: 0.0340\n",
      "38/38 [==============================] - 0s 554us/step - loss: 0.0360 - mse: 0.0360\n",
      "2/2 - 0s - loss: 0.0338 - mse: 0.0338 - val_loss: 0.0334 - val_mse: 0.0334 - 28ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 3ms/step - loss: 0.0331 - mse: 0.0331\n",
      "38/38 [==============================] - 0s 564us/step - loss: 0.0349 - mse: 0.0349\n",
      "2/2 - 0s - loss: 0.0328 - mse: 0.0328 - val_loss: 0.0323 - val_mse: 0.0323 - 29ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0320 - mse: 0.0320\n",
      "38/38 [==============================] - 0s 589us/step - loss: 0.0339 - mse: 0.0339\n",
      "2/2 - 0s - loss: 0.0318 - mse: 0.0318 - val_loss: 0.0313 - val_mse: 0.0313 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0311 - mse: 0.0311\n",
      "38/38 [==============================] - 0s 605us/step - loss: 0.0329 - mse: 0.0329\n",
      "2/2 - 0s - loss: 0.0309 - mse: 0.0309 - val_loss: 0.0304 - val_mse: 0.0304 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0302 - mse: 0.0302\n",
      "38/38 [==============================] - 0s 734us/step - loss: 0.0320 - mse: 0.0320\n",
      "2/2 - 0s - loss: 0.0300 - mse: 0.0300 - val_loss: 0.0295 - val_mse: 0.0295 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0293 - mse: 0.0293\n",
      "38/38 [==============================] - 0s 628us/step - loss: 0.0310 - mse: 0.0310\n",
      "2/2 - 0s - loss: 0.0291 - mse: 0.0291 - val_loss: 0.0287 - val_mse: 0.0287 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0285 - mse: 0.0285\n",
      "38/38 [==============================] - 0s 722us/step - loss: 0.0301 - mse: 0.0301\n",
      "2/2 - 0s - loss: 0.0283 - mse: 0.0283 - val_loss: 0.0280 - val_mse: 0.0280 - 28ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0277 - mse: 0.0277\n",
      "38/38 [==============================] - 0s 634us/step - loss: 0.0293 - mse: 0.0293\n",
      "2/2 - 0s - loss: 0.0275 - mse: 0.0275 - val_loss: 0.0272 - val_mse: 0.0272 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0270 - mse: 0.0270\n",
      "38/38 [==============================] - 0s 663us/step - loss: 0.0285 - mse: 0.0285\n",
      "2/2 - 0s - loss: 0.0268 - mse: 0.0268 - val_loss: 0.0264 - val_mse: 0.0264 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0262 - mse: 0.0262\n",
      "38/38 [==============================] - 0s 608us/step - loss: 0.0278 - mse: 0.0278\n",
      "2/2 - 0s - loss: 0.0261 - mse: 0.0261 - val_loss: 0.0258 - val_mse: 0.0258 - 25ms/epoch - 12ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0255 - mse: 0.0255\n",
      "38/38 [==============================] - 0s 681us/step - loss: 0.0270 - mse: 0.0270\n",
      "2/2 - 0s - loss: 0.0253 - mse: 0.0253 - val_loss: 0.0251 - val_mse: 0.0251 - 33ms/epoch - 16ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0249 - mse: 0.0249\n",
      "38/38 [==============================] - 0s 654us/step - loss: 0.0263 - mse: 0.0263\n",
      "2/2 - 0s - loss: 0.0247 - mse: 0.0247 - val_loss: 0.0245 - val_mse: 0.0245 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0243 - mse: 0.0243\n",
      "38/38 [==============================] - 0s 611us/step - loss: 0.0257 - mse: 0.0257\n",
      "2/2 - 0s - loss: 0.0241 - mse: 0.0241 - val_loss: 0.0239 - val_mse: 0.0239 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0236 - mse: 0.0236\n",
      "38/38 [==============================] - 0s 617us/step - loss: 0.0250 - mse: 0.0250\n",
      "2/2 - 0s - loss: 0.0235 - mse: 0.0235 - val_loss: 0.0233 - val_mse: 0.0233 - 29ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0231 - mse: 0.0231\n",
      "38/38 [==============================] - 0s 669us/step - loss: 0.0244 - mse: 0.0244\n",
      "2/2 - 0s - loss: 0.0229 - mse: 0.0229 - val_loss: 0.0228 - val_mse: 0.0228 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0225 - mse: 0.0225\n",
      "38/38 [==============================] - 0s 614us/step - loss: 0.0239 - mse: 0.0239\n",
      "2/2 - 0s - loss: 0.0224 - mse: 0.0224 - val_loss: 0.0223 - val_mse: 0.0223 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0220 - mse: 0.0220\n",
      "38/38 [==============================] - 0s 638us/step - loss: 0.0233 - mse: 0.0233\n",
      "2/2 - 0s - loss: 0.0218 - mse: 0.0218 - val_loss: 0.0218 - val_mse: 0.0218 - 25ms/epoch - 12ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0215 - mse: 0.0215\n",
      "38/38 [==============================] - 0s 659us/step - loss: 0.0228 - mse: 0.0228\n",
      "2/2 - 0s - loss: 0.0213 - mse: 0.0213 - val_loss: 0.0213 - val_mse: 0.0213 - 25ms/epoch - 12ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0210 - mse: 0.0210\n",
      "38/38 [==============================] - 0s 664us/step - loss: 0.0222 - mse: 0.0222\n",
      "2/2 - 0s - loss: 0.0208 - mse: 0.0208 - val_loss: 0.0208 - val_mse: 0.0208 - 31ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0205 - mse: 0.0205\n",
      "38/38 [==============================] - 0s 709us/step - loss: 0.0217 - mse: 0.0217\n",
      "2/2 - 0s - loss: 0.0204 - mse: 0.0204 - val_loss: 0.0204 - val_mse: 0.0204 - 32ms/epoch - 16ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0201 - mse: 0.0201\n",
      "38/38 [==============================] - 0s 655us/step - loss: 0.0213 - mse: 0.0213\n",
      "2/2 - 0s - loss: 0.0199 - mse: 0.0199 - val_loss: 0.0200 - val_mse: 0.0200 - 27ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0197 - mse: 0.0197\n",
      "38/38 [==============================] - 0s 636us/step - loss: 0.0208 - mse: 0.0208\n",
      "2/2 - 0s - loss: 0.0195 - mse: 0.0195 - val_loss: 0.0196 - val_mse: 0.0196 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0192 - mse: 0.0192\n",
      "38/38 [==============================] - 0s 633us/step - loss: 0.0204 - mse: 0.0204\n",
      "2/2 - 0s - loss: 0.0191 - mse: 0.0191 - val_loss: 0.0191 - val_mse: 0.0191 - 27ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0188 - mse: 0.0188\n",
      "38/38 [==============================] - 0s 582us/step - loss: 0.0199 - mse: 0.0199\n",
      "2/2 - 0s - loss: 0.0187 - mse: 0.0187 - val_loss: 0.0188 - val_mse: 0.0188 - 25ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0185 - mse: 0.0185\n",
      "38/38 [==============================] - 0s 605us/step - loss: 0.0195 - mse: 0.0195\n",
      "2/2 - 0s - loss: 0.0183 - mse: 0.0183 - val_loss: 0.0185 - val_mse: 0.0185 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0181 - mse: 0.0181\n",
      "38/38 [==============================] - 0s 622us/step - loss: 0.0192 - mse: 0.0192\n",
      "2/2 - 0s - loss: 0.0179 - mse: 0.0179 - val_loss: 0.0181 - val_mse: 0.0181 - 25ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0177 - mse: 0.0177\n",
      "38/38 [==============================] - 0s 575us/step - loss: 0.0188 - mse: 0.0188\n",
      "2/2 - 0s - loss: 0.0176 - mse: 0.0176 - val_loss: 0.0177 - val_mse: 0.0177 - 27ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0174 - mse: 0.0174\n",
      "38/38 [==============================] - 0s 617us/step - loss: 0.0184 - mse: 0.0184\n",
      "2/2 - 0s - loss: 0.0173 - mse: 0.0173 - val_loss: 0.0174 - val_mse: 0.0174 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0171 - mse: 0.0171\n",
      "38/38 [==============================] - 0s 653us/step - loss: 0.0181 - mse: 0.0181\n",
      "2/2 - 0s - loss: 0.0169 - mse: 0.0169 - val_loss: 0.0171 - val_mse: 0.0171 - 33ms/epoch - 16ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0168 - mse: 0.0168\n",
      "38/38 [==============================] - 0s 608us/step - loss: 0.0177 - mse: 0.0177\n",
      "2/2 - 0s - loss: 0.0166 - mse: 0.0166 - val_loss: 0.0168 - val_mse: 0.0168 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0165 - mse: 0.0165\n",
      "38/38 [==============================] - 0s 590us/step - loss: 0.0174 - mse: 0.0174\n",
      "2/2 - 0s - loss: 0.0163 - mse: 0.0163 - val_loss: 0.0165 - val_mse: 0.0165 - 36ms/epoch - 18ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0162 - mse: 0.0162\n",
      "38/38 [==============================] - 0s 566us/step - loss: 0.0171 - mse: 0.0171\n",
      "2/2 - 0s - loss: 0.0160 - mse: 0.0160 - val_loss: 0.0163 - val_mse: 0.0163 - 27ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0159 - mse: 0.0159\n",
      "38/38 [==============================] - 0s 551us/step - loss: 0.0168 - mse: 0.0168\n",
      "2/2 - 0s - loss: 0.0157 - mse: 0.0157 - val_loss: 0.0160 - val_mse: 0.0160 - 30ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0156 - mse: 0.0156\n",
      "38/38 [==============================] - 0s 653us/step - loss: 0.0165 - mse: 0.0165\n",
      "2/2 - 0s - loss: 0.0155 - mse: 0.0155 - val_loss: 0.0157 - val_mse: 0.0157 - 28ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0154 - mse: 0.0154\n",
      "38/38 [==============================] - 0s 672us/step - loss: 0.0162 - mse: 0.0162\n",
      "2/2 - 0s - loss: 0.0152 - mse: 0.0152 - val_loss: 0.0155 - val_mse: 0.0155 - 28ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0151 - mse: 0.0151\n",
      "38/38 [==============================] - 0s 595us/step - loss: 0.0160 - mse: 0.0160\n",
      "2/2 - 0s - loss: 0.0149 - mse: 0.0149 - val_loss: 0.0153 - val_mse: 0.0153 - 27ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0149 - mse: 0.0149\n",
      "38/38 [==============================] - 0s 639us/step - loss: 0.0157 - mse: 0.0157\n",
      "2/2 - 0s - loss: 0.0147 - mse: 0.0147 - val_loss: 0.0150 - val_mse: 0.0150 - 31ms/epoch - 16ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0146 - mse: 0.0146\n",
      "38/38 [==============================] - 0s 632us/step - loss: 0.0154 - mse: 0.0154\n",
      "2/2 - 0s - loss: 0.0145 - mse: 0.0145 - val_loss: 0.0147 - val_mse: 0.0147 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0144 - mse: 0.0144\n",
      "38/38 [==============================] - 0s 596us/step - loss: 0.0152 - mse: 0.0152\n",
      "2/2 - 0s - loss: 0.0142 - mse: 0.0142 - val_loss: 0.0145 - val_mse: 0.0145 - 31ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0141 - mse: 0.0141\n",
      "38/38 [==============================] - 0s 713us/step - loss: 0.0149 - mse: 0.0149\n",
      "2/2 - 0s - loss: 0.0140 - mse: 0.0140 - val_loss: 0.0143 - val_mse: 0.0143 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0139 - mse: 0.0139\n",
      "38/38 [==============================] - 0s 566us/step - loss: 0.0147 - mse: 0.0147\n",
      "2/2 - 0s - loss: 0.0138 - mse: 0.0138 - val_loss: 0.0142 - val_mse: 0.0142 - 30ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0138 - mse: 0.0138\n",
      "38/38 [==============================] - 0s 623us/step - loss: 0.0145 - mse: 0.0145\n",
      "2/2 - 0s - loss: 0.0136 - mse: 0.0136 - val_loss: 0.0139 - val_mse: 0.0139 - 33ms/epoch - 16ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0135 - mse: 0.0135\n",
      "38/38 [==============================] - 0s 620us/step - loss: 0.0143 - mse: 0.0143\n",
      "2/2 - 0s - loss: 0.0134 - mse: 0.0134 - val_loss: 0.0138 - val_mse: 0.0138 - 31ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0133 - mse: 0.0133\n",
      "38/38 [==============================] - 0s 600us/step - loss: 0.0141 - mse: 0.0141\n",
      "2/2 - 0s - loss: 0.0132 - mse: 0.0132 - val_loss: 0.0136 - val_mse: 0.0136 - 30ms/epoch - 15ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0131 - mse: 0.0131\n",
      "38/38 [==============================] - 0s 629us/step - loss: 0.0139 - mse: 0.0139\n",
      "2/2 - 0s - loss: 0.0130 - mse: 0.0130 - val_loss: 0.0134 - val_mse: 0.0134 - 31ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0130 - mse: 0.0130\n",
      "38/38 [==============================] - 0s 561us/step - loss: 0.0137 - mse: 0.0137\n",
      "2/2 - 0s - loss: 0.0128 - mse: 0.0128 - val_loss: 0.0132 - val_mse: 0.0132 - 28ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0128 - mse: 0.0128\n",
      "38/38 [==============================] - 0s 626us/step - loss: 0.0135 - mse: 0.0135\n",
      "2/2 - 0s - loss: 0.0126 - mse: 0.0126 - val_loss: 0.0130 - val_mse: 0.0130 - 28ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0126 - mse: 0.0126\n",
      "38/38 [==============================] - 0s 722us/step - loss: 0.0133 - mse: 0.0133\n",
      "2/2 - 0s - loss: 0.0124 - mse: 0.0124 - val_loss: 0.0129 - val_mse: 0.0129 - 27ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0124 - mse: 0.0124\n",
      "38/38 [==============================] - 0s 566us/step - loss: 0.0131 - mse: 0.0131\n",
      "2/2 - 0s - loss: 0.0122 - mse: 0.0122 - val_loss: 0.0127 - val_mse: 0.0127 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0122 - mse: 0.0122\n",
      "38/38 [==============================] - 0s 632us/step - loss: 0.0129 - mse: 0.0129\n",
      "2/2 - 0s - loss: 0.0121 - mse: 0.0121 - val_loss: 0.0125 - val_mse: 0.0125 - 31ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0120 - mse: 0.0120\n",
      "38/38 [==============================] - 0s 638us/step - loss: 0.0127 - mse: 0.0127\n",
      "2/2 - 0s - loss: 0.0119 - mse: 0.0119 - val_loss: 0.0123 - val_mse: 0.0123 - 32ms/epoch - 16ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0119 - mse: 0.0119\n",
      "38/38 [==============================] - 0s 688us/step - loss: 0.0125 - mse: 0.0125\n",
      "2/2 - 0s - loss: 0.0117 - mse: 0.0117 - val_loss: 0.0121 - val_mse: 0.0121 - 31ms/epoch - 16ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0117 - mse: 0.0117\n",
      "38/38 [==============================] - 0s 603us/step - loss: 0.0123 - mse: 0.0123\n",
      "2/2 - 0s - loss: 0.0116 - mse: 0.0116 - val_loss: 0.0120 - val_mse: 0.0120 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0116 - mse: 0.0116\n",
      "38/38 [==============================] - 0s 676us/step - loss: 0.0122 - mse: 0.0122\n",
      "2/2 - 0s - loss: 0.0114 - mse: 0.0114 - val_loss: 0.0119 - val_mse: 0.0119 - 27ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0114 - mse: 0.0114\n",
      "38/38 [==============================] - 0s 620us/step - loss: 0.0120 - mse: 0.0120\n",
      "2/2 - 0s - loss: 0.0112 - mse: 0.0112 - val_loss: 0.0117 - val_mse: 0.0117 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0113 - mse: 0.0113\n",
      "38/38 [==============================] - 0s 625us/step - loss: 0.0118 - mse: 0.0118\n",
      "2/2 - 0s - loss: 0.0111 - mse: 0.0111 - val_loss: 0.0115 - val_mse: 0.0115 - 27ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0111 - mse: 0.0111\n",
      "38/38 [==============================] - 0s 619us/step - loss: 0.0117 - mse: 0.0117\n",
      "2/2 - 0s - loss: 0.0109 - mse: 0.0109 - val_loss: 0.0114 - val_mse: 0.0114 - 27ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0109 - mse: 0.0109\n",
      "38/38 [==============================] - 0s 554us/step - loss: 0.0115 - mse: 0.0115\n",
      "2/2 - 0s - loss: 0.0108 - mse: 0.0108 - val_loss: 0.0113 - val_mse: 0.0113 - 27ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0108 - mse: 0.0108\n",
      "38/38 [==============================] - 0s 661us/step - loss: 0.0114 - mse: 0.0114\n",
      "2/2 - 0s - loss: 0.0106 - mse: 0.0106 - val_loss: 0.0111 - val_mse: 0.0111 - 28ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0107 - mse: 0.0107\n",
      "38/38 [==============================] - 0s 586us/step - loss: 0.0112 - mse: 0.0112\n",
      "2/2 - 0s - loss: 0.0105 - mse: 0.0105 - val_loss: 0.0110 - val_mse: 0.0110 - 31ms/epoch - 16ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0105 - mse: 0.0105\n",
      "38/38 [==============================] - 0s 588us/step - loss: 0.0111 - mse: 0.0111\n",
      "2/2 - 0s - loss: 0.0104 - mse: 0.0104 - val_loss: 0.0108 - val_mse: 0.0108 - 27ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0104 - mse: 0.0104\n",
      "38/38 [==============================] - 0s 680us/step - loss: 0.0109 - mse: 0.0109\n",
      "2/2 - 0s - loss: 0.0102 - mse: 0.0102 - val_loss: 0.0107 - val_mse: 0.0107 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0103 - mse: 0.0103\n",
      "38/38 [==============================] - 0s 710us/step - loss: 0.0108 - mse: 0.0108\n",
      "2/2 - 0s - loss: 0.0101 - mse: 0.0101 - val_loss: 0.0106 - val_mse: 0.0106 - 27ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0101 - mse: 0.0101\n",
      "38/38 [==============================] - 0s 632us/step - loss: 0.0107 - mse: 0.0107\n",
      "2/2 - 0s - loss: 0.0100 - mse: 0.0100 - val_loss: 0.0105 - val_mse: 0.0105 - 28ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0100 - mse: 0.0100\n",
      "38/38 [==============================] - 0s 609us/step - loss: 0.0105 - mse: 0.0105\n",
      "2/2 - 0s - loss: 0.0098 - mse: 0.0098 - val_loss: 0.0103 - val_mse: 0.0103 - 31ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0099 - mse: 0.0099\n",
      "38/38 [==============================] - 0s 636us/step - loss: 0.0104 - mse: 0.0104\n",
      "2/2 - 0s - loss: 0.0097 - mse: 0.0097 - val_loss: 0.0102 - val_mse: 0.0102 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0098 - mse: 0.0098\n",
      "38/38 [==============================] - 0s 563us/step - loss: 0.0103 - mse: 0.0103\n",
      "2/2 - 0s - loss: 0.0096 - mse: 0.0096 - val_loss: 0.0101 - val_mse: 0.0101 - 27ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0096 - mse: 0.0096\n",
      "38/38 [==============================] - 0s 615us/step - loss: 0.0102 - mse: 0.0102\n",
      "2/2 - 0s - loss: 0.0095 - mse: 0.0095 - val_loss: 0.0100 - val_mse: 0.0100 - 28ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0095 - mse: 0.0095\n",
      "38/38 [==============================] - 0s 629us/step - loss: 0.0100 - mse: 0.0100\n",
      "2/2 - 0s - loss: 0.0094 - mse: 0.0094 - val_loss: 0.0099 - val_mse: 0.0099 - 32ms/epoch - 16ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0094 - mse: 0.0094\n",
      "38/38 [==============================] - 0s 639us/step - loss: 0.0099 - mse: 0.0099\n",
      "2/2 - 0s - loss: 0.0092 - mse: 0.0092 - val_loss: 0.0097 - val_mse: 0.0097 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0093 - mse: 0.0093\n",
      "38/38 [==============================] - 0s 595us/step - loss: 0.0098 - mse: 0.0098\n",
      "2/2 - 0s - loss: 0.0091 - mse: 0.0091 - val_loss: 0.0096 - val_mse: 0.0096 - 25ms/epoch - 12ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0092 - mse: 0.0092\n",
      "38/38 [==============================] - 0s 634us/step - loss: 0.0097 - mse: 0.0097\n",
      "2/2 - 0s - loss: 0.0090 - mse: 0.0090 - val_loss: 0.0095 - val_mse: 0.0095 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0091 - mse: 0.0091\n",
      "38/38 [==============================] - 0s 609us/step - loss: 0.0095 - mse: 0.0095\n",
      "2/2 - 0s - loss: 0.0089 - mse: 0.0089 - val_loss: 0.0095 - val_mse: 0.0095 - 30ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0090 - mse: 0.0090\n",
      "38/38 [==============================] - 0s 653us/step - loss: 0.0094 - mse: 0.0094\n",
      "2/2 - 0s - loss: 0.0088 - mse: 0.0088 - val_loss: 0.0094 - val_mse: 0.0094 - 27ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0089 - mse: 0.0089\n",
      "38/38 [==============================] - 0s 642us/step - loss: 0.0093 - mse: 0.0093\n",
      "2/2 - 0s - loss: 0.0087 - mse: 0.0087 - val_loss: 0.0093 - val_mse: 0.0093 - 31ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0088 - mse: 0.0088\n",
      "38/38 [==============================] - 0s 645us/step - loss: 0.0092 - mse: 0.0092\n",
      "2/2 - 0s - loss: 0.0086 - mse: 0.0086 - val_loss: 0.0091 - val_mse: 0.0091 - 27ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0086 - mse: 0.0086\n",
      "38/38 [==============================] - 0s 608us/step - loss: 0.0091 - mse: 0.0091\n",
      "2/2 - 0s - loss: 0.0085 - mse: 0.0085 - val_loss: 0.0090 - val_mse: 0.0090 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0085 - mse: 0.0085\n",
      "38/38 [==============================] - 0s 635us/step - loss: 0.0090 - mse: 0.0090\n",
      "2/2 - 0s - loss: 0.0084 - mse: 0.0084 - val_loss: 0.0089 - val_mse: 0.0089 - 30ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0085 - mse: 0.0085\n",
      "38/38 [==============================] - 0s 615us/step - loss: 0.0089 - mse: 0.0089\n",
      "2/2 - 0s - loss: 0.0083 - mse: 0.0083 - val_loss: 0.0088 - val_mse: 0.0088 - 25ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0084 - mse: 0.0084\n",
      "38/38 [==============================] - 0s 663us/step - loss: 0.0088 - mse: 0.0088\n",
      "2/2 - 0s - loss: 0.0082 - mse: 0.0082 - val_loss: 0.0087 - val_mse: 0.0087 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0083 - mse: 0.0083\n",
      "38/38 [==============================] - 0s 630us/step - loss: 0.0087 - mse: 0.0087\n",
      "2/2 - 0s - loss: 0.0081 - mse: 0.0081 - val_loss: 0.0086 - val_mse: 0.0086 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0082 - mse: 0.0082\n",
      "38/38 [==============================] - 0s 647us/step - loss: 0.0086 - mse: 0.0086\n",
      "2/2 - 0s - loss: 0.0080 - mse: 0.0080 - val_loss: 0.0085 - val_mse: 0.0085 - 25ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0081 - mse: 0.0081\n",
      "38/38 [==============================] - 0s 702us/step - loss: 0.0085 - mse: 0.0085\n",
      "2/2 - 0s - loss: 0.0079 - mse: 0.0079 - val_loss: 0.0085 - val_mse: 0.0085 - 25ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0080 - mse: 0.0080\n",
      "38/38 [==============================] - 0s 594us/step - loss: 0.0084 - mse: 0.0084\n",
      "2/2 - 0s - loss: 0.0078 - mse: 0.0078 - val_loss: 0.0084 - val_mse: 0.0084 - 31ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0079 - mse: 0.0079\n",
      "38/38 [==============================] - 0s 654us/step - loss: 0.0083 - mse: 0.0083\n",
      "2/2 - 0s - loss: 0.0078 - mse: 0.0078 - val_loss: 0.0083 - val_mse: 0.0083 - 27ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0078 - mse: 0.0078\n",
      "38/38 [==============================] - 0s 628us/step - loss: 0.0083 - mse: 0.0083\n",
      "2/2 - 0s - loss: 0.0077 - mse: 0.0077 - val_loss: 0.0082 - val_mse: 0.0082 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0078 - mse: 0.0078\n",
      "38/38 [==============================] - 0s 581us/step - loss: 0.0082 - mse: 0.0082\n",
      "2/2 - 0s - loss: 0.0076 - mse: 0.0076 - val_loss: 0.0081 - val_mse: 0.0081 - 30ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0077 - mse: 0.0077\n",
      "38/38 [==============================] - 0s 617us/step - loss: 0.0081 - mse: 0.0081\n",
      "2/2 - 0s - loss: 0.0075 - mse: 0.0075 - val_loss: 0.0080 - val_mse: 0.0080 - 29ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0076 - mse: 0.0076\n",
      "38/38 [==============================] - 0s 594us/step - loss: 0.0080 - mse: 0.0080\n",
      "2/2 - 0s - loss: 0.0074 - mse: 0.0074 - val_loss: 0.0079 - val_mse: 0.0079 - 30ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0075 - mse: 0.0075\n",
      "38/38 [==============================] - 0s 664us/step - loss: 0.0079 - mse: 0.0079\n",
      "2/2 - 0s - loss: 0.0073 - mse: 0.0073 - val_loss: 0.0079 - val_mse: 0.0079 - 29ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0074 - mse: 0.0074\n",
      "38/38 [==============================] - 0s 650us/step - loss: 0.0078 - mse: 0.0078\n",
      "2/2 - 0s - loss: 0.0073 - mse: 0.0073 - val_loss: 0.0079 - val_mse: 0.0079 - 31ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0074 - mse: 0.0074\n",
      "38/38 [==============================] - 0s 630us/step - loss: 0.0077 - mse: 0.0077\n",
      "2/2 - 0s - loss: 0.0072 - mse: 0.0072 - val_loss: 0.0077 - val_mse: 0.0077 - 31ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0073 - mse: 0.0073\n",
      "38/38 [==============================] - 0s 621us/step - loss: 0.0077 - mse: 0.0077\n",
      "2/2 - 0s - loss: 0.0071 - mse: 0.0071 - val_loss: 0.0076 - val_mse: 0.0076 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0072 - mse: 0.0072\n",
      "38/38 [==============================] - 0s 573us/step - loss: 0.0076 - mse: 0.0076\n",
      "2/2 - 0s - loss: 0.0071 - mse: 0.0071 - val_loss: 0.0076 - val_mse: 0.0076 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0071 - mse: 0.0071\n",
      "38/38 [==============================] - 0s 570us/step - loss: 0.0075 - mse: 0.0075\n",
      "2/2 - 0s - loss: 0.0070 - mse: 0.0070 - val_loss: 0.0076 - val_mse: 0.0076 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0071 - mse: 0.0071\n",
      "38/38 [==============================] - 0s 621us/step - loss: 0.0074 - mse: 0.0074\n",
      "2/2 - 0s - loss: 0.0069 - mse: 0.0069 - val_loss: 0.0074 - val_mse: 0.0074 - 32ms/epoch - 16ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0070 - mse: 0.0070\n",
      "38/38 [==============================] - 0s 651us/step - loss: 0.0074 - mse: 0.0074\n",
      "2/2 - 0s - loss: 0.0068 - mse: 0.0068 - val_loss: 0.0074 - val_mse: 0.0074 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0069 - mse: 0.0069\n",
      "38/38 [==============================] - 0s 613us/step - loss: 0.0073 - mse: 0.0073\n",
      "2/2 - 0s - loss: 0.0068 - mse: 0.0068 - val_loss: 0.0073 - val_mse: 0.0073 - 29ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0069 - mse: 0.0069\n",
      "38/38 [==============================] - 0s 604us/step - loss: 0.0072 - mse: 0.0072\n",
      "2/2 - 0s - loss: 0.0067 - mse: 0.0067 - val_loss: 0.0072 - val_mse: 0.0072 - 31ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0068 - mse: 0.0068\n",
      "38/38 [==============================] - 0s 622us/step - loss: 0.0071 - mse: 0.0071\n",
      "2/2 - 0s - loss: 0.0066 - mse: 0.0066 - val_loss: 0.0071 - val_mse: 0.0071 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0067 - mse: 0.0067\n",
      "38/38 [==============================] - 0s 577us/step - loss: 0.0071 - mse: 0.0071\n",
      "2/2 - 0s - loss: 0.0066 - mse: 0.0066 - val_loss: 0.0071 - val_mse: 0.0071 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0067 - mse: 0.0067\n",
      "38/38 [==============================] - 0s 571us/step - loss: 0.0070 - mse: 0.0070\n",
      "2/2 - 0s - loss: 0.0065 - mse: 0.0065 - val_loss: 0.0071 - val_mse: 0.0071 - 25ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0066 - mse: 0.0066\n",
      "38/38 [==============================] - 0s 629us/step - loss: 0.0070 - mse: 0.0070\n",
      "2/2 - 0s - loss: 0.0064 - mse: 0.0064 - val_loss: 0.0070 - val_mse: 0.0070 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0065 - mse: 0.0065\n",
      "38/38 [==============================] - 0s 635us/step - loss: 0.0069 - mse: 0.0069\n",
      "2/2 - 0s - loss: 0.0064 - mse: 0.0064 - val_loss: 0.0069 - val_mse: 0.0069 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0065 - mse: 0.0065\n",
      "38/38 [==============================] - 0s 591us/step - loss: 0.0068 - mse: 0.0068\n",
      "2/2 - 0s - loss: 0.0063 - mse: 0.0063 - val_loss: 0.0068 - val_mse: 0.0068 - 31ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0064 - mse: 0.0064\n",
      "38/38 [==============================] - 0s 614us/step - loss: 0.0068 - mse: 0.0068\n",
      "2/2 - 0s - loss: 0.0063 - mse: 0.0063 - val_loss: 0.0068 - val_mse: 0.0068 - 27ms/epoch - 14ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0063 - mse: 0.0063\n",
      "38/38 [==============================] - 0s 632us/step - loss: 0.0067 - mse: 0.0067\n",
      "2/2 - 0s - loss: 0.0062 - mse: 0.0062 - val_loss: 0.0068 - val_mse: 0.0068 - 27ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0063 - mse: 0.0063\n",
      "38/38 [==============================] - 0s 591us/step - loss: 0.0066 - mse: 0.0066\n",
      "2/2 - 0s - loss: 0.0062 - mse: 0.0062 - val_loss: 0.0067 - val_mse: 0.0067 - 27ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0063 - mse: 0.0063\n",
      "38/38 [==============================] - 0s 715us/step - loss: 0.0066 - mse: 0.0066\n",
      "2/2 - 0s - loss: 0.0061 - mse: 0.0061 - val_loss: 0.0066 - val_mse: 0.0066 - 27ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0062 - mse: 0.0062\n",
      "38/38 [==============================] - 0s 655us/step - loss: 0.0065 - mse: 0.0065\n",
      "2/2 - 0s - loss: 0.0060 - mse: 0.0060 - val_loss: 0.0065 - val_mse: 0.0065 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0061 - mse: 0.0061\n",
      "38/38 [==============================] - 0s 633us/step - loss: 0.0065 - mse: 0.0065\n",
      "2/2 - 0s - loss: 0.0060 - mse: 0.0060 - val_loss: 0.0065 - val_mse: 0.0065 - 25ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0061 - mse: 0.0061\n",
      "38/38 [==============================] - 0s 602us/step - loss: 0.0064 - mse: 0.0064\n",
      "2/2 - 0s - loss: 0.0059 - mse: 0.0059 - val_loss: 0.0065 - val_mse: 0.0065 - 29ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0061 - mse: 0.0061\n",
      "38/38 [==============================] - 0s 641us/step - loss: 0.0064 - mse: 0.0064\n",
      "2/2 - 0s - loss: 0.0059 - mse: 0.0059 - val_loss: 0.0064 - val_mse: 0.0064 - 31ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0060 - mse: 0.0060\n",
      "38/38 [==============================] - 0s 615us/step - loss: 0.0063 - mse: 0.0063\n",
      "2/2 - 0s - loss: 0.0058 - mse: 0.0058 - val_loss: 0.0063 - val_mse: 0.0063 - 31ms/epoch - 16ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0059 - mse: 0.0059\n",
      "38/38 [==============================] - 0s 672us/step - loss: 0.0063 - mse: 0.0063\n",
      "2/2 - 0s - loss: 0.0058 - mse: 0.0058 - val_loss: 0.0063 - val_mse: 0.0063 - 27ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0059 - mse: 0.0059\n",
      "38/38 [==============================] - 0s 609us/step - loss: 0.0062 - mse: 0.0062\n",
      "2/2 - 0s - loss: 0.0057 - mse: 0.0057 - val_loss: 0.0063 - val_mse: 0.0063 - 24ms/epoch - 12ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0058 - mse: 0.0058\n",
      "38/38 [==============================] - 0s 745us/step - loss: 0.0062 - mse: 0.0062\n",
      "2/2 - 0s - loss: 0.0057 - mse: 0.0057 - val_loss: 0.0062 - val_mse: 0.0062 - 27ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0058 - mse: 0.0058\n",
      "38/38 [==============================] - 0s 613us/step - loss: 0.0061 - mse: 0.0061\n",
      "2/2 - 0s - loss: 0.0056 - mse: 0.0056 - val_loss: 0.0061 - val_mse: 0.0061 - 24ms/epoch - 12ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0057 - mse: 0.0057\n",
      "38/38 [==============================] - 0s 605us/step - loss: 0.0061 - mse: 0.0061\n",
      "2/2 - 0s - loss: 0.0056 - mse: 0.0056 - val_loss: 0.0060 - val_mse: 0.0060 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0057 - mse: 0.0057\n",
      "38/38 [==============================] - 0s 584us/step - loss: 0.0060 - mse: 0.0060\n",
      "2/2 - 0s - loss: 0.0056 - mse: 0.0056 - val_loss: 0.0060 - val_mse: 0.0060 - 29ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0056 - mse: 0.0056\n",
      "38/38 [==============================] - 0s 820us/step - loss: 0.0060 - mse: 0.0060\n",
      "2/2 - 0s - loss: 0.0055 - mse: 0.0055 - val_loss: 0.0060 - val_mse: 0.0060 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0056 - mse: 0.0056\n",
      "38/38 [==============================] - 0s 607us/step - loss: 0.0059 - mse: 0.0059\n",
      "2/2 - 0s - loss: 0.0055 - mse: 0.0055 - val_loss: 0.0060 - val_mse: 0.0060 - 30ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0055 - mse: 0.0055\n",
      "38/38 [==============================] - 0s 673us/step - loss: 0.0059 - mse: 0.0059\n",
      "2/2 - 0s - loss: 0.0054 - mse: 0.0054 - val_loss: 0.0059 - val_mse: 0.0059 - 30ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0055 - mse: 0.0055\n",
      "38/38 [==============================] - 0s 653us/step - loss: 0.0058 - mse: 0.0058\n",
      "2/2 - 0s - loss: 0.0054 - mse: 0.0054 - val_loss: 0.0059 - val_mse: 0.0059 - 27ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0055 - mse: 0.0055\n",
      "38/38 [==============================] - 0s 615us/step - loss: 0.0058 - mse: 0.0058\n",
      "2/2 - 0s - loss: 0.0053 - mse: 0.0053 - val_loss: 0.0059 - val_mse: 0.0059 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0054 - mse: 0.0054\n",
      "38/38 [==============================] - 0s 658us/step - loss: 0.0058 - mse: 0.0058\n",
      "2/2 - 0s - loss: 0.0053 - mse: 0.0053 - val_loss: 0.0058 - val_mse: 0.0058 - 27ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0054 - mse: 0.0054\n",
      "38/38 [==============================] - 0s 598us/step - loss: 0.0057 - mse: 0.0057\n",
      "2/2 - 0s - loss: 0.0052 - mse: 0.0052 - val_loss: 0.0057 - val_mse: 0.0057 - 25ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0053 - mse: 0.0053\n",
      "38/38 [==============================] - 0s 645us/step - loss: 0.0057 - mse: 0.0057\n",
      "2/2 - 0s - loss: 0.0052 - mse: 0.0052 - val_loss: 0.0057 - val_mse: 0.0057 - 27ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0053 - mse: 0.0053\n",
      "38/38 [==============================] - 0s 699us/step - loss: 0.0056 - mse: 0.0056\n",
      "2/2 - 0s - loss: 0.0052 - mse: 0.0052 - val_loss: 0.0057 - val_mse: 0.0057 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 3ms/step - loss: 0.0053 - mse: 0.0053\n",
      "38/38 [==============================] - 0s 716us/step - loss: 0.0056 - mse: 0.0056\n",
      "2/2 - 0s - loss: 0.0051 - mse: 0.0051 - val_loss: 0.0056 - val_mse: 0.0056 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0052 - mse: 0.0052\n",
      "38/38 [==============================] - 0s 693us/step - loss: 0.0055 - mse: 0.0055\n",
      "2/2 - 0s - loss: 0.0051 - mse: 0.0051 - val_loss: 0.0055 - val_mse: 0.0055 - 27ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0052 - mse: 0.0052\n",
      "38/38 [==============================] - 0s 671us/step - loss: 0.0055 - mse: 0.0055\n",
      "2/2 - 0s - loss: 0.0050 - mse: 0.0050 - val_loss: 0.0055 - val_mse: 0.0055 - 31ms/epoch - 16ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0051 - mse: 0.0051\n",
      "38/38 [==============================] - 0s 690us/step - loss: 0.0054 - mse: 0.0054\n",
      "2/2 - 0s - loss: 0.0050 - mse: 0.0050 - val_loss: 0.0055 - val_mse: 0.0055 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0051 - mse: 0.0051\n",
      "38/38 [==============================] - 0s 733us/step - loss: 0.0054 - mse: 0.0054\n",
      "2/2 - 0s - loss: 0.0050 - mse: 0.0050 - val_loss: 0.0055 - val_mse: 0.0055 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0051 - mse: 0.0051\n",
      "38/38 [==============================] - 0s 625us/step - loss: 0.0054 - mse: 0.0054\n",
      "2/2 - 0s - loss: 0.0049 - mse: 0.0049 - val_loss: 0.0054 - val_mse: 0.0054 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0050 - mse: 0.0050\n",
      "38/38 [==============================] - 0s 610us/step - loss: 0.0053 - mse: 0.0053\n",
      "2/2 - 0s - loss: 0.0049 - mse: 0.0049 - val_loss: 0.0053 - val_mse: 0.0053 - 25ms/epoch - 12ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0050 - mse: 0.0050\n",
      "38/38 [==============================] - 0s 633us/step - loss: 0.0053 - mse: 0.0053\n",
      "2/2 - 0s - loss: 0.0049 - mse: 0.0049 - val_loss: 0.0053 - val_mse: 0.0053 - 25ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0049 - mse: 0.0049\n",
      "38/38 [==============================] - 0s 627us/step - loss: 0.0053 - mse: 0.0053\n",
      "2/2 - 0s - loss: 0.0048 - mse: 0.0048 - val_loss: 0.0053 - val_mse: 0.0053 - 30ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0049 - mse: 0.0049\n",
      "38/38 [==============================] - 0s 647us/step - loss: 0.0052 - mse: 0.0052\n",
      "2/2 - 0s - loss: 0.0048 - mse: 0.0048 - val_loss: 0.0053 - val_mse: 0.0053 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0049 - mse: 0.0049\n",
      "38/38 [==============================] - 0s 621us/step - loss: 0.0052 - mse: 0.0052\n",
      "2/2 - 0s - loss: 0.0047 - mse: 0.0047 - val_loss: 0.0052 - val_mse: 0.0052 - 27ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0048 - mse: 0.0048\n",
      "38/38 [==============================] - 0s 658us/step - loss: 0.0051 - mse: 0.0051\n",
      "2/2 - 0s - loss: 0.0047 - mse: 0.0047 - val_loss: 0.0052 - val_mse: 0.0052 - 30ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0048 - mse: 0.0048\n",
      "38/38 [==============================] - 0s 618us/step - loss: 0.0051 - mse: 0.0051\n",
      "2/2 - 0s - loss: 0.0047 - mse: 0.0047 - val_loss: 0.0051 - val_mse: 0.0051 - 28ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0048 - mse: 0.0048\n",
      "38/38 [==============================] - 0s 620us/step - loss: 0.0051 - mse: 0.0051\n",
      "2/2 - 0s - loss: 0.0047 - mse: 0.0047 - val_loss: 0.0051 - val_mse: 0.0051 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0047 - mse: 0.0047\n",
      "38/38 [==============================] - 0s 619us/step - loss: 0.0050 - mse: 0.0050\n",
      "2/2 - 0s - loss: 0.0046 - mse: 0.0046 - val_loss: 0.0051 - val_mse: 0.0051 - 27ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0047 - mse: 0.0047\n",
      "38/38 [==============================] - 0s 607us/step - loss: 0.0050 - mse: 0.0050\n",
      "2/2 - 0s - loss: 0.0046 - mse: 0.0046 - val_loss: 0.0050 - val_mse: 0.0050 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0047 - mse: 0.0047\n",
      "38/38 [==============================] - 0s 614us/step - loss: 0.0050 - mse: 0.0050\n",
      "2/2 - 0s - loss: 0.0046 - mse: 0.0046 - val_loss: 0.0050 - val_mse: 0.0050 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0047 - mse: 0.0047\n",
      "38/38 [==============================] - 0s 643us/step - loss: 0.0049 - mse: 0.0049\n",
      "2/2 - 0s - loss: 0.0045 - mse: 0.0045 - val_loss: 0.0050 - val_mse: 0.0050 - 25ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0046 - mse: 0.0046\n",
      "38/38 [==============================] - 0s 614us/step - loss: 0.0049 - mse: 0.0049\n",
      "2/2 - 0s - loss: 0.0045 - mse: 0.0045 - val_loss: 0.0049 - val_mse: 0.0049 - 25ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0046 - mse: 0.0046\n",
      "38/38 [==============================] - 0s 593us/step - loss: 0.0049 - mse: 0.0049\n",
      "2/2 - 0s - loss: 0.0045 - mse: 0.0045 - val_loss: 0.0049 - val_mse: 0.0049 - 28ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0046 - mse: 0.0046\n",
      "38/38 [==============================] - 0s 620us/step - loss: 0.0048 - mse: 0.0048\n",
      "2/2 - 0s - loss: 0.0044 - mse: 0.0044 - val_loss: 0.0049 - val_mse: 0.0049 - 31ms/epoch - 16ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0045 - mse: 0.0045\n",
      "38/38 [==============================] - 0s 669us/step - loss: 0.0048 - mse: 0.0048\n",
      "2/2 - 0s - loss: 0.0044 - mse: 0.0044 - val_loss: 0.0048 - val_mse: 0.0048 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0045 - mse: 0.0045\n",
      "38/38 [==============================] - 0s 613us/step - loss: 0.0048 - mse: 0.0048\n",
      "2/2 - 0s - loss: 0.0044 - mse: 0.0044 - val_loss: 0.0048 - val_mse: 0.0048 - 27ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0045 - mse: 0.0045\n",
      "38/38 [==============================] - 0s 614us/step - loss: 0.0048 - mse: 0.0048\n",
      "2/2 - 0s - loss: 0.0044 - mse: 0.0044 - val_loss: 0.0048 - val_mse: 0.0048 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0044 - mse: 0.0044\n",
      "38/38 [==============================] - 0s 599us/step - loss: 0.0047 - mse: 0.0047\n",
      "2/2 - 0s - loss: 0.0043 - mse: 0.0043 - val_loss: 0.0048 - val_mse: 0.0048 - 28ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0044 - mse: 0.0044\n",
      "38/38 [==============================] - 0s 632us/step - loss: 0.0047 - mse: 0.0047\n",
      "2/2 - 0s - loss: 0.0043 - mse: 0.0043 - val_loss: 0.0047 - val_mse: 0.0047 - 25ms/epoch - 12ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0044 - mse: 0.0044\n",
      "38/38 [==============================] - 0s 597us/step - loss: 0.0047 - mse: 0.0047\n",
      "2/2 - 0s - loss: 0.0043 - mse: 0.0043 - val_loss: 0.0047 - val_mse: 0.0047 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0044 - mse: 0.0044\n",
      "38/38 [==============================] - 0s 616us/step - loss: 0.0046 - mse: 0.0046\n",
      "2/2 - 0s - loss: 0.0042 - mse: 0.0042 - val_loss: 0.0047 - val_mse: 0.0047 - 28ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0043 - mse: 0.0043\n",
      "38/38 [==============================] - 0s 600us/step - loss: 0.0046 - mse: 0.0046\n",
      "2/2 - 0s - loss: 0.0042 - mse: 0.0042 - val_loss: 0.0047 - val_mse: 0.0047 - 27ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0043 - mse: 0.0043\n",
      "38/38 [==============================] - 0s 651us/step - loss: 0.0046 - mse: 0.0046\n",
      "2/2 - 0s - loss: 0.0042 - mse: 0.0042 - val_loss: 0.0046 - val_mse: 0.0046 - 33ms/epoch - 16ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0043 - mse: 0.0043\n",
      "38/38 [==============================] - 0s 663us/step - loss: 0.0046 - mse: 0.0046\n",
      "2/2 - 0s - loss: 0.0042 - mse: 0.0042 - val_loss: 0.0045 - val_mse: 0.0045 - 38ms/epoch - 19ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0042 - mse: 0.0042\n",
      "38/38 [==============================] - 0s 708us/step - loss: 0.0045 - mse: 0.0045\n",
      "2/2 - 0s - loss: 0.0041 - mse: 0.0041 - val_loss: 0.0046 - val_mse: 0.0046 - 39ms/epoch - 19ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0042 - mse: 0.0042\n",
      "38/38 [==============================] - 0s 595us/step - loss: 0.0045 - mse: 0.0045\n",
      "2/2 - 0s - loss: 0.0041 - mse: 0.0041 - val_loss: 0.0046 - val_mse: 0.0046 - 28ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0042 - mse: 0.0042\n",
      "38/38 [==============================] - 0s 608us/step - loss: 0.0045 - mse: 0.0045\n",
      "2/2 - 0s - loss: 0.0041 - mse: 0.0041 - val_loss: 0.0045 - val_mse: 0.0045 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0042 - mse: 0.0042\n",
      "38/38 [==============================] - 0s 825us/step - loss: 0.0044 - mse: 0.0044\n",
      "2/2 - 0s - loss: 0.0041 - mse: 0.0041 - val_loss: 0.0044 - val_mse: 0.0044 - 36ms/epoch - 18ms/step\n",
      "2/2 [==============================] - 0s 3ms/step - loss: 0.0041 - mse: 0.0041\n",
      "38/38 [==============================] - 0s 641us/step - loss: 0.0044 - mse: 0.0044\n",
      "2/2 - 0s - loss: 0.0040 - mse: 0.0040 - val_loss: 0.0044 - val_mse: 0.0044 - 28ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0041 - mse: 0.0041\n",
      "38/38 [==============================] - 0s 672us/step - loss: 0.0044 - mse: 0.0044\n",
      "2/2 - 0s - loss: 0.0040 - mse: 0.0040 - val_loss: 0.0044 - val_mse: 0.0044 - 28ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0041 - mse: 0.0041\n",
      "38/38 [==============================] - 0s 626us/step - loss: 0.0044 - mse: 0.0044\n",
      "2/2 - 0s - loss: 0.0040 - mse: 0.0040 - val_loss: 0.0044 - val_mse: 0.0044 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0041 - mse: 0.0041\n",
      "38/38 [==============================] - 0s 659us/step - loss: 0.0044 - mse: 0.0044\n",
      "2/2 - 0s - loss: 0.0040 - mse: 0.0040 - val_loss: 0.0044 - val_mse: 0.0044 - 37ms/epoch - 18ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2/2 [==============================] - 0s 3ms/step - loss: 0.0041 - mse: 0.0041\n",
      "38/38 [==============================] - 0s 669us/step - loss: 0.0043 - mse: 0.0043\n",
      "2/2 - 0s - loss: 0.0039 - mse: 0.0039 - val_loss: 0.0044 - val_mse: 0.0044 - 28ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0040 - mse: 0.0040\n",
      "38/38 [==============================] - 0s 687us/step - loss: 0.0043 - mse: 0.0043\n",
      "2/2 - 0s - loss: 0.0039 - mse: 0.0039 - val_loss: 0.0043 - val_mse: 0.0043 - 34ms/epoch - 17ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0040 - mse: 0.0040\n",
      "38/38 [==============================] - 0s 646us/step - loss: 0.0043 - mse: 0.0043\n",
      "2/2 - 0s - loss: 0.0039 - mse: 0.0039 - val_loss: 0.0043 - val_mse: 0.0043 - 27ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0040 - mse: 0.0040\n",
      "38/38 [==============================] - 0s 686us/step - loss: 0.0042 - mse: 0.0042\n",
      "2/2 - 0s - loss: 0.0039 - mse: 0.0039 - val_loss: 0.0043 - val_mse: 0.0043 - 32ms/epoch - 16ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0040 - mse: 0.0040\n",
      "38/38 [==============================] - 0s 753us/step - loss: 0.0042 - mse: 0.0042\n",
      "2/2 - 0s - loss: 0.0039 - mse: 0.0039 - val_loss: 0.0042 - val_mse: 0.0042 - 38ms/epoch - 19ms/step\n",
      "2/2 [==============================] - 0s 4ms/step - loss: 0.0039 - mse: 0.0039\n",
      "38/38 [==============================] - 0s 814us/step - loss: 0.0042 - mse: 0.0042\n",
      "2/2 - 0s - loss: 0.0038 - mse: 0.0038 - val_loss: 0.0042 - val_mse: 0.0042 - 27ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0039 - mse: 0.0039\n",
      "38/38 [==============================] - 0s 594us/step - loss: 0.0042 - mse: 0.0042\n",
      "2/2 - 0s - loss: 0.0038 - mse: 0.0038 - val_loss: 0.0042 - val_mse: 0.0042 - 31ms/epoch - 16ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0039 - mse: 0.0039\n",
      "38/38 [==============================] - 0s 635us/step - loss: 0.0042 - mse: 0.0042\n",
      "2/2 - 0s - loss: 0.0038 - mse: 0.0038 - val_loss: 0.0042 - val_mse: 0.0042 - 28ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0039 - mse: 0.0039\n",
      "38/38 [==============================] - 0s 634us/step - loss: 0.0041 - mse: 0.0041\n",
      "2/2 - 0s - loss: 0.0038 - mse: 0.0038 - val_loss: 0.0041 - val_mse: 0.0041 - 29ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0038 - mse: 0.0038\n",
      "38/38 [==============================] - 0s 679us/step - loss: 0.0041 - mse: 0.0041\n",
      "2/2 - 0s - loss: 0.0037 - mse: 0.0037 - val_loss: 0.0042 - val_mse: 0.0042 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0038 - mse: 0.0038\n",
      "38/38 [==============================] - 0s 669us/step - loss: 0.0041 - mse: 0.0041\n",
      "2/2 - 0s - loss: 0.0037 - mse: 0.0037 - val_loss: 0.0041 - val_mse: 0.0041 - 27ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0038 - mse: 0.0038\n",
      "38/38 [==============================] - 0s 641us/step - loss: 0.0041 - mse: 0.0041\n",
      "2/2 - 0s - loss: 0.0037 - mse: 0.0037 - val_loss: 0.0041 - val_mse: 0.0041 - 25ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0038 - mse: 0.0038\n",
      "38/38 [==============================] - 0s 667us/step - loss: 0.0040 - mse: 0.0040\n",
      "2/2 - 0s - loss: 0.0037 - mse: 0.0037 - val_loss: 0.0040 - val_mse: 0.0040 - 39ms/epoch - 20ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0038 - mse: 0.0038\n",
      "38/38 [==============================] - 0s 688us/step - loss: 0.0040 - mse: 0.0040\n",
      "2/2 - 0s - loss: 0.0037 - mse: 0.0037 - val_loss: 0.0040 - val_mse: 0.0040 - 37ms/epoch - 19ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0037 - mse: 0.0037\n",
      "38/38 [==============================] - 0s 731us/step - loss: 0.0040 - mse: 0.0040\n",
      "2/2 - 0s - loss: 0.0036 - mse: 0.0036 - val_loss: 0.0040 - val_mse: 0.0040 - 34ms/epoch - 17ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0037 - mse: 0.0037\n",
      "38/38 [==============================] - 0s 782us/step - loss: 0.0040 - mse: 0.0040\n",
      "2/2 - 0s - loss: 0.0036 - mse: 0.0036 - val_loss: 0.0040 - val_mse: 0.0040 - 27ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0037 - mse: 0.0037\n",
      "38/38 [==============================] - 0s 690us/step - loss: 0.0040 - mse: 0.0040\n",
      "2/2 - 0s - loss: 0.0036 - mse: 0.0036 - val_loss: 0.0040 - val_mse: 0.0040 - 30ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0037 - mse: 0.0037\n",
      "38/38 [==============================] - 0s 735us/step - loss: 0.0039 - mse: 0.0039\n",
      "2/2 - 0s - loss: 0.0036 - mse: 0.0036 - val_loss: 0.0040 - val_mse: 0.0040 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0037 - mse: 0.0037\n",
      "38/38 [==============================] - 0s 693us/step - loss: 0.0039 - mse: 0.0039\n",
      "2/2 - 0s - loss: 0.0036 - mse: 0.0036 - val_loss: 0.0039 - val_mse: 0.0039 - 31ms/epoch - 16ms/step\n",
      "2/2 [==============================] - 0s 3ms/step - loss: 0.0036 - mse: 0.0036\n",
      "38/38 [==============================] - 0s 754us/step - loss: 0.0039 - mse: 0.0039\n",
      "2/2 - 0s - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0039 - val_mse: 0.0039 - 27ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 3ms/step - loss: 0.0036 - mse: 0.0036\n",
      "38/38 [==============================] - 0s 581us/step - loss: 0.0039 - mse: 0.0039\n",
      "2/2 - 0s - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0039 - val_mse: 0.0039 - 30ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0036 - mse: 0.0036\n",
      "38/38 [==============================] - 0s 634us/step - loss: 0.0039 - mse: 0.0039\n",
      "2/2 - 0s - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0039 - val_mse: 0.0039 - 33ms/epoch - 17ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0036 - mse: 0.0036\n",
      "38/38 [==============================] - 0s 603us/step - loss: 0.0038 - mse: 0.0038\n",
      "2/2 - 0s - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0038 - val_mse: 0.0038 - 31ms/epoch - 16ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0036 - mse: 0.0036\n",
      "38/38 [==============================] - 0s 575us/step - loss: 0.0038 - mse: 0.0038\n",
      "2/2 - 0s - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0038 - val_mse: 0.0038 - 31ms/epoch - 16ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0035 - mse: 0.0035\n",
      "38/38 [==============================] - 0s 589us/step - loss: 0.0038 - mse: 0.0038\n",
      "2/2 - 0s - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0038 - val_mse: 0.0038 - 28ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0035 - mse: 0.0035\n",
      "38/38 [==============================] - 0s 680us/step - loss: 0.0038 - mse: 0.0038\n",
      "2/2 - 0s - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0038 - val_mse: 0.0038 - 28ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0035 - mse: 0.0035\n",
      "38/38 [==============================] - 0s 664us/step - loss: 0.0038 - mse: 0.0038\n",
      "2/2 - 0s - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0038 - val_mse: 0.0038 - 27ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0035 - mse: 0.0035\n",
      "38/38 [==============================] - 0s 612us/step - loss: 0.0037 - mse: 0.0037\n",
      "2/2 - 0s - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0037 - val_mse: 0.0037 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0035 - mse: 0.0035\n",
      "38/38 [==============================] - 0s 598us/step - loss: 0.0037 - mse: 0.0037\n",
      "2/2 - 0s - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0037 - val_mse: 0.0037 - 27ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0035 - mse: 0.0035\n",
      "38/38 [==============================] - 0s 633us/step - loss: 0.0037 - mse: 0.0037\n",
      "2/2 - 0s - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0037 - val_mse: 0.0037 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0034 - mse: 0.0034\n",
      "38/38 [==============================] - 0s 663us/step - loss: 0.0037 - mse: 0.0037\n",
      "2/2 - 0s - loss: 0.0033 - mse: 0.0033 - val_loss: 0.0037 - val_mse: 0.0037 - 35ms/epoch - 17ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0034 - mse: 0.0034\n",
      "38/38 [==============================] - 0s 758us/step - loss: 0.0037 - mse: 0.0037\n",
      "2/2 - 0s - loss: 0.0033 - mse: 0.0033 - val_loss: 0.0037 - val_mse: 0.0037 - 27ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0034 - mse: 0.0034\n",
      "38/38 [==============================] - 0s 662us/step - loss: 0.0036 - mse: 0.0036\n",
      "2/2 - 0s - loss: 0.0033 - mse: 0.0033 - val_loss: 0.0036 - val_mse: 0.0036 - 31ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0034 - mse: 0.0034\n",
      "38/38 [==============================] - 0s 638us/step - loss: 0.0036 - mse: 0.0036\n",
      "2/2 - 0s - loss: 0.0033 - mse: 0.0033 - val_loss: 0.0036 - val_mse: 0.0036 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 3ms/step - loss: 0.0034 - mse: 0.0034\n",
      "38/38 [==============================] - 0s 657us/step - loss: 0.0036 - mse: 0.0036\n",
      "2/2 - 0s - loss: 0.0033 - mse: 0.0033 - val_loss: 0.0036 - val_mse: 0.0036 - 30ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0034 - mse: 0.0034\n",
      "38/38 [==============================] - 0s 778us/step - loss: 0.0036 - mse: 0.0036\n",
      "2/2 - 0s - loss: 0.0033 - mse: 0.0033 - val_loss: 0.0036 - val_mse: 0.0036 - 34ms/epoch - 17ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0033 - mse: 0.0033\n",
      "38/38 [==============================] - 0s 684us/step - loss: 0.0036 - mse: 0.0036\n",
      "2/2 - 0s - loss: 0.0033 - mse: 0.0033 - val_loss: 0.0036 - val_mse: 0.0036 - 31ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0033 - mse: 0.0033\n",
      "38/38 [==============================] - 0s 709us/step - loss: 0.0036 - mse: 0.0036\n",
      "2/2 - 0s - loss: 0.0032 - mse: 0.0032 - val_loss: 0.0036 - val_mse: 0.0036 - 27ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0033 - mse: 0.0033\n",
      "38/38 [==============================] - 0s 698us/step - loss: 0.0035 - mse: 0.0035\n",
      "2/2 - 0s - loss: 0.0032 - mse: 0.0032 - val_loss: 0.0035 - val_mse: 0.0035 - 30ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0033 - mse: 0.0033\n",
      "38/38 [==============================] - 0s 791us/step - loss: 0.0035 - mse: 0.0035\n",
      "2/2 - 0s - loss: 0.0032 - mse: 0.0032 - val_loss: 0.0035 - val_mse: 0.0035 - 40ms/epoch - 20ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0033 - mse: 0.0033\n",
      "38/38 [==============================] - 0s 705us/step - loss: 0.0035 - mse: 0.0035\n",
      "2/2 - 0s - loss: 0.0032 - mse: 0.0032 - val_loss: 0.0035 - val_mse: 0.0035 - 28ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0033 - mse: 0.0033\n",
      "38/38 [==============================] - 0s 681us/step - loss: 0.0035 - mse: 0.0035\n",
      "2/2 - 0s - loss: 0.0032 - mse: 0.0032 - val_loss: 0.0035 - val_mse: 0.0035 - 27ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0032 - mse: 0.0032\n",
      "38/38 [==============================] - 0s 693us/step - loss: 0.0035 - mse: 0.0035\n",
      "2/2 - 0s - loss: 0.0032 - mse: 0.0032 - val_loss: 0.0035 - val_mse: 0.0035 - 27ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0032 - mse: 0.0032\n",
      "38/38 [==============================] - 0s 667us/step - loss: 0.0035 - mse: 0.0035\n",
      "2/2 - 0s - loss: 0.0031 - mse: 0.0031 - val_loss: 0.0035 - val_mse: 0.0035 - 27ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0032 - mse: 0.0032\n",
      "38/38 [==============================] - 0s 594us/step - loss: 0.0034 - mse: 0.0034\n",
      "2/2 - 0s - loss: 0.0031 - mse: 0.0031 - val_loss: 0.0034 - val_mse: 0.0034 - 27ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0032 - mse: 0.0032\n",
      "38/38 [==============================] - 0s 627us/step - loss: 0.0034 - mse: 0.0034\n",
      "2/2 - 0s - loss: 0.0031 - mse: 0.0031 - val_loss: 0.0034 - val_mse: 0.0034 - 27ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0032 - mse: 0.0032\n",
      "38/38 [==============================] - 0s 577us/step - loss: 0.0034 - mse: 0.0034\n",
      "2/2 - 0s - loss: 0.0031 - mse: 0.0031 - val_loss: 0.0034 - val_mse: 0.0034 - 25ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0032 - mse: 0.0032\n",
      "38/38 [==============================] - 0s 648us/step - loss: 0.0034 - mse: 0.0034\n",
      "2/2 - 0s - loss: 0.0031 - mse: 0.0031 - val_loss: 0.0034 - val_mse: 0.0034 - 30ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0031 - mse: 0.0031\n",
      "38/38 [==============================] - 0s 569us/step - loss: 0.0034 - mse: 0.0034\n",
      "2/2 - 0s - loss: 0.0031 - mse: 0.0031 - val_loss: 0.0034 - val_mse: 0.0034 - 31ms/epoch - 16ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0031 - mse: 0.0031\n",
      "38/38 [==============================] - 0s 569us/step - loss: 0.0034 - mse: 0.0034\n",
      "2/2 - 0s - loss: 0.0031 - mse: 0.0031 - val_loss: 0.0034 - val_mse: 0.0034 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0031 - mse: 0.0031\n",
      "38/38 [==============================] - 0s 535us/step - loss: 0.0033 - mse: 0.0033\n",
      "2/2 - 0s - loss: 0.0030 - mse: 0.0030 - val_loss: 0.0033 - val_mse: 0.0033 - 27ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0031 - mse: 0.0031\n",
      "38/38 [==============================] - 0s 639us/step - loss: 0.0033 - mse: 0.0033\n",
      "2/2 - 0s - loss: 0.0030 - mse: 0.0030 - val_loss: 0.0033 - val_mse: 0.0033 - 30ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0031 - mse: 0.0031\n",
      "38/38 [==============================] - 0s 651us/step - loss: 0.0033 - mse: 0.0033\n",
      "2/2 - 0s - loss: 0.0030 - mse: 0.0030 - val_loss: 0.0033 - val_mse: 0.0033 - 25ms/epoch - 12ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0031 - mse: 0.0031\n",
      "38/38 [==============================] - 0s 604us/step - loss: 0.0033 - mse: 0.0033\n",
      "2/2 - 0s - loss: 0.0030 - mse: 0.0030 - val_loss: 0.0033 - val_mse: 0.0033 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0031 - mse: 0.0031\n",
      "38/38 [==============================] - 0s 576us/step - loss: 0.0033 - mse: 0.0033\n",
      "2/2 - 0s - loss: 0.0030 - mse: 0.0030 - val_loss: 0.0033 - val_mse: 0.0033 - 25ms/epoch - 12ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0030 - mse: 0.0030\n",
      "38/38 [==============================] - 0s 762us/step - loss: 0.0033 - mse: 0.0033\n",
      "2/2 - 0s - loss: 0.0030 - mse: 0.0030 - val_loss: 0.0033 - val_mse: 0.0033 - 29ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0030 - mse: 0.0030\n",
      "38/38 [==============================] - 0s 731us/step - loss: 0.0032 - mse: 0.0032\n",
      "2/2 - 0s - loss: 0.0030 - mse: 0.0030 - val_loss: 0.0033 - val_mse: 0.0033 - 27ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0030 - mse: 0.0030\n",
      "38/38 [==============================] - 0s 663us/step - loss: 0.0032 - mse: 0.0032\n",
      "2/2 - 0s - loss: 0.0029 - mse: 0.0029 - val_loss: 0.0032 - val_mse: 0.0032 - 32ms/epoch - 16ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0030 - mse: 0.0030\n",
      "38/38 [==============================] - 0s 738us/step - loss: 0.0032 - mse: 0.0032\n",
      "2/2 - 0s - loss: 0.0029 - mse: 0.0029 - val_loss: 0.0032 - val_mse: 0.0032 - 25ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0030 - mse: 0.0030\n",
      "38/38 [==============================] - 0s 682us/step - loss: 0.0032 - mse: 0.0032\n",
      "2/2 - 0s - loss: 0.0029 - mse: 0.0029 - val_loss: 0.0032 - val_mse: 0.0032 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0030 - mse: 0.0030\n",
      "38/38 [==============================] - 0s 607us/step - loss: 0.0032 - mse: 0.0032\n",
      "2/2 - 0s - loss: 0.0029 - mse: 0.0029 - val_loss: 0.0032 - val_mse: 0.0032 - 25ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0030 - mse: 0.0030\n",
      "38/38 [==============================] - 0s 580us/step - loss: 0.0032 - mse: 0.0032\n",
      "2/2 - 0s - loss: 0.0029 - mse: 0.0029 - val_loss: 0.0032 - val_mse: 0.0032 - 26ms/epoch - 13ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0029 - mse: 0.0029\n",
      "38/38 [==============================] - 0s 612us/step - loss: 0.0032 - mse: 0.0032\n",
      "2/2 - 0s - loss: 0.0029 - mse: 0.0029 - val_loss: 0.0032 - val_mse: 0.0032 - 27ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0029 - mse: 0.0029\n",
      "38/38 [==============================] - 0s 604us/step - loss: 0.0032 - mse: 0.0032\n",
      "2/2 - 0s - loss: 0.0029 - mse: 0.0029 - val_loss: 0.0032 - val_mse: 0.0032 - 27ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0029 - mse: 0.0029\n",
      "38/38 [==============================] - 0s 611us/step - loss: 0.0031 - mse: 0.0031\n",
      "2/2 - 0s - loss: 0.0028 - mse: 0.0028 - val_loss: 0.0031 - val_mse: 0.0031 - 28ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0029 - mse: 0.0029\n",
      "38/38 [==============================] - 0s 634us/step - loss: 0.0031 - mse: 0.0031\n",
      "2/2 - 0s - loss: 0.0028 - mse: 0.0028 - val_loss: 0.0031 - val_mse: 0.0031 - 29ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0029 - mse: 0.0029\n",
      "38/38 [==============================] - 0s 634us/step - loss: 0.0031 - mse: 0.0031\n",
      "2/2 - 0s - loss: 0.0028 - mse: 0.0028 - val_loss: 0.0031 - val_mse: 0.0031 - 32ms/epoch - 16ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0029 - mse: 0.0029\n",
      "38/38 [==============================] - 0s 634us/step - loss: 0.0031 - mse: 0.0031\n",
      "2/2 - 0s - loss: 0.0028 - mse: 0.0028 - val_loss: 0.0031 - val_mse: 0.0031 - 25ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0029 - mse: 0.0029\n",
      "38/38 [==============================] - 0s 616us/step - loss: 0.0031 - mse: 0.0031\n",
      "2/2 - 0s - loss: 0.0028 - mse: 0.0028 - val_loss: 0.0031 - val_mse: 0.0031 - 27ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0029 - mse: 0.0029\n",
      "38/38 [==============================] - 0s 692us/step - loss: 0.0031 - mse: 0.0031\n",
      "2/2 - 0s - loss: 0.0028 - mse: 0.0028 - val_loss: 0.0031 - val_mse: 0.0031 - 29ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0028 - mse: 0.0028\n",
      "38/38 [==============================] - 0s 576us/step - loss: 0.0031 - mse: 0.0031\n",
      "2/2 - 0s - loss: 0.0028 - mse: 0.0028 - val_loss: 0.0031 - val_mse: 0.0031 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0028 - mse: 0.0028\n",
      "38/38 [==============================] - 0s 598us/step - loss: 0.0030 - mse: 0.0030\n",
      "2/2 - 0s - loss: 0.0028 - mse: 0.0028 - val_loss: 0.0030 - val_mse: 0.0030 - 25ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0028 - mse: 0.0028\n",
      "38/38 [==============================] - 0s 666us/step - loss: 0.0030 - mse: 0.0030\n",
      "2/2 - 0s - loss: 0.0028 - mse: 0.0028 - val_loss: 0.0030 - val_mse: 0.0030 - 25ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0028 - mse: 0.0028\n",
      "38/38 [==============================] - 0s 686us/step - loss: 0.0030 - mse: 0.0030\n",
      "2/2 - 0s - loss: 0.0027 - mse: 0.0027 - val_loss: 0.0030 - val_mse: 0.0030 - 28ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0028 - mse: 0.0028\n",
      "38/38 [==============================] - 0s 630us/step - loss: 0.0030 - mse: 0.0030\n",
      "2/2 - 0s - loss: 0.0027 - mse: 0.0027 - val_loss: 0.0030 - val_mse: 0.0030 - 27ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0028 - mse: 0.0028\n",
      "38/38 [==============================] - 0s 602us/step - loss: 0.0030 - mse: 0.0030\n",
      "2/2 - 0s - loss: 0.0027 - mse: 0.0027 - val_loss: 0.0030 - val_mse: 0.0030 - 32ms/epoch - 16ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0028 - mse: 0.0028\n",
      "38/38 [==============================] - 0s 658us/step - loss: 0.0030 - mse: 0.0030\n",
      "2/2 - 0s - loss: 0.0027 - mse: 0.0027 - val_loss: 0.0030 - val_mse: 0.0030 - 28ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0028 - mse: 0.0028\n",
      "38/38 [==============================] - 0s 617us/step - loss: 0.0030 - mse: 0.0030\n",
      "2/2 - 0s - loss: 0.0027 - mse: 0.0027 - val_loss: 0.0029 - val_mse: 0.0029 - 27ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0028 - mse: 0.0028\n",
      "38/38 [==============================] - 0s 673us/step - loss: 0.0030 - mse: 0.0030\n",
      "2/2 - 0s - loss: 0.0027 - mse: 0.0027 - val_loss: 0.0030 - val_mse: 0.0030 - 28ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0027 - mse: 0.0027\n",
      "38/38 [==============================] - 0s 603us/step - loss: 0.0029 - mse: 0.0029\n",
      "2/2 - 0s - loss: 0.0027 - mse: 0.0027 - val_loss: 0.0030 - val_mse: 0.0030 - 28ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0028 - mse: 0.0028\n",
      "38/38 [==============================] - 0s 718us/step - loss: 0.0030 - mse: 0.0030\n",
      "2/2 - 0s - loss: 0.0027 - mse: 0.0027 - val_loss: 0.0029 - val_mse: 0.0029 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0027 - mse: 0.0027\n",
      "38/38 [==============================] - 0s 708us/step - loss: 0.0029 - mse: 0.0029\n",
      "2/2 - 0s - loss: 0.0027 - mse: 0.0027 - val_loss: 0.0029 - val_mse: 0.0029 - 29ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0027 - mse: 0.0027\n",
      "38/38 [==============================] - 0s 701us/step - loss: 0.0029 - mse: 0.0029\n",
      "2/2 - 0s - loss: 0.0026 - mse: 0.0026 - val_loss: 0.0029 - val_mse: 0.0029 - 25ms/epoch - 12ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0027 - mse: 0.0027\n",
      "38/38 [==============================] - 0s 590us/step - loss: 0.0029 - mse: 0.0029\n",
      "2/2 - 0s - loss: 0.0026 - mse: 0.0026 - val_loss: 0.0029 - val_mse: 0.0029 - 25ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0027 - mse: 0.0027\n",
      "38/38 [==============================] - 0s 699us/step - loss: 0.0029 - mse: 0.0029\n",
      "2/2 - 0s - loss: 0.0026 - mse: 0.0026 - val_loss: 0.0029 - val_mse: 0.0029 - 30ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0027 - mse: 0.0027\n",
      "38/38 [==============================] - 0s 583us/step - loss: 0.0029 - mse: 0.0029\n",
      "2/2 - 0s - loss: 0.0026 - mse: 0.0026 - val_loss: 0.0028 - val_mse: 0.0028 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0026 - mse: 0.0026\n",
      "38/38 [==============================] - 0s 768us/step - loss: 0.0029 - mse: 0.0029\n",
      "2/2 - 0s - loss: 0.0026 - mse: 0.0026 - val_loss: 0.0029 - val_mse: 0.0029 - 24ms/epoch - 12ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0026 - mse: 0.0026\n",
      "38/38 [==============================] - 0s 599us/step - loss: 0.0028 - mse: 0.0028\n",
      "2/2 - 0s - loss: 0.0026 - mse: 0.0026 - val_loss: 0.0029 - val_mse: 0.0029 - 25ms/epoch - 12ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0026 - mse: 0.0026\n",
      "38/38 [==============================] - 0s 656us/step - loss: 0.0028 - mse: 0.0028\n",
      "2/2 - 0s - loss: 0.0026 - mse: 0.0026 - val_loss: 0.0028 - val_mse: 0.0028 - 25ms/epoch - 12ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0026 - mse: 0.0026\n",
      "38/38 [==============================] - 0s 655us/step - loss: 0.0028 - mse: 0.0028\n",
      "2/2 - 0s - loss: 0.0026 - mse: 0.0026 - val_loss: 0.0028 - val_mse: 0.0028 - 28ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0026 - mse: 0.0026\n",
      "38/38 [==============================] - 0s 682us/step - loss: 0.0028 - mse: 0.0028\n",
      "2/2 - 0s - loss: 0.0025 - mse: 0.0025 - val_loss: 0.0028 - val_mse: 0.0028 - 27ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0026 - mse: 0.0026\n",
      "38/38 [==============================] - 0s 595us/step - loss: 0.0028 - mse: 0.0028\n",
      "2/2 - 0s - loss: 0.0025 - mse: 0.0025 - val_loss: 0.0028 - val_mse: 0.0028 - 28ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0026 - mse: 0.0026\n",
      "38/38 [==============================] - 0s 661us/step - loss: 0.0028 - mse: 0.0028\n",
      "2/2 - 0s - loss: 0.0025 - mse: 0.0025 - val_loss: 0.0028 - val_mse: 0.0028 - 33ms/epoch - 16ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0026 - mse: 0.0026\n",
      "38/38 [==============================] - 0s 703us/step - loss: 0.0028 - mse: 0.0028\n",
      "2/2 - 0s - loss: 0.0025 - mse: 0.0025 - val_loss: 0.0028 - val_mse: 0.0028 - 36ms/epoch - 18ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0026 - mse: 0.0026\n",
      "38/38 [==============================] - 0s 687us/step - loss: 0.0028 - mse: 0.0028\n",
      "2/2 - 0s - loss: 0.0025 - mse: 0.0025 - val_loss: 0.0027 - val_mse: 0.0027 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0026 - mse: 0.0026\n",
      "38/38 [==============================] - 0s 655us/step - loss: 0.0027 - mse: 0.0027\n",
      "2/2 - 0s - loss: 0.0025 - mse: 0.0025 - val_loss: 0.0028 - val_mse: 0.0028 - 27ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0025 - mse: 0.0025\n",
      "38/38 [==============================] - 0s 649us/step - loss: 0.0027 - mse: 0.0027\n",
      "2/2 - 0s - loss: 0.0025 - mse: 0.0025 - val_loss: 0.0027 - val_mse: 0.0027 - 28ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0025 - mse: 0.0025\n",
      "38/38 [==============================] - 0s 631us/step - loss: 0.0027 - mse: 0.0027\n",
      "2/2 - 0s - loss: 0.0025 - mse: 0.0025 - val_loss: 0.0027 - val_mse: 0.0027 - 28ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0025 - mse: 0.0025\n",
      "38/38 [==============================] - 0s 636us/step - loss: 0.0027 - mse: 0.0027\n",
      "2/2 - 0s - loss: 0.0025 - mse: 0.0025 - val_loss: 0.0027 - val_mse: 0.0027 - 25ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0025 - mse: 0.0025\n",
      "38/38 [==============================] - 0s 630us/step - loss: 0.0027 - mse: 0.0027\n",
      "2/2 - 0s - loss: 0.0024 - mse: 0.0024 - val_loss: 0.0027 - val_mse: 0.0027 - 27ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0025 - mse: 0.0025\n",
      "38/38 [==============================] - 0s 599us/step - loss: 0.0027 - mse: 0.0027\n",
      "2/2 - 0s - loss: 0.0024 - mse: 0.0024 - val_loss: 0.0027 - val_mse: 0.0027 - 28ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0025 - mse: 0.0025\n",
      "38/38 [==============================] - 0s 556us/step - loss: 0.0027 - mse: 0.0027\n",
      "2/2 - 0s - loss: 0.0024 - mse: 0.0024 - val_loss: 0.0027 - val_mse: 0.0027 - 28ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0025 - mse: 0.0025\n",
      "38/38 [==============================] - 0s 595us/step - loss: 0.0027 - mse: 0.0027\n",
      "2/2 - 0s - loss: 0.0024 - mse: 0.0024 - val_loss: 0.0027 - val_mse: 0.0027 - 31ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0025 - mse: 0.0025\n",
      "38/38 [==============================] - 0s 644us/step - loss: 0.0027 - mse: 0.0027\n",
      "2/2 - 0s - loss: 0.0024 - mse: 0.0024 - val_loss: 0.0026 - val_mse: 0.0026 - 27ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0025 - mse: 0.0025\n",
      "38/38 [==============================] - 0s 770us/step - loss: 0.0026 - mse: 0.0026\n",
      "2/2 - 0s - loss: 0.0024 - mse: 0.0024 - val_loss: 0.0026 - val_mse: 0.0026 - 28ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0024 - mse: 0.0024\n",
      "38/38 [==============================] - 0s 590us/step - loss: 0.0026 - mse: 0.0026\n",
      "2/2 - 0s - loss: 0.0024 - mse: 0.0024 - val_loss: 0.0026 - val_mse: 0.0026 - 28ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 3ms/step - loss: 0.0024 - mse: 0.0024\n",
      "38/38 [==============================] - 0s 623us/step - loss: 0.0026 - mse: 0.0026\n",
      "2/2 - 0s - loss: 0.0024 - mse: 0.0024 - val_loss: 0.0026 - val_mse: 0.0026 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0024 - mse: 0.0024\n",
      "38/38 [==============================] - 0s 625us/step - loss: 0.0026 - mse: 0.0026\n",
      "2/2 - 0s - loss: 0.0024 - mse: 0.0024 - val_loss: 0.0026 - val_mse: 0.0026 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0024 - mse: 0.0024\n",
      "38/38 [==============================] - 0s 624us/step - loss: 0.0026 - mse: 0.0026\n",
      "2/2 - 0s - loss: 0.0024 - mse: 0.0024 - val_loss: 0.0026 - val_mse: 0.0026 - 29ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0024 - mse: 0.0024\n",
      "38/38 [==============================] - 0s 613us/step - loss: 0.0026 - mse: 0.0026\n",
      "2/2 - 0s - loss: 0.0024 - mse: 0.0024 - val_loss: 0.0026 - val_mse: 0.0026 - 26ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0024 - mse: 0.0024\n",
      "38/38 [==============================] - 0s 697us/step - loss: 0.0026 - mse: 0.0026\n",
      "2/2 - 0s - loss: 0.0023 - mse: 0.0023 - val_loss: 0.0026 - val_mse: 0.0026 - 30ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0024 - mse: 0.0024\n",
      "38/38 [==============================] - 0s 666us/step - loss: 0.0026 - mse: 0.0026\n",
      "2/2 - 0s - loss: 0.0023 - mse: 0.0023 - val_loss: 0.0026 - val_mse: 0.0026 - 36ms/epoch - 18ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0024 - mse: 0.0024\n",
      "38/38 [==============================] - 0s 608us/step - loss: 0.0026 - mse: 0.0026\n",
      "2/2 - 0s - loss: 0.0023 - mse: 0.0023 - val_loss: 0.0026 - val_mse: 0.0026 - 25ms/epoch - 13ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0024 - mse: 0.0024\n",
      "38/38 [==============================] - 0s 691us/step - loss: 0.0026 - mse: 0.0026\n",
      "2/2 - 0s - loss: 0.0023 - mse: 0.0023 - val_loss: 0.0025 - val_mse: 0.0025 - 28ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0024 - mse: 0.0024\n",
      "38/38 [==============================] - 0s 625us/step - loss: 0.0025 - mse: 0.0025\n",
      "2/2 - 0s - loss: 0.0023 - mse: 0.0023 - val_loss: 0.0025 - val_mse: 0.0025 - 27ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0024 - mse: 0.0024\n",
      "38/38 [==============================] - 0s 589us/step - loss: 0.0025 - mse: 0.0025\n",
      "2/2 - 0s - loss: 0.0023 - mse: 0.0023 - val_loss: 0.0025 - val_mse: 0.0025 - 29ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0023 - mse: 0.0023\n",
      "38/38 [==============================] - 0s 679us/step - loss: 0.0025 - mse: 0.0025\n",
      "2/2 - 0s - loss: 0.0023 - mse: 0.0023 - val_loss: 0.0025 - val_mse: 0.0025 - 28ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0023 - mse: 0.0023\n",
      "38/38 [==============================] - 0s 610us/step - loss: 0.0025 - mse: 0.0025\n",
      "2/2 - 0s - loss: 0.0023 - mse: 0.0023 - val_loss: 0.0025 - val_mse: 0.0025 - 28ms/epoch - 14ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0023 - mse: 0.0023\n",
      "38/38 [==============================] - 0s 637us/step - loss: 0.0025 - mse: 0.0025\n",
      "2/2 - 0s - loss: 0.0023 - mse: 0.0023 - val_loss: 0.0025 - val_mse: 0.0025 - 144ms/epoch - 72ms/step\n",
      "2/2 [==============================] - 0s 1ms/step - loss: 0.0023 - mse: 0.0023\n",
      "38/38 [==============================] - 0s 697us/step - loss: 0.0025 - mse: 0.0025\n",
      "2/2 - 0s - loss: 0.0023 - mse: 0.0023 - val_loss: 0.0025 - val_mse: 0.0025 - 29ms/epoch - 15ms/step\n",
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0023 - mse: 0.0023\n",
      "38/38 [==============================] - 0s 711us/step - loss: 0.0025 - mse: 0.0025\n",
      "54.47199606895447\n"
     ]
    }
   ],
   "source": [
    "t0 = time.time()\n",
    "history_F = [] #collect data for figures\n",
    "for i in range(400):\n",
    "    history = final_model_PQ.fit(X_train, y_train, epochs=1, batch_size=256, validation_split=0.25, verbose=2)\n",
    "    loss_and_metrics_train = final_model_PQ.evaluate(X_train, y_train, batch_size=256)\n",
    "    loss_and_metrics_test = final_model_PQ.evaluate(X_test, y_test, batch_size=256)\n",
    "    history_F.append([loss_and_metrics_train[0],loss_and_metrics_test[0]])\n",
    "    i = i + 1\n",
    "t1 = time.time()\n",
    "print(t1-t0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "388b3084",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2/2 [==============================] - 0s 2ms/step - loss: 0.0023 - mse: 0.0023\n",
      "38/38 [==============================] - 0s 631us/step - loss: 0.0025 - mse: 0.0025\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": 31,
   "id": "f9ed7589",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "history_F = np.array(history_F)  # shape: (num_epochs, 5)\n",
    "# Plot each variable\n",
    "plt.figure(figsize=(10, 6))\n",
    "for i in range(2):\n",
    "    plt.plot(history_F[:, i], label=f'Variable {i}')\n",
    "\n",
    "plt.xlabel('Epoch')\n",
    "plt.ylabel('Value')\n",
    "plt.title('Five Variables over Epochs')\n",
    "plt.legend()\n",
    "plt.grid(True)\n",
    "plt.tight_layout()\n",
    "plt.show()\n",
    "\n",
    "savemat('history_F.mat', {'value': history_F})"
   ]
  }
 ],
 "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
}
