{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "539ebd7b",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "from tensorflow.keras.models import Sequential\n",
    "from tensorflow.keras.layers import Dense\n",
    "from sklearn.preprocessing import StandardScaler\n",
    "from sklearn.model_selection import train_test_split\n",
    "\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",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import time "
   ]
  },
  {
   "cell_type": "markdown",
   "id": "069e2e34",
   "metadata": {},
   "source": [
    "# import target dataset, use the first trajectory"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "3a4a2d8e",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Load the npz file\n",
    "data = np.load('Sines_full.npz', allow_pickle=True)\n",
    "\n",
    "keys = list(data.keys())\n",
    "print(\"Keys in file:\", keys) #index is not needed\n",
    "\n",
    "# Assume correct order of keys: s1, u1, s2, s3, u2\n",
    "s1 = data[keys[0]]\n",
    "u1 = data[keys[2]]\n",
    "s2 = data[keys[3]]\n",
    "s3 = data[keys[4]]\n",
    "u2 = data[keys[5]]\n",
    "\n",
    "#we should use constrained_torques as input, which is the derised_torques under the actua condition\n",
    "\n",
    "# # Concatenate input at time t: [s1, s2, s3, u1, u2] → shape: (38, 14000, 15)\n",
    "# X_full = np.concatenate([s1, s2, s3, u1, u2], axis=-1)\n",
    "\n",
    "# Concatenate input at time t: [s1, s2, s3, u1] → shape: (38, 14000, 14)\n",
    "X_full = np.concatenate([s1, s2, s3, u1], axis=-1)\n",
    "\n",
    "# Concatenate states for next step (output at t+1): [s1, s2, s3]\n",
    "Y_full = np.concatenate([s1, s2, s3], axis=-1)  # shape: (38, 14000, 9)\n",
    "\n",
    "# Build training data from t and t+1\n",
    "X_list = []\n",
    "Y_list = []\n",
    "\n",
    "for i in range(1):  # 38 trajectories\n",
    "    X_t = X_full[i, :-1, :]   # inputs at time t, shape: (13999, 14)\n",
    "    Y_tp1 = Y_full[i, 1:, :]  # next states at time t+1, shape: (13999, 9)\n",
    "\n",
    "    X_list.append(X_t)\n",
    "    Y_list.append(Y_tp1)\n",
    "\n",
    "# Stack across all trajectories\n",
    "X = np.vstack(X_list)  # shape: (38*13999, 14)\n",
    "Y = np.vstack(Y_list)  # shape: (38*13999, 9)\n",
    "\n",
    "print(\"Input shape:\", X.shape)   # → (531962, 14)\n",
    "print(\"Output shape:\", Y.shape)  # → (531962, 9)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "a7948aac",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[['0.99921' '4.9728' '4.9728']\n",
      " ['1.0172' '4.9722' '4.9722']\n",
      " ['1.0318' '4.9703' '4.9703']\n",
      " ...\n",
      " ['0.88351' '3.7978' '3.7978']\n",
      " ['0.9162' '3.7807' '3.7807']\n",
      " ['0.94805' '3.7151' '3.7151']] [['4.9722' '4.9722']\n",
      " ['4.9703' '4.9703']\n",
      " ['4.988' '4.988']\n",
      " ...\n",
      " ['3.7807' '3.7807']\n",
      " ['3.7151' '3.7151']\n",
      " ['3.7179' '3.7179']]\n"
     ]
    }
   ],
   "source": [
    "# Load your preprocessed X and Y from earlier\n",
    "# X: shape (N, 15), Y: shape (N, 9)\n",
    "\n",
    "# Step 1: Normalize using sklearn StandardScaler\n",
    "x_scaler = StandardScaler()\n",
    "y_scaler = StandardScaler()\n",
    "\n",
    "X_norm = x_scaler.fit_transform(X)\n",
    "Y_norm = y_scaler.fit_transform(Y)\n",
    "\n",
    "# Step 2: Split into train and test\n",
    "X_train, X_test, Y_train, Y_test = train_test_split(X_norm, Y_norm, test_size=0.9, random_state=42)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ec0cb9e6",
   "metadata": {},
   "source": [
    "# Standard NN model as benchmark"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "118fa7f5",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Step 3: Define the neural network\n",
    "model = Sequential([\n",
    "    Dense(64, activation='relu', input_shape=(X.shape[1],)),  # input: 15\n",
    "    Dense(32, activation='relu'),\n",
    "    Dense(Y.shape[1], activation='linear')  # output: 9\n",
    "])\n",
    "\n",
    "model.compile(loss='mse', metrics=['mae'])\n",
    "\n",
    "\n",
    "t0 = time.time()\n",
    "# Step 4: Train the model\n",
    "history = model.fit(X_train, Y_train, epochs=300, batch_size=256, validation_split=0.1, verbose=1)\n",
    "t1 = time.time()\n",
    "print(t1-t0)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e48f5901",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d3c9df57",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0a13e66a",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "d8e4402d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(204, 3) (819, 3) (204, 2) (819, 2)\n"
     ]
    }
   ],
   "source": [
    "# === Step 3: Normalize data (optional but recommended) ===\n",
    "scaler_X = StandardScaler()\n",
    "scaler_Y = StandardScaler()\n",
    "\n",
    "X_scaled = scaler_X.fit_transform(X)\n",
    "Y_scaled = scaler_Y.fit_transform(Y)\n",
    "\n",
    "# === Step 4: Train-test split ===\n",
    "X_train, X_test, Y_train, Y_test = train_test_split(X_scaled, Y_scaled, test_size=0.8, random_state=42)\n",
    "\n",
    "print(X_train.shape, X_test.shape, Y_train.shape, Y_test.shape)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3d8c5f41",
   "metadata": {},
   "source": [
    "# Develop the benchmark"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "d0ab6116",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model: \"sequential\"\n",
      "_________________________________________________________________\n",
      " Layer (type)                Output Shape              Param #   \n",
      "=================================================================\n",
      " dense (Dense)               (None, 8)                 32        \n",
      "                                                                 \n",
      " dense_1 (Dense)             (None, 2)                 18        \n",
      "                                                                 \n",
      "=================================================================\n",
      "Total params: 50\n",
      "Trainable params: 50\n",
      "Non-trainable params: 0\n",
      "_________________________________________________________________\n",
      "None\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-07-17 15:37:20.246259: 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 15:37:20.246292: 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 15:37:20.247254: 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"
     ]
    }
   ],
   "source": [
    "# === Step 5: Define and train FNN model ===\n",
    "model = Sequential([\n",
    "    Dense(8, activation='tanh', input_shape=(3,)),\n",
    "    Dense(2, activation='linear')\n",
    "])\n",
    "\n",
    "model.compile(optimizer='adam', loss='mse', metrics=['mse'])\n",
    "print(model.summary())\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "2cc77d23",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/400\n",
      "7/7 [==============================] - 0s 14ms/step - loss: 2.3070 - mse: 2.3070 - val_loss: 2.0506 - val_mse: 2.0506\n",
      "Epoch 2/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 2.2044 - mse: 2.2044 - val_loss: 1.9583 - val_mse: 1.9583\n",
      "Epoch 3/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 2.1054 - mse: 2.1054 - val_loss: 1.8682 - val_mse: 1.8682\n",
      "Epoch 4/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 2.0065 - mse: 2.0065 - val_loss: 1.7809 - val_mse: 1.7809\n",
      "Epoch 5/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 1.9132 - mse: 1.9132 - val_loss: 1.6949 - val_mse: 1.6949\n",
      "Epoch 6/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 1.8206 - mse: 1.8206 - val_loss: 1.6115 - val_mse: 1.6115\n",
      "Epoch 7/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 1.7316 - mse: 1.7316 - val_loss: 1.5298 - val_mse: 1.5298\n",
      "Epoch 8/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 1.6438 - mse: 1.6438 - val_loss: 1.4512 - val_mse: 1.4512\n",
      "Epoch 9/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 1.5606 - mse: 1.5606 - val_loss: 1.3739 - val_mse: 1.3739\n",
      "Epoch 10/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 1.4768 - mse: 1.4768 - val_loss: 1.2988 - val_mse: 1.2988\n",
      "Epoch 11/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 1.3967 - mse: 1.3967 - val_loss: 1.2244 - val_mse: 1.2244\n",
      "Epoch 12/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 1.3178 - mse: 1.3178 - val_loss: 1.1533 - val_mse: 1.1533\n",
      "Epoch 13/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 1.2432 - mse: 1.2432 - val_loss: 1.0841 - val_mse: 1.0841\n",
      "Epoch 14/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 1.1700 - mse: 1.1700 - val_loss: 1.0177 - val_mse: 1.0177\n",
      "Epoch 15/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 1.0990 - mse: 1.0990 - val_loss: 0.9550 - val_mse: 0.9550\n",
      "Epoch 16/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 1.0313 - mse: 1.0313 - val_loss: 0.8946 - val_mse: 0.8946\n",
      "Epoch 17/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.9676 - mse: 0.9676 - val_loss: 0.8365 - val_mse: 0.8365\n",
      "Epoch 18/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.9081 - mse: 0.9081 - val_loss: 0.7800 - val_mse: 0.7800\n",
      "Epoch 19/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.8470 - mse: 0.8470 - val_loss: 0.7264 - val_mse: 0.7264\n",
      "Epoch 20/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.7899 - mse: 0.7899 - val_loss: 0.6766 - val_mse: 0.6766\n",
      "Epoch 21/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.7372 - mse: 0.7372 - val_loss: 0.6290 - val_mse: 0.6290\n",
      "Epoch 22/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.6851 - mse: 0.6851 - val_loss: 0.5835 - val_mse: 0.5835\n",
      "Epoch 23/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.6379 - mse: 0.6379 - val_loss: 0.5395 - val_mse: 0.5395\n",
      "Epoch 24/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.5909 - mse: 0.5909 - val_loss: 0.4987 - val_mse: 0.4987\n",
      "Epoch 25/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.5474 - mse: 0.5474 - val_loss: 0.4608 - val_mse: 0.4608\n",
      "Epoch 26/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.5075 - mse: 0.5075 - val_loss: 0.4246 - val_mse: 0.4246\n",
      "Epoch 27/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.4686 - mse: 0.4686 - val_loss: 0.3919 - val_mse: 0.3919\n",
      "Epoch 28/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.4350 - mse: 0.4350 - val_loss: 0.3604 - val_mse: 0.3604\n",
      "Epoch 29/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.4013 - mse: 0.4013 - val_loss: 0.3322 - val_mse: 0.3322\n",
      "Epoch 30/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.3705 - mse: 0.3705 - val_loss: 0.3061 - val_mse: 0.3061\n",
      "Epoch 31/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.3426 - mse: 0.3426 - val_loss: 0.2815 - val_mse: 0.2815\n",
      "Epoch 32/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.3163 - mse: 0.3163 - val_loss: 0.2591 - val_mse: 0.2591\n",
      "Epoch 33/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.2927 - mse: 0.2927 - val_loss: 0.2382 - val_mse: 0.2382\n",
      "Epoch 34/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.2697 - mse: 0.2697 - val_loss: 0.2194 - val_mse: 0.2194\n",
      "Epoch 35/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.2494 - mse: 0.2494 - val_loss: 0.2017 - val_mse: 0.2017\n",
      "Epoch 36/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.2308 - mse: 0.2308 - val_loss: 0.1854 - val_mse: 0.1854\n",
      "Epoch 37/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.2127 - mse: 0.2127 - val_loss: 0.1705 - val_mse: 0.1705\n",
      "Epoch 38/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.1970 - mse: 0.1970 - val_loss: 0.1567 - val_mse: 0.1567\n",
      "Epoch 39/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.1820 - mse: 0.1820 - val_loss: 0.1442 - val_mse: 0.1442\n",
      "Epoch 40/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.1685 - mse: 0.1685 - val_loss: 0.1326 - val_mse: 0.1326\n",
      "Epoch 41/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.1555 - mse: 0.1555 - val_loss: 0.1226 - val_mse: 0.1226\n",
      "Epoch 42/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.1443 - mse: 0.1443 - val_loss: 0.1136 - val_mse: 0.1136\n",
      "Epoch 43/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.1347 - mse: 0.1347 - val_loss: 0.1049 - val_mse: 0.1049\n",
      "Epoch 44/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.1251 - mse: 0.1251 - val_loss: 0.0971 - val_mse: 0.0971\n",
      "Epoch 45/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.1166 - mse: 0.1166 - val_loss: 0.0903 - val_mse: 0.0903\n",
      "Epoch 46/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.1088 - mse: 0.1088 - val_loss: 0.0841 - val_mse: 0.0841\n",
      "Epoch 47/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.1019 - mse: 0.1019 - val_loss: 0.0785 - val_mse: 0.0785\n",
      "Epoch 48/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0958 - mse: 0.0958 - val_loss: 0.0735 - val_mse: 0.0735\n",
      "Epoch 49/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0900 - mse: 0.0900 - val_loss: 0.0689 - val_mse: 0.0689\n",
      "Epoch 50/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0847 - mse: 0.0847 - val_loss: 0.0648 - val_mse: 0.0648\n",
      "Epoch 51/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0800 - mse: 0.0800 - val_loss: 0.0610 - val_mse: 0.0610\n",
      "Epoch 52/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0756 - mse: 0.0756 - val_loss: 0.0577 - val_mse: 0.0577\n",
      "Epoch 53/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0716 - mse: 0.0716 - val_loss: 0.0548 - val_mse: 0.0548\n",
      "Epoch 54/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0681 - mse: 0.0681 - val_loss: 0.0520 - val_mse: 0.0520\n",
      "Epoch 55/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0650 - mse: 0.0650 - val_loss: 0.0496 - val_mse: 0.0496\n",
      "Epoch 56/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0619 - mse: 0.0619 - val_loss: 0.0475 - val_mse: 0.0475\n",
      "Epoch 57/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0594 - mse: 0.0594 - val_loss: 0.0456 - val_mse: 0.0456\n",
      "Epoch 58/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0571 - mse: 0.0571 - val_loss: 0.0438 - val_mse: 0.0438\n",
      "Epoch 59/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0549 - mse: 0.0549 - val_loss: 0.0422 - val_mse: 0.0422\n",
      "Epoch 60/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0528 - mse: 0.0528 - val_loss: 0.0407 - val_mse: 0.0407\n",
      "Epoch 61/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0513 - mse: 0.0513 - val_loss: 0.0394 - val_mse: 0.0394\n",
      "Epoch 62/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0494 - mse: 0.0494 - val_loss: 0.0384 - val_mse: 0.0384\n",
      "Epoch 63/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0481 - mse: 0.0481 - val_loss: 0.0375 - val_mse: 0.0375\n",
      "Epoch 64/400\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0468 - mse: 0.0468 - val_loss: 0.0366 - val_mse: 0.0366\n",
      "Epoch 65/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0456 - mse: 0.0456 - val_loss: 0.0358 - val_mse: 0.0358\n",
      "Epoch 66/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0445 - mse: 0.0445 - val_loss: 0.0350 - val_mse: 0.0350\n",
      "Epoch 67/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0436 - mse: 0.0436 - val_loss: 0.0343 - val_mse: 0.0343\n",
      "Epoch 68/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0426 - mse: 0.0426 - val_loss: 0.0337 - val_mse: 0.0337\n",
      "Epoch 69/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0418 - mse: 0.0418 - val_loss: 0.0331 - val_mse: 0.0331\n",
      "Epoch 70/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0409 - mse: 0.0409 - val_loss: 0.0327 - val_mse: 0.0327\n",
      "Epoch 71/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0402 - mse: 0.0402 - val_loss: 0.0322 - val_mse: 0.0322\n",
      "Epoch 72/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0394 - mse: 0.0394 - val_loss: 0.0317 - val_mse: 0.0317\n",
      "Epoch 73/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0387 - mse: 0.0387 - val_loss: 0.0313 - val_mse: 0.0313\n",
      "Epoch 74/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0381 - mse: 0.0381 - val_loss: 0.0308 - val_mse: 0.0308\n",
      "Epoch 75/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0375 - mse: 0.0375 - val_loss: 0.0304 - val_mse: 0.0304\n",
      "Epoch 76/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0369 - mse: 0.0369 - val_loss: 0.0301 - val_mse: 0.0301\n",
      "Epoch 77/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0363 - mse: 0.0363 - val_loss: 0.0297 - val_mse: 0.0297\n",
      "Epoch 78/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0358 - mse: 0.0358 - val_loss: 0.0294 - val_mse: 0.0294\n",
      "Epoch 79/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0353 - mse: 0.0353 - val_loss: 0.0290 - val_mse: 0.0290\n",
      "Epoch 80/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0348 - mse: 0.0348 - val_loss: 0.0287 - val_mse: 0.0287\n",
      "Epoch 81/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0344 - mse: 0.0344 - val_loss: 0.0284 - val_mse: 0.0284\n",
      "Epoch 82/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0338 - mse: 0.0338 - val_loss: 0.0281 - val_mse: 0.0281\n",
      "Epoch 83/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0333 - mse: 0.0333 - val_loss: 0.0278 - val_mse: 0.0278\n",
      "Epoch 84/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0329 - mse: 0.0329 - val_loss: 0.0275 - val_mse: 0.0275\n",
      "Epoch 85/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0325 - mse: 0.0325 - val_loss: 0.0272 - val_mse: 0.0272\n",
      "Epoch 86/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0321 - mse: 0.0321 - val_loss: 0.0270 - val_mse: 0.0270\n",
      "Epoch 87/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0317 - mse: 0.0317 - val_loss: 0.0267 - val_mse: 0.0267\n",
      "Epoch 88/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0312 - mse: 0.0312 - val_loss: 0.0264 - val_mse: 0.0264\n",
      "Epoch 89/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0308 - mse: 0.0308 - val_loss: 0.0261 - val_mse: 0.0261\n",
      "Epoch 90/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0304 - mse: 0.0304 - val_loss: 0.0258 - val_mse: 0.0258\n",
      "Epoch 91/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0301 - mse: 0.0301 - val_loss: 0.0256 - val_mse: 0.0256\n",
      "Epoch 92/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0296 - mse: 0.0296 - val_loss: 0.0253 - val_mse: 0.0253\n",
      "Epoch 93/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0293 - mse: 0.0293 - val_loss: 0.0251 - val_mse: 0.0251\n",
      "Epoch 94/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0289 - mse: 0.0289 - val_loss: 0.0248 - val_mse: 0.0248\n",
      "Epoch 95/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0285 - mse: 0.0285 - val_loss: 0.0246 - val_mse: 0.0246\n",
      "Epoch 96/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0282 - mse: 0.0282 - val_loss: 0.0243 - val_mse: 0.0243\n",
      "Epoch 97/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0279 - mse: 0.0279 - val_loss: 0.0241 - val_mse: 0.0241\n",
      "Epoch 98/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0275 - mse: 0.0275 - val_loss: 0.0238 - val_mse: 0.0238\n",
      "Epoch 99/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0272 - mse: 0.0272 - val_loss: 0.0236 - val_mse: 0.0236\n",
      "Epoch 100/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0268 - mse: 0.0268 - val_loss: 0.0233 - val_mse: 0.0233\n",
      "Epoch 101/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0265 - mse: 0.0265 - val_loss: 0.0231 - val_mse: 0.0231\n",
      "Epoch 102/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0262 - mse: 0.0262 - val_loss: 0.0228 - val_mse: 0.0228\n",
      "Epoch 103/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0258 - mse: 0.0258 - val_loss: 0.0226 - val_mse: 0.0226\n",
      "Epoch 104/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0255 - mse: 0.0255 - val_loss: 0.0224 - val_mse: 0.0224\n",
      "Epoch 105/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0252 - mse: 0.0252 - val_loss: 0.0222 - val_mse: 0.0222\n",
      "Epoch 106/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0249 - mse: 0.0249 - val_loss: 0.0219 - val_mse: 0.0219\n",
      "Epoch 107/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0246 - mse: 0.0246 - val_loss: 0.0217 - val_mse: 0.0217\n",
      "Epoch 108/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0243 - mse: 0.0243 - val_loss: 0.0215 - val_mse: 0.0215\n",
      "Epoch 109/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0241 - mse: 0.0241 - val_loss: 0.0213 - val_mse: 0.0213\n",
      "Epoch 110/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0238 - mse: 0.0238 - val_loss: 0.0211 - val_mse: 0.0211\n",
      "Epoch 111/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0235 - mse: 0.0235 - val_loss: 0.0209 - val_mse: 0.0209\n",
      "Epoch 112/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0232 - mse: 0.0232 - val_loss: 0.0207 - val_mse: 0.0207\n",
      "Epoch 113/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0229 - mse: 0.0229 - val_loss: 0.0205 - val_mse: 0.0205\n",
      "Epoch 114/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0227 - mse: 0.0227 - val_loss: 0.0203 - val_mse: 0.0203\n",
      "Epoch 115/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0224 - mse: 0.0224 - val_loss: 0.0201 - val_mse: 0.0201\n",
      "Epoch 116/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0221 - mse: 0.0221 - val_loss: 0.0199 - val_mse: 0.0199\n",
      "Epoch 117/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0219 - mse: 0.0219 - val_loss: 0.0197 - val_mse: 0.0197\n",
      "Epoch 118/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0217 - mse: 0.0217 - val_loss: 0.0195 - val_mse: 0.0195\n",
      "Epoch 119/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0214 - mse: 0.0214 - val_loss: 0.0193 - val_mse: 0.0193\n",
      "Epoch 120/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0212 - mse: 0.0212 - val_loss: 0.0191 - val_mse: 0.0191\n",
      "Epoch 121/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0209 - mse: 0.0209 - val_loss: 0.0189 - val_mse: 0.0189\n",
      "Epoch 122/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0207 - mse: 0.0207 - val_loss: 0.0188 - val_mse: 0.0188\n",
      "Epoch 123/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0205 - mse: 0.0205 - val_loss: 0.0186 - val_mse: 0.0186\n",
      "Epoch 124/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0203 - mse: 0.0203 - val_loss: 0.0184 - val_mse: 0.0184\n",
      "Epoch 125/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0200 - mse: 0.0200 - val_loss: 0.0182 - val_mse: 0.0182\n",
      "Epoch 126/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0198 - mse: 0.0198 - val_loss: 0.0181 - val_mse: 0.0181\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 127/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0196 - mse: 0.0196 - val_loss: 0.0179 - val_mse: 0.0179\n",
      "Epoch 128/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0194 - mse: 0.0194 - val_loss: 0.0178 - val_mse: 0.0178\n",
      "Epoch 129/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0191 - mse: 0.0191 - val_loss: 0.0176 - val_mse: 0.0176\n",
      "Epoch 130/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0189 - mse: 0.0189 - val_loss: 0.0174 - val_mse: 0.0174\n",
      "Epoch 131/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0187 - mse: 0.0187 - val_loss: 0.0173 - val_mse: 0.0173\n",
      "Epoch 132/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0185 - mse: 0.0185 - val_loss: 0.0172 - val_mse: 0.0172\n",
      "Epoch 133/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0183 - mse: 0.0183 - val_loss: 0.0170 - val_mse: 0.0170\n",
      "Epoch 134/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0181 - mse: 0.0181 - val_loss: 0.0169 - val_mse: 0.0169\n",
      "Epoch 135/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0180 - mse: 0.0180 - val_loss: 0.0167 - val_mse: 0.0167\n",
      "Epoch 136/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0178 - mse: 0.0178 - val_loss: 0.0166 - val_mse: 0.0166\n",
      "Epoch 137/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0176 - mse: 0.0176 - val_loss: 0.0164 - val_mse: 0.0164\n",
      "Epoch 138/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0174 - mse: 0.0174 - val_loss: 0.0163 - val_mse: 0.0163\n",
      "Epoch 139/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0172 - mse: 0.0172 - val_loss: 0.0161 - val_mse: 0.0161\n",
      "Epoch 140/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0171 - mse: 0.0171 - val_loss: 0.0160 - val_mse: 0.0160\n",
      "Epoch 141/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0169 - mse: 0.0169 - val_loss: 0.0159 - val_mse: 0.0159\n",
      "Epoch 142/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0167 - mse: 0.0167 - val_loss: 0.0157 - val_mse: 0.0157\n",
      "Epoch 143/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0165 - mse: 0.0165 - val_loss: 0.0156 - val_mse: 0.0156\n",
      "Epoch 144/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0164 - mse: 0.0164 - val_loss: 0.0155 - val_mse: 0.0155\n",
      "Epoch 145/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0162 - mse: 0.0162 - val_loss: 0.0153 - val_mse: 0.0153\n",
      "Epoch 146/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0160 - mse: 0.0160 - val_loss: 0.0152 - val_mse: 0.0152\n",
      "Epoch 147/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0159 - mse: 0.0159 - val_loss: 0.0151 - val_mse: 0.0151\n",
      "Epoch 148/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0157 - mse: 0.0157 - val_loss: 0.0150 - val_mse: 0.0150\n",
      "Epoch 149/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0156 - mse: 0.0156 - val_loss: 0.0149 - val_mse: 0.0149\n",
      "Epoch 150/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0154 - mse: 0.0154 - val_loss: 0.0147 - val_mse: 0.0147\n",
      "Epoch 151/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0153 - mse: 0.0153 - val_loss: 0.0146 - val_mse: 0.0146\n",
      "Epoch 152/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0151 - mse: 0.0151 - val_loss: 0.0145 - val_mse: 0.0145\n",
      "Epoch 153/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0150 - mse: 0.0150 - val_loss: 0.0144 - val_mse: 0.0144\n",
      "Epoch 154/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0149 - mse: 0.0149 - val_loss: 0.0142 - val_mse: 0.0142\n",
      "Epoch 155/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0147 - mse: 0.0147 - val_loss: 0.0141 - val_mse: 0.0141\n",
      "Epoch 156/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0146 - mse: 0.0146 - val_loss: 0.0140 - val_mse: 0.0140\n",
      "Epoch 157/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0144 - mse: 0.0144 - val_loss: 0.0139 - val_mse: 0.0139\n",
      "Epoch 158/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0143 - mse: 0.0143 - val_loss: 0.0138 - val_mse: 0.0138\n",
      "Epoch 159/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0141 - mse: 0.0141 - val_loss: 0.0137 - val_mse: 0.0137\n",
      "Epoch 160/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0140 - mse: 0.0140 - val_loss: 0.0136 - val_mse: 0.0136\n",
      "Epoch 161/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0139 - mse: 0.0139 - val_loss: 0.0135 - val_mse: 0.0135\n",
      "Epoch 162/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0138 - mse: 0.0138 - val_loss: 0.0134 - val_mse: 0.0134\n",
      "Epoch 163/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0136 - mse: 0.0136 - val_loss: 0.0133 - val_mse: 0.0133\n",
      "Epoch 164/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0135 - mse: 0.0135 - val_loss: 0.0132 - val_mse: 0.0132\n",
      "Epoch 165/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0134 - mse: 0.0134 - val_loss: 0.0131 - val_mse: 0.0131\n",
      "Epoch 166/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0133 - mse: 0.0133 - val_loss: 0.0130 - val_mse: 0.0130\n",
      "Epoch 167/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0132 - mse: 0.0132 - val_loss: 0.0129 - val_mse: 0.0129\n",
      "Epoch 168/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0130 - mse: 0.0130 - val_loss: 0.0128 - val_mse: 0.0128\n",
      "Epoch 169/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0129 - mse: 0.0129 - val_loss: 0.0127 - val_mse: 0.0127\n",
      "Epoch 170/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0128 - mse: 0.0128 - val_loss: 0.0126 - val_mse: 0.0126\n",
      "Epoch 171/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0127 - mse: 0.0127 - val_loss: 0.0125 - val_mse: 0.0125\n",
      "Epoch 172/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0126 - mse: 0.0126 - val_loss: 0.0124 - val_mse: 0.0124\n",
      "Epoch 173/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0125 - mse: 0.0125 - val_loss: 0.0123 - val_mse: 0.0123\n",
      "Epoch 174/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0124 - mse: 0.0124 - val_loss: 0.0122 - val_mse: 0.0122\n",
      "Epoch 175/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0123 - mse: 0.0123 - val_loss: 0.0121 - val_mse: 0.0121\n",
      "Epoch 176/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0122 - mse: 0.0122 - val_loss: 0.0120 - val_mse: 0.0120\n",
      "Epoch 177/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0120 - mse: 0.0120 - val_loss: 0.0119 - val_mse: 0.0119\n",
      "Epoch 178/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0120 - mse: 0.0120 - val_loss: 0.0118 - val_mse: 0.0118\n",
      "Epoch 179/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0118 - mse: 0.0118 - val_loss: 0.0118 - val_mse: 0.0118\n",
      "Epoch 180/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0117 - mse: 0.0117 - val_loss: 0.0117 - val_mse: 0.0117\n",
      "Epoch 181/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0116 - mse: 0.0116 - val_loss: 0.0116 - val_mse: 0.0116\n",
      "Epoch 182/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0115 - mse: 0.0115 - val_loss: 0.0115 - val_mse: 0.0115\n",
      "Epoch 183/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0114 - mse: 0.0114 - val_loss: 0.0114 - val_mse: 0.0114\n",
      "Epoch 184/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0113 - mse: 0.0113 - val_loss: 0.0113 - val_mse: 0.0113\n",
      "Epoch 185/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0112 - mse: 0.0112 - val_loss: 0.0113 - val_mse: 0.0113\n",
      "Epoch 186/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0112 - mse: 0.0112 - val_loss: 0.0112 - val_mse: 0.0112\n",
      "Epoch 187/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0111 - mse: 0.0111 - val_loss: 0.0111 - val_mse: 0.0111\n",
      "Epoch 188/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0110 - mse: 0.0110 - val_loss: 0.0110 - val_mse: 0.0110\n",
      "Epoch 189/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0109 - mse: 0.0109 - val_loss: 0.0110 - val_mse: 0.0110\n",
      "Epoch 190/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0108 - mse: 0.0108 - val_loss: 0.0109 - val_mse: 0.0109\n",
      "Epoch 191/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0107 - mse: 0.0107 - val_loss: 0.0108 - val_mse: 0.0108\n",
      "Epoch 192/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0106 - mse: 0.0106 - val_loss: 0.0107 - val_mse: 0.0107\n",
      "Epoch 193/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0105 - mse: 0.0105 - val_loss: 0.0106 - val_mse: 0.0106\n",
      "Epoch 194/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0104 - mse: 0.0104 - val_loss: 0.0106 - val_mse: 0.0106\n",
      "Epoch 195/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0103 - mse: 0.0103 - val_loss: 0.0105 - val_mse: 0.0105\n",
      "Epoch 196/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0103 - mse: 0.0103 - val_loss: 0.0104 - val_mse: 0.0104\n",
      "Epoch 197/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0102 - mse: 0.0102 - val_loss: 0.0103 - val_mse: 0.0103\n",
      "Epoch 198/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0101 - mse: 0.0101 - val_loss: 0.0102 - val_mse: 0.0102\n",
      "Epoch 199/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0100 - mse: 0.0100 - val_loss: 0.0102 - val_mse: 0.0102\n",
      "Epoch 200/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0099 - mse: 0.0099 - val_loss: 0.0101 - val_mse: 0.0101\n",
      "Epoch 201/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0099 - mse: 0.0099 - val_loss: 0.0100 - val_mse: 0.0100\n",
      "Epoch 202/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0098 - mse: 0.0098 - val_loss: 0.0100 - val_mse: 0.0100\n",
      "Epoch 203/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0097 - mse: 0.0097 - val_loss: 0.0099 - val_mse: 0.0099\n",
      "Epoch 204/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0096 - mse: 0.0096 - val_loss: 0.0098 - val_mse: 0.0098\n",
      "Epoch 205/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0096 - mse: 0.0096 - val_loss: 0.0097 - val_mse: 0.0097\n",
      "Epoch 206/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0095 - mse: 0.0095 - val_loss: 0.0097 - val_mse: 0.0097\n",
      "Epoch 207/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0094 - mse: 0.0094 - val_loss: 0.0096 - val_mse: 0.0096\n",
      "Epoch 208/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0093 - mse: 0.0093 - val_loss: 0.0096 - val_mse: 0.0096\n",
      "Epoch 209/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0093 - mse: 0.0093 - val_loss: 0.0095 - val_mse: 0.0095\n",
      "Epoch 210/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0092 - mse: 0.0092 - val_loss: 0.0094 - val_mse: 0.0094\n",
      "Epoch 211/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0091 - mse: 0.0091 - val_loss: 0.0094 - val_mse: 0.0094\n",
      "Epoch 212/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0091 - mse: 0.0091 - val_loss: 0.0093 - val_mse: 0.0093\n",
      "Epoch 213/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0090 - mse: 0.0090 - val_loss: 0.0093 - val_mse: 0.0093\n",
      "Epoch 214/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0089 - mse: 0.0089 - val_loss: 0.0092 - val_mse: 0.0092\n",
      "Epoch 215/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0089 - mse: 0.0089 - val_loss: 0.0091 - val_mse: 0.0091\n",
      "Epoch 216/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0088 - mse: 0.0088 - val_loss: 0.0091 - val_mse: 0.0091\n",
      "Epoch 217/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0087 - mse: 0.0087 - val_loss: 0.0090 - val_mse: 0.0090\n",
      "Epoch 218/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0087 - mse: 0.0087 - val_loss: 0.0089 - val_mse: 0.0089\n",
      "Epoch 219/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0086 - mse: 0.0086 - val_loss: 0.0089 - val_mse: 0.0089\n",
      "Epoch 220/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0085 - mse: 0.0085 - val_loss: 0.0088 - val_mse: 0.0088\n",
      "Epoch 221/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0085 - mse: 0.0085 - val_loss: 0.0087 - val_mse: 0.0087\n",
      "Epoch 222/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0084 - mse: 0.0084 - val_loss: 0.0087 - val_mse: 0.0087\n",
      "Epoch 223/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0083 - mse: 0.0083 - val_loss: 0.0086 - val_mse: 0.0086\n",
      "Epoch 224/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0083 - mse: 0.0083 - val_loss: 0.0086 - val_mse: 0.0086\n",
      "Epoch 225/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0082 - mse: 0.0082 - val_loss: 0.0085 - val_mse: 0.0085\n",
      "Epoch 226/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0081 - mse: 0.0081 - val_loss: 0.0085 - val_mse: 0.0085\n",
      "Epoch 227/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0081 - mse: 0.0081 - val_loss: 0.0084 - val_mse: 0.0084\n",
      "Epoch 228/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0080 - mse: 0.0080 - val_loss: 0.0084 - val_mse: 0.0084\n",
      "Epoch 229/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0080 - mse: 0.0080 - val_loss: 0.0083 - val_mse: 0.0083\n",
      "Epoch 230/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0079 - mse: 0.0079 - val_loss: 0.0082 - val_mse: 0.0082\n",
      "Epoch 231/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0078 - mse: 0.0078 - val_loss: 0.0082 - val_mse: 0.0082\n",
      "Epoch 232/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0078 - mse: 0.0078 - val_loss: 0.0081 - val_mse: 0.0081\n",
      "Epoch 233/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0077 - mse: 0.0077 - val_loss: 0.0081 - val_mse: 0.0081\n",
      "Epoch 234/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0077 - mse: 0.0077 - val_loss: 0.0080 - val_mse: 0.0080\n",
      "Epoch 235/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0076 - mse: 0.0076 - val_loss: 0.0080 - val_mse: 0.0080\n",
      "Epoch 236/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0076 - mse: 0.0076 - val_loss: 0.0079 - val_mse: 0.0079\n",
      "Epoch 237/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0075 - mse: 0.0075 - val_loss: 0.0079 - val_mse: 0.0079\n",
      "Epoch 238/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0074 - mse: 0.0074 - val_loss: 0.0078 - val_mse: 0.0078\n",
      "Epoch 239/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0074 - mse: 0.0074 - val_loss: 0.0078 - val_mse: 0.0078\n",
      "Epoch 240/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0074 - mse: 0.0074 - val_loss: 0.0077 - val_mse: 0.0077\n",
      "Epoch 241/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0073 - mse: 0.0073 - val_loss: 0.0077 - val_mse: 0.0077\n",
      "Epoch 242/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0072 - mse: 0.0072 - val_loss: 0.0076 - val_mse: 0.0076\n",
      "Epoch 243/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0072 - mse: 0.0072 - val_loss: 0.0076 - val_mse: 0.0076\n",
      "Epoch 244/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0072 - mse: 0.0072 - val_loss: 0.0075 - val_mse: 0.0075\n",
      "Epoch 245/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0071 - mse: 0.0071 - val_loss: 0.0075 - val_mse: 0.0075\n",
      "Epoch 246/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0071 - mse: 0.0071 - val_loss: 0.0075 - val_mse: 0.0075\n",
      "Epoch 247/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0070 - mse: 0.0070 - val_loss: 0.0074 - val_mse: 0.0074\n",
      "Epoch 248/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0070 - mse: 0.0070 - val_loss: 0.0074 - val_mse: 0.0074\n",
      "Epoch 249/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0069 - mse: 0.0069 - val_loss: 0.0073 - val_mse: 0.0073\n",
      "Epoch 250/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0069 - mse: 0.0069 - val_loss: 0.0073 - val_mse: 0.0073\n",
      "Epoch 251/400\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0068 - mse: 0.0068 - val_loss: 0.0072 - val_mse: 0.0072\n",
      "Epoch 252/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0068 - mse: 0.0068 - val_loss: 0.0072 - val_mse: 0.0072\n",
      "Epoch 253/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0067 - mse: 0.0067 - val_loss: 0.0071 - val_mse: 0.0071\n",
      "Epoch 254/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0067 - mse: 0.0067 - val_loss: 0.0071 - val_mse: 0.0071\n",
      "Epoch 255/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0066 - mse: 0.0066 - val_loss: 0.0070 - val_mse: 0.0070\n",
      "Epoch 256/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0066 - mse: 0.0066 - val_loss: 0.0070 - val_mse: 0.0070\n",
      "Epoch 257/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0065 - mse: 0.0065 - val_loss: 0.0069 - val_mse: 0.0069\n",
      "Epoch 258/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0065 - mse: 0.0065 - val_loss: 0.0069 - val_mse: 0.0069\n",
      "Epoch 259/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0064 - mse: 0.0064 - val_loss: 0.0069 - val_mse: 0.0069\n",
      "Epoch 260/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0064 - mse: 0.0064 - val_loss: 0.0068 - val_mse: 0.0068\n",
      "Epoch 261/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0064 - mse: 0.0064 - val_loss: 0.0068 - val_mse: 0.0068\n",
      "Epoch 262/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0063 - mse: 0.0063 - val_loss: 0.0067 - val_mse: 0.0067\n",
      "Epoch 263/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0063 - mse: 0.0063 - val_loss: 0.0067 - val_mse: 0.0067\n",
      "Epoch 264/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0062 - mse: 0.0062 - val_loss: 0.0067 - val_mse: 0.0067\n",
      "Epoch 265/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0062 - mse: 0.0062 - val_loss: 0.0066 - val_mse: 0.0066\n",
      "Epoch 266/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0062 - mse: 0.0062 - val_loss: 0.0066 - val_mse: 0.0066\n",
      "Epoch 267/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0061 - mse: 0.0061 - val_loss: 0.0066 - val_mse: 0.0066\n",
      "Epoch 268/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0061 - mse: 0.0061 - val_loss: 0.0065 - val_mse: 0.0065\n",
      "Epoch 269/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0060 - mse: 0.0060 - val_loss: 0.0065 - val_mse: 0.0065\n",
      "Epoch 270/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0060 - mse: 0.0060 - val_loss: 0.0064 - val_mse: 0.0064\n",
      "Epoch 271/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0060 - mse: 0.0060 - val_loss: 0.0064 - val_mse: 0.0064\n",
      "Epoch 272/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0059 - mse: 0.0059 - val_loss: 0.0064 - val_mse: 0.0064\n",
      "Epoch 273/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0059 - mse: 0.0059 - val_loss: 0.0063 - val_mse: 0.0063\n",
      "Epoch 274/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0059 - mse: 0.0059 - val_loss: 0.0063 - val_mse: 0.0063\n",
      "Epoch 275/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0058 - mse: 0.0058 - val_loss: 0.0063 - val_mse: 0.0063\n",
      "Epoch 276/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0058 - mse: 0.0058 - val_loss: 0.0062 - val_mse: 0.0062\n",
      "Epoch 277/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0057 - mse: 0.0057 - val_loss: 0.0062 - val_mse: 0.0062\n",
      "Epoch 278/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0057 - mse: 0.0057 - val_loss: 0.0062 - val_mse: 0.0062\n",
      "Epoch 279/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0057 - mse: 0.0057 - val_loss: 0.0061 - val_mse: 0.0061\n",
      "Epoch 280/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0056 - mse: 0.0056 - val_loss: 0.0061 - val_mse: 0.0061\n",
      "Epoch 281/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0056 - mse: 0.0056 - val_loss: 0.0061 - val_mse: 0.0061\n",
      "Epoch 282/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0056 - mse: 0.0056 - val_loss: 0.0060 - val_mse: 0.0060\n",
      "Epoch 283/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0055 - mse: 0.0055 - val_loss: 0.0060 - val_mse: 0.0060\n",
      "Epoch 284/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0055 - mse: 0.0055 - val_loss: 0.0060 - val_mse: 0.0060\n",
      "Epoch 285/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0055 - mse: 0.0055 - val_loss: 0.0059 - val_mse: 0.0059\n",
      "Epoch 286/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0054 - mse: 0.0054 - val_loss: 0.0059 - val_mse: 0.0059\n",
      "Epoch 287/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0054 - mse: 0.0054 - val_loss: 0.0059 - val_mse: 0.0059\n",
      "Epoch 288/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0054 - mse: 0.0054 - val_loss: 0.0058 - val_mse: 0.0058\n",
      "Epoch 289/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0053 - mse: 0.0053 - val_loss: 0.0058 - val_mse: 0.0058\n",
      "Epoch 290/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0053 - mse: 0.0053 - val_loss: 0.0058 - val_mse: 0.0058\n",
      "Epoch 291/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0053 - mse: 0.0053 - val_loss: 0.0057 - val_mse: 0.0057\n",
      "Epoch 292/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0052 - mse: 0.0052 - val_loss: 0.0057 - val_mse: 0.0057\n",
      "Epoch 293/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0052 - mse: 0.0052 - val_loss: 0.0056 - val_mse: 0.0056\n",
      "Epoch 294/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0052 - mse: 0.0052 - val_loss: 0.0056 - val_mse: 0.0056\n",
      "Epoch 295/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0052 - mse: 0.0052 - val_loss: 0.0056 - val_mse: 0.0056\n",
      "Epoch 296/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0051 - mse: 0.0051 - val_loss: 0.0056 - val_mse: 0.0056\n",
      "Epoch 297/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0051 - mse: 0.0051 - val_loss: 0.0055 - val_mse: 0.0055\n",
      "Epoch 298/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0051 - mse: 0.0051 - val_loss: 0.0055 - val_mse: 0.0055\n",
      "Epoch 299/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0051 - mse: 0.0051 - val_loss: 0.0055 - val_mse: 0.0055\n",
      "Epoch 300/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0050 - mse: 0.0050 - val_loss: 0.0055 - val_mse: 0.0055\n",
      "Epoch 301/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0050 - mse: 0.0050 - val_loss: 0.0055 - val_mse: 0.0055\n",
      "Epoch 302/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0050 - mse: 0.0050 - val_loss: 0.0054 - val_mse: 0.0054\n",
      "Epoch 303/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0049 - mse: 0.0049 - val_loss: 0.0054 - val_mse: 0.0054\n",
      "Epoch 304/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0049 - mse: 0.0049 - val_loss: 0.0054 - val_mse: 0.0054\n",
      "Epoch 305/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0049 - mse: 0.0049 - val_loss: 0.0054 - val_mse: 0.0054\n",
      "Epoch 306/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0048 - mse: 0.0048 - val_loss: 0.0053 - val_mse: 0.0053\n",
      "Epoch 307/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0048 - mse: 0.0048 - val_loss: 0.0053 - val_mse: 0.0053\n",
      "Epoch 308/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0048 - mse: 0.0048 - val_loss: 0.0052 - val_mse: 0.0052\n",
      "Epoch 309/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0048 - mse: 0.0048 - val_loss: 0.0052 - val_mse: 0.0052\n",
      "Epoch 310/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0047 - mse: 0.0047 - val_loss: 0.0052 - val_mse: 0.0052\n",
      "Epoch 311/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0047 - mse: 0.0047 - val_loss: 0.0052 - val_mse: 0.0052\n",
      "Epoch 312/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0047 - mse: 0.0047 - val_loss: 0.0052 - val_mse: 0.0052\n",
      "Epoch 313/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0047 - mse: 0.0047 - val_loss: 0.0051 - val_mse: 0.0051\n",
      "Epoch 314/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0046 - mse: 0.0046 - val_loss: 0.0051 - val_mse: 0.0051\n",
      "Epoch 315/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0046 - mse: 0.0046 - val_loss: 0.0051 - val_mse: 0.0051\n",
      "Epoch 316/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0046 - mse: 0.0046 - val_loss: 0.0050 - val_mse: 0.0050\n",
      "Epoch 317/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0046 - mse: 0.0046 - val_loss: 0.0050 - val_mse: 0.0050\n",
      "Epoch 318/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0045 - mse: 0.0045 - val_loss: 0.0050 - val_mse: 0.0050\n",
      "Epoch 319/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0045 - mse: 0.0045 - val_loss: 0.0050 - val_mse: 0.0050\n",
      "Epoch 320/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0045 - mse: 0.0045 - val_loss: 0.0050 - val_mse: 0.0050\n",
      "Epoch 321/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0045 - mse: 0.0045 - val_loss: 0.0050 - val_mse: 0.0050\n",
      "Epoch 322/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0044 - mse: 0.0044 - val_loss: 0.0049 - val_mse: 0.0049\n",
      "Epoch 323/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0044 - mse: 0.0044 - val_loss: 0.0049 - val_mse: 0.0049\n",
      "Epoch 324/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0044 - mse: 0.0044 - val_loss: 0.0049 - val_mse: 0.0049\n",
      "Epoch 325/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0044 - mse: 0.0044 - val_loss: 0.0048 - val_mse: 0.0048\n",
      "Epoch 326/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0044 - mse: 0.0044 - val_loss: 0.0048 - val_mse: 0.0048\n",
      "Epoch 327/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0043 - mse: 0.0043 - val_loss: 0.0048 - val_mse: 0.0048\n",
      "Epoch 328/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0043 - mse: 0.0043 - val_loss: 0.0047 - val_mse: 0.0047\n",
      "Epoch 329/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0043 - mse: 0.0043 - val_loss: 0.0047 - val_mse: 0.0047\n",
      "Epoch 330/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0043 - mse: 0.0043 - val_loss: 0.0047 - val_mse: 0.0047\n",
      "Epoch 331/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0042 - mse: 0.0042 - val_loss: 0.0047 - val_mse: 0.0047\n",
      "Epoch 332/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0042 - mse: 0.0042 - val_loss: 0.0047 - val_mse: 0.0047\n",
      "Epoch 333/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0042 - mse: 0.0042 - val_loss: 0.0047 - val_mse: 0.0047\n",
      "Epoch 334/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0042 - mse: 0.0042 - val_loss: 0.0047 - val_mse: 0.0047\n",
      "Epoch 335/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0042 - mse: 0.0042 - val_loss: 0.0047 - val_mse: 0.0047\n",
      "Epoch 336/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0042 - mse: 0.0042 - val_loss: 0.0046 - val_mse: 0.0046\n",
      "Epoch 337/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0041 - mse: 0.0041 - val_loss: 0.0046 - val_mse: 0.0046\n",
      "Epoch 338/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0041 - mse: 0.0041 - val_loss: 0.0046 - val_mse: 0.0046\n",
      "Epoch 339/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0041 - mse: 0.0041 - val_loss: 0.0046 - val_mse: 0.0046\n",
      "Epoch 340/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0041 - mse: 0.0041 - val_loss: 0.0045 - val_mse: 0.0045\n",
      "Epoch 341/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0041 - mse: 0.0041 - val_loss: 0.0045 - val_mse: 0.0045\n",
      "Epoch 342/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0040 - mse: 0.0040 - val_loss: 0.0045 - val_mse: 0.0045\n",
      "Epoch 343/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0040 - mse: 0.0040 - val_loss: 0.0045 - val_mse: 0.0045\n",
      "Epoch 344/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0040 - mse: 0.0040 - val_loss: 0.0044 - val_mse: 0.0044\n",
      "Epoch 345/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0040 - mse: 0.0040 - val_loss: 0.0044 - val_mse: 0.0044\n",
      "Epoch 346/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0040 - mse: 0.0040 - val_loss: 0.0044 - val_mse: 0.0044\n",
      "Epoch 347/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0040 - mse: 0.0040 - val_loss: 0.0044 - val_mse: 0.0044\n",
      "Epoch 348/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0039 - mse: 0.0039 - val_loss: 0.0044 - val_mse: 0.0044\n",
      "Epoch 349/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0039 - mse: 0.0039 - val_loss: 0.0043 - val_mse: 0.0043\n",
      "Epoch 350/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0039 - mse: 0.0039 - val_loss: 0.0043 - val_mse: 0.0043\n",
      "Epoch 351/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0039 - mse: 0.0039 - val_loss: 0.0043 - val_mse: 0.0043\n",
      "Epoch 352/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0038 - mse: 0.0038 - val_loss: 0.0043 - val_mse: 0.0043\n",
      "Epoch 353/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0038 - mse: 0.0038 - val_loss: 0.0043 - val_mse: 0.0043\n",
      "Epoch 354/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0038 - mse: 0.0038 - val_loss: 0.0043 - val_mse: 0.0043\n",
      "Epoch 355/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0038 - mse: 0.0038 - val_loss: 0.0042 - val_mse: 0.0042\n",
      "Epoch 356/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0038 - mse: 0.0038 - val_loss: 0.0042 - val_mse: 0.0042\n",
      "Epoch 357/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0038 - mse: 0.0038 - val_loss: 0.0042 - val_mse: 0.0042\n",
      "Epoch 358/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0037 - mse: 0.0037 - val_loss: 0.0042 - val_mse: 0.0042\n",
      "Epoch 359/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0037 - mse: 0.0037 - val_loss: 0.0041 - val_mse: 0.0041\n",
      "Epoch 360/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0037 - mse: 0.0037 - val_loss: 0.0042 - val_mse: 0.0042\n",
      "Epoch 361/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0037 - mse: 0.0037 - val_loss: 0.0041 - val_mse: 0.0041\n",
      "Epoch 362/400\n",
      "7/7 [==============================] - 0s 6ms/step - loss: 0.0037 - mse: 0.0037 - val_loss: 0.0041 - val_mse: 0.0041\n",
      "Epoch 363/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0037 - mse: 0.0037 - val_loss: 0.0041 - val_mse: 0.0041\n",
      "Epoch 364/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0036 - mse: 0.0036 - val_loss: 0.0041 - val_mse: 0.0041\n",
      "Epoch 365/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0036 - mse: 0.0036 - val_loss: 0.0041 - val_mse: 0.0041\n",
      "Epoch 366/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0036 - mse: 0.0036 - val_loss: 0.0041 - val_mse: 0.0041\n",
      "Epoch 367/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0036 - mse: 0.0036 - val_loss: 0.0040 - val_mse: 0.0040\n",
      "Epoch 368/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0036 - mse: 0.0036 - val_loss: 0.0040 - val_mse: 0.0040\n",
      "Epoch 369/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0040 - val_mse: 0.0040\n",
      "Epoch 370/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0040 - val_mse: 0.0040\n",
      "Epoch 371/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0040 - val_mse: 0.0040\n",
      "Epoch 372/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0040 - val_mse: 0.0040\n",
      "Epoch 373/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0040 - val_mse: 0.0040\n",
      "Epoch 374/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0039 - val_mse: 0.0039\n",
      "Epoch 375/400\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0039 - val_mse: 0.0039\n",
      "Epoch 376/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0039 - val_mse: 0.0039\n",
      "Epoch 377/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0039 - val_mse: 0.0039\n",
      "Epoch 378/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0039 - val_mse: 0.0039\n",
      "Epoch 379/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0038 - val_mse: 0.0038\n",
      "Epoch 380/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0038 - val_mse: 0.0038\n",
      "Epoch 381/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0038 - val_mse: 0.0038\n",
      "Epoch 382/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0038 - val_mse: 0.0038\n",
      "Epoch 383/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0033 - mse: 0.0033 - val_loss: 0.0038 - val_mse: 0.0038\n",
      "Epoch 384/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0033 - mse: 0.0033 - val_loss: 0.0038 - val_mse: 0.0038\n",
      "Epoch 385/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0033 - mse: 0.0033 - val_loss: 0.0038 - val_mse: 0.0038\n",
      "Epoch 386/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0033 - mse: 0.0033 - val_loss: 0.0038 - val_mse: 0.0038\n",
      "Epoch 387/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0033 - mse: 0.0033 - val_loss: 0.0037 - val_mse: 0.0037\n",
      "Epoch 388/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0033 - mse: 0.0033 - val_loss: 0.0037 - val_mse: 0.0037\n",
      "Epoch 389/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0033 - mse: 0.0033 - val_loss: 0.0037 - val_mse: 0.0037\n",
      "Epoch 390/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0033 - mse: 0.0033 - val_loss: 0.0037 - val_mse: 0.0037\n",
      "Epoch 391/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0033 - mse: 0.0033 - val_loss: 0.0037 - val_mse: 0.0037\n",
      "Epoch 392/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0032 - mse: 0.0032 - val_loss: 0.0037 - val_mse: 0.0037\n",
      "Epoch 393/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0032 - mse: 0.0032 - val_loss: 0.0037 - val_mse: 0.0037\n",
      "Epoch 394/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0032 - mse: 0.0032 - val_loss: 0.0036 - val_mse: 0.0036\n",
      "Epoch 395/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0032 - mse: 0.0032 - val_loss: 0.0036 - val_mse: 0.0036\n",
      "Epoch 396/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0032 - mse: 0.0032 - val_loss: 0.0036 - val_mse: 0.0036\n",
      "Epoch 397/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0032 - mse: 0.0032 - val_loss: 0.0036 - val_mse: 0.0036\n",
      "Epoch 398/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0032 - mse: 0.0032 - val_loss: 0.0036 - val_mse: 0.0036\n",
      "Epoch 399/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0031 - mse: 0.0031 - val_loss: 0.0036 - val_mse: 0.0036\n",
      "Epoch 400/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0031 - mse: 0.0031 - val_loss: 0.0035 - val_mse: 0.0035\n"
     ]
    }
   ],
   "source": [
    "t0 = time.time()\n",
    "model.fit(X_train, Y_train, epochs=400, batch_size=32, validation_data=(X_test, Y_test))\n",
    "t1 = time.time()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "81f35c9a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1/1 [==============================] - 0s 13ms/step - loss: 0.0031 - mse: 0.0031\n",
      "4/4 [==============================] - 0s 605us/step - loss: 0.0035 - mse: 0.0035\n",
      "[0.003547520376741886, 0.003547520376741886]\n",
      "10.64811897277832\n"
     ]
    }
   ],
   "source": [
    "#use the target train and test data to evaluate the model\n",
    "loss_and_metrics = model.evaluate(X_train, Y_train, batch_size=256)\n",
    "\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": 8,
   "id": "d659a2af",
   "metadata": {},
   "outputs": [],
   "source": [
    "model = load_model(\"pretrained_model_N.h5\")\n",
    "X_train_S = np.load('source_input_data_N.npy')\n",
    "Y_train_S = np.load('source_output_data_N.npy')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "4687c4cf",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "375/375 [==============================] - 0s 323us/step - loss: 1.9066e-05 - mse: 1.9066e-05\n",
      "7/7 [==============================] - 0s 855us/step - loss: 0.6980 - mse: 0.6980\n",
      "48/48 [==============================] - 0s 567us/step - loss: 0.0117 - mse: 0.0117\n"
     ]
    }
   ],
   "source": [
    "#combine source and target for training\n",
    "#first 640 target, 3995 source\n",
    "RNN_input_final_Train = np.concatenate((X_train, X_train_S), axis=0) \n",
    "RNN_output_final_Train = np.concatenate((Y_train, Y_train_S), axis=0)\n",
    "\n",
    "NN_S = model.predict(X_train_S)\n",
    "\n",
    "#performance of the pre-trained model on train data\n",
    "loss_and_metrics = model.evaluate(X_train_S, Y_train_S)\n",
    "loss_and_metrics = model.evaluate(X_train, Y_train)\n",
    "\n",
    "loss_and_metrics = model.evaluate(RNN_input_final_Train, RNN_output_final_Train, batch_size=256)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "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=(3))  # 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(3, activation='linear', use_bias=False)  # New front layer\n",
    "\n",
    "# Connect the frozen original model\n",
    "x = model(new_input_layer2(new_input_layer1(new_input_layer(input_layer))))\n",
    "\n",
    "# Add new output layer\n",
    "new_output_layer = Dense(4, activation='linear', use_bias=False)  # Replace output_dim with your desired final output size\n",
    "new_output_layer1 = Dense(4, activation='linear', use_bias=False)  # Replace output_dim with your desired final output size\n",
    "new_output_layer2 = Dense(2, activation='linear', use_bias=False)  # Replace output_dim with your desired final output size\n",
    "\n",
    "output = new_output_layer2(new_output_layer1(new_output_layer(x)))\n",
    "# Step 4: Assemble final model\n",
    "final_model = Model(inputs=input_layer, outputs=output)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "e9a742b1",
   "metadata": {},
   "outputs": [],
   "source": [
    "#assign parameters\n",
    "# Define A: 3x8 matrix [I_3 | 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",
    "], dtype=np.float32)\n",
    "\n",
    "# Define B: 8x8 identity matrix\n",
    "B = np.array(np.eye(8), dtype=np.float32)\n",
    "\n",
    "# Define C: 8x3 matrix [I_3; 0]\n",
    "C = np.array([\n",
    "    [1, 0, 0],\n",
    "    [0, 1, 0],\n",
    "    [0, 0, 1],\n",
    "    [0, 0, 0],\n",
    "    [0, 0, 0],\n",
    "    [0, 0, 0],\n",
    "    [0, 0, 0],\n",
    "    [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": 12,
   "id": "a5792001",
   "metadata": {},
   "outputs": [],
   "source": [
    "# A: 2x4 matrix [I_2 | 0]\n",
    "Ao = np.array([\n",
    "    [1, 0, 0, 0],\n",
    "    [0, 1, 0, 0]\n",
    "], dtype=np.float32)\n",
    "\n",
    "# B: 4x4 identity\n",
    "Bo = np.array(np.eye(4), dtype=np.float32)\n",
    "\n",
    "# C: 4x2 matrix [I_2; 0]\n",
    "Co = np.array([\n",
    "    [1, 0],\n",
    "    [0, 1],\n",
    "    [0, 0],\n",
    "    [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": 13,
   "id": "4b514281",
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "# Step 5: Custom loss function\n",
    "def custom_loss(y_true, y_pred):\n",
    "    Num = 204 #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": 14,
   "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, 3)]               0         \n",
      "                                                                 \n",
      " dense_2 (Dense)             (None, 8)                 24        \n",
      "                                                                 \n",
      " dense_3 (Dense)             (None, 8)                 64        \n",
      "                                                                 \n",
      " dense_4 (Dense)             (None, 3)                 24        \n",
      "                                                                 \n",
      " sequential (Sequential)     (None, 2)                 50        \n",
      "                                                                 \n",
      " dense_5 (Dense)             (None, 4)                 8         \n",
      "                                                                 \n",
      " dense_6 (Dense)             (None, 4)                 16        \n",
      "                                                                 \n",
      " dense_7 (Dense)             (None, 2)                 8         \n",
      "                                                                 \n",
      "=================================================================\n",
      "Total params: 194\n",
      "Trainable params: 144\n",
      "Non-trainable params: 50\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": 15,
   "id": "a2d89c02",
   "metadata": {},
   "outputs": [],
   "source": [
    "# t0 = time.time()\n",
    "# for i in range(100):\n",
    "#     Num = 204 #number of training target data\n",
    "#      # Access the layers\n",
    "#     input_layer_weights = final_model.layers[1].trainable_weights[0]  # weight matrix only\n",
    "#     output_layer_weights = final_model.layers[-1].trainable_weights[0]\n",
    "    \n",
    "#     #prediction performance on the target training set\n",
    "#     NN_out = final_model(RNN_input_final_Train) \n",
    "#     loss11 =  tf.math.reduce_mean((NN_out[:Num,:]-RNN_output_final_Train[:Num,:])**2) # prediction on target\n",
    "#     print(\"iteration :\" + str(i) + \"     Target train: \" + str(loss11))\n",
    "    \n",
    "#     #history = final_model.fit(RNN_input_final_Train, RNN_output_final_Train, epochs=1, batch_size=256, validation_split=0.25, verbose=2)\n",
    "#     history = final_model.fit(X_train, Y_train, epochs=1, batch_size=256, validation_split=0.25, verbose=2)\n",
    "#     i += 1\n",
    "\n",
    "# t1 = time.time()\n",
    "# print(t1 - t0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "c34f6e3f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1/1 - 0s - loss: 0.7081 - mse: 0.7033 - val_loss: 0.6933 - val_mse: 0.6681 - 362ms/epoch - 362ms/step\n",
      "iteration :1 Target train: tf.Tensor(0.6832768, shape=(), dtype=float32) loss1 tf.Tensor(0.6831731, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.000103681734, shape=(), dtype=float32) loss2   tf.Tensor(8.575702e-05, shape=(), dtype=float32) loss3  tf.Tensor(0.9999989, shape=(), dtype=float32) Target test: tf.Tensor(0.79448307, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6933 - mse: 0.6883 - val_loss: 0.6789 - val_mse: 0.6544 - 24ms/epoch - 24ms/step\n",
      "iteration :2 Target train: tf.Tensor(0.66881233, shape=(), dtype=float32) loss1 tf.Tensor(0.6684542, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.00035813768, shape=(), dtype=float32) loss2   tf.Tensor(0.00034124276, shape=(), dtype=float32) loss3  tf.Tensor(0.99999404, shape=(), dtype=float32) Target test: tf.Tensor(0.7783858, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6789 - mse: 0.6736 - val_loss: 0.6647 - val_mse: 0.6409 - 25ms/epoch - 25ms/step\n",
      "iteration :3 Target train: tf.Tensor(0.65459627, shape=(), dtype=float32) loss1 tf.Tensor(0.65381664, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.0007796436, shape=(), dtype=float32) loss2   tf.Tensor(0.00076366775, shape=(), dtype=float32) loss3  tf.Tensor(0.9999874, shape=(), dtype=float32) Target test: tf.Tensor(0.7625498, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6647 - mse: 0.6592 - val_loss: 0.6507 - val_mse: 0.6277 - 25ms/epoch - 25ms/step\n",
      "iteration :4 Target train: tf.Tensor(0.64063096, shape=(), dtype=float32) loss1 tf.Tensor(0.6392657, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.0013652315, shape=(), dtype=float32) loss2   tf.Tensor(0.0013500652, shape=(), dtype=float32) loss3  tf.Tensor(0.9999801, shape=(), dtype=float32) Target test: tf.Tensor(0.74697715, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6507 - mse: 0.6450 - val_loss: 0.6370 - val_mse: 0.6146 - 28ms/epoch - 28ms/step\n",
      "iteration :5 Target train: tf.Tensor(0.62691766, shape=(), dtype=float32) loss1 tf.Tensor(0.62480587, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.0021117856, shape=(), dtype=float32) loss2   tf.Tensor(0.00209732, shape=(), dtype=float32) loss3  tf.Tensor(0.9999726, shape=(), dtype=float32) Target test: tf.Tensor(0.7316689, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6370 - mse: 0.6310 - val_loss: 0.6235 - val_mse: 0.6018 - 28ms/epoch - 28ms/step\n",
      "iteration :6 Target train: tf.Tensor(0.6134576, shape=(), dtype=float32) loss1 tf.Tensor(0.61044157, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.0030160402, shape=(), dtype=float32) loss2   tf.Tensor(0.0030021693, shape=(), dtype=float32) loss3  tf.Tensor(0.9999656, shape=(), dtype=float32) Target test: tf.Tensor(0.71662635, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6235 - mse: 0.6173 - val_loss: 0.6104 - val_mse: 0.5893 - 32ms/epoch - 32ms/step\n",
      "iteration :7 Target train: tf.Tensor(0.6002519, shape=(), dtype=float32) loss1 tf.Tensor(0.59617734, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.004074571, shape=(), dtype=float32) loss2   tf.Tensor(0.004061189, shape=(), dtype=float32) loss3  tf.Tensor(0.9999596, shape=(), dtype=float32) Target test: tf.Tensor(0.70185065, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.6104 - mse: 0.6039 - val_loss: 0.5974 - val_mse: 0.5769 - 29ms/epoch - 29ms/step\n",
      "iteration :8 Target train: tf.Tensor(0.5873013, shape=(), dtype=float32) loss1 tf.Tensor(0.5820175, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.00528383, shape=(), dtype=float32) loss2   tf.Tensor(0.0052708327, shape=(), dtype=float32) loss3  tf.Tensor(0.99995506, shape=(), dtype=float32) Target test: tf.Tensor(0.6873422, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5974 - mse: 0.5908 - val_loss: 0.5847 - val_mse: 0.5648 - 30ms/epoch - 30ms/step\n",
      "iteration :9 Target train: tf.Tensor(0.57460606, shape=(), dtype=float32) loss1 tf.Tensor(0.5679659, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.006640137, shape=(), dtype=float32) loss2   tf.Tensor(0.0066274237, shape=(), dtype=float32) loss3  tf.Tensor(0.99995244, shape=(), dtype=float32) Target test: tf.Tensor(0.6731013, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5847 - mse: 0.5779 - val_loss: 0.5723 - val_mse: 0.5530 - 29ms/epoch - 29ms/step\n",
      "iteration :10 Target train: tf.Tensor(0.5621662, shape=(), dtype=float32) loss1 tf.Tensor(0.5540265, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.008139704, shape=(), dtype=float32) loss2   tf.Tensor(0.008127174, shape=(), dtype=float32) loss3  tf.Tensor(0.99995214, shape=(), dtype=float32) Target test: tf.Tensor(0.65912807, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5723 - mse: 0.5652 - val_loss: 0.5601 - val_mse: 0.5413 - 28ms/epoch - 28ms/step\n",
      "iteration :11 Target train: tf.Tensor(0.54998153, shape=(), dtype=float32) loss1 tf.Tensor(0.5402029, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.009778631, shape=(), dtype=float32) loss2   tf.Tensor(0.009766186, shape=(), dtype=float32) loss3  tf.Tensor(0.9999547, shape=(), dtype=float32) Target test: tf.Tensor(0.64542204, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5601 - mse: 0.5529 - val_loss: 0.5482 - val_mse: 0.5299 - 30ms/epoch - 30ms/step\n",
      "iteration :12 Target train: tf.Tensor(0.53805155, shape=(), dtype=float32) loss1 tf.Tensor(0.5264986, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.011552902, shape=(), dtype=float32) loss2   tf.Tensor(0.011540447, shape=(), dtype=float32) loss3  tf.Tensor(0.9999606, shape=(), dtype=float32) Target test: tf.Tensor(0.6319828, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5482 - mse: 0.5408 - val_loss: 0.5366 - val_mse: 0.5187 - 33ms/epoch - 33ms/step\n",
      "iteration :13 Target train: tf.Tensor(0.5263753, shape=(), dtype=float32) loss1 tf.Tensor(0.51291686, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.013458446, shape=(), dtype=float32) loss2   tf.Tensor(0.013445883, shape=(), dtype=float32) loss3  tf.Tensor(0.9999702, shape=(), dtype=float32) Target test: tf.Tensor(0.6188093, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5366 - mse: 0.5289 - val_loss: 0.5252 - val_mse: 0.5077 - 27ms/epoch - 27ms/step\n",
      "iteration :14 Target train: tf.Tensor(0.5149515, shape=(), dtype=float32) loss1 tf.Tensor(0.49946043, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.015491107, shape=(), dtype=float32) loss2   tf.Tensor(0.015478349, shape=(), dtype=float32) loss3  tf.Tensor(0.9999838, shape=(), dtype=float32) Target test: tf.Tensor(0.60590047, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5252 - mse: 0.5174 - val_loss: 0.5140 - val_mse: 0.4970 - 32ms/epoch - 32ms/step\n",
      "iteration :15 Target train: tf.Tensor(0.5037787, shape=(), dtype=float32) loss1 tf.Tensor(0.48613203, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.01764668, shape=(), dtype=float32) loss2   tf.Tensor(0.017633632, shape=(), dtype=float32) loss3  tf.Tensor(1.0000019, shape=(), dtype=float32) Target test: tf.Tensor(0.5932545, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5140 - mse: 0.5060 - val_loss: 0.5031 - val_mse: 0.4865 - 28ms/epoch - 28ms/step\n",
      "iteration :16 Target train: tf.Tensor(0.49285534, shape=(), dtype=float32) loss1 tf.Tensor(0.47293448, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.019920863, shape=(), dtype=float32) loss2   tf.Tensor(0.019907441, shape=(), dtype=float32) loss3  tf.Tensor(1.0000249, shape=(), dtype=float32) Target test: tf.Tensor(0.58087015, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.5031 - mse: 0.4950 - val_loss: 0.4924 - val_mse: 0.4762 - 27ms/epoch - 27ms/step\n",
      "iteration :17 Target train: tf.Tensor(0.48217905, shape=(), dtype=float32) loss1 tf.Tensor(0.45986965, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.022309382, shape=(), dtype=float32) loss2   tf.Tensor(0.022295501, shape=(), dtype=float32) loss3  tf.Tensor(1.0000532, shape=(), dtype=float32) Target test: tf.Tensor(0.568745, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4924 - mse: 0.4842 - val_loss: 0.4820 - val_mse: 0.4661 - 28ms/epoch - 28ms/step\n",
      "iteration :18 Target train: tf.Tensor(0.47174767, shape=(), dtype=float32) loss1 tf.Tensor(0.4469398, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.024807872, shape=(), dtype=float32) loss2   tf.Tensor(0.024793446, shape=(), dtype=float32) loss3  tf.Tensor(1.0000868, shape=(), dtype=float32) Target test: tf.Tensor(0.55687696, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4820 - mse: 0.4736 - val_loss: 0.4719 - val_mse: 0.4563 - 26ms/epoch - 26ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iteration :19 Target train: tf.Tensor(0.46155876, shape=(), dtype=float32) loss1 tf.Tensor(0.4341468, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.027411968, shape=(), dtype=float32) loss2   tf.Tensor(0.027396917, shape=(), dtype=float32) loss3  tf.Tensor(1.0001265, shape=(), dtype=float32) Target test: tf.Tensor(0.5452637, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4719 - mse: 0.4633 - val_loss: 0.4620 - val_mse: 0.4467 - 27ms/epoch - 27ms/step\n",
      "iteration :20 Target train: tf.Tensor(0.45160937, shape=(), dtype=float32) loss1 tf.Tensor(0.42149204, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.030117318, shape=(), dtype=float32) loss2   tf.Tensor(0.03010156, shape=(), dtype=float32) loss3  tf.Tensor(1.000172, shape=(), dtype=float32) Target test: tf.Tensor(0.5339023, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4620 - mse: 0.4533 - val_loss: 0.4523 - val_mse: 0.4372 - 27ms/epoch - 27ms/step\n",
      "iteration :21 Target train: tf.Tensor(0.44189632, shape=(), dtype=float32) loss1 tf.Tensor(0.40897676, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.03291956, shape=(), dtype=float32) loss2   tf.Tensor(0.03290302, shape=(), dtype=float32) loss3  tf.Tensor(1.000224, shape=(), dtype=float32) Target test: tf.Tensor(0.52278984, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4523 - mse: 0.4434 - val_loss: 0.4428 - val_mse: 0.4280 - 30ms/epoch - 30ms/step\n",
      "iteration :22 Target train: tf.Tensor(0.43241665, shape=(), dtype=float32) loss1 tf.Tensor(0.3966023, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.035814356, shape=(), dtype=float32) loss2   tf.Tensor(0.035796963, shape=(), dtype=float32) loss3  tf.Tensor(1.0002825, shape=(), dtype=float32) Target test: tf.Tensor(0.51192325, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4428 - mse: 0.4339 - val_loss: 0.4336 - val_mse: 0.4190 - 26ms/epoch - 26ms/step\n",
      "iteration :23 Target train: tf.Tensor(0.42316675, shape=(), dtype=float32) loss1 tf.Tensor(0.3843694, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.03879736, shape=(), dtype=float32) loss2   tf.Tensor(0.038779035, shape=(), dtype=float32) loss3  tf.Tensor(1.0003477, shape=(), dtype=float32) Target test: tf.Tensor(0.5012992, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4336 - mse: 0.4245 - val_loss: 0.4246 - val_mse: 0.4103 - 32ms/epoch - 32ms/step\n",
      "iteration :24 Target train: tf.Tensor(0.41414294, shape=(), dtype=float32) loss1 tf.Tensor(0.37227863, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.04186431, shape=(), dtype=float32) loss2   tf.Tensor(0.04184499, shape=(), dtype=float32) loss3  tf.Tensor(1.00042, shape=(), dtype=float32) Target test: tf.Tensor(0.49091434, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4246 - mse: 0.4154 - val_loss: 0.4158 - val_mse: 0.4017 - 27ms/epoch - 27ms/step\n",
      "iteration :25 Target train: tf.Tensor(0.4053415, shape=(), dtype=float32) loss1 tf.Tensor(0.36033055, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.045010954, shape=(), dtype=float32) loss2   tf.Tensor(0.04499057, shape=(), dtype=float32) loss3  tf.Tensor(1.0004991, shape=(), dtype=float32) Target test: tf.Tensor(0.48076496, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4158 - mse: 0.4066 - val_loss: 0.4073 - val_mse: 0.3933 - 30ms/epoch - 30ms/step\n",
      "iteration :26 Target train: tf.Tensor(0.3967586, shape=(), dtype=float32) loss1 tf.Tensor(0.3485255, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.048233084, shape=(), dtype=float32) loss2   tf.Tensor(0.04821156, shape=(), dtype=float32) loss3  tf.Tensor(1.0005854, shape=(), dtype=float32) Target test: tf.Tensor(0.4708472, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.4073 - mse: 0.3979 - val_loss: 0.3989 - val_mse: 0.3851 - 25ms/epoch - 25ms/step\n",
      "iteration :27 Target train: tf.Tensor(0.38839, shape=(), dtype=float32) loss1 tf.Tensor(0.33686346, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.05152656, shape=(), dtype=float32) loss2   tf.Tensor(0.051503845, shape=(), dtype=float32) loss3  tf.Tensor(1.000679, shape=(), dtype=float32) Target test: tf.Tensor(0.46115753, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.3989 - mse: 0.3895 - val_loss: 0.3908 - val_mse: 0.3771 - 26ms/epoch - 26ms/step\n",
      "iteration :28 Target train: tf.Tensor(0.3802316, shape=(), dtype=float32) loss1 tf.Tensor(0.32534426, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.05488734, shape=(), dtype=float32) loss2   tf.Tensor(0.054863352, shape=(), dtype=float32) loss3  tf.Tensor(1.0007797, shape=(), dtype=float32) Target test: tf.Tensor(0.45169172, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.3908 - mse: 0.3813 - val_loss: 0.3829 - val_mse: 0.3693 - 27ms/epoch - 27ms/step\n",
      "iteration :29 Target train: tf.Tensor(0.37227923, shape=(), dtype=float32) loss1 tf.Tensor(0.31396782, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.05831139, shape=(), dtype=float32) loss2   tf.Tensor(0.058286082, shape=(), dtype=float32) loss3  tf.Tensor(1.0008879, shape=(), dtype=float32) Target test: tf.Tensor(0.44244578, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.3829 - mse: 0.3733 - val_loss: 0.3752 - val_mse: 0.3616 - 28ms/epoch - 28ms/step\n",
      "iteration :30 Target train: tf.Tensor(0.36452848, shape=(), dtype=float32) loss1 tf.Tensor(0.3027337, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.0617948, shape=(), dtype=float32) loss2   tf.Tensor(0.06176811, shape=(), dtype=float32) loss3  tf.Tensor(1.0010031, shape=(), dtype=float32) Target test: tf.Tensor(0.43341574, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.3752 - mse: 0.3655 - val_loss: 0.3677 - val_mse: 0.3542 - 25ms/epoch - 25ms/step\n",
      "iteration :31 Target train: tf.Tensor(0.35697493, shape=(), dtype=float32) loss1 tf.Tensor(0.2916412, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.06533373, shape=(), dtype=float32) loss2   tf.Tensor(0.06530561, shape=(), dtype=float32) loss3  tf.Tensor(1.0011257, shape=(), dtype=float32) Target test: tf.Tensor(0.42459735, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.3677 - mse: 0.3579 - val_loss: 0.3603 - val_mse: 0.3469 - 28ms/epoch - 28ms/step\n",
      "iteration :32 Target train: tf.Tensor(0.34961423, shape=(), dtype=float32) loss1 tf.Tensor(0.28068978, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.06892445, shape=(), dtype=float32) loss2   tf.Tensor(0.06889483, shape=(), dtype=float32) loss3  tf.Tensor(1.0012553, shape=(), dtype=float32) Target test: tf.Tensor(0.41598654, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.3603 - mse: 0.3505 - val_loss: 0.3532 - val_mse: 0.3398 - 30ms/epoch - 30ms/step\n",
      "iteration :33 Target train: tf.Tensor(0.34244186, shape=(), dtype=float32) loss1 tf.Tensor(0.26987857, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.072563276, shape=(), dtype=float32) loss2   tf.Tensor(0.07253211, shape=(), dtype=float32) loss3  tf.Tensor(1.0013919, shape=(), dtype=float32) Target test: tf.Tensor(0.4075789, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.3532 - mse: 0.3433 - val_loss: 0.3463 - val_mse: 0.3329 - 29ms/epoch - 29ms/step\n",
      "iteration :34 Target train: tf.Tensor(0.3354533, shape=(), dtype=float32) loss1 tf.Tensor(0.25920662, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.07624667, shape=(), dtype=float32) loss2   tf.Tensor(0.0762139, shape=(), dtype=float32) loss3  tf.Tensor(1.0015353, shape=(), dtype=float32) Target test: tf.Tensor(0.39937028, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.3463 - mse: 0.3363 - val_loss: 0.3395 - val_mse: 0.3262 - 27ms/epoch - 27ms/step\n",
      "iteration :35 Target train: tf.Tensor(0.32864413, shape=(), dtype=float32) loss1 tf.Tensor(0.24867299, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.07997114, shape=(), dtype=float32) loss2   tf.Tensor(0.07993673, shape=(), dtype=float32) loss3  tf.Tensor(1.0016855, shape=(), dtype=float32) Target test: tf.Tensor(0.3913564, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.3395 - mse: 0.3295 - val_loss: 0.3329 - val_mse: 0.3196 - 31ms/epoch - 31ms/step\n",
      "iteration :36 Target train: tf.Tensor(0.32200992, shape=(), dtype=float32) loss1 tf.Tensor(0.23827656, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.083733365, shape=(), dtype=float32) loss2   tf.Tensor(0.08369725, shape=(), dtype=float32) loss3  tf.Tensor(1.0018421, shape=(), dtype=float32) Target test: tf.Tensor(0.38353306, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.3329 - mse: 0.3228 - val_loss: 0.3265 - val_mse: 0.3132 - 26ms/epoch - 26ms/step\n",
      "iteration :37 Target train: tf.Tensor(0.31554615, shape=(), dtype=float32) loss1 tf.Tensor(0.22801606, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.08753009, shape=(), dtype=float32) loss2   tf.Tensor(0.08749223, shape=(), dtype=float32) loss3  tf.Tensor(1.0020052, shape=(), dtype=float32) Target test: tf.Tensor(0.37589616, shape=(), dtype=float32)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1/1 - 0s - loss: 0.3265 - mse: 0.3163 - val_loss: 0.3202 - val_mse: 0.3069 - 27ms/epoch - 27ms/step\n",
      "iteration :38 Target train: tf.Tensor(0.30924842, shape=(), dtype=float32) loss1 tf.Tensor(0.21789029, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.091358125, shape=(), dtype=float32) loss2   tf.Tensor(0.09131848, shape=(), dtype=float32) loss3  tf.Tensor(1.0021741, shape=(), dtype=float32) Target test: tf.Tensor(0.3684414, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.3202 - mse: 0.3100 - val_loss: 0.3141 - val_mse: 0.3008 - 29ms/epoch - 29ms/step\n",
      "iteration :39 Target train: tf.Tensor(0.30311248, shape=(), dtype=float32) loss1 tf.Tensor(0.20789805, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.09521442, shape=(), dtype=float32) loss2   tf.Tensor(0.09517291, shape=(), dtype=float32) loss3  tf.Tensor(1.002349, shape=(), dtype=float32) Target test: tf.Tensor(0.3611647, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.3141 - mse: 0.3039 - val_loss: 0.3082 - val_mse: 0.2948 - 27ms/epoch - 27ms/step\n",
      "iteration :40 Target train: tf.Tensor(0.29713386, shape=(), dtype=float32) loss1 tf.Tensor(0.19803777, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.09909609, shape=(), dtype=float32) loss2   tf.Tensor(0.09905271, shape=(), dtype=float32) loss3  tf.Tensor(1.0025295, shape=(), dtype=float32) Target test: tf.Tensor(0.35406187, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.3082 - mse: 0.2979 - val_loss: 0.3024 - val_mse: 0.2890 - 28ms/epoch - 28ms/step\n",
      "iteration :41 Target train: tf.Tensor(0.2913083, shape=(), dtype=float32) loss1 tf.Tensor(0.188308, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.103000306, shape=(), dtype=float32) loss2   tf.Tensor(0.102955, shape=(), dtype=float32) loss3  tf.Tensor(1.002715, shape=(), dtype=float32) Target test: tf.Tensor(0.34712887, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.3024 - mse: 0.2921 - val_loss: 0.2967 - val_mse: 0.2833 - 30ms/epoch - 30ms/step\n",
      "iteration :42 Target train: tf.Tensor(0.28563175, shape=(), dtype=float32) loss1 tf.Tensor(0.17870745, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.106924295, shape=(), dtype=float32) loss2   tf.Tensor(0.106877014, shape=(), dtype=float32) loss3  tf.Tensor(1.0029055, shape=(), dtype=float32) Target test: tf.Tensor(0.34036177, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.2967 - mse: 0.2864 - val_loss: 0.2913 - val_mse: 0.2778 - 28ms/epoch - 28ms/step\n",
      "iteration :43 Target train: tf.Tensor(0.28010005, shape=(), dtype=float32) loss1 tf.Tensor(0.16923453, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.11086552, shape=(), dtype=float32) loss2   tf.Tensor(0.1108162, shape=(), dtype=float32) loss3  tf.Tensor(1.0031005, shape=(), dtype=float32) Target test: tf.Tensor(0.3337565, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.2913 - mse: 0.2809 - val_loss: 0.2859 - val_mse: 0.2723 - 26ms/epoch - 26ms/step\n",
      "iteration :44 Target train: tf.Tensor(0.2747091, shape=(), dtype=float32) loss1 tf.Tensor(0.15988776, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.11482135, shape=(), dtype=float32) loss2   tf.Tensor(0.11477001, shape=(), dtype=float32) loss3  tf.Tensor(1.0032998, shape=(), dtype=float32) Target test: tf.Tensor(0.32730934, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.2859 - mse: 0.2755 - val_loss: 0.2807 - val_mse: 0.2671 - 26ms/epoch - 26ms/step\n",
      "iteration :45 Target train: tf.Tensor(0.26945496, shape=(), dtype=float32) loss1 tf.Tensor(0.15066543, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.11878953, shape=(), dtype=float32) loss2   tf.Tensor(0.11873608, shape=(), dtype=float32) loss3  tf.Tensor(1.0035028, shape=(), dtype=float32) Target test: tf.Tensor(0.32101634, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.2807 - mse: 0.2702 - val_loss: 0.2756 - val_mse: 0.2619 - 27ms/epoch - 27ms/step\n",
      "iteration :46 Target train: tf.Tensor(0.26433387, shape=(), dtype=float32) loss1 tf.Tensor(0.14156623, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.12276764, shape=(), dtype=float32) loss2   tf.Tensor(0.122712076, shape=(), dtype=float32) loss3  tf.Tensor(1.0037096, shape=(), dtype=float32) Target test: tf.Tensor(0.31487384, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.2756 - mse: 0.2651 - val_loss: 0.2707 - val_mse: 0.2569 - 27ms/epoch - 27ms/step\n",
      "iteration :47 Target train: tf.Tensor(0.259342, shape=(), dtype=float32) loss1 tf.Tensor(0.13258848, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.12675354, shape=(), dtype=float32) loss2   tf.Tensor(0.12669581, shape=(), dtype=float32) loss3  tf.Tensor(1.0039192, shape=(), dtype=float32) Target test: tf.Tensor(0.30887815, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.2707 - mse: 0.2602 - val_loss: 0.2658 - val_mse: 0.2520 - 28ms/epoch - 28ms/step\n",
      "iteration :48 Target train: tf.Tensor(0.25447565, shape=(), dtype=float32) loss1 tf.Tensor(0.12373051, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.13074514, shape=(), dtype=float32) loss2   tf.Tensor(0.13068521, shape=(), dtype=float32) loss3  tf.Tensor(1.0041316, shape=(), dtype=float32) Target test: tf.Tensor(0.30302557, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.2658 - mse: 0.2553 - val_loss: 0.2611 - val_mse: 0.2472 - 28ms/epoch - 28ms/step\n",
      "iteration :49 Target train: tf.Tensor(0.24973126, shape=(), dtype=float32) loss1 tf.Tensor(0.114990816, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.13474044, shape=(), dtype=float32) loss2   tf.Tensor(0.13467826, shape=(), dtype=float32) loss3  tf.Tensor(1.0043463, shape=(), dtype=float32) Target test: tf.Tensor(0.29731274, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.2611 - mse: 0.2506 - val_loss: 0.2565 - val_mse: 0.2426 - 28ms/epoch - 28ms/step\n",
      "iteration :50 Target train: tf.Tensor(0.24510531, shape=(), dtype=float32) loss1 tf.Tensor(0.1063678, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.13873751, shape=(), dtype=float32) loss2   tf.Tensor(0.13867308, shape=(), dtype=float32) loss3  tf.Tensor(1.0045629, shape=(), dtype=float32) Target test: tf.Tensor(0.29173616, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.2565 - mse: 0.2459 - val_loss: 0.2521 - val_mse: 0.2380 - 31ms/epoch - 31ms/step\n",
      "iteration :51 Target train: tf.Tensor(0.2405945, shape=(), dtype=float32) loss1 tf.Tensor(0.097859904, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.1427346, shape=(), dtype=float32) loss2   tf.Tensor(0.14266784, shape=(), dtype=float32) loss3  tf.Tensor(1.0047809, shape=(), dtype=float32) Target test: tf.Tensor(0.28629234, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.2521 - mse: 0.2415 - val_loss: 0.2477 - val_mse: 0.2336 - 25ms/epoch - 25ms/step\n",
      "iteration :52 Target train: tf.Tensor(0.23619537, shape=(), dtype=float32) loss1 tf.Tensor(0.08946538, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.14672999, shape=(), dtype=float32) loss2   tf.Tensor(0.14666091, shape=(), dtype=float32) loss3  tf.Tensor(1.0050001, shape=(), dtype=float32) Target test: tf.Tensor(0.28097805, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.2477 - mse: 0.2371 - val_loss: 0.2435 - val_mse: 0.2293 - 27ms/epoch - 27ms/step\n",
      "iteration :53 Target train: tf.Tensor(0.23190486, shape=(), dtype=float32) loss1 tf.Tensor(0.08118282, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.15072204, shape=(), dtype=float32) loss2   tf.Tensor(0.15065059, shape=(), dtype=float32) loss3  tf.Tensor(1.00522, shape=(), dtype=float32) Target test: tf.Tensor(0.2757901, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.2435 - mse: 0.2328 - val_loss: 0.2393 - val_mse: 0.2250 - 33ms/epoch - 33ms/step\n",
      "iteration :54 Target train: tf.Tensor(0.22771974, shape=(), dtype=float32) loss1 tf.Tensor(0.073010474, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.15470926, shape=(), dtype=float32) loss2   tf.Tensor(0.1546354, shape=(), dtype=float32) loss3  tf.Tensor(1.0054402, shape=(), dtype=float32) Target test: tf.Tensor(0.27072522, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.2393 - mse: 0.2286 - val_loss: 0.2353 - val_mse: 0.2209 - 28ms/epoch - 28ms/step\n",
      "iteration :55 Target train: tf.Tensor(0.22363709, shape=(), dtype=float32) loss1 tf.Tensor(0.06494689, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.1586902, shape=(), dtype=float32) loss2   tf.Tensor(0.15861392, shape=(), dtype=float32) loss3  tf.Tensor(1.0056603, shape=(), dtype=float32) Target test: tf.Tensor(0.2657804, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.2353 - mse: 0.2245 - val_loss: 0.2313 - val_mse: 0.2169 - 27ms/epoch - 27ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iteration :56 Target train: tf.Tensor(0.21965393, shape=(), dtype=float32) loss1 tf.Tensor(0.056990445, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.16266349, shape=(), dtype=float32) loss2   tf.Tensor(0.16258475, shape=(), dtype=float32) loss3  tf.Tensor(1.0058799, shape=(), dtype=float32) Target test: tf.Tensor(0.26095265, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.2313 - mse: 0.2206 - val_loss: 0.2275 - val_mse: 0.2130 - 29ms/epoch - 29ms/step\n",
      "iteration :57 Target train: tf.Tensor(0.21576747, shape=(), dtype=float32) loss1 tf.Tensor(0.04913959, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.16662788, shape=(), dtype=float32) loss2   tf.Tensor(0.16654669, shape=(), dtype=float32) loss3  tf.Tensor(1.0060986, shape=(), dtype=float32) Target test: tf.Tensor(0.25623894, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.2275 - mse: 0.2167 - val_loss: 0.2237 - val_mse: 0.2091 - 27ms/epoch - 27ms/step\n",
      "iteration :58 Target train: tf.Tensor(0.21197487, shape=(), dtype=float32) loss1 tf.Tensor(0.04139264, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.17058223, shape=(), dtype=float32) loss2   tf.Tensor(0.1704985, shape=(), dtype=float32) loss3  tf.Tensor(1.0063162, shape=(), dtype=float32) Target test: tf.Tensor(0.25163645, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.2237 - mse: 0.2129 - val_loss: 0.2201 - val_mse: 0.2054 - 28ms/epoch - 28ms/step\n",
      "iteration :59 Target train: tf.Tensor(0.20827353, shape=(), dtype=float32) loss1 tf.Tensor(0.033748165, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.17452537, shape=(), dtype=float32) loss2   tf.Tensor(0.17443909, shape=(), dtype=float32) loss3  tf.Tensor(1.0065321, shape=(), dtype=float32) Target test: tf.Tensor(0.24714231, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.2201 - mse: 0.2092 - val_loss: 0.2165 - val_mse: 0.2018 - 30ms/epoch - 30ms/step\n",
      "iteration :60 Target train: tf.Tensor(0.20466085, shape=(), dtype=float32) loss1 tf.Tensor(0.026204586, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.17845626, shape=(), dtype=float32) loss2   tf.Tensor(0.17836744, shape=(), dtype=float32) loss3  tf.Tensor(1.006746, shape=(), dtype=float32) Target test: tf.Tensor(0.24275385, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.2165 - mse: 0.2056 - val_loss: 0.2130 - val_mse: 0.1982 - 29ms/epoch - 29ms/step\n",
      "iteration :61 Target train: tf.Tensor(0.20113437, shape=(), dtype=float32) loss1 tf.Tensor(0.018760383, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.18237399, shape=(), dtype=float32) loss2   tf.Tensor(0.1822826, shape=(), dtype=float32) loss3  tf.Tensor(1.0069577, shape=(), dtype=float32) Target test: tf.Tensor(0.23846829, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.2130 - mse: 0.2021 - val_loss: 0.2096 - val_mse: 0.1947 - 26ms/epoch - 26ms/step\n",
      "iteration :62 Target train: tf.Tensor(0.19769156, shape=(), dtype=float32) loss1 tf.Tensor(0.011413932, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.18627763, shape=(), dtype=float32) loss2   tf.Tensor(0.18618363, shape=(), dtype=float32) loss3  tf.Tensor(1.0071666, shape=(), dtype=float32) Target test: tf.Tensor(0.23428306, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.2096 - mse: 0.1987 - val_loss: 0.2063 - val_mse: 0.1913 - 28ms/epoch - 28ms/step\n",
      "iteration :63 Target train: tf.Tensor(0.19433014, shape=(), dtype=float32) loss1 tf.Tensor(0.0041636974, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.19016644, shape=(), dtype=float32) loss2   tf.Tensor(0.19006982, shape=(), dtype=float32) loss3  tf.Tensor(1.0073726, shape=(), dtype=float32) Target test: tf.Tensor(0.23019557, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.2063 - mse: 0.1953 - val_loss: 0.2031 - val_mse: 0.1880 - 25ms/epoch - 25ms/step\n",
      "iteration :64 Target train: tf.Tensor(0.19104783, shape=(), dtype=float32) loss1 tf.Tensor(0.002991721, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.19403955, shape=(), dtype=float32) loss2   tf.Tensor(0.19394033, shape=(), dtype=float32) loss3  tf.Tensor(1.0075752, shape=(), dtype=float32) Target test: tf.Tensor(0.22620335, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.2031 - mse: 0.1921 - val_loss: 0.1999 - val_mse: 0.1848 - 29ms/epoch - 29ms/step\n",
      "iteration :65 Target train: tf.Tensor(0.18784258, shape=(), dtype=float32) loss1 tf.Tensor(0.01005362, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.1978962, shape=(), dtype=float32) loss2   tf.Tensor(0.19779432, shape=(), dtype=float32) loss3  tf.Tensor(1.0077744, shape=(), dtype=float32) Target test: tf.Tensor(0.22230409, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.1999 - mse: 0.1889 - val_loss: 0.1968 - val_mse: 0.1816 - 26ms/epoch - 26ms/step\n",
      "iteration :66 Target train: tf.Tensor(0.18471222, shape=(), dtype=float32) loss1 tf.Tensor(0.017023504, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.20173572, shape=(), dtype=float32) loss2   tf.Tensor(0.20163114, shape=(), dtype=float32) loss3  tf.Tensor(1.0079696, shape=(), dtype=float32) Target test: tf.Tensor(0.21849538, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.1968 - mse: 0.1857 - val_loss: 0.1938 - val_mse: 0.1785 - 29ms/epoch - 29ms/step\n",
      "iteration :67 Target train: tf.Tensor(0.18165465, shape=(), dtype=float32) loss1 tf.Tensor(0.023902863, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.20555751, shape=(), dtype=float32) loss2   tf.Tensor(0.20545028, shape=(), dtype=float32) loss3  tf.Tensor(1.0081606, shape=(), dtype=float32) Target test: tf.Tensor(0.21477488, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.1938 - mse: 0.1827 - val_loss: 0.1908 - val_mse: 0.1755 - 26ms/epoch - 26ms/step\n",
      "iteration :68 Target train: tf.Tensor(0.17866783, shape=(), dtype=float32) loss1 tf.Tensor(0.030693337, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.20936117, shape=(), dtype=float32) loss2   tf.Tensor(0.20925122, shape=(), dtype=float32) loss3  tf.Tensor(1.0083473, shape=(), dtype=float32) Target test: tf.Tensor(0.21114023, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.1908 - mse: 0.1797 - val_loss: 0.1880 - val_mse: 0.1726 - 34ms/epoch - 34ms/step\n",
      "iteration :69 Target train: tf.Tensor(0.17574982, shape=(), dtype=float32) loss1 tf.Tensor(0.03739634, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.21314617, shape=(), dtype=float32) loss2   tf.Tensor(0.21303353, shape=(), dtype=float32) loss3  tf.Tensor(1.0085292, shape=(), dtype=float32) Target test: tf.Tensor(0.20758925, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.1880 - mse: 0.1768 - val_loss: 0.1852 - val_mse: 0.1697 - 27ms/epoch - 27ms/step\n",
      "iteration :70 Target train: tf.Tensor(0.17289878, shape=(), dtype=float32) loss1 tf.Tensor(0.04401332, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.2169121, shape=(), dtype=float32) loss2   tf.Tensor(0.21679676, shape=(), dtype=float32) loss3  tf.Tensor(1.0087063, shape=(), dtype=float32) Target test: tf.Tensor(0.20411973, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.1852 - mse: 0.1740 - val_loss: 0.1824 - val_mse: 0.1669 - 31ms/epoch - 31ms/step\n",
      "iteration :71 Target train: tf.Tensor(0.17011288, shape=(), dtype=float32) loss1 tf.Tensor(0.050545767, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.22065865, shape=(), dtype=float32) loss2   tf.Tensor(0.22054055, shape=(), dtype=float32) loss3  tf.Tensor(1.0088782, shape=(), dtype=float32) Target test: tf.Tensor(0.20072961, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.1824 - mse: 0.1712 - val_loss: 0.1797 - val_mse: 0.1642 - 30ms/epoch - 30ms/step\n",
      "iteration :72 Target train: tf.Tensor(0.16739033, shape=(), dtype=float32) loss1 tf.Tensor(0.056995124, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.22438546, shape=(), dtype=float32) loss2   tf.Tensor(0.22426462, shape=(), dtype=float32) loss3  tf.Tensor(1.009045, shape=(), dtype=float32) Target test: tf.Tensor(0.19741675, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.1797 - mse: 0.1685 - val_loss: 0.1771 - val_mse: 0.1615 - 29ms/epoch - 29ms/step\n",
      "iteration :73 Target train: tf.Tensor(0.16472936, shape=(), dtype=float32) loss1 tf.Tensor(0.06336288, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.22809224, shape=(), dtype=float32) loss2   tf.Tensor(0.22796871, shape=(), dtype=float32) loss3  tf.Tensor(1.0092062, shape=(), dtype=float32) Target test: tf.Tensor(0.19417912, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.1771 - mse: 0.1658 - val_loss: 0.1745 - val_mse: 0.1589 - 29ms/epoch - 29ms/step\n",
      "iteration :74 Target train: tf.Tensor(0.16212836, shape=(), dtype=float32) loss1 tf.Tensor(0.069650486, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.23177885, shape=(), dtype=float32) loss2   tf.Tensor(0.23165251, shape=(), dtype=float32) loss3  tf.Tensor(1.0093617, shape=(), dtype=float32) Target test: tf.Tensor(0.19101474, shape=(), dtype=float32)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1/1 - 0s - loss: 0.1745 - mse: 0.1632 - val_loss: 0.1720 - val_mse: 0.1563 - 27ms/epoch - 27ms/step\n",
      "iteration :75 Target train: tf.Tensor(0.15958576, shape=(), dtype=float32) loss1 tf.Tensor(0.075859174, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.23544493, shape=(), dtype=float32) loss2   tf.Tensor(0.23531587, shape=(), dtype=float32) loss3  tf.Tensor(1.0095116, shape=(), dtype=float32) Target test: tf.Tensor(0.18792173, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.1720 - mse: 0.1607 - val_loss: 0.1696 - val_mse: 0.1538 - 29ms/epoch - 29ms/step\n",
      "iteration :76 Target train: tf.Tensor(0.15709992, shape=(), dtype=float32) loss1 tf.Tensor(0.081990495, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.23909041, shape=(), dtype=float32) loss2   tf.Tensor(0.23895861, shape=(), dtype=float32) loss3  tf.Tensor(1.0096554, shape=(), dtype=float32) Target test: tf.Tensor(0.18489817, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.1696 - mse: 0.1582 - val_loss: 0.1672 - val_mse: 0.1514 - 28ms/epoch - 28ms/step\n",
      "iteration :77 Target train: tf.Tensor(0.1546693, shape=(), dtype=float32) loss1 tf.Tensor(0.088045835, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.24271514, shape=(), dtype=float32) loss2   tf.Tensor(0.24258056, shape=(), dtype=float32) loss3  tf.Tensor(1.0097932, shape=(), dtype=float32) Target test: tf.Tensor(0.18194221, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.1672 - mse: 0.1558 - val_loss: 0.1649 - val_mse: 0.1490 - 33ms/epoch - 33ms/step\n",
      "iteration :78 Target train: tf.Tensor(0.15229248, shape=(), dtype=float32) loss1 tf.Tensor(0.09402652, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.246319, shape=(), dtype=float32) loss2   tf.Tensor(0.24618168, shape=(), dtype=float32) loss3  tf.Tensor(1.0099248, shape=(), dtype=float32) Target test: tf.Tensor(0.17905205, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.1649 - mse: 0.1534 - val_loss: 0.1626 - val_mse: 0.1466 - 28ms/epoch - 28ms/step\n",
      "iteration :79 Target train: tf.Tensor(0.14996801, shape=(), dtype=float32) loss1 tf.Tensor(0.09993392, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.24990194, shape=(), dtype=float32) loss2   tf.Tensor(0.24976188, shape=(), dtype=float32) loss3  tf.Tensor(1.0100499, shape=(), dtype=float32) Target test: tf.Tensor(0.17622599, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.1626 - mse: 0.1511 - val_loss: 0.1603 - val_mse: 0.1444 - 29ms/epoch - 29ms/step\n",
      "iteration :80 Target train: tf.Tensor(0.1476945, shape=(), dtype=float32) loss1 tf.Tensor(0.10576928, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.25346377, shape=(), dtype=float32) loss2   tf.Tensor(0.253321, shape=(), dtype=float32) loss3  tf.Tensor(1.0101687, shape=(), dtype=float32) Target test: tf.Tensor(0.17346235, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.1603 - mse: 0.1488 - val_loss: 0.1582 - val_mse: 0.1421 - 26ms/epoch - 26ms/step\n",
      "iteration :81 Target train: tf.Tensor(0.1454706, shape=(), dtype=float32) loss1 tf.Tensor(0.111533985, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.2570046, shape=(), dtype=float32) loss2   tf.Tensor(0.2568591, shape=(), dtype=float32) loss3  tf.Tensor(1.0102811, shape=(), dtype=float32) Target test: tf.Tensor(0.1707594, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.1582 - mse: 0.1466 - val_loss: 0.1560 - val_mse: 0.1399 - 26ms/epoch - 26ms/step\n",
      "iteration :82 Target train: tf.Tensor(0.14329505, shape=(), dtype=float32) loss1 tf.Tensor(0.11722928, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.26052433, shape=(), dtype=float32) loss2   tf.Tensor(0.26037607, shape=(), dtype=float32) loss3  tf.Tensor(1.0103868, shape=(), dtype=float32) Target test: tf.Tensor(0.16811562, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.1560 - mse: 0.1444 - val_loss: 0.1539 - val_mse: 0.1378 - 27ms/epoch - 27ms/step\n",
      "iteration :83 Target train: tf.Tensor(0.14116652, shape=(), dtype=float32) loss1 tf.Tensor(0.12285639, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.26402292, shape=(), dtype=float32) loss2   tf.Tensor(0.26387194, shape=(), dtype=float32) loss3  tf.Tensor(1.0104859, shape=(), dtype=float32) Target test: tf.Tensor(0.16552937, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.1539 - mse: 0.1423 - val_loss: 0.1519 - val_mse: 0.1357 - 29ms/epoch - 29ms/step\n",
      "iteration :84 Target train: tf.Tensor(0.13908377, shape=(), dtype=float32) loss1 tf.Tensor(0.12841666, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.26750043, shape=(), dtype=float32) loss2   tf.Tensor(0.2673467, shape=(), dtype=float32) loss3  tf.Tensor(1.0105784, shape=(), dtype=float32) Target test: tf.Tensor(0.16299921, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.1519 - mse: 0.1402 - val_loss: 0.1499 - val_mse: 0.1337 - 26ms/epoch - 26ms/step\n",
      "iteration :85 Target train: tf.Tensor(0.1370457, shape=(), dtype=float32) loss1 tf.Tensor(0.13391115, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.27095684, shape=(), dtype=float32) loss2   tf.Tensor(0.2708004, shape=(), dtype=float32) loss3  tf.Tensor(1.010664, shape=(), dtype=float32) Target test: tf.Tensor(0.1605236, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.1499 - mse: 0.1382 - val_loss: 0.1479 - val_mse: 0.1317 - 28ms/epoch - 28ms/step\n",
      "iteration :86 Target train: tf.Tensor(0.13505104, shape=(), dtype=float32) loss1 tf.Tensor(0.13934112, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.27439216, shape=(), dtype=float32) loss2   tf.Tensor(0.27423304, shape=(), dtype=float32) loss3  tf.Tensor(1.0107429, shape=(), dtype=float32) Target test: tf.Tensor(0.1581011, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.1479 - mse: 0.1362 - val_loss: 0.1460 - val_mse: 0.1297 - 30ms/epoch - 30ms/step\n",
      "iteration :87 Target train: tf.Tensor(0.13309869, shape=(), dtype=float32) loss1 tf.Tensor(0.1447078, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.2778065, shape=(), dtype=float32) loss2   tf.Tensor(0.27764466, shape=(), dtype=float32) loss3  tf.Tensor(1.0108149, shape=(), dtype=float32) Target test: tf.Tensor(0.15573034, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.1460 - mse: 0.1342 - val_loss: 0.1441 - val_mse: 0.1278 - 28ms/epoch - 28ms/step\n",
      "iteration :88 Target train: tf.Tensor(0.13118759, shape=(), dtype=float32) loss1 tf.Tensor(0.15001225, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.28119984, shape=(), dtype=float32) loss2   tf.Tensor(0.2810353, shape=(), dtype=float32) loss3  tf.Tensor(1.0108802, shape=(), dtype=float32) Target test: tf.Tensor(0.15340996, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.1441 - mse: 0.1323 - val_loss: 0.1423 - val_mse: 0.1259 - 27ms/epoch - 27ms/step\n",
      "iteration :89 Target train: tf.Tensor(0.12931664, shape=(), dtype=float32) loss1 tf.Tensor(0.15525551, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.28457215, shape=(), dtype=float32) loss2   tf.Tensor(0.284405, shape=(), dtype=float32) loss3  tf.Tensor(1.0109385, shape=(), dtype=float32) Target test: tf.Tensor(0.15113863, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.1423 - mse: 0.1305 - val_loss: 0.1405 - val_mse: 0.1241 - 27ms/epoch - 27ms/step\n",
      "iteration :90 Target train: tf.Tensor(0.12748483, shape=(), dtype=float32) loss1 tf.Tensor(0.16043884, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.28792366, shape=(), dtype=float32) loss2   tf.Tensor(0.2877538, shape=(), dtype=float32) loss3  tf.Tensor(1.01099, shape=(), dtype=float32) Target test: tf.Tensor(0.14891505, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.1405 - mse: 0.1286 - val_loss: 0.1387 - val_mse: 0.1223 - 27ms/epoch - 27ms/step\n",
      "iteration :91 Target train: tf.Tensor(0.12569115, shape=(), dtype=float32) loss1 tf.Tensor(0.16556317, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.2912543, shape=(), dtype=float32) loss2   tf.Tensor(0.2910818, shape=(), dtype=float32) loss3  tf.Tensor(1.0110347, shape=(), dtype=float32) Target test: tf.Tensor(0.14673801, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.1387 - mse: 0.1268 - val_loss: 0.1370 - val_mse: 0.1205 - 29ms/epoch - 29ms/step\n",
      "iteration :92 Target train: tf.Tensor(0.1239346, shape=(), dtype=float32) loss1 tf.Tensor(0.17062956, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.29456416, shape=(), dtype=float32) loss2   tf.Tensor(0.294389, shape=(), dtype=float32) loss3  tf.Tensor(1.0110724, shape=(), dtype=float32) Target test: tf.Tensor(0.14460629, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.1370 - mse: 0.1251 - val_loss: 0.1353 - val_mse: 0.1188 - 26ms/epoch - 26ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iteration :93 Target train: tf.Tensor(0.12221426, shape=(), dtype=float32) loss1 tf.Tensor(0.17563903, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.2978533, shape=(), dtype=float32) loss2   tf.Tensor(0.29767555, shape=(), dtype=float32) loss3  tf.Tensor(1.0111033, shape=(), dtype=float32) Target test: tf.Tensor(0.14251871, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.1353 - mse: 0.1234 - val_loss: 0.1337 - val_mse: 0.1171 - 29ms/epoch - 29ms/step\n",
      "iteration :94 Target train: tf.Tensor(0.12052922, shape=(), dtype=float32) loss1 tf.Tensor(0.18059255, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.30112177, shape=(), dtype=float32) loss2   tf.Tensor(0.3009414, shape=(), dtype=float32) loss3  tf.Tensor(1.0111274, shape=(), dtype=float32) Target test: tf.Tensor(0.14047414, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.1337 - mse: 0.1217 - val_loss: 0.1321 - val_mse: 0.1154 - 25ms/epoch - 25ms/step\n",
      "iteration :95 Target train: tf.Tensor(0.11887859, shape=(), dtype=float32) loss1 tf.Tensor(0.18549104, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.30436963, shape=(), dtype=float32) loss2   tf.Tensor(0.3041866, shape=(), dtype=float32) loss3  tf.Tensor(1.0111444, shape=(), dtype=float32) Target test: tf.Tensor(0.13847147, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.1321 - mse: 0.1200 - val_loss: 0.1305 - val_mse: 0.1138 - 31ms/epoch - 31ms/step\n",
      "iteration :96 Target train: tf.Tensor(0.117261454, shape=(), dtype=float32) loss1 tf.Tensor(0.19033547, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.30759692, shape=(), dtype=float32) loss2   tf.Tensor(0.30741134, shape=(), dtype=float32) loss3  tf.Tensor(1.0111548, shape=(), dtype=float32) Target test: tf.Tensor(0.13650966, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.1305 - mse: 0.1184 - val_loss: 0.1289 - val_mse: 0.1122 - 26ms/epoch - 26ms/step\n",
      "iteration :97 Target train: tf.Tensor(0.115676984, shape=(), dtype=float32) loss1 tf.Tensor(0.19512676, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.31080374, shape=(), dtype=float32) loss2   tf.Tensor(0.31061563, shape=(), dtype=float32) loss3  tf.Tensor(1.0111583, shape=(), dtype=float32) Target test: tf.Tensor(0.13458763, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.1289 - mse: 0.1168 - val_loss: 0.1274 - val_mse: 0.1107 - 27ms/epoch - 27ms/step\n",
      "iteration :98 Target train: tf.Tensor(0.114124395, shape=(), dtype=float32) loss1 tf.Tensor(0.19986573, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.31399012, shape=(), dtype=float32) loss2   tf.Tensor(0.3137994, shape=(), dtype=float32) loss3  tf.Tensor(1.0111549, shape=(), dtype=float32) Target test: tf.Tensor(0.13270444, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.1274 - mse: 0.1153 - val_loss: 0.1259 - val_mse: 0.1091 - 27ms/epoch - 27ms/step\n",
      "iteration :99 Target train: tf.Tensor(0.11260289, shape=(), dtype=float32) loss1 tf.Tensor(0.20455319, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.31715608, shape=(), dtype=float32) loss2   tf.Tensor(0.31696284, shape=(), dtype=float32) loss3  tf.Tensor(1.0111449, shape=(), dtype=float32) Target test: tf.Tensor(0.13085906, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.1259 - mse: 0.1138 - val_loss: 0.1244 - val_mse: 0.1076 - 27ms/epoch - 27ms/step\n",
      "iteration :100 Target train: tf.Tensor(0.11111167, shape=(), dtype=float32) loss1 tf.Tensor(0.20919004, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.3203017, shape=(), dtype=float32) loss2   tf.Tensor(0.32010597, shape=(), dtype=float32) loss3  tf.Tensor(1.0111281, shape=(), dtype=float32) Target test: tf.Tensor(0.12905054, 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 = 204\n",
    "    \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": 17,
   "id": "4bd4e1d5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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FvhbSbUvIiIiIvJnaO4bERERERE3SpBFRERERNwoQRYRERERcaMEWURERETEjRJkERERERE3SpBFRERERNwoQRYRERERcaMEWURERETEjRJkERERERE3SpBFRERERNwoQRYRERERcaMEWURERETEjRJkERERERE3SpBFRERERNwoQRYRERERcaMEWURERETEjRJkERERERE3SpBFRERERNwoQRYRERERcaMEWURERETEjRJkERERERE3SpBFRERERNwoQRYRERERcaMEWURERETEjRJkERERERE3SpBFRERERNwoQRYRERERcaMEWURERETEjRJkERERERE3SpBFRERERNwoQRYRERERcaMEWURERETEjRJkERERERE3SpBFRERERNwoQRYRERERcaMEWURERETEjRJkERERERE3SpBFRERERNwoQRYRERERcaMEWURERETEjRJkERERERE3SpBFRERERNwoQRYRERERcaMEWURERETEjRJkERERERE3SpBFRERERNwoQRYRERERcaMEWURERETEjRJkERERERE3SpBFRERERNwoQRYRERERcaMEWURERETEjRJkERERERE3SpBFRERERNwoQRYRERERcaMEWURERETEjRJkERERERE3JZogG2O6GWM2GmO2GGMezWd/JWPMV8aYNcaYdcaYO0oyHhERERGRcymxBNkY4wO8AVwHNAcGGmOa5yr2N2C9tbY1EA+MMcb4l1RMIiIiIiLnUpI9yO2BLdbabdba00AC0CtXGQuEGGMMEAwcAjJKMCYRERERkUIZa23JVGxMX6CbtfYu1/dbgQ7W2r+7lQkBvgQigBCgv7V2Vj513Q3cDVCzZs3ohISEEom5INZa0tOOU7l60EVtVy6+o0ePEhwc7OkwpATpGpcPus5ln65x+VDS17lTp04rrbUxubf7lliLYPLZljsb7wr8BFwNNAK+NcZ8Z639PcdB1o4HxgPExMTY+Pj44o+2EMu/2sbG73bQ/v421G5S+aK2LRdXYmIiF/vfl1xcusblg65z2adrXD546jqX5BCL3UA9t+91gb25ytwBfG6dtgDbcfYme5WmsZfgUwFmvLqaTSv2ezocERERESlBJZkgrwCaGGMauh68G4BzOIW7XUBnAGNMTaApsK0EY/pTKlUPpOE1hprhoXz73nqSvt5BSQ1NERERERHP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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",
    "\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": 18,
   "id": "8f14a2c7",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Target train:  tf.Tensor(0.11111167, shape=(), dtype=float32)\n",
      "Target test:  tf.Tensor(0.12905054, 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": 19,
   "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": 20,
   "id": "b90b3b96",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Weights (kernel_P1):\n",
      " [array([[ 0.9189399 , -0.06522479,  0.        ,  0.        ],\n",
      "       [ 0.04527445,  0.9397795 ,  0.        ,  0.        ]],\n",
      "      dtype=float32)]\n",
      "Weights (kernel_P2):\n",
      " [array([[ 0.9183176 , -0.06415426,  0.        ,  0.        ],\n",
      "       [ 0.05035371,  0.940913  ,  0.        ,  0.        ],\n",
      "       [ 0.        ,  0.        ,  1.        ,  0.        ],\n",
      "       [ 0.        ,  0.        ,  0.        ,  1.        ]],\n",
      "      dtype=float32)]\n",
      "Weights (kernel_P3):\n",
      " [array([[ 0.91787547, -0.06294557],\n",
      "       [ 0.0557649 ,  0.9403551 ],\n",
      "       [ 0.        ,  0.        ],\n",
      "       [ 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": 21,
   "id": "e2032c68",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Weights (kernel_I1):\n",
      " [[ 0.9232407  -0.08566698 -0.08396465  0.          0.          0.\n",
      "   0.          0.        ]\n",
      " [ 0.0624108   1.075262   -0.03229606  0.          0.          0.\n",
      "   0.          0.        ]\n",
      " [ 0.06227631  0.0782476   0.967329    0.          0.          0.\n",
      "   0.          0.        ]]\n",
      "Weights (kernel_I2):\n",
      " [[ 0.9223991  -0.08086369 -0.07736414  0.          0.          0.\n",
      "   0.          0.        ]\n",
      " [ 0.07053182  1.0842083  -0.03361598  0.          0.          0.\n",
      "   0.          0.        ]\n",
      " [ 0.06769754  0.08146314  0.9679433   0.          0.          0.\n",
      "   0.          0.        ]\n",
      " [ 0.          0.          0.          1.          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.9222526  -0.07516589 -0.06957939]\n",
      " [ 0.07786296  1.0865252  -0.04131889]\n",
      " [ 0.07217962  0.08134121  0.96367943]\n",
      " [ 0.          0.          0.        ]\n",
      " [ 0.          0.          0.        ]\n",
      " [ 0.          0.          0.        ]\n",
      " [ 0.          0.          0.        ]\n",
      " [ 0.          0.          0.        ]]\n",
      "Weights (kernel_P1):\n",
      " [[ 0.9189399  -0.06522479  0.          0.        ]\n",
      " [ 0.04527445  0.9397795   0.          0.        ]]\n",
      "Weights (kernel_P2):\n",
      " [[ 0.9183176  -0.06415426  0.          0.        ]\n",
      " [ 0.05035371  0.940913    0.          0.        ]\n",
      " [ 0.          0.          1.          0.        ]\n",
      " [ 0.          0.          0.          1.        ]]\n",
      "Weights (kernel_P3):\n",
      " [[ 0.91787547 -0.06294557]\n",
      " [ 0.0557649   0.9403551 ]\n",
      " [ 0.          0.        ]\n",
      " [ 0.          0.        ]]\n",
      "Weights Final input P:\n",
      " [[ 0.75018084 -0.2647816  -0.19561   ]\n",
      " [ 0.2059809   1.2425985  -0.12659444]\n",
      " [ 0.19785665  0.23822616  0.87964356]]\n",
      "Weights Final output Q:\n",
      " [[ 0.76485103 -0.16605969]\n",
      " [ 0.13074522  0.8231827 ]]\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": 22,
   "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=(3))  # Replace input_dim with your actual input feature dimension\n",
    "new_input_layer = Dense(3, 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(2, 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": 23,
   "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": 24,
   "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, 3)]               0         \n",
      "                                                                 \n",
      " dense_8 (Dense)             (None, 3)                 9         \n",
      "                                                                 \n",
      " sequential (Sequential)     (None, 2)                 50        \n",
      "                                                                 \n",
      " dense_9 (Dense)             (None, 2)                 4         \n",
      "                                                                 \n",
      "=================================================================\n",
      "Total params: 63\n",
      "Trainable params: 63\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": 25,
   "id": "55fbdca2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1/1 - 0s - loss: 0.1123 - mse: 0.1123 - val_loss: 0.1039 - val_mse: 0.1039 - 195ms/epoch - 195ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.1075 - mse: 0.1075\n",
      "4/4 [==============================] - 0s 696us/step - loss: 0.1246 - mse: 0.1246\n",
      "1/1 - 0s - loss: 0.1087 - mse: 0.1087 - val_loss: 0.1002 - val_mse: 0.1002 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.1039 - mse: 0.1039\n",
      "4/4 [==============================] - 0s 828us/step - loss: 0.1203 - mse: 0.1203\n",
      "1/1 - 0s - loss: 0.1052 - mse: 0.1052 - val_loss: 0.0967 - val_mse: 0.0967 - 29ms/epoch - 29ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.1006 - mse: 0.1006\n",
      "4/4 [==============================] - 0s 675us/step - loss: 0.1161 - mse: 0.1161\n",
      "1/1 - 0s - loss: 0.1018 - mse: 0.1018 - val_loss: 0.0934 - val_mse: 0.0934 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 9ms/step - loss: 0.0973 - mse: 0.0973\n",
      "4/4 [==============================] - 0s 685us/step - loss: 0.1121 - mse: 0.1121\n",
      "1/1 - 0s - loss: 0.0986 - mse: 0.0986 - val_loss: 0.0901 - val_mse: 0.0901 - 22ms/epoch - 22ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0941 - mse: 0.0941\n",
      "4/4 [==============================] - 0s 806us/step - loss: 0.1082 - mse: 0.1082\n",
      "1/1 - 0s - loss: 0.0955 - mse: 0.0955 - val_loss: 0.0870 - val_mse: 0.0870 - 23ms/epoch - 23ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0911 - mse: 0.0911\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.1045 - mse: 0.1045\n",
      "1/1 - 0s - loss: 0.0925 - mse: 0.0925 - val_loss: 0.0841 - val_mse: 0.0841 - 25ms/epoch - 25ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0882 - mse: 0.0882\n",
      "4/4 [==============================] - 0s 757us/step - loss: 0.1009 - mse: 0.1009\n",
      "1/1 - 0s - loss: 0.0896 - mse: 0.0896 - val_loss: 0.0812 - val_mse: 0.0812 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0854 - mse: 0.0854\n",
      "4/4 [==============================] - 0s 633us/step - loss: 0.0974 - mse: 0.0974\n",
      "1/1 - 0s - loss: 0.0868 - mse: 0.0868 - val_loss: 0.0785 - val_mse: 0.0785 - 27ms/epoch - 27ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0827 - mse: 0.0827\n",
      "4/4 [==============================] - 0s 791us/step - loss: 0.0941 - mse: 0.0941\n",
      "1/1 - 0s - loss: 0.0841 - mse: 0.0841 - val_loss: 0.0759 - val_mse: 0.0759 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0802 - mse: 0.0802\n",
      "4/4 [==============================] - 0s 666us/step - loss: 0.0909 - mse: 0.0909\n",
      "1/1 - 0s - loss: 0.0816 - mse: 0.0816 - val_loss: 0.0734 - val_mse: 0.0734 - 27ms/epoch - 27ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0777 - mse: 0.0777\n",
      "4/4 [==============================] - 0s 721us/step - loss: 0.0879 - mse: 0.0879\n",
      "1/1 - 0s - loss: 0.0791 - mse: 0.0791 - val_loss: 0.0710 - val_mse: 0.0710 - 26ms/epoch - 26ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0753 - mse: 0.0753\n",
      "4/4 [==============================] - 0s 787us/step - loss: 0.0850 - mse: 0.0850\n",
      "1/1 - 0s - loss: 0.0767 - mse: 0.0767 - val_loss: 0.0687 - val_mse: 0.0687 - 26ms/epoch - 26ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0730 - mse: 0.0730\n",
      "4/4 [==============================] - 0s 601us/step - loss: 0.0822 - mse: 0.0822\n",
      "1/1 - 0s - loss: 0.0744 - mse: 0.0744 - val_loss: 0.0665 - val_mse: 0.0665 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0708 - mse: 0.0708\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0795 - mse: 0.0795\n",
      "1/1 - 0s - loss: 0.0722 - mse: 0.0722 - val_loss: 0.0644 - val_mse: 0.0644 - 27ms/epoch - 27ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0686 - mse: 0.0686\n",
      "4/4 [==============================] - 0s 715us/step - loss: 0.0769 - mse: 0.0769\n",
      "1/1 - 0s - loss: 0.0701 - mse: 0.0701 - val_loss: 0.0623 - val_mse: 0.0623 - 23ms/epoch - 23ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0666 - mse: 0.0666\n",
      "4/4 [==============================] - 0s 569us/step - loss: 0.0744 - mse: 0.0744\n",
      "1/1 - 0s - loss: 0.0680 - mse: 0.0680 - val_loss: 0.0604 - val_mse: 0.0604 - 27ms/epoch - 27ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0646 - mse: 0.0646\n",
      "4/4 [==============================] - 0s 573us/step - loss: 0.0721 - mse: 0.0721\n",
      "1/1 - 0s - loss: 0.0660 - mse: 0.0660 - val_loss: 0.0585 - val_mse: 0.0585 - 26ms/epoch - 26ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0627 - mse: 0.0627\n",
      "4/4 [==============================] - 0s 721us/step - loss: 0.0698 - mse: 0.0698\n",
      "1/1 - 0s - loss: 0.0641 - mse: 0.0641 - val_loss: 0.0567 - val_mse: 0.0567 - 25ms/epoch - 25ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0608 - mse: 0.0608\n",
      "4/4 [==============================] - 0s 773us/step - loss: 0.0677 - mse: 0.0677\n",
      "1/1 - 0s - loss: 0.0622 - mse: 0.0622 - val_loss: 0.0550 - val_mse: 0.0550 - 23ms/epoch - 23ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0590 - mse: 0.0590\n",
      "4/4 [==============================] - 0s 615us/step - loss: 0.0656 - mse: 0.0656\n",
      "1/1 - 0s - loss: 0.0604 - mse: 0.0604 - val_loss: 0.0533 - val_mse: 0.0533 - 26ms/epoch - 26ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0573 - mse: 0.0573\n",
      "4/4 [==============================] - 0s 608us/step - loss: 0.0636 - mse: 0.0636\n",
      "1/1 - 0s - loss: 0.0586 - mse: 0.0586 - val_loss: 0.0516 - val_mse: 0.0516 - 25ms/epoch - 25ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0556 - mse: 0.0556\n",
      "4/4 [==============================] - 0s 818us/step - loss: 0.0617 - mse: 0.0617\n",
      "1/1 - 0s - loss: 0.0569 - mse: 0.0569 - val_loss: 0.0501 - val_mse: 0.0501 - 25ms/epoch - 25ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0540 - mse: 0.0540\n",
      "4/4 [==============================] - 0s 865us/step - loss: 0.0598 - mse: 0.0598\n",
      "1/1 - 0s - loss: 0.0552 - mse: 0.0552 - val_loss: 0.0486 - val_mse: 0.0486 - 27ms/epoch - 27ms/step\n",
      "1/1 [==============================] - 0s 9ms/step - loss: 0.0524 - mse: 0.0524\n",
      "4/4 [==============================] - 0s 725us/step - loss: 0.0580 - mse: 0.0580\n",
      "1/1 - 0s - loss: 0.0536 - mse: 0.0536 - val_loss: 0.0471 - val_mse: 0.0471 - 23ms/epoch - 23ms/step\n",
      "1/1 [==============================] - 0s 9ms/step - loss: 0.0508 - mse: 0.0508\n",
      "4/4 [==============================] - 0s 633us/step - loss: 0.0563 - mse: 0.0563\n",
      "1/1 - 0s - loss: 0.0521 - mse: 0.0521 - val_loss: 0.0457 - val_mse: 0.0457 - 23ms/epoch - 23ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0494 - mse: 0.0494\n",
      "4/4 [==============================] - 0s 847us/step - loss: 0.0546 - mse: 0.0546\n",
      "1/1 - 0s - loss: 0.0506 - mse: 0.0506 - val_loss: 0.0443 - val_mse: 0.0443 - 26ms/epoch - 26ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0479 - mse: 0.0479\n",
      "4/4 [==============================] - 0s 694us/step - loss: 0.0530 - mse: 0.0530\n",
      "1/1 - 0s - loss: 0.0491 - mse: 0.0491 - val_loss: 0.0430 - val_mse: 0.0430 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 9ms/step - loss: 0.0465 - mse: 0.0465\n",
      "4/4 [==============================] - 0s 962us/step - loss: 0.0515 - mse: 0.0515\n",
      "1/1 - 0s - loss: 0.0477 - mse: 0.0477 - val_loss: 0.0417 - val_mse: 0.0417 - 26ms/epoch - 26ms/step\n",
      "1/1 [==============================] - 0s 9ms/step - loss: 0.0452 - mse: 0.0452\n",
      "4/4 [==============================] - 0s 560us/step - loss: 0.0499 - mse: 0.0499\n",
      "1/1 - 0s - loss: 0.0463 - mse: 0.0463 - val_loss: 0.0404 - val_mse: 0.0404 - 26ms/epoch - 26ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0438 - mse: 0.0438\n",
      "4/4 [==============================] - 0s 703us/step - loss: 0.0485 - mse: 0.0485\n",
      "1/1 - 0s - loss: 0.0450 - mse: 0.0450 - val_loss: 0.0392 - val_mse: 0.0392 - 23ms/epoch - 23ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0426 - mse: 0.0426\n",
      "4/4 [==============================] - 0s 929us/step - loss: 0.0471 - mse: 0.0471\n",
      "1/1 - 0s - loss: 0.0437 - mse: 0.0437 - val_loss: 0.0381 - val_mse: 0.0381 - 25ms/epoch - 25ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0413 - mse: 0.0413\n",
      "4/4 [==============================] - 0s 604us/step - loss: 0.0457 - mse: 0.0457\n",
      "1/1 - 0s - loss: 0.0424 - mse: 0.0424 - val_loss: 0.0369 - val_mse: 0.0369 - 23ms/epoch - 23ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0401 - mse: 0.0401\n",
      "4/4 [==============================] - 0s 636us/step - loss: 0.0444 - mse: 0.0444\n",
      "1/1 - 0s - loss: 0.0412 - mse: 0.0412 - val_loss: 0.0358 - val_mse: 0.0358 - 23ms/epoch - 23ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0390 - mse: 0.0390\n",
      "4/4 [==============================] - 0s 806us/step - loss: 0.0431 - mse: 0.0431\n",
      "1/1 - 0s - loss: 0.0400 - mse: 0.0400 - val_loss: 0.0347 - val_mse: 0.0347 - 26ms/epoch - 26ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0379 - mse: 0.0379\n",
      "4/4 [==============================] - 0s 684us/step - loss: 0.0418 - mse: 0.0418\n",
      "1/1 - 0s - loss: 0.0389 - mse: 0.0389 - val_loss: 0.0337 - val_mse: 0.0337 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0368 - mse: 0.0368\n",
      "4/4 [==============================] - 0s 866us/step - loss: 0.0406 - mse: 0.0406\n",
      "1/1 - 0s - loss: 0.0378 - mse: 0.0378 - val_loss: 0.0327 - val_mse: 0.0327 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 9ms/step - loss: 0.0357 - mse: 0.0357\n",
      "4/4 [==============================] - 0s 604us/step - loss: 0.0394 - mse: 0.0394\n",
      "1/1 - 0s - loss: 0.0367 - mse: 0.0367 - val_loss: 0.0317 - val_mse: 0.0317 - 23ms/epoch - 23ms/step\n",
      "1/1 [==============================] - 0s 9ms/step - loss: 0.0347 - mse: 0.0347\n",
      "4/4 [==============================] - 0s 651us/step - loss: 0.0383 - mse: 0.0383\n",
      "1/1 - 0s - loss: 0.0357 - mse: 0.0357 - val_loss: 0.0308 - val_mse: 0.0308 - 26ms/epoch - 26ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0337 - mse: 0.0337\n",
      "4/4 [==============================] - 0s 690us/step - loss: 0.0372 - mse: 0.0372\n",
      "1/1 - 0s - loss: 0.0346 - mse: 0.0346 - val_loss: 0.0299 - val_mse: 0.0299 - 23ms/epoch - 23ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0327 - mse: 0.0327\n",
      "4/4 [==============================] - 0s 605us/step - loss: 0.0361 - mse: 0.0361\n",
      "1/1 - 0s - loss: 0.0337 - mse: 0.0337 - val_loss: 0.0290 - val_mse: 0.0290 - 22ms/epoch - 22ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0318 - mse: 0.0318\n",
      "4/4 [==============================] - 0s 646us/step - loss: 0.0350 - mse: 0.0350\n",
      "1/1 - 0s - loss: 0.0327 - mse: 0.0327 - val_loss: 0.0282 - val_mse: 0.0282 - 23ms/epoch - 23ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0309 - mse: 0.0309\n",
      "4/4 [==============================] - 0s 628us/step - loss: 0.0340 - mse: 0.0340\n",
      "1/1 - 0s - loss: 0.0318 - mse: 0.0318 - val_loss: 0.0273 - val_mse: 0.0273 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0300 - mse: 0.0300\n",
      "4/4 [==============================] - 0s 733us/step - loss: 0.0330 - mse: 0.0330\n",
      "1/1 - 0s - loss: 0.0309 - mse: 0.0309 - val_loss: 0.0266 - val_mse: 0.0266 - 26ms/epoch - 26ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0291 - mse: 0.0291\n",
      "4/4 [==============================] - 0s 963us/step - loss: 0.0320 - mse: 0.0320\n",
      "1/1 - 0s - loss: 0.0300 - mse: 0.0300 - val_loss: 0.0258 - val_mse: 0.0258 - 25ms/epoch - 25ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0283 - mse: 0.0283\n",
      "4/4 [==============================] - 0s 975us/step - loss: 0.0311 - mse: 0.0311\n",
      "1/1 - 0s - loss: 0.0292 - mse: 0.0292 - val_loss: 0.0250 - val_mse: 0.0250 - 25ms/epoch - 25ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0275 - mse: 0.0275\n",
      "4/4 [==============================] - 0s 669us/step - loss: 0.0302 - mse: 0.0302\n",
      "1/1 - 0s - loss: 0.0283 - mse: 0.0283 - val_loss: 0.0243 - val_mse: 0.0243 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 9ms/step - loss: 0.0267 - mse: 0.0267\n",
      "4/4 [==============================] - 0s 757us/step - loss: 0.0293 - mse: 0.0293\n",
      "1/1 - 0s - loss: 0.0276 - mse: 0.0276 - val_loss: 0.0236 - val_mse: 0.0236 - 27ms/epoch - 27ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0260 - mse: 0.0260\n",
      "4/4 [==============================] - 0s 576us/step - loss: 0.0285 - mse: 0.0285\n",
      "1/1 - 0s - loss: 0.0268 - mse: 0.0268 - val_loss: 0.0229 - val_mse: 0.0229 - 27ms/epoch - 27ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0253 - mse: 0.0253\n",
      "4/4 [==============================] - 0s 941us/step - loss: 0.0276 - mse: 0.0276\n",
      "1/1 - 0s - loss: 0.0260 - mse: 0.0260 - val_loss: 0.0223 - val_mse: 0.0223 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0245 - mse: 0.0245\n",
      "4/4 [==============================] - 0s 660us/step - loss: 0.0268 - mse: 0.0268\n",
      "1/1 - 0s - loss: 0.0253 - mse: 0.0253 - val_loss: 0.0217 - val_mse: 0.0217 - 23ms/epoch - 23ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0239 - mse: 0.0239\n",
      "4/4 [==============================] - 0s 612us/step - loss: 0.0261 - mse: 0.0261\n",
      "1/1 - 0s - loss: 0.0246 - mse: 0.0246 - val_loss: 0.0211 - val_mse: 0.0211 - 23ms/epoch - 23ms/step\n",
      "1/1 [==============================] - 0s 9ms/step - loss: 0.0232 - mse: 0.0232\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0253 - mse: 0.0253\n",
      "1/1 - 0s - loss: 0.0239 - mse: 0.0239 - val_loss: 0.0205 - val_mse: 0.0205 - 25ms/epoch - 25ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0225 - mse: 0.0225\n",
      "4/4 [==============================] - 0s 662us/step - loss: 0.0246 - mse: 0.0246\n",
      "1/1 - 0s - loss: 0.0232 - mse: 0.0232 - val_loss: 0.0199 - val_mse: 0.0199 - 23ms/epoch - 23ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0219 - mse: 0.0219\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0239 - mse: 0.0239\n",
      "1/1 - 0s - loss: 0.0226 - mse: 0.0226 - val_loss: 0.0193 - val_mse: 0.0193 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0213 - mse: 0.0213\n",
      "4/4 [==============================] - 0s 563us/step - loss: 0.0232 - mse: 0.0232\n",
      "1/1 - 0s - loss: 0.0220 - mse: 0.0220 - val_loss: 0.0188 - val_mse: 0.0188 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 9ms/step - loss: 0.0207 - mse: 0.0207\n",
      "4/4 [==============================] - 0s 570us/step - loss: 0.0225 - mse: 0.0225\n",
      "1/1 - 0s - loss: 0.0214 - mse: 0.0214 - val_loss: 0.0183 - val_mse: 0.0183 - 28ms/epoch - 28ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0202 - mse: 0.0202\n",
      "4/4 [==============================] - 0s 629us/step - loss: 0.0219 - mse: 0.0219\n",
      "1/1 - 0s - loss: 0.0208 - mse: 0.0208 - val_loss: 0.0178 - val_mse: 0.0178 - 22ms/epoch - 22ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0196 - mse: 0.0196\n",
      "4/4 [==============================] - 0s 566us/step - loss: 0.0213 - mse: 0.0213\n",
      "1/1 - 0s - loss: 0.0202 - mse: 0.0202 - val_loss: 0.0173 - val_mse: 0.0173 - 23ms/epoch - 23ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0191 - mse: 0.0191\n",
      "4/4 [==============================] - 0s 685us/step - loss: 0.0207 - mse: 0.0207\n",
      "1/1 - 0s - loss: 0.0196 - mse: 0.0196 - val_loss: 0.0168 - val_mse: 0.0168 - 23ms/epoch - 23ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0185 - mse: 0.0185\n",
      "4/4 [==============================] - 0s 598us/step - loss: 0.0201 - mse: 0.0201\n",
      "1/1 - 0s - loss: 0.0191 - mse: 0.0191 - val_loss: 0.0164 - val_mse: 0.0164 - 22ms/epoch - 22ms/step\n",
      "1/1 [==============================] - 0s 9ms/step - loss: 0.0180 - mse: 0.0180\n",
      "4/4 [==============================] - 0s 598us/step - loss: 0.0195 - mse: 0.0195\n",
      "1/1 - 0s - loss: 0.0186 - mse: 0.0186 - val_loss: 0.0159 - val_mse: 0.0159 - 23ms/epoch - 23ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0175 - mse: 0.0175\n",
      "4/4 [==============================] - 0s 570us/step - loss: 0.0190 - mse: 0.0190\n",
      "1/1 - 0s - loss: 0.0181 - mse: 0.0181 - val_loss: 0.0155 - val_mse: 0.0155 - 23ms/epoch - 23ms/step\n",
      "1/1 [==============================] - 0s 9ms/step - loss: 0.0171 - mse: 0.0171\n",
      "4/4 [==============================] - 0s 665us/step - loss: 0.0185 - mse: 0.0185\n",
      "1/1 - 0s - loss: 0.0176 - mse: 0.0176 - val_loss: 0.0151 - val_mse: 0.0151 - 23ms/epoch - 23ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0166 - mse: 0.0166\n",
      "4/4 [==============================] - 0s 719us/step - loss: 0.0179 - mse: 0.0179\n",
      "1/1 - 0s - loss: 0.0171 - mse: 0.0171 - val_loss: 0.0147 - val_mse: 0.0147 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0161 - mse: 0.0161\n",
      "4/4 [==============================] - 0s 906us/step - loss: 0.0175 - mse: 0.0175\n",
      "1/1 - 0s - loss: 0.0166 - mse: 0.0166 - val_loss: 0.0143 - val_mse: 0.0143 - 27ms/epoch - 27ms/step\n",
      "1/1 [==============================] - 0s 9ms/step - loss: 0.0157 - mse: 0.0157\n",
      "4/4 [==============================] - 0s 689us/step - loss: 0.0170 - mse: 0.0170\n",
      "1/1 - 0s - loss: 0.0162 - mse: 0.0162 - val_loss: 0.0139 - val_mse: 0.0139 - 23ms/epoch - 23ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0153 - mse: 0.0153\n",
      "4/4 [==============================] - 0s 663us/step - loss: 0.0165 - mse: 0.0165\n",
      "1/1 - 0s - loss: 0.0158 - mse: 0.0158 - val_loss: 0.0135 - val_mse: 0.0135 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0149 - mse: 0.0149\n",
      "4/4 [==============================] - 0s 655us/step - loss: 0.0161 - mse: 0.0161\n",
      "1/1 - 0s - loss: 0.0153 - mse: 0.0153 - val_loss: 0.0131 - val_mse: 0.0131 - 23ms/epoch - 23ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0145 - mse: 0.0145\n",
      "4/4 [==============================] - 0s 881us/step - loss: 0.0156 - mse: 0.0156\n",
      "1/1 - 0s - loss: 0.0149 - mse: 0.0149 - val_loss: 0.0128 - val_mse: 0.0128 - 25ms/epoch - 25ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0141 - mse: 0.0141\n",
      "4/4 [==============================] - 0s 698us/step - loss: 0.0152 - mse: 0.0152\n",
      "1/1 - 0s - loss: 0.0145 - mse: 0.0145 - val_loss: 0.0124 - val_mse: 0.0124 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 9ms/step - loss: 0.0137 - mse: 0.0137\n",
      "4/4 [==============================] - 0s 591us/step - loss: 0.0148 - mse: 0.0148\n",
      "1/1 - 0s - loss: 0.0141 - mse: 0.0141 - val_loss: 0.0121 - val_mse: 0.0121 - 22ms/epoch - 22ms/step\n",
      "1/1 [==============================] - 0s 9ms/step - loss: 0.0133 - mse: 0.0133\n",
      "4/4 [==============================] - 0s 896us/step - loss: 0.0144 - mse: 0.0144\n",
      "1/1 - 0s - loss: 0.0137 - mse: 0.0137 - val_loss: 0.0118 - val_mse: 0.0118 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0130 - mse: 0.0130\n",
      "4/4 [==============================] - 0s 716us/step - loss: 0.0140 - mse: 0.0140\n",
      "1/1 - 0s - loss: 0.0134 - mse: 0.0134 - val_loss: 0.0115 - val_mse: 0.0115 - 25ms/epoch - 25ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0126 - mse: 0.0126\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0136 - mse: 0.0136\n",
      "1/1 - 0s - loss: 0.0130 - mse: 0.0130 - val_loss: 0.0112 - val_mse: 0.0112 - 27ms/epoch - 27ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0123 - mse: 0.0123\n",
      "4/4 [==============================] - 0s 602us/step - loss: 0.0132 - mse: 0.0132\n",
      "1/1 - 0s - loss: 0.0127 - mse: 0.0127 - val_loss: 0.0109 - val_mse: 0.0109 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0120 - mse: 0.0120\n",
      "4/4 [==============================] - 0s 534us/step - loss: 0.0129 - mse: 0.0129\n",
      "1/1 - 0s - loss: 0.0123 - mse: 0.0123 - val_loss: 0.0106 - val_mse: 0.0106 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0117 - mse: 0.0117\n",
      "4/4 [==============================] - 0s 661us/step - loss: 0.0125 - mse: 0.0125\n",
      "1/1 - 0s - loss: 0.0120 - mse: 0.0120 - val_loss: 0.0103 - val_mse: 0.0103 - 26ms/epoch - 26ms/step\n",
      "1/1 [==============================] - 0s 9ms/step - loss: 0.0114 - mse: 0.0114\n",
      "4/4 [==============================] - 0s 558us/step - loss: 0.0122 - mse: 0.0122\n",
      "1/1 - 0s - loss: 0.0117 - mse: 0.0117 - val_loss: 0.0100 - val_mse: 0.0100 - 25ms/epoch - 25ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0111 - mse: 0.0111\n",
      "4/4 [==============================] - 0s 717us/step - loss: 0.0119 - mse: 0.0119\n",
      "1/1 - 0s - loss: 0.0114 - mse: 0.0114 - val_loss: 0.0098 - val_mse: 0.0098 - 25ms/epoch - 25ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0108 - mse: 0.0108\n",
      "4/4 [==============================] - 0s 942us/step - loss: 0.0116 - mse: 0.0116\n",
      "1/1 - 0s - loss: 0.0111 - mse: 0.0111 - val_loss: 0.0095 - val_mse: 0.0095 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0105 - mse: 0.0105\n",
      "4/4 [==============================] - 0s 637us/step - loss: 0.0113 - mse: 0.0113\n",
      "1/1 - 0s - loss: 0.0108 - mse: 0.0108 - val_loss: 0.0093 - val_mse: 0.0093 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0102 - mse: 0.0102\n",
      "4/4 [==============================] - 0s 884us/step - loss: 0.0110 - mse: 0.0110\n",
      "1/1 - 0s - loss: 0.0105 - mse: 0.0105 - val_loss: 0.0090 - val_mse: 0.0090 - 22ms/epoch - 22ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0099 - mse: 0.0099\n",
      "4/4 [==============================] - 0s 716us/step - loss: 0.0107 - mse: 0.0107\n",
      "1/1 - 0s - loss: 0.0102 - mse: 0.0102 - val_loss: 0.0088 - val_mse: 0.0088 - 30ms/epoch - 30ms/step\n",
      "1/1 [==============================] - 0s 9ms/step - loss: 0.0097 - mse: 0.0097\n",
      "4/4 [==============================] - 0s 543us/step - loss: 0.0104 - mse: 0.0104\n",
      "1/1 - 0s - loss: 0.0100 - mse: 0.0100 - val_loss: 0.0086 - val_mse: 0.0086 - 28ms/epoch - 28ms/step\n",
      "1/1 [==============================] - 0s 9ms/step - loss: 0.0094 - mse: 0.0094\n",
      "4/4 [==============================] - 0s 656us/step - loss: 0.0101 - mse: 0.0101\n",
      "1/1 - 0s - loss: 0.0097 - mse: 0.0097 - val_loss: 0.0084 - val_mse: 0.0084 - 26ms/epoch - 26ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0092 - mse: 0.0092\n",
      "4/4 [==============================] - 0s 561us/step - loss: 0.0099 - mse: 0.0099\n",
      "1/1 - 0s - loss: 0.0095 - mse: 0.0095 - val_loss: 0.0082 - val_mse: 0.0082 - 23ms/epoch - 23ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0090 - mse: 0.0090\n",
      "4/4 [==============================] - 0s 691us/step - loss: 0.0096 - mse: 0.0096\n",
      "1/1 - 0s - loss: 0.0092 - mse: 0.0092 - val_loss: 0.0080 - val_mse: 0.0080 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0087 - mse: 0.0087\n",
      "4/4 [==============================] - 0s 665us/step - loss: 0.0094 - mse: 0.0094\n",
      "1/1 - 0s - loss: 0.0090 - mse: 0.0090 - val_loss: 0.0078 - val_mse: 0.0078 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0085 - mse: 0.0085\n",
      "4/4 [==============================] - 0s 708us/step - loss: 0.0091 - mse: 0.0091\n",
      "1/1 - 0s - loss: 0.0088 - mse: 0.0088 - val_loss: 0.0076 - val_mse: 0.0076 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 9ms/step - loss: 0.0083 - mse: 0.0083\n",
      "4/4 [==============================] - 0s 694us/step - loss: 0.0089 - mse: 0.0089\n",
      "1/1 - 0s - loss: 0.0085 - mse: 0.0085 - val_loss: 0.0074 - val_mse: 0.0074 - 23ms/epoch - 23ms/step\n",
      "1/1 [==============================] - 0s 13ms/step - loss: 0.0081 - mse: 0.0081\n",
      "4/4 [==============================] - 0s 691us/step - loss: 0.0087 - mse: 0.0087\n",
      "1/1 - 0s - loss: 0.0083 - mse: 0.0083 - val_loss: 0.0072 - val_mse: 0.0072 - 25ms/epoch - 25ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0079 - mse: 0.0079\n",
      "4/4 [==============================] - 0s 761us/step - loss: 0.0085 - mse: 0.0085\n",
      "1/1 - 0s - loss: 0.0081 - mse: 0.0081 - val_loss: 0.0070 - val_mse: 0.0070 - 29ms/epoch - 29ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0077 - mse: 0.0077\n",
      "4/4 [==============================] - 0s 763us/step - loss: 0.0083 - mse: 0.0083\n",
      "1/1 - 0s - loss: 0.0079 - mse: 0.0079 - val_loss: 0.0068 - val_mse: 0.0068 - 23ms/epoch - 23ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0075 - mse: 0.0075\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0081 - mse: 0.0081\n",
      "1/1 - 0s - loss: 0.0077 - mse: 0.0077 - val_loss: 0.0067 - val_mse: 0.0067 - 25ms/epoch - 25ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0073 - mse: 0.0073\n",
      "4/4 [==============================] - 0s 680us/step - loss: 0.0079 - mse: 0.0079\n",
      "1/1 - 0s - loss: 0.0075 - mse: 0.0075 - val_loss: 0.0065 - val_mse: 0.0065 - 23ms/epoch - 23ms/step\n",
      "1/1 [==============================] - 0s 9ms/step - loss: 0.0071 - mse: 0.0071\n",
      "4/4 [==============================] - 0s 568us/step - loss: 0.0077 - mse: 0.0077\n",
      "1/1 - 0s - loss: 0.0073 - mse: 0.0073 - val_loss: 0.0064 - val_mse: 0.0064 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0069 - mse: 0.0069\n",
      "4/4 [==============================] - 0s 607us/step - loss: 0.0075 - mse: 0.0075\n",
      "1/1 - 0s - loss: 0.0071 - mse: 0.0071 - val_loss: 0.0062 - val_mse: 0.0062 - 27ms/epoch - 27ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0068 - mse: 0.0068\n",
      "4/4 [==============================] - 0s 916us/step - loss: 0.0073 - mse: 0.0073\n",
      "1/1 - 0s - loss: 0.0070 - mse: 0.0070 - val_loss: 0.0061 - val_mse: 0.0061 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0066 - mse: 0.0066\n",
      "4/4 [==============================] - 0s 869us/step - loss: 0.0071 - mse: 0.0071\n",
      "1/1 - 0s - loss: 0.0068 - mse: 0.0068 - val_loss: 0.0059 - val_mse: 0.0059 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 9ms/step - loss: 0.0064 - mse: 0.0064\n",
      "4/4 [==============================] - 0s 630us/step - loss: 0.0070 - mse: 0.0070\n",
      "1/1 - 0s - loss: 0.0066 - mse: 0.0066 - val_loss: 0.0058 - val_mse: 0.0058 - 23ms/epoch - 23ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0063 - mse: 0.0063\n",
      "4/4 [==============================] - 0s 671us/step - loss: 0.0068 - mse: 0.0068\n",
      "1/1 - 0s - loss: 0.0065 - mse: 0.0065 - val_loss: 0.0056 - val_mse: 0.0056 - 27ms/epoch - 27ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0061 - mse: 0.0061\n",
      "4/4 [==============================] - 0s 732us/step - loss: 0.0066 - mse: 0.0066\n",
      "1/1 - 0s - loss: 0.0063 - mse: 0.0063 - val_loss: 0.0055 - val_mse: 0.0055 - 28ms/epoch - 28ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0060 - mse: 0.0060\n",
      "4/4 [==============================] - 0s 615us/step - loss: 0.0065 - mse: 0.0065\n",
      "1/1 - 0s - loss: 0.0062 - mse: 0.0062 - val_loss: 0.0054 - val_mse: 0.0054 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0059 - mse: 0.0059\n",
      "4/4 [==============================] - 0s 579us/step - loss: 0.0063 - mse: 0.0063\n",
      "1/1 - 0s - loss: 0.0060 - mse: 0.0060 - val_loss: 0.0053 - val_mse: 0.0053 - 23ms/epoch - 23ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0057 - mse: 0.0057\n",
      "4/4 [==============================] - 0s 616us/step - loss: 0.0062 - mse: 0.0062\n",
      "1/1 - 0s - loss: 0.0059 - mse: 0.0059 - val_loss: 0.0051 - val_mse: 0.0051 - 23ms/epoch - 23ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0056 - mse: 0.0056\n",
      "4/4 [==============================] - 0s 831us/step - loss: 0.0060 - mse: 0.0060\n",
      "1/1 - 0s - loss: 0.0057 - mse: 0.0057 - val_loss: 0.0050 - val_mse: 0.0050 - 26ms/epoch - 26ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0054 - mse: 0.0054\n",
      "4/4 [==============================] - 0s 611us/step - loss: 0.0059 - mse: 0.0059\n",
      "1/1 - 0s - loss: 0.0056 - mse: 0.0056 - val_loss: 0.0049 - val_mse: 0.0049 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0053 - mse: 0.0053\n",
      "4/4 [==============================] - 0s 618us/step - loss: 0.0058 - mse: 0.0058\n",
      "1/1 - 0s - loss: 0.0055 - mse: 0.0055 - val_loss: 0.0048 - val_mse: 0.0048 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0052 - mse: 0.0052\n",
      "4/4 [==============================] - 0s 627us/step - loss: 0.0056 - mse: 0.0056\n",
      "1/1 - 0s - loss: 0.0053 - mse: 0.0053 - val_loss: 0.0047 - val_mse: 0.0047 - 23ms/epoch - 23ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0051 - mse: 0.0051\n",
      "4/4 [==============================] - 0s 563us/step - loss: 0.0055 - mse: 0.0055\n",
      "1/1 - 0s - loss: 0.0052 - mse: 0.0052 - val_loss: 0.0046 - val_mse: 0.0046 - 28ms/epoch - 28ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0050 - mse: 0.0050\n",
      "4/4 [==============================] - 0s 685us/step - loss: 0.0054 - mse: 0.0054\n",
      "1/1 - 0s - loss: 0.0051 - mse: 0.0051 - val_loss: 0.0045 - val_mse: 0.0045 - 28ms/epoch - 28ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0049 - mse: 0.0049\n",
      "4/4 [==============================] - 0s 594us/step - loss: 0.0053 - mse: 0.0053\n",
      "1/1 - 0s - loss: 0.0050 - mse: 0.0050 - val_loss: 0.0044 - val_mse: 0.0044 - 25ms/epoch - 25ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0047 - mse: 0.0047\n",
      "4/4 [==============================] - 0s 701us/step - loss: 0.0052 - mse: 0.0052\n",
      "1/1 - 0s - loss: 0.0049 - mse: 0.0049 - val_loss: 0.0043 - val_mse: 0.0043 - 25ms/epoch - 25ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0046 - mse: 0.0046\n",
      "4/4 [==============================] - 0s 606us/step - loss: 0.0051 - mse: 0.0051\n",
      "1/1 - 0s - loss: 0.0047 - mse: 0.0047 - val_loss: 0.0042 - val_mse: 0.0042 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0045 - mse: 0.0045\n",
      "4/4 [==============================] - 0s 677us/step - loss: 0.0050 - mse: 0.0050\n",
      "1/1 - 0s - loss: 0.0046 - mse: 0.0046 - val_loss: 0.0041 - val_mse: 0.0041 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0044 - mse: 0.0044\n",
      "4/4 [==============================] - 0s 592us/step - loss: 0.0048 - mse: 0.0048\n",
      "1/1 - 0s - loss: 0.0045 - mse: 0.0045 - val_loss: 0.0041 - val_mse: 0.0041 - 26ms/epoch - 26ms/step\n",
      "1/1 [==============================] - 0s 9ms/step - loss: 0.0043 - mse: 0.0043\n",
      "4/4 [==============================] - 0s 574us/step - loss: 0.0048 - mse: 0.0048\n",
      "1/1 - 0s - loss: 0.0044 - mse: 0.0044 - val_loss: 0.0040 - val_mse: 0.0040 - 27ms/epoch - 27ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0042 - mse: 0.0042\n",
      "4/4 [==============================] - 0s 685us/step - loss: 0.0047 - mse: 0.0047\n",
      "1/1 - 0s - loss: 0.0043 - mse: 0.0043 - val_loss: 0.0039 - val_mse: 0.0039 - 22ms/epoch - 22ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0042 - mse: 0.0042\n",
      "4/4 [==============================] - 0s 809us/step - loss: 0.0046 - mse: 0.0046\n",
      "1/1 - 0s - loss: 0.0042 - mse: 0.0042 - val_loss: 0.0038 - val_mse: 0.0038 - 22ms/epoch - 22ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0041 - mse: 0.0041\n",
      "4/4 [==============================] - 0s 734us/step - loss: 0.0045 - mse: 0.0045\n",
      "1/1 - 0s - loss: 0.0042 - mse: 0.0042 - val_loss: 0.0038 - val_mse: 0.0038 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0040 - mse: 0.0040\n",
      "4/4 [==============================] - 0s 567us/step - loss: 0.0044 - mse: 0.0044\n",
      "1/1 - 0s - loss: 0.0041 - mse: 0.0041 - val_loss: 0.0037 - val_mse: 0.0037 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0039 - mse: 0.0039\n",
      "4/4 [==============================] - 0s 651us/step - loss: 0.0043 - mse: 0.0043\n",
      "1/1 - 0s - loss: 0.0040 - mse: 0.0040 - val_loss: 0.0036 - val_mse: 0.0036 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0038 - mse: 0.0038\n",
      "4/4 [==============================] - 0s 689us/step - loss: 0.0042 - mse: 0.0042\n",
      "1/1 - 0s - loss: 0.0039 - mse: 0.0039 - val_loss: 0.0035 - val_mse: 0.0035 - 25ms/epoch - 25ms/step\n",
      "1/1 [==============================] - 0s 9ms/step - loss: 0.0037 - mse: 0.0037\n",
      "4/4 [==============================] - 0s 581us/step - loss: 0.0041 - mse: 0.0041\n",
      "1/1 - 0s - loss: 0.0038 - mse: 0.0038 - val_loss: 0.0035 - val_mse: 0.0035 - 26ms/epoch - 26ms/step\n",
      "1/1 [==============================] - 0s 9ms/step - loss: 0.0037 - mse: 0.0037\n",
      "4/4 [==============================] - 0s 637us/step - loss: 0.0041 - mse: 0.0041\n",
      "1/1 - 0s - loss: 0.0037 - mse: 0.0037 - val_loss: 0.0034 - val_mse: 0.0034 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0036 - mse: 0.0036\n",
      "4/4 [==============================] - 0s 623us/step - loss: 0.0040 - mse: 0.0040\n",
      "1/1 - 0s - loss: 0.0037 - mse: 0.0037 - val_loss: 0.0034 - val_mse: 0.0034 - 28ms/epoch - 28ms/step\n",
      "1/1 [==============================] - 0s 9ms/step - loss: 0.0035 - mse: 0.0035\n",
      "4/4 [==============================] - 0s 681us/step - loss: 0.0039 - mse: 0.0039\n",
      "1/1 - 0s - loss: 0.0036 - mse: 0.0036 - val_loss: 0.0033 - val_mse: 0.0033 - 23ms/epoch - 23ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0035 - mse: 0.0035\n",
      "4/4 [==============================] - 0s 630us/step - loss: 0.0039 - mse: 0.0039\n",
      "1/1 - 0s - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0032 - val_mse: 0.0032 - 23ms/epoch - 23ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0034 - mse: 0.0034\n",
      "4/4 [==============================] - 0s 820us/step - loss: 0.0038 - mse: 0.0038\n",
      "1/1 - 0s - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0032 - val_mse: 0.0032 - 27ms/epoch - 27ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0033 - mse: 0.0033\n",
      "4/4 [==============================] - 0s 535us/step - loss: 0.0037 - mse: 0.0037\n",
      "1/1 - 0s - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0031 - val_mse: 0.0031 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0033 - mse: 0.0033\n",
      "4/4 [==============================] - 0s 661us/step - loss: 0.0037 - mse: 0.0037\n",
      "1/1 - 0s - loss: 0.0033 - mse: 0.0033 - val_loss: 0.0031 - val_mse: 0.0031 - 26ms/epoch - 26ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0032 - mse: 0.0032\n",
      "4/4 [==============================] - 0s 619us/step - loss: 0.0036 - mse: 0.0036\n",
      "1/1 - 0s - loss: 0.0033 - mse: 0.0033 - val_loss: 0.0030 - val_mse: 0.0030 - 23ms/epoch - 23ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0032 - mse: 0.0032\n",
      "4/4 [==============================] - 0s 646us/step - loss: 0.0035 - mse: 0.0035\n",
      "1/1 - 0s - loss: 0.0032 - mse: 0.0032 - val_loss: 0.0030 - val_mse: 0.0030 - 23ms/epoch - 23ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0031 - mse: 0.0031\n",
      "4/4 [==============================] - 0s 778us/step - loss: 0.0035 - mse: 0.0035\n",
      "1/1 - 0s - loss: 0.0031 - mse: 0.0031 - val_loss: 0.0029 - val_mse: 0.0029 - 25ms/epoch - 25ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0030 - mse: 0.0030\n",
      "4/4 [==============================] - 0s 974us/step - loss: 0.0034 - mse: 0.0034\n",
      "1/1 - 0s - loss: 0.0031 - mse: 0.0031 - val_loss: 0.0029 - val_mse: 0.0029 - 27ms/epoch - 27ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0030 - mse: 0.0030\n",
      "4/4 [==============================] - 0s 629us/step - loss: 0.0034 - mse: 0.0034\n",
      "1/1 - 0s - loss: 0.0030 - mse: 0.0030 - val_loss: 0.0029 - val_mse: 0.0029 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 9ms/step - loss: 0.0029 - mse: 0.0029\n",
      "4/4 [==============================] - 0s 624us/step - loss: 0.0033 - mse: 0.0033\n",
      "1/1 - 0s - loss: 0.0030 - mse: 0.0030 - val_loss: 0.0028 - val_mse: 0.0028 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 9ms/step - loss: 0.0029 - mse: 0.0029\n",
      "4/4 [==============================] - 0s 695us/step - loss: 0.0033 - mse: 0.0033\n",
      "1/1 - 0s - loss: 0.0029 - mse: 0.0029 - val_loss: 0.0028 - val_mse: 0.0028 - 27ms/epoch - 27ms/step\n",
      "1/1 [==============================] - 0s 9ms/step - loss: 0.0028 - mse: 0.0028\n",
      "4/4 [==============================] - 0s 580us/step - loss: 0.0032 - mse: 0.0032\n",
      "1/1 - 0s - loss: 0.0029 - mse: 0.0029 - val_loss: 0.0027 - val_mse: 0.0027 - 23ms/epoch - 23ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0028 - mse: 0.0028\n",
      "4/4 [==============================] - 0s 727us/step - loss: 0.0032 - mse: 0.0032\n",
      "1/1 - 0s - loss: 0.0028 - mse: 0.0028 - val_loss: 0.0027 - val_mse: 0.0027 - 25ms/epoch - 25ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0028 - mse: 0.0028\n",
      "4/4 [==============================] - 0s 640us/step - loss: 0.0031 - mse: 0.0031\n",
      "1/1 - 0s - loss: 0.0028 - mse: 0.0028 - val_loss: 0.0027 - val_mse: 0.0027 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0027 - mse: 0.0027\n",
      "4/4 [==============================] - 0s 643us/step - loss: 0.0031 - mse: 0.0031\n",
      "1/1 - 0s - loss: 0.0027 - mse: 0.0027 - val_loss: 0.0026 - val_mse: 0.0026 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0027 - mse: 0.0027\n",
      "4/4 [==============================] - 0s 569us/step - loss: 0.0031 - mse: 0.0031\n",
      "1/1 - 0s - loss: 0.0027 - mse: 0.0027 - val_loss: 0.0026 - val_mse: 0.0026 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 9ms/step - loss: 0.0026 - mse: 0.0026\n",
      "4/4 [==============================] - 0s 572us/step - loss: 0.0030 - mse: 0.0030\n",
      "1/1 - 0s - loss: 0.0026 - mse: 0.0026 - val_loss: 0.0026 - val_mse: 0.0026 - 28ms/epoch - 28ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0026 - mse: 0.0026\n",
      "4/4 [==============================] - 0s 773us/step - loss: 0.0030 - mse: 0.0030\n",
      "1/1 - 0s - loss: 0.0026 - mse: 0.0026 - val_loss: 0.0025 - val_mse: 0.0025 - 25ms/epoch - 25ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0026 - mse: 0.0026\n",
      "4/4 [==============================] - 0s 643us/step - loss: 0.0029 - mse: 0.0029\n",
      "1/1 - 0s - loss: 0.0026 - mse: 0.0026 - val_loss: 0.0025 - val_mse: 0.0025 - 25ms/epoch - 25ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0025 - mse: 0.0025\n",
      "4/4 [==============================] - 0s 716us/step - loss: 0.0029 - mse: 0.0029\n",
      "1/1 - 0s - loss: 0.0025 - mse: 0.0025 - val_loss: 0.0025 - val_mse: 0.0025 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0025 - mse: 0.0025\n",
      "4/4 [==============================] - 0s 579us/step - loss: 0.0029 - mse: 0.0029\n",
      "1/1 - 0s - loss: 0.0025 - mse: 0.0025 - val_loss: 0.0024 - val_mse: 0.0024 - 25ms/epoch - 25ms/step\n",
      "1/1 [==============================] - 0s 9ms/step - loss: 0.0024 - mse: 0.0024\n",
      "4/4 [==============================] - 0s 732us/step - loss: 0.0028 - mse: 0.0028\n",
      "1/1 - 0s - loss: 0.0025 - mse: 0.0025 - val_loss: 0.0024 - val_mse: 0.0024 - 23ms/epoch - 23ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0024 - mse: 0.0024\n",
      "4/4 [==============================] - 0s 676us/step - loss: 0.0028 - mse: 0.0028\n",
      "1/1 - 0s - loss: 0.0024 - mse: 0.0024 - val_loss: 0.0024 - val_mse: 0.0024 - 23ms/epoch - 23ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0024 - mse: 0.0024\n",
      "4/4 [==============================] - 0s 698us/step - loss: 0.0028 - mse: 0.0028\n",
      "1/1 - 0s - loss: 0.0024 - mse: 0.0024 - val_loss: 0.0024 - val_mse: 0.0024 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 9ms/step - loss: 0.0024 - mse: 0.0024\n",
      "4/4 [==============================] - 0s 760us/step - loss: 0.0028 - mse: 0.0028\n",
      "1/1 - 0s - loss: 0.0024 - mse: 0.0024 - val_loss: 0.0023 - val_mse: 0.0023 - 25ms/epoch - 25ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0023 - mse: 0.0023\n",
      "4/4 [==============================] - 0s 689us/step - loss: 0.0027 - mse: 0.0027\n",
      "1/1 - 0s - loss: 0.0023 - mse: 0.0023 - val_loss: 0.0023 - val_mse: 0.0023 - 28ms/epoch - 28ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0023 - mse: 0.0023\n",
      "4/4 [==============================] - 0s 562us/step - loss: 0.0027 - mse: 0.0027\n",
      "1/1 - 0s - loss: 0.0023 - mse: 0.0023 - val_loss: 0.0023 - val_mse: 0.0023 - 23ms/epoch - 23ms/step\n",
      "1/1 [==============================] - 0s 9ms/step - loss: 0.0023 - mse: 0.0023\n",
      "4/4 [==============================] - 0s 640us/step - loss: 0.0027 - mse: 0.0027\n",
      "1/1 - 0s - loss: 0.0023 - mse: 0.0023 - val_loss: 0.0023 - val_mse: 0.0023 - 23ms/epoch - 23ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0022 - mse: 0.0022\n",
      "4/4 [==============================] - 0s 777us/step - loss: 0.0027 - mse: 0.0027\n",
      "1/1 - 0s - loss: 0.0022 - mse: 0.0022 - val_loss: 0.0022 - val_mse: 0.0022 - 27ms/epoch - 27ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0022 - mse: 0.0022\n",
      "4/4 [==============================] - 0s 622us/step - loss: 0.0026 - mse: 0.0026\n",
      "1/1 - 0s - loss: 0.0022 - mse: 0.0022 - val_loss: 0.0022 - val_mse: 0.0022 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0022 - mse: 0.0022\n",
      "4/4 [==============================] - 0s 627us/step - loss: 0.0026 - mse: 0.0026\n",
      "1/1 - 0s - loss: 0.0022 - mse: 0.0022 - val_loss: 0.0022 - val_mse: 0.0022 - 25ms/epoch - 25ms/step\n",
      "1/1 [==============================] - 0s 9ms/step - loss: 0.0022 - mse: 0.0022\n",
      "4/4 [==============================] - 0s 719us/step - loss: 0.0026 - mse: 0.0026\n",
      "1/1 - 0s - loss: 0.0022 - mse: 0.0022 - val_loss: 0.0022 - val_mse: 0.0022 - 26ms/epoch - 26ms/step\n",
      "1/1 [==============================] - 0s 9ms/step - loss: 0.0021 - mse: 0.0021\n",
      "4/4 [==============================] - 0s 554us/step - loss: 0.0026 - mse: 0.0026\n",
      "1/1 - 0s - loss: 0.0021 - mse: 0.0021 - val_loss: 0.0022 - val_mse: 0.0022 - 23ms/epoch - 23ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0021 - mse: 0.0021\n",
      "4/4 [==============================] - 0s 637us/step - loss: 0.0025 - mse: 0.0025\n",
      "1/1 - 0s - loss: 0.0021 - mse: 0.0021 - val_loss: 0.0022 - val_mse: 0.0022 - 26ms/epoch - 26ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0021 - mse: 0.0021\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0025 - mse: 0.0025\n",
      "1/1 - 0s - loss: 0.0021 - mse: 0.0021 - val_loss: 0.0021 - val_mse: 0.0021 - 27ms/epoch - 27ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0021 - mse: 0.0021\n",
      "4/4 [==============================] - 0s 642us/step - loss: 0.0025 - mse: 0.0025\n",
      "1/1 - 0s - loss: 0.0021 - mse: 0.0021 - val_loss: 0.0021 - val_mse: 0.0021 - 23ms/epoch - 23ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0021 - mse: 0.0021\n",
      "4/4 [==============================] - 0s 565us/step - loss: 0.0025 - mse: 0.0025\n",
      "1/1 - 0s - loss: 0.0020 - mse: 0.0020 - val_loss: 0.0021 - val_mse: 0.0021 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 9ms/step - loss: 0.0020 - mse: 0.0020\n",
      "4/4 [==============================] - 0s 794us/step - loss: 0.0025 - mse: 0.0025\n",
      "1/1 - 0s - loss: 0.0020 - mse: 0.0020 - val_loss: 0.0021 - val_mse: 0.0021 - 28ms/epoch - 28ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0020 - mse: 0.0020\n",
      "4/4 [==============================] - 0s 665us/step - loss: 0.0024 - mse: 0.0024\n",
      "1/1 - 0s - loss: 0.0020 - mse: 0.0020 - val_loss: 0.0021 - val_mse: 0.0021 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0020 - mse: 0.0020\n",
      "4/4 [==============================] - 0s 829us/step - loss: 0.0024 - mse: 0.0024\n",
      "1/1 - 0s - loss: 0.0020 - mse: 0.0020 - val_loss: 0.0021 - val_mse: 0.0021 - 26ms/epoch - 26ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0020 - mse: 0.0020\n",
      "4/4 [==============================] - 0s 848us/step - loss: 0.0024 - mse: 0.0024\n",
      "1/1 - 0s - loss: 0.0020 - mse: 0.0020 - val_loss: 0.0020 - val_mse: 0.0020 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0020 - mse: 0.0020\n",
      "4/4 [==============================] - 0s 853us/step - loss: 0.0024 - mse: 0.0024\n",
      "1/1 - 0s - loss: 0.0020 - mse: 0.0020 - val_loss: 0.0020 - val_mse: 0.0020 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0020 - mse: 0.0020\n",
      "4/4 [==============================] - 0s 599us/step - loss: 0.0024 - mse: 0.0024\n",
      "1/1 - 0s - loss: 0.0019 - mse: 0.0019 - val_loss: 0.0020 - val_mse: 0.0020 - 23ms/epoch - 23ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0019 - mse: 0.0019\n",
      "4/4 [==============================] - 0s 583us/step - loss: 0.0024 - mse: 0.0024\n",
      "1/1 - 0s - loss: 0.0019 - mse: 0.0019 - val_loss: 0.0020 - val_mse: 0.0020 - 27ms/epoch - 27ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0019 - mse: 0.0019\n",
      "4/4 [==============================] - 0s 999us/step - loss: 0.0024 - mse: 0.0024\n",
      "1/1 - 0s - loss: 0.0019 - mse: 0.0019 - val_loss: 0.0020 - val_mse: 0.0020 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 13ms/step - loss: 0.0019 - mse: 0.0019\n",
      "4/4 [==============================] - 0s 662us/step - loss: 0.0023 - mse: 0.0023\n",
      "1/1 - 0s - loss: 0.0019 - mse: 0.0019 - val_loss: 0.0020 - val_mse: 0.0020 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 9ms/step - loss: 0.0019 - mse: 0.0019\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0023 - mse: 0.0023\n",
      "1/1 - 0s - loss: 0.0019 - mse: 0.0019 - val_loss: 0.0020 - val_mse: 0.0020 - 29ms/epoch - 29ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0019 - mse: 0.0019\n",
      "4/4 [==============================] - 0s 574us/step - loss: 0.0023 - mse: 0.0023\n",
      "1/1 - 0s - loss: 0.0019 - mse: 0.0019 - val_loss: 0.0020 - val_mse: 0.0020 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0019 - mse: 0.0019\n",
      "4/4 [==============================] - 0s 899us/step - loss: 0.0023 - mse: 0.0023\n",
      "1/1 - 0s - loss: 0.0018 - mse: 0.0018 - val_loss: 0.0020 - val_mse: 0.0020 - 25ms/epoch - 25ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0019 - mse: 0.0019\n",
      "4/4 [==============================] - 0s 640us/step - loss: 0.0023 - mse: 0.0023\n",
      "1/1 - 0s - loss: 0.0018 - mse: 0.0018 - val_loss: 0.0019 - val_mse: 0.0019 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0018 - mse: 0.0018\n",
      "4/4 [==============================] - 0s 622us/step - loss: 0.0023 - mse: 0.0023\n",
      "1/1 - 0s - loss: 0.0018 - mse: 0.0018 - val_loss: 0.0019 - val_mse: 0.0019 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0018 - mse: 0.0018\n",
      "4/4 [==============================] - 0s 651us/step - loss: 0.0023 - mse: 0.0023\n",
      "1/1 - 0s - loss: 0.0018 - mse: 0.0018 - val_loss: 0.0019 - val_mse: 0.0019 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0018 - mse: 0.0018\n",
      "4/4 [==============================] - 0s 2ms/step - loss: 0.0023 - mse: 0.0023\n",
      "1/1 - 0s - loss: 0.0018 - mse: 0.0018 - val_loss: 0.0019 - val_mse: 0.0019 - 31ms/epoch - 31ms/step\n",
      "1/1 [==============================] - 0s 9ms/step - loss: 0.0018 - mse: 0.0018\n",
      "4/4 [==============================] - 0s 638us/step - loss: 0.0023 - mse: 0.0023\n",
      "1/1 - 0s - loss: 0.0018 - mse: 0.0018 - val_loss: 0.0019 - val_mse: 0.0019 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0018 - mse: 0.0018\n",
      "4/4 [==============================] - 0s 685us/step - loss: 0.0022 - mse: 0.0022\n",
      "1/1 - 0s - loss: 0.0018 - mse: 0.0018 - val_loss: 0.0019 - val_mse: 0.0019 - 25ms/epoch - 25ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0018 - mse: 0.0018\n",
      "4/4 [==============================] - 0s 888us/step - loss: 0.0022 - mse: 0.0022\n",
      "1/1 - 0s - loss: 0.0018 - mse: 0.0018 - val_loss: 0.0019 - val_mse: 0.0019 - 25ms/epoch - 25ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0018 - mse: 0.0018\n",
      "4/4 [==============================] - 0s 903us/step - loss: 0.0022 - mse: 0.0022\n",
      "1/1 - 0s - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0019 - val_mse: 0.0019 - 36ms/epoch - 36ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0018 - mse: 0.0018\n",
      "4/4 [==============================] - 0s 897us/step - loss: 0.0022 - mse: 0.0022\n",
      "1/1 - 0s - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0019 - val_mse: 0.0019 - 28ms/epoch - 28ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0018 - mse: 0.0018\n",
      "4/4 [==============================] - 0s 920us/step - loss: 0.0022 - mse: 0.0022\n",
      "1/1 - 0s - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0019 - val_mse: 0.0019 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0018 - mse: 0.0018\n",
      "4/4 [==============================] - 0s 558us/step - loss: 0.0022 - mse: 0.0022\n",
      "1/1 - 0s - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0019 - val_mse: 0.0019 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0018 - mse: 0.0018\n",
      "4/4 [==============================] - 0s 694us/step - loss: 0.0022 - mse: 0.0022\n",
      "1/1 - 0s - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0019 - val_mse: 0.0019 - 28ms/epoch - 28ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0017 - mse: 0.0017\n",
      "4/4 [==============================] - 0s 588us/step - loss: 0.0022 - mse: 0.0022\n",
      "1/1 - 0s - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0019 - val_mse: 0.0019 - 29ms/epoch - 29ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0017 - mse: 0.0017\n",
      "4/4 [==============================] - 0s 695us/step - loss: 0.0022 - mse: 0.0022\n",
      "1/1 - 0s - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0019 - val_mse: 0.0019 - 23ms/epoch - 23ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0017 - mse: 0.0017\n",
      "4/4 [==============================] - 0s 891us/step - loss: 0.0022 - mse: 0.0022\n",
      "1/1 - 0s - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0018 - val_mse: 0.0018 - 23ms/epoch - 23ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0017 - mse: 0.0017\n",
      "4/4 [==============================] - 0s 632us/step - loss: 0.0022 - mse: 0.0022\n",
      "1/1 - 0s - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0018 - val_mse: 0.0018 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0017 - mse: 0.0017\n",
      "4/4 [==============================] - 0s 660us/step - loss: 0.0022 - mse: 0.0022\n",
      "1/1 - 0s - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0018 - val_mse: 0.0018 - 26ms/epoch - 26ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0017 - mse: 0.0017\n",
      "4/4 [==============================] - 0s 600us/step - loss: 0.0022 - mse: 0.0022\n",
      "1/1 - 0s - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0018 - val_mse: 0.0018 - 28ms/epoch - 28ms/step\n",
      "1/1 [==============================] - 0s 13ms/step - loss: 0.0017 - mse: 0.0017\n",
      "4/4 [==============================] - 0s 735us/step - loss: 0.0022 - mse: 0.0022\n",
      "1/1 - 0s - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0018 - val_mse: 0.0018 - 31ms/epoch - 31ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0017 - mse: 0.0017\n",
      "4/4 [==============================] - 0s 2ms/step - loss: 0.0022 - mse: 0.0022\n",
      "1/1 - 0s - loss: 0.0016 - mse: 0.0016 - val_loss: 0.0018 - val_mse: 0.0018 - 33ms/epoch - 33ms/step\n",
      "1/1 [==============================] - 0s 15ms/step - loss: 0.0017 - mse: 0.0017\n",
      "4/4 [==============================] - 0s 689us/step - loss: 0.0021 - mse: 0.0021\n",
      "1/1 - 0s - loss: 0.0016 - mse: 0.0016 - val_loss: 0.0018 - val_mse: 0.0018 - 26ms/epoch - 26ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0017 - mse: 0.0017\n",
      "4/4 [==============================] - 0s 2ms/step - loss: 0.0021 - mse: 0.0021\n",
      "1/1 - 0s - loss: 0.0016 - mse: 0.0016 - val_loss: 0.0018 - val_mse: 0.0018 - 38ms/epoch - 38ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0017 - mse: 0.0017\n",
      "4/4 [==============================] - 0s 790us/step - loss: 0.0021 - mse: 0.0021\n",
      "1/1 - 0s - loss: 0.0016 - mse: 0.0016 - val_loss: 0.0018 - val_mse: 0.0018 - 28ms/epoch - 28ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0017 - mse: 0.0017\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0021 - mse: 0.0021\n",
      "1/1 - 0s - loss: 0.0016 - mse: 0.0016 - val_loss: 0.0018 - val_mse: 0.0018 - 29ms/epoch - 29ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0017 - mse: 0.0017\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0021 - mse: 0.0021\n",
      "1/1 - 0s - loss: 0.0016 - mse: 0.0016 - val_loss: 0.0018 - val_mse: 0.0018 - 28ms/epoch - 28ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0017 - mse: 0.0017\n",
      "4/4 [==============================] - 0s 707us/step - loss: 0.0021 - mse: 0.0021\n",
      "1/1 - 0s - loss: 0.0016 - mse: 0.0016 - val_loss: 0.0018 - val_mse: 0.0018 - 31ms/epoch - 31ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0017 - mse: 0.0017\n",
      "4/4 [==============================] - 0s 646us/step - loss: 0.0021 - mse: 0.0021\n",
      "1/1 - 0s - loss: 0.0016 - mse: 0.0016 - val_loss: 0.0018 - val_mse: 0.0018 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0016 - mse: 0.0016\n",
      "4/4 [==============================] - 0s 951us/step - loss: 0.0021 - mse: 0.0021\n",
      "1/1 - 0s - loss: 0.0016 - mse: 0.0016 - val_loss: 0.0018 - val_mse: 0.0018 - 25ms/epoch - 25ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0016 - mse: 0.0016\n",
      "4/4 [==============================] - 0s 826us/step - loss: 0.0021 - mse: 0.0021\n",
      "1/1 - 0s - loss: 0.0016 - mse: 0.0016 - val_loss: 0.0018 - val_mse: 0.0018 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0016 - mse: 0.0016\n",
      "4/4 [==============================] - 0s 937us/step - loss: 0.0021 - mse: 0.0021\n",
      "1/1 - 0s - loss: 0.0016 - mse: 0.0016 - val_loss: 0.0018 - val_mse: 0.0018 - 28ms/epoch - 28ms/step\n",
      "1/1 [==============================] - 0s 15ms/step - loss: 0.0016 - mse: 0.0016\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0021 - mse: 0.0021\n",
      "1/1 - 0s - loss: 0.0016 - mse: 0.0016 - val_loss: 0.0018 - val_mse: 0.0018 - 33ms/epoch - 33ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0016 - mse: 0.0016\n",
      "4/4 [==============================] - 0s 734us/step - loss: 0.0021 - mse: 0.0021\n",
      "1/1 - 0s - loss: 0.0016 - mse: 0.0016 - val_loss: 0.0018 - val_mse: 0.0018 - 26ms/epoch - 26ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0016 - mse: 0.0016\n",
      "4/4 [==============================] - 0s 948us/step - loss: 0.0021 - mse: 0.0021\n",
      "1/1 - 0s - loss: 0.0016 - mse: 0.0016 - val_loss: 0.0018 - val_mse: 0.0018 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0016 - mse: 0.0016\n",
      "4/4 [==============================] - 0s 646us/step - loss: 0.0021 - mse: 0.0021\n",
      "1/1 - 0s - loss: 0.0016 - mse: 0.0016 - val_loss: 0.0018 - val_mse: 0.0018 - 23ms/epoch - 23ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0016 - mse: 0.0016\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0021 - mse: 0.0021\n",
      "1/1 - 0s - loss: 0.0016 - mse: 0.0016 - val_loss: 0.0018 - val_mse: 0.0018 - 25ms/epoch - 25ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0016 - mse: 0.0016\n",
      "4/4 [==============================] - 0s 578us/step - loss: 0.0021 - mse: 0.0021\n",
      "1/1 - 0s - loss: 0.0016 - mse: 0.0016 - val_loss: 0.0018 - val_mse: 0.0018 - 27ms/epoch - 27ms/step\n",
      "1/1 [==============================] - 0s 13ms/step - loss: 0.0016 - mse: 0.0016\n",
      "4/4 [==============================] - 0s 766us/step - loss: 0.0021 - mse: 0.0021\n",
      "1/1 - 0s - loss: 0.0016 - mse: 0.0016 - val_loss: 0.0018 - val_mse: 0.0018 - 33ms/epoch - 33ms/step\n",
      "1/1 [==============================] - 0s 16ms/step - loss: 0.0016 - mse: 0.0016\n",
      "4/4 [==============================] - 0s 963us/step - loss: 0.0021 - mse: 0.0021\n",
      "1/1 - 0s - loss: 0.0016 - mse: 0.0016 - val_loss: 0.0018 - val_mse: 0.0018 - 25ms/epoch - 25ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0016 - mse: 0.0016\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0021 - mse: 0.0021\n",
      "1/1 - 0s - loss: 0.0016 - mse: 0.0016 - val_loss: 0.0018 - val_mse: 0.0018 - 29ms/epoch - 29ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0016 - mse: 0.0016\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0021 - mse: 0.0021\n",
      "1/1 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0017 - val_mse: 0.0017 - 36ms/epoch - 36ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0016 - mse: 0.0016\n",
      "4/4 [==============================] - 0s 791us/step - loss: 0.0021 - mse: 0.0021\n",
      "1/1 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0017 - val_mse: 0.0017 - 27ms/epoch - 27ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0016 - mse: 0.0016\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0021 - mse: 0.0021\n",
      "1/1 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0017 - val_mse: 0.0017 - 28ms/epoch - 28ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0016 - mse: 0.0016\n",
      "4/4 [==============================] - 0s 617us/step - loss: 0.0021 - mse: 0.0021\n",
      "1/1 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0017 - val_mse: 0.0017 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0016 - mse: 0.0016\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0021 - mse: 0.0021\n",
      "1/1 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0017 - val_mse: 0.0017 - 26ms/epoch - 26ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0016 - mse: 0.0016\n",
      "4/4 [==============================] - 0s 729us/step - loss: 0.0021 - mse: 0.0021\n",
      "1/1 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0017 - val_mse: 0.0017 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0016 - mse: 0.0016\n",
      "4/4 [==============================] - 0s 590us/step - loss: 0.0020 - mse: 0.0020\n",
      "1/1 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0017 - val_mse: 0.0017 - 27ms/epoch - 27ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0016 - mse: 0.0016\n",
      "4/4 [==============================] - 0s 641us/step - loss: 0.0020 - mse: 0.0020\n",
      "1/1 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0017 - val_mse: 0.0017 - 25ms/epoch - 25ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0016 - mse: 0.0016\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0020 - mse: 0.0020\n",
      "1/1 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0017 - val_mse: 0.0017 - 34ms/epoch - 34ms/step\n",
      "1/1 [==============================] - 0s 13ms/step - loss: 0.0016 - mse: 0.0016\n",
      "4/4 [==============================] - 0s 980us/step - loss: 0.0020 - mse: 0.0020\n",
      "1/1 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0017 - val_mse: 0.0017 - 32ms/epoch - 32ms/step\n",
      "1/1 [==============================] - 0s 9ms/step - loss: 0.0016 - mse: 0.0016\n",
      "4/4 [==============================] - 0s 646us/step - loss: 0.0020 - mse: 0.0020\n",
      "1/1 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0017 - val_mse: 0.0017 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0016 - mse: 0.0016\n",
      "4/4 [==============================] - 0s 591us/step - loss: 0.0020 - mse: 0.0020\n",
      "1/1 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0017 - val_mse: 0.0017 - 27ms/epoch - 27ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0016 - mse: 0.0016\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0020 - mse: 0.0020\n",
      "1/1 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0017 - val_mse: 0.0017 - 27ms/epoch - 27ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0016 - mse: 0.0016\n",
      "4/4 [==============================] - 0s 661us/step - loss: 0.0020 - mse: 0.0020\n",
      "1/1 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0017 - val_mse: 0.0017 - 26ms/epoch - 26ms/step\n",
      "1/1 [==============================] - 0s 14ms/step - loss: 0.0016 - mse: 0.0016\n",
      "4/4 [==============================] - 0s 675us/step - loss: 0.0020 - mse: 0.0020\n",
      "1/1 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0017 - val_mse: 0.0017 - 29ms/epoch - 29ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0016 - mse: 0.0016\n",
      "4/4 [==============================] - 0s 776us/step - loss: 0.0020 - mse: 0.0020\n",
      "1/1 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0017 - val_mse: 0.0017 - 33ms/epoch - 33ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0016 - mse: 0.0016\n",
      "4/4 [==============================] - 0s 693us/step - loss: 0.0020 - mse: 0.0020\n",
      "1/1 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0017 - val_mse: 0.0017 - 29ms/epoch - 29ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 896us/step - loss: 0.0020 - mse: 0.0020\n",
      "1/1 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0017 - val_mse: 0.0017 - 30ms/epoch - 30ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 623us/step - loss: 0.0020 - mse: 0.0020\n",
      "1/1 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0017 - val_mse: 0.0017 - 30ms/epoch - 30ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 590us/step - loss: 0.0020 - mse: 0.0020\n",
      "1/1 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0017 - val_mse: 0.0017 - 29ms/epoch - 29ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 840us/step - loss: 0.0020 - mse: 0.0020\n",
      "1/1 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0017 - val_mse: 0.0017 - 26ms/epoch - 26ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 861us/step - loss: 0.0020 - mse: 0.0020\n",
      "1/1 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0017 - val_mse: 0.0017 - 26ms/epoch - 26ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 559us/step - loss: 0.0020 - mse: 0.0020\n",
      "1/1 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0017 - val_mse: 0.0017 - 26ms/epoch - 26ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 643us/step - loss: 0.0020 - mse: 0.0020\n",
      "1/1 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0017 - val_mse: 0.0017 - 32ms/epoch - 32ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 737us/step - loss: 0.0020 - mse: 0.0020\n",
      "1/1 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0017 - val_mse: 0.0017 - 25ms/epoch - 25ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0020 - mse: 0.0020\n",
      "1/1 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0017 - val_mse: 0.0017 - 29ms/epoch - 29ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 654us/step - loss: 0.0020 - mse: 0.0020\n",
      "1/1 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0017 - val_mse: 0.0017 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 2ms/step - loss: 0.0020 - mse: 0.0020\n",
      "1/1 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0017 - val_mse: 0.0017 - 25ms/epoch - 25ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 688us/step - loss: 0.0020 - mse: 0.0020\n",
      "1/1 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0017 - val_mse: 0.0017 - 25ms/epoch - 25ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 586us/step - loss: 0.0020 - mse: 0.0020\n",
      "1/1 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0017 - val_mse: 0.0017 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 843us/step - loss: 0.0020 - mse: 0.0020\n",
      "1/1 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0017 - val_mse: 0.0017 - 26ms/epoch - 26ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 639us/step - loss: 0.0020 - mse: 0.0020\n",
      "1/1 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0017 - val_mse: 0.0017 - 25ms/epoch - 25ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 632us/step - loss: 0.0020 - mse: 0.0020\n",
      "1/1 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0017 - val_mse: 0.0017 - 25ms/epoch - 25ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 590us/step - loss: 0.0020 - mse: 0.0020\n",
      "1/1 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0017 - val_mse: 0.0017 - 25ms/epoch - 25ms/step\n",
      "1/1 [==============================] - 0s 9ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 564us/step - loss: 0.0020 - mse: 0.0020\n",
      "1/1 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0017 - val_mse: 0.0017 - 30ms/epoch - 30ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 2ms/step - loss: 0.0020 - mse: 0.0020\n",
      "1/1 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0017 - val_mse: 0.0017 - 33ms/epoch - 33ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 805us/step - loss: 0.0020 - mse: 0.0020\n",
      "1/1 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0017 - val_mse: 0.0017 - 28ms/epoch - 28ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 729us/step - loss: 0.0020 - mse: 0.0020\n",
      "1/1 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0017 - val_mse: 0.0017 - 27ms/epoch - 27ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 2ms/step - loss: 0.0020 - mse: 0.0020\n",
      "1/1 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0017 - val_mse: 0.0017 - 32ms/epoch - 32ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 873us/step - loss: 0.0020 - mse: 0.0020\n",
      "1/1 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0017 - val_mse: 0.0017 - 29ms/epoch - 29ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0020 - mse: 0.0020\n",
      "1/1 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0017 - val_mse: 0.0017 - 32ms/epoch - 32ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 984us/step - loss: 0.0020 - mse: 0.0020\n",
      "1/1 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0017 - val_mse: 0.0017 - 27ms/epoch - 27ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 715us/step - loss: 0.0020 - mse: 0.0020\n",
      "1/1 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0017 - val_mse: 0.0017 - 26ms/epoch - 26ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 620us/step - loss: 0.0020 - mse: 0.0020\n",
      "1/1 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0017 - val_mse: 0.0017 - 28ms/epoch - 28ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 797us/step - loss: 0.0020 - mse: 0.0020\n",
      "1/1 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0017 - val_mse: 0.0017 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 577us/step - loss: 0.0020 - mse: 0.0020\n",
      "1/1 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0017 - val_mse: 0.0017 - 23ms/epoch - 23ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 680us/step - loss: 0.0020 - mse: 0.0020\n",
      "1/1 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0017 - val_mse: 0.0017 - 26ms/epoch - 26ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 805us/step - loss: 0.0020 - mse: 0.0020\n",
      "1/1 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0017 - val_mse: 0.0017 - 23ms/epoch - 23ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 581us/step - loss: 0.0020 - mse: 0.0020\n",
      "1/1 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0017 - val_mse: 0.0017 - 23ms/epoch - 23ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 616us/step - loss: 0.0020 - mse: 0.0020\n",
      "1/1 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0017 - val_mse: 0.0017 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 9ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 696us/step - loss: 0.0020 - mse: 0.0020\n",
      "1/1 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0016 - val_mse: 0.0016 - 25ms/epoch - 25ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 641us/step - loss: 0.0019 - mse: 0.0019\n",
      "1/1 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0016 - val_mse: 0.0016 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 9ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 823us/step - loss: 0.0019 - mse: 0.0019\n",
      "1/1 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0016 - val_mse: 0.0016 - 29ms/epoch - 29ms/step\n",
      "1/1 [==============================] - 0s 9ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 685us/step - loss: 0.0019 - mse: 0.0019\n",
      "1/1 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0016 - val_mse: 0.0016 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 783us/step - loss: 0.0019 - mse: 0.0019\n",
      "1/1 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0016 - val_mse: 0.0016 - 27ms/epoch - 27ms/step\n",
      "1/1 [==============================] - 0s 14ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0019 - mse: 0.0019\n",
      "1/1 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0016 - val_mse: 0.0016 - 28ms/epoch - 28ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 962us/step - loss: 0.0019 - mse: 0.0019\n",
      "1/1 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0016 - val_mse: 0.0016 - 26ms/epoch - 26ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 2ms/step - loss: 0.0019 - mse: 0.0019\n",
      "1/1 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0016 - val_mse: 0.0016 - 28ms/epoch - 28ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0019 - mse: 0.0019\n",
      "1/1 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0016 - val_mse: 0.0016 - 29ms/epoch - 29ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0019 - mse: 0.0019\n",
      "1/1 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0016 - val_mse: 0.0016 - 25ms/epoch - 25ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 764us/step - loss: 0.0019 - mse: 0.0019\n",
      "1/1 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0016 - val_mse: 0.0016 - 26ms/epoch - 26ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 933us/step - loss: 0.0019 - mse: 0.0019\n",
      "1/1 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0016 - val_mse: 0.0016 - 34ms/epoch - 34ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0019 - mse: 0.0019\n",
      "1/1 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0016 - val_mse: 0.0016 - 31ms/epoch - 31ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0019 - mse: 0.0019\n",
      "1/1 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0016 - val_mse: 0.0016 - 29ms/epoch - 29ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0019 - mse: 0.0019\n",
      "1/1 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0016 - val_mse: 0.0016 - 28ms/epoch - 28ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 797us/step - loss: 0.0019 - mse: 0.0019\n",
      "1/1 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0016 - val_mse: 0.0016 - 25ms/epoch - 25ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 782us/step - loss: 0.0019 - mse: 0.0019\n",
      "1/1 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0016 - val_mse: 0.0016 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 695us/step - loss: 0.0019 - mse: 0.0019\n",
      "1/1 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0016 - val_mse: 0.0016 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 695us/step - loss: 0.0019 - mse: 0.0019\n",
      "1/1 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0016 - val_mse: 0.0016 - 23ms/epoch - 23ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 631us/step - loss: 0.0019 - mse: 0.0019\n",
      "1/1 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0016 - val_mse: 0.0016 - 25ms/epoch - 25ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0019 - mse: 0.0019\n",
      "1/1 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0016 - val_mse: 0.0016 - 28ms/epoch - 28ms/step\n",
      "1/1 [==============================] - 0s 9ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 764us/step - loss: 0.0019 - mse: 0.0019\n",
      "1/1 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0016 - val_mse: 0.0016 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0014 - mse: 0.0014\n",
      "4/4 [==============================] - 0s 918us/step - loss: 0.0019 - mse: 0.0019\n",
      "1/1 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0016 - val_mse: 0.0016 - 23ms/epoch - 23ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0014 - mse: 0.0014\n",
      "4/4 [==============================] - 0s 730us/step - loss: 0.0019 - mse: 0.0019\n",
      "1/1 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0016 - val_mse: 0.0016 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0014 - mse: 0.0014\n",
      "4/4 [==============================] - 0s 944us/step - loss: 0.0019 - mse: 0.0019\n",
      "1/1 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0016 - val_mse: 0.0016 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0014 - mse: 0.0014\n",
      "4/4 [==============================] - 0s 728us/step - loss: 0.0019 - mse: 0.0019\n",
      "1/1 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0016 - val_mse: 0.0016 - 24ms/epoch - 24ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0014 - mse: 0.0014\n",
      "4/4 [==============================] - 0s 860us/step - loss: 0.0019 - mse: 0.0019\n",
      "1/1 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0016 - val_mse: 0.0016 - 25ms/epoch - 25ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0014 - mse: 0.0014\n",
      "4/4 [==============================] - 0s 817us/step - loss: 0.0019 - mse: 0.0019\n",
      "1/1 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0016 - val_mse: 0.0016 - 26ms/epoch - 26ms/step\n",
      "1/1 [==============================] - 0s 14ms/step - loss: 0.0014 - mse: 0.0014\n",
      "4/4 [==============================] - 0s 739us/step - loss: 0.0019 - mse: 0.0019\n",
      "1/1 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0016 - val_mse: 0.0016 - 25ms/epoch - 25ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0014 - mse: 0.0014\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0019 - mse: 0.0019\n",
      "1/1 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0016 - val_mse: 0.0016 - 34ms/epoch - 34ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0014 - mse: 0.0014\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0019 - mse: 0.0019\n",
      "1/1 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0016 - val_mse: 0.0016 - 30ms/epoch - 30ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0014 - mse: 0.0014\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0019 - mse: 0.0019\n",
      "1/1 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0016 - val_mse: 0.0016 - 25ms/epoch - 25ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0014 - mse: 0.0014\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0019 - mse: 0.0019\n",
      "1/1 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0016 - val_mse: 0.0016 - 29ms/epoch - 29ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0014 - mse: 0.0014\n",
      "4/4 [==============================] - 0s 712us/step - loss: 0.0019 - mse: 0.0019\n",
      "1/1 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0016 - val_mse: 0.0016 - 26ms/epoch - 26ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0014 - mse: 0.0014\n",
      "4/4 [==============================] - 0s 569us/step - loss: 0.0019 - mse: 0.0019\n",
      "32.34633159637451\n"
     ]
    }
   ],
   "source": [
    "t0 = time.time()\n",
    "history_F = [] #collect data for figures\n",
    "for i in range(300):\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": 26,
   "id": "388b3084",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1/1 [==============================] - 0s 13ms/step - loss: 0.0014 - mse: 0.0014\n",
      "4/4 [==============================] - 0s 556us/step - loss: 0.0019 - mse: 0.0019\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": 27,
   "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
}
