{
 "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"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "3a4a2d8e",
   "metadata": {},
   "outputs": [],
   "source": [
    "# === Step 1: Load data ===\n",
    "filename = 'dataBenchmark.csv'  # Replace with your filename\n",
    "df = pd.read_csv(filename, header=None)\n",
    "\n",
    "# Columns: assume 0-based indexing, so:\n",
    "# u(t) is in column 1\n",
    "# y(t) is in column 3\n",
    "u = df.iloc[1:, 1].values  # u(t) #delete the first element which shows the label\n",
    "y = df.iloc[1:, 3].values  # y(t)\n",
    "\n",
    "# === Step 2: Construct input-output pairs ===\n",
    "X = []\n",
    "Y = []\n",
    "for t in range(1, len(y)):\n",
    "    X.append([u[t], y[t-1], y[t-1]])  # input: u(t), y(t-1)\n",
    "    Y.append([y[t], y[t]])            # output: y(t)\n",
    "\n",
    "X = np.array(X)\n",
    "Y = np.array(Y).reshape(-1, 2)"
   ]
  },
  {
   "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": [
    "print(X,Y)"
   ]
  },
  {
   "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-19 22:25:38.511223: 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-19 22:25:38.511254: 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-19 22:25:38.511684: 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: 0.5780 - mse: 0.5780 - val_loss: 0.4601 - val_mse: 0.4601\n",
      "Epoch 2/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.5121 - mse: 0.5121 - val_loss: 0.4093 - val_mse: 0.4093\n",
      "Epoch 3/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.4560 - mse: 0.4560 - val_loss: 0.3618 - val_mse: 0.3618\n",
      "Epoch 4/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.4032 - mse: 0.4032 - val_loss: 0.3185 - val_mse: 0.3185\n",
      "Epoch 5/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.3514 - mse: 0.3514 - val_loss: 0.2800 - val_mse: 0.2800\n",
      "Epoch 6/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.3076 - mse: 0.3076 - val_loss: 0.2446 - val_mse: 0.2446\n",
      "Epoch 7/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.2683 - mse: 0.2683 - val_loss: 0.2127 - val_mse: 0.2127\n",
      "Epoch 8/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.2316 - mse: 0.2316 - val_loss: 0.1846 - val_mse: 0.1846\n",
      "Epoch 9/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.2011 - mse: 0.2011 - val_loss: 0.1593 - val_mse: 0.1593\n",
      "Epoch 10/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.1731 - mse: 0.1731 - val_loss: 0.1375 - val_mse: 0.1375\n",
      "Epoch 11/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.1488 - mse: 0.1488 - val_loss: 0.1181 - val_mse: 0.1181\n",
      "Epoch 12/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.1276 - mse: 0.1276 - val_loss: 0.1006 - val_mse: 0.1006\n",
      "Epoch 13/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.1093 - mse: 0.1093 - val_loss: 0.0859 - val_mse: 0.0859\n",
      "Epoch 14/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0931 - mse: 0.0931 - val_loss: 0.0735 - val_mse: 0.0735\n",
      "Epoch 15/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0801 - mse: 0.0801 - val_loss: 0.0627 - val_mse: 0.0627\n",
      "Epoch 16/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0684 - mse: 0.0684 - val_loss: 0.0538 - val_mse: 0.0538\n",
      "Epoch 17/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0589 - mse: 0.0589 - val_loss: 0.0461 - val_mse: 0.0461\n",
      "Epoch 18/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0507 - mse: 0.0507 - val_loss: 0.0397 - val_mse: 0.0397\n",
      "Epoch 19/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0441 - mse: 0.0441 - val_loss: 0.0343 - val_mse: 0.0343\n",
      "Epoch 20/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0382 - mse: 0.0382 - val_loss: 0.0301 - val_mse: 0.0301\n",
      "Epoch 21/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0343 - mse: 0.0343 - val_loss: 0.0266 - val_mse: 0.0266\n",
      "Epoch 22/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0303 - mse: 0.0303 - val_loss: 0.0239 - val_mse: 0.0239\n",
      "Epoch 23/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0276 - mse: 0.0276 - val_loss: 0.0217 - val_mse: 0.0217\n",
      "Epoch 24/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0250 - mse: 0.0250 - val_loss: 0.0199 - val_mse: 0.0199\n",
      "Epoch 25/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0233 - mse: 0.0233 - val_loss: 0.0184 - val_mse: 0.0184\n",
      "Epoch 26/400\n",
      "7/7 [==============================] - 0s 6ms/step - loss: 0.0218 - mse: 0.0218 - val_loss: 0.0173 - val_mse: 0.0173\n",
      "Epoch 27/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0204 - mse: 0.0204 - val_loss: 0.0165 - val_mse: 0.0165\n",
      "Epoch 28/400\n",
      "7/7 [==============================] - 0s 6ms/step - loss: 0.0194 - mse: 0.0194 - val_loss: 0.0158 - val_mse: 0.0158\n",
      "Epoch 29/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0187 - mse: 0.0187 - val_loss: 0.0152 - val_mse: 0.0152\n",
      "Epoch 30/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0181 - mse: 0.0181 - val_loss: 0.0148 - val_mse: 0.0148\n",
      "Epoch 31/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0176 - mse: 0.0176 - val_loss: 0.0145 - val_mse: 0.0145\n",
      "Epoch 32/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0172 - mse: 0.0172 - val_loss: 0.0142 - val_mse: 0.0142\n",
      "Epoch 33/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0168 - mse: 0.0168 - val_loss: 0.0139 - val_mse: 0.0139\n",
      "Epoch 34/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0165 - mse: 0.0165 - val_loss: 0.0137 - val_mse: 0.0137\n",
      "Epoch 35/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0162 - mse: 0.0162 - val_loss: 0.0135 - val_mse: 0.0135\n",
      "Epoch 36/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0160 - mse: 0.0160 - val_loss: 0.0133 - val_mse: 0.0133\n",
      "Epoch 37/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0157 - mse: 0.0157 - val_loss: 0.0132 - val_mse: 0.0132\n",
      "Epoch 38/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0155 - mse: 0.0155 - val_loss: 0.0130 - val_mse: 0.0130\n",
      "Epoch 39/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0152 - mse: 0.0152 - val_loss: 0.0128 - val_mse: 0.0128\n",
      "Epoch 40/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0150 - mse: 0.0150 - val_loss: 0.0126 - val_mse: 0.0126\n",
      "Epoch 41/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0148 - mse: 0.0148 - val_loss: 0.0125 - val_mse: 0.0125\n",
      "Epoch 42/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0146 - mse: 0.0146 - val_loss: 0.0123 - val_mse: 0.0123\n",
      "Epoch 43/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0144 - mse: 0.0144 - val_loss: 0.0122 - val_mse: 0.0122\n",
      "Epoch 44/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0142 - mse: 0.0142 - val_loss: 0.0121 - val_mse: 0.0121\n",
      "Epoch 45/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0140 - mse: 0.0140 - val_loss: 0.0119 - val_mse: 0.0119\n",
      "Epoch 46/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0138 - mse: 0.0138 - val_loss: 0.0118 - val_mse: 0.0118\n",
      "Epoch 47/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0136 - mse: 0.0136 - val_loss: 0.0117 - val_mse: 0.0117\n",
      "Epoch 48/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0134 - mse: 0.0134 - val_loss: 0.0115 - val_mse: 0.0115\n",
      "Epoch 49/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0132 - mse: 0.0132 - val_loss: 0.0114 - val_mse: 0.0114\n",
      "Epoch 50/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0130 - mse: 0.0130 - val_loss: 0.0112 - val_mse: 0.0112\n",
      "Epoch 51/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0128 - mse: 0.0128 - val_loss: 0.0111 - val_mse: 0.0111\n",
      "Epoch 52/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0126 - mse: 0.0126 - val_loss: 0.0110 - val_mse: 0.0110\n",
      "Epoch 53/400\n",
      "7/7 [==============================] - 0s 8ms/step - loss: 0.0125 - mse: 0.0125 - val_loss: 0.0109 - val_mse: 0.0109\n",
      "Epoch 54/400\n",
      "7/7 [==============================] - 0s 7ms/step - loss: 0.0123 - mse: 0.0123 - val_loss: 0.0108 - val_mse: 0.0108\n",
      "Epoch 55/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0121 - mse: 0.0121 - val_loss: 0.0106 - val_mse: 0.0106\n",
      "Epoch 56/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0119 - mse: 0.0119 - val_loss: 0.0105 - val_mse: 0.0105\n",
      "Epoch 57/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0118 - mse: 0.0118 - val_loss: 0.0104 - val_mse: 0.0104\n",
      "Epoch 58/400\n",
      "7/7 [==============================] - 0s 6ms/step - loss: 0.0116 - mse: 0.0116 - val_loss: 0.0103 - val_mse: 0.0103\n",
      "Epoch 59/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0115 - mse: 0.0115 - val_loss: 0.0101 - val_mse: 0.0101\n",
      "Epoch 60/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0113 - mse: 0.0113 - val_loss: 0.0100 - val_mse: 0.0100\n",
      "Epoch 61/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0111 - mse: 0.0111 - val_loss: 0.0099 - val_mse: 0.0099\n",
      "Epoch 62/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0110 - mse: 0.0110 - val_loss: 0.0098 - val_mse: 0.0098\n",
      "Epoch 63/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0108 - mse: 0.0108 - val_loss: 0.0097 - val_mse: 0.0097\n",
      "Epoch 64/400\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0107 - mse: 0.0107 - val_loss: 0.0096 - val_mse: 0.0096\n",
      "Epoch 65/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0106 - mse: 0.0106 - val_loss: 0.0095 - val_mse: 0.0095\n",
      "Epoch 66/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0104 - mse: 0.0104 - val_loss: 0.0094 - val_mse: 0.0094\n",
      "Epoch 67/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0103 - mse: 0.0103 - val_loss: 0.0093 - val_mse: 0.0093\n",
      "Epoch 68/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0101 - mse: 0.0101 - val_loss: 0.0092 - val_mse: 0.0092\n",
      "Epoch 69/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0100 - mse: 0.0100 - val_loss: 0.0091 - val_mse: 0.0091\n",
      "Epoch 70/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0099 - mse: 0.0099 - val_loss: 0.0090 - val_mse: 0.0090\n",
      "Epoch 71/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0098 - mse: 0.0098 - val_loss: 0.0089 - val_mse: 0.0089\n",
      "Epoch 72/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0096 - mse: 0.0096 - val_loss: 0.0088 - val_mse: 0.0088\n",
      "Epoch 73/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0095 - mse: 0.0095 - val_loss: 0.0087 - val_mse: 0.0087\n",
      "Epoch 74/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0094 - mse: 0.0094 - val_loss: 0.0086 - val_mse: 0.0086\n",
      "Epoch 75/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0093 - mse: 0.0093 - val_loss: 0.0085 - val_mse: 0.0085\n",
      "Epoch 76/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0092 - mse: 0.0092 - val_loss: 0.0084 - val_mse: 0.0084\n",
      "Epoch 77/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0091 - mse: 0.0091 - val_loss: 0.0084 - val_mse: 0.0084\n",
      "Epoch 78/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0089 - mse: 0.0089 - val_loss: 0.0083 - val_mse: 0.0083\n",
      "Epoch 79/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0088 - mse: 0.0088 - val_loss: 0.0082 - val_mse: 0.0082\n",
      "Epoch 80/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0087 - mse: 0.0087 - val_loss: 0.0081 - val_mse: 0.0081\n",
      "Epoch 81/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0086 - mse: 0.0086 - val_loss: 0.0080 - val_mse: 0.0080\n",
      "Epoch 82/400\n",
      "7/7 [==============================] - 0s 6ms/step - loss: 0.0085 - mse: 0.0085 - val_loss: 0.0080 - val_mse: 0.0080\n",
      "Epoch 83/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0084 - mse: 0.0084 - val_loss: 0.0079 - val_mse: 0.0079\n",
      "Epoch 84/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0083 - mse: 0.0083 - val_loss: 0.0078 - val_mse: 0.0078\n",
      "Epoch 85/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0082 - mse: 0.0082 - val_loss: 0.0078 - val_mse: 0.0078\n",
      "Epoch 86/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0081 - mse: 0.0081 - val_loss: 0.0077 - val_mse: 0.0077\n",
      "Epoch 87/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0080 - mse: 0.0080 - val_loss: 0.0076 - val_mse: 0.0076\n",
      "Epoch 88/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0079 - mse: 0.0079 - val_loss: 0.0075 - val_mse: 0.0075\n",
      "Epoch 89/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0078 - mse: 0.0078 - val_loss: 0.0075 - val_mse: 0.0075\n",
      "Epoch 90/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0077 - mse: 0.0077 - val_loss: 0.0074 - val_mse: 0.0074\n",
      "Epoch 91/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0076 - mse: 0.0076 - val_loss: 0.0073 - val_mse: 0.0073\n",
      "Epoch 92/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0076 - mse: 0.0076 - val_loss: 0.0073 - val_mse: 0.0073\n",
      "Epoch 93/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0075 - mse: 0.0075 - val_loss: 0.0072 - val_mse: 0.0072\n",
      "Epoch 94/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0074 - mse: 0.0074 - val_loss: 0.0071 - val_mse: 0.0071\n",
      "Epoch 95/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0073 - mse: 0.0073 - val_loss: 0.0071 - val_mse: 0.0071\n",
      "Epoch 96/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0072 - mse: 0.0072 - val_loss: 0.0070 - val_mse: 0.0070\n",
      "Epoch 97/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0072 - mse: 0.0072 - val_loss: 0.0069 - val_mse: 0.0069\n",
      "Epoch 98/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0071 - mse: 0.0071 - val_loss: 0.0069 - val_mse: 0.0069\n",
      "Epoch 99/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0070 - mse: 0.0070 - val_loss: 0.0068 - val_mse: 0.0068\n",
      "Epoch 100/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0069 - mse: 0.0069 - val_loss: 0.0068 - val_mse: 0.0068\n",
      "Epoch 101/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0069 - mse: 0.0069 - val_loss: 0.0067 - val_mse: 0.0067\n",
      "Epoch 102/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0068 - mse: 0.0068 - val_loss: 0.0066 - val_mse: 0.0066\n",
      "Epoch 103/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0067 - mse: 0.0067 - val_loss: 0.0066 - val_mse: 0.0066\n",
      "Epoch 104/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0066 - mse: 0.0066 - val_loss: 0.0065 - val_mse: 0.0065\n",
      "Epoch 105/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0066 - mse: 0.0066 - val_loss: 0.0065 - val_mse: 0.0065\n",
      "Epoch 106/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0065 - mse: 0.0065 - val_loss: 0.0064 - val_mse: 0.0064\n",
      "Epoch 107/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0064 - mse: 0.0064 - val_loss: 0.0064 - val_mse: 0.0064\n",
      "Epoch 108/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0064 - mse: 0.0064 - val_loss: 0.0063 - val_mse: 0.0063\n",
      "Epoch 109/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0063 - mse: 0.0063 - val_loss: 0.0063 - val_mse: 0.0063\n",
      "Epoch 110/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0063 - mse: 0.0063 - val_loss: 0.0062 - val_mse: 0.0062\n",
      "Epoch 111/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0062 - mse: 0.0062 - val_loss: 0.0062 - val_mse: 0.0062\n",
      "Epoch 112/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0061 - mse: 0.0061 - val_loss: 0.0061 - val_mse: 0.0061\n",
      "Epoch 113/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0061 - mse: 0.0061 - val_loss: 0.0061 - val_mse: 0.0061\n",
      "Epoch 114/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0060 - mse: 0.0060 - val_loss: 0.0060 - val_mse: 0.0060\n",
      "Epoch 115/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0059 - mse: 0.0059 - val_loss: 0.0060 - val_mse: 0.0060\n",
      "Epoch 116/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0059 - mse: 0.0059 - val_loss: 0.0059 - val_mse: 0.0059\n",
      "Epoch 117/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0058 - mse: 0.0058 - val_loss: 0.0059 - val_mse: 0.0059\n",
      "Epoch 118/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0058 - mse: 0.0058 - val_loss: 0.0058 - val_mse: 0.0058\n",
      "Epoch 119/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0057 - mse: 0.0057 - val_loss: 0.0058 - val_mse: 0.0058\n",
      "Epoch 120/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0057 - mse: 0.0057 - val_loss: 0.0057 - val_mse: 0.0057\n",
      "Epoch 121/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0056 - mse: 0.0056 - val_loss: 0.0057 - val_mse: 0.0057\n",
      "Epoch 122/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0056 - mse: 0.0056 - val_loss: 0.0057 - val_mse: 0.0057\n",
      "Epoch 123/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0055 - mse: 0.0055 - val_loss: 0.0056 - val_mse: 0.0056\n",
      "Epoch 124/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0055 - mse: 0.0055 - val_loss: 0.0056 - val_mse: 0.0056\n",
      "Epoch 125/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0054 - mse: 0.0054 - val_loss: 0.0055 - val_mse: 0.0055\n",
      "Epoch 126/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0054 - mse: 0.0054 - val_loss: 0.0055 - val_mse: 0.0055\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 127/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0053 - mse: 0.0053 - val_loss: 0.0054 - val_mse: 0.0054\n",
      "Epoch 128/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0053 - mse: 0.0053 - val_loss: 0.0054 - val_mse: 0.0054\n",
      "Epoch 129/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0052 - mse: 0.0052 - val_loss: 0.0054 - val_mse: 0.0054\n",
      "Epoch 130/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0052 - mse: 0.0052 - val_loss: 0.0053 - val_mse: 0.0053\n",
      "Epoch 131/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0051 - mse: 0.0051 - val_loss: 0.0053 - val_mse: 0.0053\n",
      "Epoch 132/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0051 - mse: 0.0051 - val_loss: 0.0052 - val_mse: 0.0052\n",
      "Epoch 133/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0051 - mse: 0.0051 - val_loss: 0.0052 - val_mse: 0.0052\n",
      "Epoch 134/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0050 - mse: 0.0050 - val_loss: 0.0052 - val_mse: 0.0052\n",
      "Epoch 135/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0050 - mse: 0.0050 - val_loss: 0.0051 - val_mse: 0.0051\n",
      "Epoch 136/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0049 - mse: 0.0049 - val_loss: 0.0051 - val_mse: 0.0051\n",
      "Epoch 137/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0049 - mse: 0.0049 - val_loss: 0.0051 - val_mse: 0.0051\n",
      "Epoch 138/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0048 - mse: 0.0048 - val_loss: 0.0050 - val_mse: 0.0050\n",
      "Epoch 139/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0048 - mse: 0.0048 - val_loss: 0.0050 - val_mse: 0.0050\n",
      "Epoch 140/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0048 - mse: 0.0048 - val_loss: 0.0050 - val_mse: 0.0050\n",
      "Epoch 141/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0047 - mse: 0.0047 - val_loss: 0.0049 - val_mse: 0.0049\n",
      "Epoch 142/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0047 - mse: 0.0047 - val_loss: 0.0049 - val_mse: 0.0049\n",
      "Epoch 143/400\n",
      "7/7 [==============================] - 0s 6ms/step - loss: 0.0046 - mse: 0.0046 - val_loss: 0.0048 - val_mse: 0.0048\n",
      "Epoch 144/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0046 - mse: 0.0046 - val_loss: 0.0048 - val_mse: 0.0048\n",
      "Epoch 145/400\n",
      "7/7 [==============================] - 0s 6ms/step - loss: 0.0046 - mse: 0.0046 - val_loss: 0.0048 - val_mse: 0.0048\n",
      "Epoch 146/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0045 - mse: 0.0045 - val_loss: 0.0048 - val_mse: 0.0048\n",
      "Epoch 147/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0045 - mse: 0.0045 - val_loss: 0.0047 - val_mse: 0.0047\n",
      "Epoch 148/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0045 - mse: 0.0045 - val_loss: 0.0047 - val_mse: 0.0047\n",
      "Epoch 149/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0044 - mse: 0.0044 - val_loss: 0.0047 - val_mse: 0.0047\n",
      "Epoch 150/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0044 - mse: 0.0044 - val_loss: 0.0047 - val_mse: 0.0047\n",
      "Epoch 151/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0044 - mse: 0.0044 - val_loss: 0.0046 - val_mse: 0.0046\n",
      "Epoch 152/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0043 - mse: 0.0043 - val_loss: 0.0046 - val_mse: 0.0046\n",
      "Epoch 153/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0043 - mse: 0.0043 - val_loss: 0.0045 - val_mse: 0.0045\n",
      "Epoch 154/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0043 - mse: 0.0043 - val_loss: 0.0045 - val_mse: 0.0045\n",
      "Epoch 155/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0042 - mse: 0.0042 - val_loss: 0.0045 - val_mse: 0.0045\n",
      "Epoch 156/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0042 - mse: 0.0042 - val_loss: 0.0045 - val_mse: 0.0045\n",
      "Epoch 157/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0042 - mse: 0.0042 - val_loss: 0.0045 - val_mse: 0.0045\n",
      "Epoch 158/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0042 - mse: 0.0042 - val_loss: 0.0044 - val_mse: 0.0044\n",
      "Epoch 159/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0041 - mse: 0.0041 - val_loss: 0.0044 - val_mse: 0.0044\n",
      "Epoch 160/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0041 - mse: 0.0041 - val_loss: 0.0043 - val_mse: 0.0043\n",
      "Epoch 161/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0041 - mse: 0.0041 - val_loss: 0.0043 - val_mse: 0.0043\n",
      "Epoch 162/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0040 - mse: 0.0040 - val_loss: 0.0043 - val_mse: 0.0043\n",
      "Epoch 163/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0040 - mse: 0.0040 - val_loss: 0.0043 - val_mse: 0.0043\n",
      "Epoch 164/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0040 - mse: 0.0040 - val_loss: 0.0043 - val_mse: 0.0043\n",
      "Epoch 165/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0039 - mse: 0.0039 - val_loss: 0.0042 - val_mse: 0.0042\n",
      "Epoch 166/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0039 - mse: 0.0039 - val_loss: 0.0042 - val_mse: 0.0042\n",
      "Epoch 167/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0039 - mse: 0.0039 - val_loss: 0.0042 - val_mse: 0.0042\n",
      "Epoch 168/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0039 - mse: 0.0039 - val_loss: 0.0041 - val_mse: 0.0041\n",
      "Epoch 169/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0038 - mse: 0.0038 - val_loss: 0.0041 - val_mse: 0.0041\n",
      "Epoch 170/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0038 - mse: 0.0038 - val_loss: 0.0041 - val_mse: 0.0041\n",
      "Epoch 171/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0038 - mse: 0.0038 - val_loss: 0.0041 - val_mse: 0.0041\n",
      "Epoch 172/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0037 - mse: 0.0037 - val_loss: 0.0041 - val_mse: 0.0041\n",
      "Epoch 173/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0037 - mse: 0.0037 - val_loss: 0.0040 - val_mse: 0.0040\n",
      "Epoch 174/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0037 - mse: 0.0037 - val_loss: 0.0040 - val_mse: 0.0040\n",
      "Epoch 175/400\n",
      "7/7 [==============================] - 0s 7ms/step - loss: 0.0037 - mse: 0.0037 - val_loss: 0.0040 - val_mse: 0.0040\n",
      "Epoch 176/400\n",
      "7/7 [==============================] - 0s 7ms/step - loss: 0.0036 - mse: 0.0036 - val_loss: 0.0040 - val_mse: 0.0040\n",
      "Epoch 177/400\n",
      "7/7 [==============================] - 0s 7ms/step - loss: 0.0036 - mse: 0.0036 - val_loss: 0.0039 - val_mse: 0.0039\n",
      "Epoch 178/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0036 - mse: 0.0036 - val_loss: 0.0039 - val_mse: 0.0039\n",
      "Epoch 179/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0036 - mse: 0.0036 - val_loss: 0.0039 - val_mse: 0.0039\n",
      "Epoch 180/400\n",
      "7/7 [==============================] - 0s 7ms/step - loss: 0.0036 - mse: 0.0036 - val_loss: 0.0039 - val_mse: 0.0039\n",
      "Epoch 181/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0038 - val_mse: 0.0038\n",
      "Epoch 182/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0038 - val_mse: 0.0038\n",
      "Epoch 183/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0038 - val_mse: 0.0038\n",
      "Epoch 184/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0038 - val_mse: 0.0038\n",
      "Epoch 185/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0037 - val_mse: 0.0037\n",
      "Epoch 186/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0037 - val_mse: 0.0037\n",
      "Epoch 187/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0037 - val_mse: 0.0037\n",
      "Epoch 188/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0037 - val_mse: 0.0037\n",
      "Epoch 189/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0037 - val_mse: 0.0037\n",
      "Epoch 190/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0033 - mse: 0.0033 - val_loss: 0.0036 - val_mse: 0.0036\n",
      "Epoch 191/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0033 - mse: 0.0033 - val_loss: 0.0036 - val_mse: 0.0036\n",
      "Epoch 192/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0033 - mse: 0.0033 - val_loss: 0.0036 - val_mse: 0.0036\n",
      "Epoch 193/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0033 - mse: 0.0033 - val_loss: 0.0036 - val_mse: 0.0036\n",
      "Epoch 194/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0033 - mse: 0.0033 - val_loss: 0.0036 - val_mse: 0.0036\n",
      "Epoch 195/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0032 - mse: 0.0032 - val_loss: 0.0036 - val_mse: 0.0036\n",
      "Epoch 196/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0032 - mse: 0.0032 - val_loss: 0.0036 - val_mse: 0.0036\n",
      "Epoch 197/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0032 - mse: 0.0032 - val_loss: 0.0035 - val_mse: 0.0035\n",
      "Epoch 198/400\n",
      "7/7 [==============================] - 0s 7ms/step - loss: 0.0032 - mse: 0.0032 - val_loss: 0.0035 - val_mse: 0.0035\n",
      "Epoch 199/400\n",
      "7/7 [==============================] - 0s 7ms/step - loss: 0.0032 - mse: 0.0032 - val_loss: 0.0035 - val_mse: 0.0035\n",
      "Epoch 200/400\n",
      "7/7 [==============================] - 0s 7ms/step - loss: 0.0031 - mse: 0.0031 - val_loss: 0.0034 - val_mse: 0.0034\n",
      "Epoch 201/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0031 - mse: 0.0031 - val_loss: 0.0034 - val_mse: 0.0034\n",
      "Epoch 202/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0031 - mse: 0.0031 - val_loss: 0.0034 - val_mse: 0.0034\n",
      "Epoch 203/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0031 - mse: 0.0031 - val_loss: 0.0034 - val_mse: 0.0034\n",
      "Epoch 204/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0031 - mse: 0.0031 - val_loss: 0.0034 - val_mse: 0.0034\n",
      "Epoch 205/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0030 - mse: 0.0030 - val_loss: 0.0034 - val_mse: 0.0034\n",
      "Epoch 206/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0030 - mse: 0.0030 - val_loss: 0.0034 - val_mse: 0.0034\n",
      "Epoch 207/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0030 - mse: 0.0030 - val_loss: 0.0033 - val_mse: 0.0033\n",
      "Epoch 208/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0030 - mse: 0.0030 - val_loss: 0.0033 - val_mse: 0.0033\n",
      "Epoch 209/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0030 - mse: 0.0030 - val_loss: 0.0033 - val_mse: 0.0033\n",
      "Epoch 210/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0030 - mse: 0.0030 - val_loss: 0.0033 - val_mse: 0.0033\n",
      "Epoch 211/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0030 - mse: 0.0030 - val_loss: 0.0033 - val_mse: 0.0033\n",
      "Epoch 212/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0029 - mse: 0.0029 - val_loss: 0.0033 - val_mse: 0.0033\n",
      "Epoch 213/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0029 - mse: 0.0029 - val_loss: 0.0033 - val_mse: 0.0033\n",
      "Epoch 214/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0029 - mse: 0.0029 - val_loss: 0.0032 - val_mse: 0.0032\n",
      "Epoch 215/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0029 - mse: 0.0029 - val_loss: 0.0032 - val_mse: 0.0032\n",
      "Epoch 216/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0029 - mse: 0.0029 - val_loss: 0.0032 - val_mse: 0.0032\n",
      "Epoch 217/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0029 - mse: 0.0029 - val_loss: 0.0032 - val_mse: 0.0032\n",
      "Epoch 218/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0028 - mse: 0.0028 - val_loss: 0.0032 - val_mse: 0.0032\n",
      "Epoch 219/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0028 - mse: 0.0028 - val_loss: 0.0032 - val_mse: 0.0032\n",
      "Epoch 220/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0028 - mse: 0.0028 - val_loss: 0.0031 - val_mse: 0.0031\n",
      "Epoch 221/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0028 - mse: 0.0028 - val_loss: 0.0031 - val_mse: 0.0031\n",
      "Epoch 222/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0028 - mse: 0.0028 - val_loss: 0.0031 - val_mse: 0.0031\n",
      "Epoch 223/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0028 - mse: 0.0028 - val_loss: 0.0031 - val_mse: 0.0031\n",
      "Epoch 224/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0028 - mse: 0.0028 - val_loss: 0.0031 - val_mse: 0.0031\n",
      "Epoch 225/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0027 - mse: 0.0027 - val_loss: 0.0031 - val_mse: 0.0031\n",
      "Epoch 226/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0027 - mse: 0.0027 - val_loss: 0.0031 - val_mse: 0.0031\n",
      "Epoch 227/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0027 - mse: 0.0027 - val_loss: 0.0031 - val_mse: 0.0031\n",
      "Epoch 228/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0027 - mse: 0.0027 - val_loss: 0.0030 - val_mse: 0.0030\n",
      "Epoch 229/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0027 - mse: 0.0027 - val_loss: 0.0030 - val_mse: 0.0030\n",
      "Epoch 230/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0027 - mse: 0.0027 - val_loss: 0.0030 - val_mse: 0.0030\n",
      "Epoch 231/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0027 - mse: 0.0027 - val_loss: 0.0030 - val_mse: 0.0030\n",
      "Epoch 232/400\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0026 - mse: 0.0026 - val_loss: 0.0030 - val_mse: 0.0030\n",
      "Epoch 233/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0026 - mse: 0.0026 - val_loss: 0.0030 - val_mse: 0.0030\n",
      "Epoch 234/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0026 - mse: 0.0026 - val_loss: 0.0030 - val_mse: 0.0030\n",
      "Epoch 235/400\n",
      "7/7 [==============================] - 0s 6ms/step - loss: 0.0026 - mse: 0.0026 - val_loss: 0.0029 - val_mse: 0.0029\n",
      "Epoch 236/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0026 - mse: 0.0026 - val_loss: 0.0029 - val_mse: 0.0029\n",
      "Epoch 237/400\n",
      "7/7 [==============================] - 0s 6ms/step - loss: 0.0026 - mse: 0.0026 - val_loss: 0.0029 - val_mse: 0.0029\n",
      "Epoch 238/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0026 - mse: 0.0026 - val_loss: 0.0029 - val_mse: 0.0029\n",
      "Epoch 239/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0026 - mse: 0.0026 - val_loss: 0.0029 - val_mse: 0.0029\n",
      "Epoch 240/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0025 - mse: 0.0025 - val_loss: 0.0029 - val_mse: 0.0029\n",
      "Epoch 241/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0025 - mse: 0.0025 - val_loss: 0.0029 - val_mse: 0.0029\n",
      "Epoch 242/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0025 - mse: 0.0025 - val_loss: 0.0029 - val_mse: 0.0029\n",
      "Epoch 243/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0025 - mse: 0.0025 - val_loss: 0.0028 - val_mse: 0.0028\n",
      "Epoch 244/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0025 - mse: 0.0025 - val_loss: 0.0028 - val_mse: 0.0028\n",
      "Epoch 245/400\n",
      "7/7 [==============================] - 0s 7ms/step - loss: 0.0025 - mse: 0.0025 - val_loss: 0.0028 - val_mse: 0.0028\n",
      "Epoch 246/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0025 - mse: 0.0025 - val_loss: 0.0028 - val_mse: 0.0028\n",
      "Epoch 247/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0025 - mse: 0.0025 - val_loss: 0.0028 - val_mse: 0.0028\n",
      "Epoch 248/400\n",
      "7/7 [==============================] - 0s 6ms/step - loss: 0.0025 - mse: 0.0025 - val_loss: 0.0028 - val_mse: 0.0028\n",
      "Epoch 249/400\n",
      "7/7 [==============================] - 0s 6ms/step - loss: 0.0024 - mse: 0.0024 - val_loss: 0.0028 - val_mse: 0.0028\n",
      "Epoch 250/400\n",
      "7/7 [==============================] - 0s 6ms/step - loss: 0.0024 - mse: 0.0024 - val_loss: 0.0028 - val_mse: 0.0028\n",
      "Epoch 251/400\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0024 - mse: 0.0024 - val_loss: 0.0028 - val_mse: 0.0028\n",
      "Epoch 252/400\n",
      "7/7 [==============================] - 0s 6ms/step - loss: 0.0024 - mse: 0.0024 - val_loss: 0.0027 - val_mse: 0.0027\n",
      "Epoch 253/400\n",
      "7/7 [==============================] - 0s 7ms/step - loss: 0.0024 - mse: 0.0024 - val_loss: 0.0028 - val_mse: 0.0028\n",
      "Epoch 254/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0024 - mse: 0.0024 - val_loss: 0.0027 - val_mse: 0.0027\n",
      "Epoch 255/400\n",
      "7/7 [==============================] - 0s 6ms/step - loss: 0.0024 - mse: 0.0024 - val_loss: 0.0027 - val_mse: 0.0027\n",
      "Epoch 256/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0024 - mse: 0.0024 - val_loss: 0.0027 - val_mse: 0.0027\n",
      "Epoch 257/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0024 - mse: 0.0024 - val_loss: 0.0027 - val_mse: 0.0027\n",
      "Epoch 258/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0024 - mse: 0.0024 - val_loss: 0.0027 - val_mse: 0.0027\n",
      "Epoch 259/400\n",
      "7/7 [==============================] - 0s 6ms/step - loss: 0.0023 - mse: 0.0023 - val_loss: 0.0027 - val_mse: 0.0027\n",
      "Epoch 260/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0023 - mse: 0.0023 - val_loss: 0.0027 - val_mse: 0.0027\n",
      "Epoch 261/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0023 - mse: 0.0023 - val_loss: 0.0027 - val_mse: 0.0027\n",
      "Epoch 262/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0023 - mse: 0.0023 - val_loss: 0.0026 - val_mse: 0.0026\n",
      "Epoch 263/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0023 - mse: 0.0023 - val_loss: 0.0026 - val_mse: 0.0026\n",
      "Epoch 264/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0023 - mse: 0.0023 - val_loss: 0.0026 - val_mse: 0.0026\n",
      "Epoch 265/400\n",
      "7/7 [==============================] - 0s 6ms/step - loss: 0.0023 - mse: 0.0023 - val_loss: 0.0026 - val_mse: 0.0026\n",
      "Epoch 266/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0023 - mse: 0.0023 - val_loss: 0.0026 - val_mse: 0.0026\n",
      "Epoch 267/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0023 - mse: 0.0023 - val_loss: 0.0026 - val_mse: 0.0026\n",
      "Epoch 268/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0023 - mse: 0.0023 - val_loss: 0.0026 - val_mse: 0.0026\n",
      "Epoch 269/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0022 - mse: 0.0022 - val_loss: 0.0026 - val_mse: 0.0026\n",
      "Epoch 270/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0022 - mse: 0.0022 - val_loss: 0.0026 - val_mse: 0.0026\n",
      "Epoch 271/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0022 - mse: 0.0022 - val_loss: 0.0026 - val_mse: 0.0026\n",
      "Epoch 272/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0022 - mse: 0.0022 - val_loss: 0.0026 - val_mse: 0.0026\n",
      "Epoch 273/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0022 - mse: 0.0022 - val_loss: 0.0025 - val_mse: 0.0025\n",
      "Epoch 274/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0022 - mse: 0.0022 - val_loss: 0.0025 - val_mse: 0.0025\n",
      "Epoch 275/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0022 - mse: 0.0022 - val_loss: 0.0025 - val_mse: 0.0025\n",
      "Epoch 276/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0022 - mse: 0.0022 - val_loss: 0.0025 - val_mse: 0.0025\n",
      "Epoch 277/400\n",
      "7/7 [==============================] - 0s 6ms/step - loss: 0.0022 - mse: 0.0022 - val_loss: 0.0025 - val_mse: 0.0025\n",
      "Epoch 278/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0022 - mse: 0.0022 - val_loss: 0.0025 - val_mse: 0.0025\n",
      "Epoch 279/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0022 - mse: 0.0022 - val_loss: 0.0025 - val_mse: 0.0025\n",
      "Epoch 280/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0021 - mse: 0.0021 - val_loss: 0.0025 - val_mse: 0.0025\n",
      "Epoch 281/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0022 - mse: 0.0022 - val_loss: 0.0025 - val_mse: 0.0025\n",
      "Epoch 282/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0021 - mse: 0.0021 - val_loss: 0.0025 - val_mse: 0.0025\n",
      "Epoch 283/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0021 - mse: 0.0021 - val_loss: 0.0025 - val_mse: 0.0025\n",
      "Epoch 284/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0021 - mse: 0.0021 - val_loss: 0.0025 - val_mse: 0.0025\n",
      "Epoch 285/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0021 - mse: 0.0021 - val_loss: 0.0025 - val_mse: 0.0025\n",
      "Epoch 286/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0021 - mse: 0.0021 - val_loss: 0.0024 - val_mse: 0.0024\n",
      "Epoch 287/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0021 - mse: 0.0021 - val_loss: 0.0024 - val_mse: 0.0024\n",
      "Epoch 288/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0021 - mse: 0.0021 - val_loss: 0.0024 - val_mse: 0.0024\n",
      "Epoch 289/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0021 - mse: 0.0021 - val_loss: 0.0025 - val_mse: 0.0025\n",
      "Epoch 290/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0021 - mse: 0.0021 - val_loss: 0.0024 - val_mse: 0.0024\n",
      "Epoch 291/400\n",
      "7/7 [==============================] - 0s 6ms/step - loss: 0.0021 - mse: 0.0021 - val_loss: 0.0024 - val_mse: 0.0024\n",
      "Epoch 292/400\n",
      "7/7 [==============================] - 0s 6ms/step - loss: 0.0021 - mse: 0.0021 - val_loss: 0.0024 - val_mse: 0.0024\n",
      "Epoch 293/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0021 - mse: 0.0021 - val_loss: 0.0024 - val_mse: 0.0024\n",
      "Epoch 294/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0021 - mse: 0.0021 - val_loss: 0.0024 - val_mse: 0.0024\n",
      "Epoch 295/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0021 - mse: 0.0021 - val_loss: 0.0024 - val_mse: 0.0024\n",
      "Epoch 296/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0021 - mse: 0.0021 - val_loss: 0.0024 - val_mse: 0.0024\n",
      "Epoch 297/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0020 - mse: 0.0020 - val_loss: 0.0024 - val_mse: 0.0024\n",
      "Epoch 298/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0020 - mse: 0.0020 - val_loss: 0.0024 - val_mse: 0.0024\n",
      "Epoch 299/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0020 - mse: 0.0020 - val_loss: 0.0023 - val_mse: 0.0023\n",
      "Epoch 300/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0020 - mse: 0.0020 - val_loss: 0.0023 - val_mse: 0.0023\n",
      "Epoch 301/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0020 - mse: 0.0020 - val_loss: 0.0023 - val_mse: 0.0023\n",
      "Epoch 302/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0020 - mse: 0.0020 - val_loss: 0.0024 - val_mse: 0.0024\n",
      "Epoch 303/400\n",
      "7/7 [==============================] - 0s 6ms/step - loss: 0.0020 - mse: 0.0020 - val_loss: 0.0024 - val_mse: 0.0024\n",
      "Epoch 304/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0020 - mse: 0.0020 - val_loss: 0.0023 - val_mse: 0.0023\n",
      "Epoch 305/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0020 - mse: 0.0020 - val_loss: 0.0024 - val_mse: 0.0024\n",
      "Epoch 306/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0020 - mse: 0.0020 - val_loss: 0.0023 - val_mse: 0.0023\n",
      "Epoch 307/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0020 - mse: 0.0020 - val_loss: 0.0023 - val_mse: 0.0023\n",
      "Epoch 308/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0020 - mse: 0.0020 - val_loss: 0.0023 - val_mse: 0.0023\n",
      "Epoch 309/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0020 - mse: 0.0020 - val_loss: 0.0023 - val_mse: 0.0023\n",
      "Epoch 310/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0020 - mse: 0.0020 - val_loss: 0.0023 - val_mse: 0.0023\n",
      "Epoch 311/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0020 - mse: 0.0020 - val_loss: 0.0023 - val_mse: 0.0023\n",
      "Epoch 312/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0019 - mse: 0.0019 - val_loss: 0.0023 - val_mse: 0.0023\n",
      "Epoch 313/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0019 - mse: 0.0019 - val_loss: 0.0023 - val_mse: 0.0023\n",
      "Epoch 314/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0019 - mse: 0.0019 - val_loss: 0.0023 - val_mse: 0.0023\n",
      "Epoch 315/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0019 - mse: 0.0019 - val_loss: 0.0023 - val_mse: 0.0023\n",
      "Epoch 316/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0019 - mse: 0.0019 - val_loss: 0.0023 - val_mse: 0.0023\n",
      "Epoch 317/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0019 - mse: 0.0019 - val_loss: 0.0023 - val_mse: 0.0023\n",
      "Epoch 318/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0019 - mse: 0.0019 - val_loss: 0.0023 - val_mse: 0.0023\n",
      "Epoch 319/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0019 - mse: 0.0019 - val_loss: 0.0023 - val_mse: 0.0023\n",
      "Epoch 320/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0019 - mse: 0.0019 - val_loss: 0.0022 - val_mse: 0.0022\n",
      "Epoch 321/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0019 - mse: 0.0019 - val_loss: 0.0022 - val_mse: 0.0022\n",
      "Epoch 322/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0019 - mse: 0.0019 - val_loss: 0.0022 - val_mse: 0.0022\n",
      "Epoch 323/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0019 - mse: 0.0019 - val_loss: 0.0022 - val_mse: 0.0022\n",
      "Epoch 324/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0019 - mse: 0.0019 - val_loss: 0.0022 - val_mse: 0.0022\n",
      "Epoch 325/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0019 - mse: 0.0019 - val_loss: 0.0022 - val_mse: 0.0022\n",
      "Epoch 326/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0019 - mse: 0.0019 - val_loss: 0.0022 - val_mse: 0.0022\n",
      "Epoch 327/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0019 - mse: 0.0019 - val_loss: 0.0022 - val_mse: 0.0022\n",
      "Epoch 328/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0019 - mse: 0.0019 - val_loss: 0.0022 - val_mse: 0.0022\n",
      "Epoch 329/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0019 - mse: 0.0019 - val_loss: 0.0022 - val_mse: 0.0022\n",
      "Epoch 330/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0019 - mse: 0.0019 - val_loss: 0.0022 - val_mse: 0.0022\n",
      "Epoch 331/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0019 - mse: 0.0019 - val_loss: 0.0022 - val_mse: 0.0022\n",
      "Epoch 332/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0019 - mse: 0.0019 - val_loss: 0.0022 - val_mse: 0.0022\n",
      "Epoch 333/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0019 - mse: 0.0019 - val_loss: 0.0022 - val_mse: 0.0022\n",
      "Epoch 334/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0019 - mse: 0.0019 - val_loss: 0.0022 - val_mse: 0.0022\n",
      "Epoch 335/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0018 - mse: 0.0018 - val_loss: 0.0022 - val_mse: 0.0022\n",
      "Epoch 336/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0018 - mse: 0.0018 - val_loss: 0.0022 - val_mse: 0.0022\n",
      "Epoch 337/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0018 - mse: 0.0018 - val_loss: 0.0022 - val_mse: 0.0022\n",
      "Epoch 338/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0018 - mse: 0.0018 - val_loss: 0.0022 - val_mse: 0.0022\n",
      "Epoch 339/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0018 - mse: 0.0018 - val_loss: 0.0022 - val_mse: 0.0022\n",
      "Epoch 340/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0018 - mse: 0.0018 - val_loss: 0.0021 - val_mse: 0.0021\n",
      "Epoch 341/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0018 - mse: 0.0018 - val_loss: 0.0022 - val_mse: 0.0022\n",
      "Epoch 342/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0018 - mse: 0.0018 - val_loss: 0.0021 - val_mse: 0.0021\n",
      "Epoch 343/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0018 - mse: 0.0018 - val_loss: 0.0022 - val_mse: 0.0022\n",
      "Epoch 344/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0018 - mse: 0.0018 - val_loss: 0.0022 - val_mse: 0.0022\n",
      "Epoch 345/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0018 - mse: 0.0018 - val_loss: 0.0021 - val_mse: 0.0021\n",
      "Epoch 346/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0018 - mse: 0.0018 - val_loss: 0.0021 - val_mse: 0.0021\n",
      "Epoch 347/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0018 - mse: 0.0018 - val_loss: 0.0021 - val_mse: 0.0021\n",
      "Epoch 348/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0018 - mse: 0.0018 - val_loss: 0.0021 - val_mse: 0.0021\n",
      "Epoch 349/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0018 - mse: 0.0018 - val_loss: 0.0021 - val_mse: 0.0021\n",
      "Epoch 350/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0018 - mse: 0.0018 - val_loss: 0.0021 - val_mse: 0.0021\n",
      "Epoch 351/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0018 - mse: 0.0018 - val_loss: 0.0021 - val_mse: 0.0021\n",
      "Epoch 352/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0018 - mse: 0.0018 - val_loss: 0.0021 - val_mse: 0.0021\n",
      "Epoch 353/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0018 - mse: 0.0018 - val_loss: 0.0021 - val_mse: 0.0021\n",
      "Epoch 354/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0018 - mse: 0.0018 - val_loss: 0.0021 - val_mse: 0.0021\n",
      "Epoch 355/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0018 - mse: 0.0018 - val_loss: 0.0021 - val_mse: 0.0021\n",
      "Epoch 356/400\n",
      "7/7 [==============================] - 0s 6ms/step - loss: 0.0018 - mse: 0.0018 - val_loss: 0.0021 - val_mse: 0.0021\n",
      "Epoch 357/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0018 - mse: 0.0018 - val_loss: 0.0021 - val_mse: 0.0021\n",
      "Epoch 358/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0018 - mse: 0.0018 - val_loss: 0.0021 - val_mse: 0.0021\n",
      "Epoch 359/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0021 - val_mse: 0.0021\n",
      "Epoch 360/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0021 - val_mse: 0.0021\n",
      "Epoch 361/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0021 - val_mse: 0.0021\n",
      "Epoch 362/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0018 - mse: 0.0018 - val_loss: 0.0021 - val_mse: 0.0021\n",
      "Epoch 363/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0018 - mse: 0.0018 - val_loss: 0.0021 - val_mse: 0.0021\n",
      "Epoch 364/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0020 - val_mse: 0.0020\n",
      "Epoch 365/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0020 - val_mse: 0.0020\n",
      "Epoch 366/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0020 - val_mse: 0.0020\n",
      "Epoch 367/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0021 - val_mse: 0.0021\n",
      "Epoch 368/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0020 - val_mse: 0.0020\n",
      "Epoch 369/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0020 - val_mse: 0.0020\n",
      "Epoch 370/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0021 - val_mse: 0.0021\n",
      "Epoch 371/400\n",
      "7/7 [==============================] - 0s 6ms/step - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0021 - val_mse: 0.0021\n",
      "Epoch 372/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0020 - val_mse: 0.0020\n",
      "Epoch 373/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0020 - val_mse: 0.0020\n",
      "Epoch 374/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0020 - val_mse: 0.0020\n",
      "Epoch 375/400\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0020 - val_mse: 0.0020\n",
      "Epoch 376/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0020 - val_mse: 0.0020\n",
      "Epoch 377/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0020 - val_mse: 0.0020\n",
      "Epoch 378/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0020 - val_mse: 0.0020\n",
      "Epoch 379/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0020 - val_mse: 0.0020\n",
      "Epoch 380/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0020 - val_mse: 0.0020\n",
      "Epoch 381/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0020 - val_mse: 0.0020\n",
      "Epoch 382/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0020 - val_mse: 0.0020\n",
      "Epoch 383/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0020 - val_mse: 0.0020\n",
      "Epoch 384/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0020 - val_mse: 0.0020\n",
      "Epoch 385/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0020 - val_mse: 0.0020\n",
      "Epoch 386/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0020 - val_mse: 0.0020\n",
      "Epoch 387/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0020 - val_mse: 0.0020\n",
      "Epoch 388/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0020 - val_mse: 0.0020\n",
      "Epoch 389/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0020 - val_mse: 0.0020\n",
      "Epoch 390/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0016 - mse: 0.0016 - val_loss: 0.0020 - val_mse: 0.0020\n",
      "Epoch 391/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0016 - mse: 0.0016 - val_loss: 0.0020 - val_mse: 0.0020\n",
      "Epoch 392/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0016 - mse: 0.0016 - val_loss: 0.0020 - val_mse: 0.0020\n",
      "Epoch 393/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0016 - mse: 0.0016 - val_loss: 0.0020 - val_mse: 0.0020\n",
      "Epoch 394/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0016 - mse: 0.0016 - val_loss: 0.0020 - val_mse: 0.0020\n",
      "Epoch 395/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0016 - mse: 0.0016 - val_loss: 0.0020 - val_mse: 0.0020\n",
      "Epoch 396/400\n",
      "7/7 [==============================] - 0s 7ms/step - loss: 0.0016 - mse: 0.0016 - val_loss: 0.0020 - val_mse: 0.0020\n",
      "Epoch 397/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0016 - mse: 0.0016 - val_loss: 0.0020 - val_mse: 0.0020\n",
      "Epoch 398/400\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0016 - mse: 0.0016 - val_loss: 0.0020 - val_mse: 0.0020\n",
      "Epoch 399/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0016 - mse: 0.0016 - val_loss: 0.0019 - val_mse: 0.0019\n",
      "Epoch 400/400\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0016 - mse: 0.0016 - val_loss: 0.0019 - val_mse: 0.0019\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 15ms/step - loss: 0.0016 - mse: 0.0016\n",
      "4/4 [==============================] - 0s 585us/step - loss: 0.0019 - mse: 0.0019\n",
      "[0.0019329285714775324, 0.0019329285714775324]\n",
      "11.700098752975464\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 352us/step - loss: 2.4464e-05 - mse: 2.4464e-05\n",
      "7/7 [==============================] - 0s 688us/step - loss: 0.6935 - mse: 0.6935\n",
      "48/48 [==============================] - 0s 662us/step - loss: 0.0116 - mse: 0.0116\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": 16,
   "id": "c34f6e3f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "5/5 - 0s - loss: 0.6760 - mse: 0.6681 - val_loss: 0.6326 - val_mse: 0.6142 - 426ms/epoch - 85ms/step\n",
      "iteration :1 Target train: tf.Tensor(0.62252825, shape=(), dtype=float32) loss1 tf.Tensor(0.62035954, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.002168724, shape=(), dtype=float32) loss2   tf.Tensor(0.0021032523, shape=(), dtype=float32) loss3  tf.Tensor(0.9999731, shape=(), dtype=float32) Target test: tf.Tensor(0.7284123, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.6075 - mse: 0.6011 - val_loss: 0.5681 - val_mse: 0.5525 - 37ms/epoch - 7ms/step\n",
      "iteration :2 Target train: tf.Tensor(0.55791616, shape=(), dtype=float32) loss1 tf.Tensor(0.5496619, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.008254274, shape=(), dtype=float32) loss2   tf.Tensor(0.00814907, shape=(), dtype=float32) loss3  tf.Tensor(0.9999508, shape=(), dtype=float32) Target test: tf.Tensor(0.6560717, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.5454 - mse: 0.5363 - val_loss: 0.5099 - val_mse: 0.4966 - 35ms/epoch - 7ms/step\n",
      "iteration :3 Target train: tf.Tensor(0.49969906, shape=(), dtype=float32) loss1 tf.Tensor(0.4818775, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.017821558, shape=(), dtype=float32) loss2   tf.Tensor(0.017678455, shape=(), dtype=float32) loss3  tf.Tensor(0.999994, shape=(), dtype=float32) Target test: tf.Tensor(0.5904046, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.4896 - mse: 0.4824 - val_loss: 0.4581 - val_mse: 0.4463 - 34ms/epoch - 7ms/step\n",
      "iteration :4 Target train: tf.Tensor(0.44771662, shape=(), dtype=float32) loss1 tf.Tensor(0.4173646, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.030352034, shape=(), dtype=float32) loss2   tf.Tensor(0.03017338, shape=(), dtype=float32) loss3  tf.Tensor(1.0001513, shape=(), dtype=float32) Target test: tf.Tensor(0.5312613, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.4401 - mse: 0.4312 - val_loss: 0.4121 - val_mse: 0.4013 - 39ms/epoch - 8ms/step\n",
      "iteration :5 Target train: tf.Tensor(0.40163946, shape=(), dtype=float32) loss1 tf.Tensor(0.35633668, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.04530277, shape=(), dtype=float32) loss2   tf.Tensor(0.045091346, shape=(), dtype=float32) loss3  tf.Tensor(1.0004586, shape=(), dtype=float32) Target test: tf.Tensor(0.47832975, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.3963 - mse: 0.3855 - val_loss: 0.3717 - val_mse: 0.3614 - 48ms/epoch - 10ms/step\n",
      "iteration :6 Target train: tf.Tensor(0.36101016, shape=(), dtype=float32) loss1 tf.Tensor(0.29887015, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.062140014, shape=(), dtype=float32) loss2   tf.Tensor(0.061898917, shape=(), dtype=float32) loss3  tf.Tensor(1.0009362, shape=(), dtype=float32) Target test: tf.Tensor(0.43117723, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.3577 - mse: 0.3461 - val_loss: 0.3361 - val_mse: 0.3260 - 36ms/epoch - 7ms/step\n",
      "iteration :7 Target train: tf.Tensor(0.32529512, shape=(), dtype=float32) loss1 tf.Tensor(0.24492851, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.080366604, shape=(), dtype=float32) loss2   tf.Tensor(0.08009904, shape=(), dtype=float32) loss3  tf.Tensor(1.0015864, shape=(), dtype=float32) Target test: tf.Tensor(0.3893002, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.3239 - mse: 0.3132 - val_loss: 0.3050 - val_mse: 0.2946 - 39ms/epoch - 8ms/step\n",
      "iteration :8 Target train: tf.Tensor(0.29393554, shape=(), dtype=float32) loss1 tf.Tensor(0.1943953, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.09954024, shape=(), dtype=float32) loss2   tf.Tensor(0.09924944, shape=(), dtype=float32) loss3  tf.Tensor(1.0023943, shape=(), dtype=float32) Target test: tf.Tensor(0.35216978, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.2942 - mse: 0.2836 - val_loss: 0.2776 - val_mse: 0.2669 - 46ms/epoch - 9ms/step\n",
      "iteration :9 Target train: tf.Tensor(0.2663879, shape=(), dtype=float32) loss1 tf.Tensor(0.14710504, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.11928288, shape=(), dtype=float32) loss2   tf.Tensor(0.118971884, shape=(), dtype=float32) loss3  tf.Tensor(1.0033299, shape=(), dtype=float32) Target test: tf.Tensor(0.31926867, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.2682 - mse: 0.2567 - val_loss: 0.2536 - val_mse: 0.2424 - 39ms/epoch - 8ms/step\n",
      "iteration :10 Target train: tf.Tensor(0.24215102, shape=(), dtype=float32) loss1 tf.Tensor(0.10286835, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.13928267, shape=(), dtype=float32) loss2   tf.Tensor(0.13895428, shape=(), dtype=float32) loss3  tf.Tensor(1.0043528, shape=(), dtype=float32) Target test: tf.Tensor(0.29011324, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.2453 - mse: 0.2345 - val_loss: 0.2324 - val_mse: 0.2208 - 42ms/epoch - 8ms/step\n",
      "iteration :11 Target train: tf.Tensor(0.22077921, shape=(), dtype=float32) loss1 tf.Tensor(0.061488107, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.1592911, shape=(), dtype=float32) loss2   tf.Tensor(0.15894774, shape=(), dtype=float32) loss3  tf.Tensor(1.0054166, shape=(), dtype=float32) Target test: tf.Tensor(0.2642638, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.2251 - mse: 0.2146 - val_loss: 0.2137 - val_mse: 0.2016 - 41ms/epoch - 8ms/step\n",
      "iteration :12 Target train: tf.Tensor(0.20188569, shape=(), dtype=float32) loss1 tf.Tensor(0.02276823, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.17911746, shape=(), dtype=float32) loss2   tf.Tensor(0.17876115, shape=(), dtype=float32) loss3  tf.Tensor(1.0064751, shape=(), dtype=float32) Target test: tf.Tensor(0.24132678, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.2073 - mse: 0.1950 - val_loss: 0.1972 - val_mse: 0.1846 - 37ms/epoch - 7ms/step\n",
      "iteration :13 Target train: tf.Tensor(0.1851392, shape=(), dtype=float32) loss1 tf.Tensor(0.013482451, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.19862165, shape=(), dtype=float32) loss2   tf.Tensor(0.19825412, shape=(), dtype=float32) loss3  tf.Tensor(1.0074846, shape=(), dtype=float32) Target test: tf.Tensor(0.2209524, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.1915 - mse: 0.1797 - val_loss: 0.1825 - val_mse: 0.1695 - 37ms/epoch - 7ms/step\n",
      "iteration :14 Target train: tf.Tensor(0.17025867, shape=(), dtype=float32) loss1 tf.Tensor(0.047446042, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.21770471, shape=(), dtype=float32) loss2   tf.Tensor(0.21732737, shape=(), dtype=float32) loss3  tf.Tensor(1.0084085, shape=(), dtype=float32) Target test: tf.Tensor(0.2028316, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.1774 - mse: 0.1659 - val_loss: 0.1695 - val_mse: 0.1561 - 43ms/epoch - 9ms/step\n",
      "iteration :15 Target train: tf.Tensor(0.15700245, shape=(), dtype=float32) loss1 tf.Tensor(0.0793035, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.23630595, shape=(), dtype=float32) loss2   tf.Tensor(0.23591988, shape=(), dtype=float32) loss3  tf.Tensor(1.0092188, shape=(), dtype=float32) Target test: tf.Tensor(0.18668754, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.1649 - mse: 0.1531 - val_loss: 0.1578 - val_mse: 0.1441 - 40ms/epoch - 8ms/step\n",
      "iteration :16 Target train: tf.Tensor(0.14516349, shape=(), dtype=float32) loss1 tf.Tensor(0.10922952, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.254393, shape=(), dtype=float32) loss2   tf.Tensor(0.25399914, shape=(), dtype=float32) loss3  tf.Tensor(1.0098953, shape=(), dtype=float32) Target test: tf.Tensor(0.17227472, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.1537 - mse: 0.1406 - val_loss: 0.1474 - val_mse: 0.1333 - 41ms/epoch - 8ms/step\n",
      "iteration :17 Target train: tf.Tensor(0.13456397, shape=(), dtype=float32) loss1 tf.Tensor(0.13738866, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.27195263, shape=(), dtype=float32) loss2   tf.Tensor(0.2715517, shape=(), dtype=float32) loss3  tf.Tensor(1.010426, shape=(), dtype=float32) Target test: tf.Tensor(0.15937704, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.1438 - mse: 0.1313 - val_loss: 0.1381 - val_mse: 0.1237 - 37ms/epoch - 7ms/step\n",
      "iteration :18 Target train: tf.Tensor(0.12505066, shape=(), dtype=float32) loss1 tf.Tensor(0.1639328, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.28898346, shape=(), dtype=float32) loss2   tf.Tensor(0.28857616, shape=(), dtype=float32) loss3  tf.Tensor(1.0108048, shape=(), dtype=float32) Target test: tf.Tensor(0.14780544, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.1348 - mse: 0.1227 - val_loss: 0.1297 - val_mse: 0.1151 - 39ms/epoch - 8ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iteration :19 Target train: tf.Tensor(0.11649118, shape=(), dtype=float32) loss1 tf.Tensor(0.18899913, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.30549031, shape=(), dtype=float32) loss2   tf.Tensor(0.30507714, shape=(), dtype=float32) loss3  tf.Tensor(1.0110297, shape=(), dtype=float32) Target test: tf.Tensor(0.13739584, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.1267 - mse: 0.1138 - val_loss: 0.1221 - val_mse: 0.1073 - 40ms/epoch - 8ms/step\n",
      "iteration :20 Target train: tf.Tensor(0.10877111, shape=(), dtype=float32) loss1 tf.Tensor(0.21270871, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.32147983, shape=(), dtype=float32) loss2   tf.Tensor(0.32106128, shape=(), dtype=float32) loss3  tf.Tensor(1.0111022, shape=(), dtype=float32) Target test: tf.Tensor(0.12800674, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.1195 - mse: 0.1068 - val_loss: 0.1153 - val_mse: 0.1002 - 38ms/epoch - 8ms/step\n",
      "iteration :21 Target train: tf.Tensor(0.10179145, shape=(), dtype=float32) loss1 tf.Tensor(0.23516673, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.33695817, shape=(), dtype=float32) loss2   tf.Tensor(0.33653477, shape=(), dtype=float32) loss3  tf.Tensor(1.0110257, shape=(), dtype=float32) Target test: tf.Tensor(0.11951677, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.1129 - mse: 0.0996 - val_loss: 0.1091 - val_mse: 0.0938 - 45ms/epoch - 9ms/step\n",
      "iteration :22 Target train: tf.Tensor(0.0954665, shape=(), dtype=float32) loss1 tf.Tensor(0.25646365, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.35193014, shape=(), dtype=float32) loss2   tf.Tensor(0.35150227, shape=(), dtype=float32) loss3  tf.Tensor(1.0108047, shape=(), dtype=float32) Target test: tf.Tensor(0.11182185, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.1069 - mse: 0.0939 - val_loss: 0.1035 - val_mse: 0.0879 - 41ms/epoch - 8ms/step\n",
      "iteration :23 Target train: tf.Tensor(0.08972201, shape=(), dtype=float32) loss1 tf.Tensor(0.2766775, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.3663995, shape=(), dtype=float32) loss2   tf.Tensor(0.36596754, shape=(), dtype=float32) loss3  tf.Tensor(1.0104444, shape=(), dtype=float32) Target test: tf.Tensor(0.10483258, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.1015 - mse: 0.0881 - val_loss: 0.0984 - val_mse: 0.0826 - 39ms/epoch - 8ms/step\n",
      "iteration :24 Target train: tf.Tensor(0.08449338, shape=(), dtype=float32) loss1 tf.Tensor(0.29587635, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.38036972, shape=(), dtype=float32) loss2   tf.Tensor(0.37993407, shape=(), dtype=float32) loss3  tf.Tensor(1.0099504, shape=(), dtype=float32) Target test: tf.Tensor(0.09847182, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0966 - mse: 0.0833 - val_loss: 0.0938 - val_mse: 0.0778 - 36ms/epoch - 7ms/step\n",
      "iteration :25 Target train: tf.Tensor(0.07972431, shape=(), dtype=float32) loss1 tf.Tensor(0.31412107, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.39384538, shape=(), dtype=float32) loss2   tf.Tensor(0.39340636, shape=(), dtype=float32) loss3  tf.Tensor(1.0093285, shape=(), dtype=float32) Target test: tf.Tensor(0.09267233, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0921 - mse: 0.0785 - val_loss: 0.0895 - val_mse: 0.0733 - 38ms/epoch - 8ms/step\n",
      "iteration :26 Target train: tf.Tensor(0.07536566, shape=(), dtype=float32) loss1 tf.Tensor(0.33146665, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.4068323, shape=(), dtype=float32) loss2   tf.Tensor(0.40639034, shape=(), dtype=float32) loss3  tf.Tensor(1.008585, shape=(), dtype=float32) Target test: tf.Tensor(0.08737543, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0880 - mse: 0.0744 - val_loss: 0.0857 - val_mse: 0.0693 - 36ms/epoch - 7ms/step\n",
      "iteration :27 Target train: tf.Tensor(0.07137422, shape=(), dtype=float32) loss1 tf.Tensor(0.34796447, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.4193387, shape=(), dtype=float32) loss2   tf.Tensor(0.41889408, shape=(), dtype=float32) loss3  tf.Tensor(1.0077256, shape=(), dtype=float32) Target test: tf.Tensor(0.0825292, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0843 - mse: 0.0707 - val_loss: 0.0821 - val_mse: 0.0655 - 35ms/epoch - 7ms/step\n",
      "iteration :28 Target train: tf.Tensor(0.06771204, shape=(), dtype=float32) loss1 tf.Tensor(0.36366275, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.4313748, shape=(), dtype=float32) loss2   tf.Tensor(0.43092772, shape=(), dtype=float32) loss3  tf.Tensor(1.0067568, shape=(), dtype=float32) Target test: tf.Tensor(0.0780878, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0809 - mse: 0.0670 - val_loss: 0.0789 - val_mse: 0.0621 - 40ms/epoch - 8ms/step\n",
      "iteration :29 Target train: tf.Tensor(0.064345606, shape=(), dtype=float32) loss1 tf.Tensor(0.37860656, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.44295216, shape=(), dtype=float32) loss2   tf.Tensor(0.442503, shape=(), dtype=float32) loss3  tf.Tensor(1.005684, shape=(), dtype=float32) Target test: tf.Tensor(0.07401046, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0777 - mse: 0.0638 - val_loss: 0.0759 - val_mse: 0.0590 - 40ms/epoch - 8ms/step\n",
      "iteration :30 Target train: tf.Tensor(0.061245456, shape=(), dtype=float32) loss1 tf.Tensor(0.3928377, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.45408317, shape=(), dtype=float32) loss2   tf.Tensor(0.4536322, shape=(), dtype=float32) loss3  tf.Tensor(1.0045129, shape=(), dtype=float32) Target test: tf.Tensor(0.07026114, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0748 - mse: 0.0610 - val_loss: 0.0731 - val_mse: 0.0561 - 37ms/epoch - 7ms/step\n",
      "iteration :31 Target train: tf.Tensor(0.058385324, shape=(), dtype=float32) loss1 tf.Tensor(0.40639594, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.46478125, shape=(), dtype=float32) loss2   tf.Tensor(0.4643287, shape=(), dtype=float32) loss3  tf.Tensor(1.0032487, shape=(), dtype=float32) Target test: tf.Tensor(0.06680762, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0721 - mse: 0.0581 - val_loss: 0.0705 - val_mse: 0.0534 - 38ms/epoch - 8ms/step\n",
      "iteration :32 Target train: tf.Tensor(0.055742007, shape=(), dtype=float32) loss1 tf.Tensor(0.41931716, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.47505915, shape=(), dtype=float32) loss2   tf.Tensor(0.47460523, shape=(), dtype=float32) loss3  tf.Tensor(1.0018963, shape=(), dtype=float32) Target test: tf.Tensor(0.06362131, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0696 - mse: 0.0556 - val_loss: 0.0682 - val_mse: 0.0509 - 42ms/epoch - 8ms/step\n",
      "iteration :33 Target train: tf.Tensor(0.05329484, shape=(), dtype=float32) loss1 tf.Tensor(0.43163472, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.48492956, shape=(), dtype=float32) loss2   tf.Tensor(0.48447454, shape=(), dtype=float32) loss3  tf.Tensor(1.00046, shape=(), dtype=float32) Target test: tf.Tensor(0.060676802, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0673 - mse: 0.0531 - val_loss: 0.0660 - val_mse: 0.0486 - 41ms/epoch - 8ms/step\n",
      "iteration :34 Target train: tf.Tensor(0.051025372, shape=(), dtype=float32) loss1 tf.Tensor(0.4433795, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.49440485, shape=(), dtype=float32) loss2   tf.Tensor(0.49394897, shape=(), dtype=float32) loss3  tf.Tensor(0.9989449, shape=(), dtype=float32) Target test: tf.Tensor(0.05795136, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0652 - mse: 0.0511 - val_loss: 0.0640 - val_mse: 0.0465 - 38ms/epoch - 8ms/step\n",
      "iteration :35 Target train: tf.Tensor(0.048917163, shape=(), dtype=float32) loss1 tf.Tensor(0.45457983, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.503497, shape=(), dtype=float32) loss2   tf.Tensor(0.5030403, shape=(), dtype=float32) loss3  tf.Tensor(0.9973553, shape=(), dtype=float32) Target test: tf.Tensor(0.055424757, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0632 - mse: 0.0490 - val_loss: 0.0621 - val_mse: 0.0445 - 38ms/epoch - 8ms/step\n",
      "iteration :36 Target train: tf.Tensor(0.046955474, shape=(), dtype=float32) loss1 tf.Tensor(0.46526206, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.5122175, shape=(), dtype=float32) loss2   tf.Tensor(0.51176023, shape=(), dtype=float32) loss3  tf.Tensor(0.9956957, shape=(), dtype=float32) Target test: tf.Tensor(0.053078867, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0614 - mse: 0.0470 - val_loss: 0.0603 - val_mse: 0.0427 - 38ms/epoch - 8ms/step\n",
      "iteration :37 Target train: tf.Tensor(0.04512715, shape=(), dtype=float32) loss1 tf.Tensor(0.47545046, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.5205776, shape=(), dtype=float32) loss2   tf.Tensor(0.52011997, shape=(), dtype=float32) loss3  tf.Tensor(0.99397045, shape=(), dtype=float32) Target test: tf.Tensor(0.050897457, shape=(), dtype=float32)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "5/5 - 0s - loss: 0.0597 - mse: 0.0452 - val_loss: 0.0587 - val_mse: 0.0409 - 37ms/epoch - 7ms/step\n",
      "iteration :38 Target train: tf.Tensor(0.04342031, shape=(), dtype=float32) loss1 tf.Tensor(0.48516822, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.52858853, shape=(), dtype=float32) loss2   tf.Tensor(0.5281307, shape=(), dtype=float32) loss3  tf.Tensor(0.9921839, shape=(), dtype=float32) Target test: tf.Tensor(0.04886594, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0581 - mse: 0.0437 - val_loss: 0.0571 - val_mse: 0.0393 - 36ms/epoch - 7ms/step\n",
      "iteration :39 Target train: tf.Tensor(0.041824322, shape=(), dtype=float32) loss1 tf.Tensor(0.49443707, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.5362614, shape=(), dtype=float32) loss2   tf.Tensor(0.5358034, shape=(), dtype=float32) loss3  tf.Tensor(0.9903404, shape=(), dtype=float32) Target test: tf.Tensor(0.046971183, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0566 - mse: 0.0421 - val_loss: 0.0557 - val_mse: 0.0378 - 38ms/epoch - 8ms/step\n",
      "iteration :40 Target train: tf.Tensor(0.040329587, shape=(), dtype=float32) loss1 tf.Tensor(0.5032774, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.543607, shape=(), dtype=float32) loss2   tf.Tensor(0.5431491, shape=(), dtype=float32) loss3  tf.Tensor(0.98844415, shape=(), dtype=float32) Target test: tf.Tensor(0.045201354, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0552 - mse: 0.0407 - val_loss: 0.0543 - val_mse: 0.0364 - 38ms/epoch - 8ms/step\n",
      "iteration :41 Target train: tf.Tensor(0.03892745, shape=(), dtype=float32) loss1 tf.Tensor(0.5117086, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.55063605, shape=(), dtype=float32) loss2   tf.Tensor(0.55017835, shape=(), dtype=float32) loss3  tf.Tensor(0.98649913, shape=(), dtype=float32) Target test: tf.Tensor(0.043545768, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0539 - mse: 0.0392 - val_loss: 0.0531 - val_mse: 0.0351 - 43ms/epoch - 9ms/step\n",
      "iteration :42 Target train: tf.Tensor(0.037610136, shape=(), dtype=float32) loss1 tf.Tensor(0.5197489, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.55735904, shape=(), dtype=float32) loss2   tf.Tensor(0.5569017, shape=(), dtype=float32) loss3  tf.Tensor(0.9845087, shape=(), dtype=float32) Target test: tf.Tensor(0.041994777, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0526 - mse: 0.0380 - val_loss: 0.0519 - val_mse: 0.0339 - 40ms/epoch - 8ms/step\n",
      "iteration :43 Target train: tf.Tensor(0.03637057, shape=(), dtype=float32) loss1 tf.Tensor(0.52741605, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.5637866, shape=(), dtype=float32) loss2   tf.Tensor(0.5633297, shape=(), dtype=float32) loss3  tf.Tensor(0.9824766, shape=(), dtype=float32) Target test: tf.Tensor(0.04053965, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0514 - mse: 0.0368 - val_loss: 0.0508 - val_mse: 0.0327 - 38ms/epoch - 8ms/step\n",
      "iteration :44 Target train: tf.Tensor(0.0352024, shape=(), dtype=float32) loss1 tf.Tensor(0.5347264, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.56992877, shape=(), dtype=float32) loss2   tf.Tensor(0.56947243, shape=(), dtype=float32) loss3  tf.Tensor(0.98040634, shape=(), dtype=float32) Target test: tf.Tensor(0.039172463, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0503 - mse: 0.0356 - val_loss: 0.0497 - val_mse: 0.0316 - 38ms/epoch - 8ms/step\n",
      "iteration :45 Target train: tf.Tensor(0.03409985, shape=(), dtype=float32) loss1 tf.Tensor(0.541696, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.5757959, shape=(), dtype=float32) loss2   tf.Tensor(0.57534015, shape=(), dtype=float32) loss3  tf.Tensor(0.97830117, shape=(), dtype=float32) Target test: tf.Tensor(0.03788606, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0493 - mse: 0.0345 - val_loss: 0.0487 - val_mse: 0.0306 - 40ms/epoch - 8ms/step\n",
      "iteration :46 Target train: tf.Tensor(0.03305767, shape=(), dtype=float32) loss1 tf.Tensor(0.5483401, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.5813978, shape=(), dtype=float32) loss2   tf.Tensor(0.5809428, shape=(), dtype=float32) loss3  tf.Tensor(0.97616357, shape=(), dtype=float32) Target test: tf.Tensor(0.036673892, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0483 - mse: 0.0335 - val_loss: 0.0477 - val_mse: 0.0296 - 38ms/epoch - 8ms/step\n",
      "iteration :47 Target train: tf.Tensor(0.03207115, shape=(), dtype=float32) loss1 tf.Tensor(0.5546731, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.58674425, shape=(), dtype=float32) loss2   tf.Tensor(0.58629006, shape=(), dtype=float32) loss3  tf.Tensor(0.9739967, shape=(), dtype=float32) Target test: tf.Tensor(0.035530057, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0474 - mse: 0.0325 - val_loss: 0.0468 - val_mse: 0.0287 - 38ms/epoch - 8ms/step\n",
      "iteration :48 Target train: tf.Tensor(0.031135952, shape=(), dtype=float32) loss1 tf.Tensor(0.5607092, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.59184515, shape=(), dtype=float32) loss2   tf.Tensor(0.591392, shape=(), dtype=float32) loss3  tf.Tensor(0.97180307, shape=(), dtype=float32) Target test: tf.Tensor(0.03444917, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0465 - mse: 0.0316 - val_loss: 0.0460 - val_mse: 0.0279 - 40ms/epoch - 8ms/step\n",
      "iteration :49 Target train: tf.Tensor(0.030248217, shape=(), dtype=float32) loss1 tf.Tensor(0.5664617, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.5967099, shape=(), dtype=float32) loss2   tf.Tensor(0.5962577, shape=(), dtype=float32) loss3  tf.Tensor(0.9695855, shape=(), dtype=float32) Target test: tf.Tensor(0.033426363, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0456 - mse: 0.0307 - val_loss: 0.0451 - val_mse: 0.0270 - 41ms/epoch - 8ms/step\n",
      "iteration :50 Target train: tf.Tensor(0.029404344, shape=(), dtype=float32) loss1 tf.Tensor(0.5719435, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.60134786, shape=(), dtype=float32) loss2   tf.Tensor(0.60089666, shape=(), dtype=float32) loss3  tf.Tensor(0.9673459, shape=(), dtype=float32) Target test: tf.Tensor(0.032457154, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0448 - mse: 0.0299 - val_loss: 0.0444 - val_mse: 0.0263 - 42ms/epoch - 8ms/step\n",
      "iteration :51 Target train: tf.Tensor(0.028601132, shape=(), dtype=float32) loss1 tf.Tensor(0.5771671, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.6057682, shape=(), dtype=float32) loss2   tf.Tensor(0.6053181, shape=(), dtype=float32) loss3  tf.Tensor(0.96508676, shape=(), dtype=float32) Target test: tf.Tensor(0.031537525, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0441 - mse: 0.0291 - val_loss: 0.0436 - val_mse: 0.0255 - 38ms/epoch - 8ms/step\n",
      "iteration :52 Target train: tf.Tensor(0.027835643, shape=(), dtype=float32) loss1 tf.Tensor(0.58214396, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.6099796, shape=(), dtype=float32) loss2   tf.Tensor(0.60953087, shape=(), dtype=float32) loss3  tf.Tensor(0.9628098, shape=(), dtype=float32) Target test: tf.Tensor(0.030663785, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0433 - mse: 0.0283 - val_loss: 0.0429 - val_mse: 0.0248 - 39ms/epoch - 8ms/step\n",
      "iteration :53 Target train: tf.Tensor(0.027105179, shape=(), dtype=float32) loss1 tf.Tensor(0.586886, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.61399114, shape=(), dtype=float32) loss2   tf.Tensor(0.6135436, shape=(), dtype=float32) loss3  tf.Tensor(0.9605171, shape=(), dtype=float32) Target test: tf.Tensor(0.029832572, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0426 - mse: 0.0276 - val_loss: 0.0422 - val_mse: 0.0242 - 39ms/epoch - 8ms/step\n",
      "iteration :54 Target train: tf.Tensor(0.026407328, shape=(), dtype=float32) loss1 tf.Tensor(0.59140396, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.61781126, shape=(), dtype=float32) loss2   tf.Tensor(0.617365, shape=(), dtype=float32) loss3  tf.Tensor(0.9582105, shape=(), dtype=float32) Target test: tf.Tensor(0.029040832, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0420 - mse: 0.0269 - val_loss: 0.0416 - val_mse: 0.0235 - 37ms/epoch - 7ms/step\n",
      "iteration :55 Target train: tf.Tensor(0.025739852, shape=(), dtype=float32) loss1 tf.Tensor(0.5957084, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.6214482, shape=(), dtype=float32) loss2   tf.Tensor(0.6210033, shape=(), dtype=float32) loss3  tf.Tensor(0.9558915, shape=(), dtype=float32) Target test: tf.Tensor(0.028285759, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0413 - mse: 0.0262 - val_loss: 0.0409 - val_mse: 0.0229 - 35ms/epoch - 7ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iteration :56 Target train: tf.Tensor(0.02510071, shape=(), dtype=float32) loss1 tf.Tensor(0.59980947, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.6249102, shape=(), dtype=float32) loss2   tf.Tensor(0.6244668, shape=(), dtype=float32) loss3  tf.Tensor(0.9535619, shape=(), dtype=float32) Target test: tf.Tensor(0.027564809, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0407 - mse: 0.0256 - val_loss: 0.0403 - val_mse: 0.0223 - 41ms/epoch - 8ms/step\n",
      "iteration :57 Target train: tf.Tensor(0.024488036, shape=(), dtype=float32) loss1 tf.Tensor(0.60371715, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.6282052, shape=(), dtype=float32) loss2   tf.Tensor(0.6277632, shape=(), dtype=float32) loss3  tf.Tensor(0.95122284, shape=(), dtype=float32) Target test: tf.Tensor(0.026875634, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0401 - mse: 0.0250 - val_loss: 0.0398 - val_mse: 0.0218 - 40ms/epoch - 8ms/step\n",
      "iteration :58 Target train: tf.Tensor(0.023900153, shape=(), dtype=float32) loss1 tf.Tensor(0.60744065, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.6313408, shape=(), dtype=float32) loss2   tf.Tensor(0.63090026, shape=(), dtype=float32) loss3  tf.Tensor(0.94887567, shape=(), dtype=float32) Target test: tf.Tensor(0.026216114, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0395 - mse: 0.0244 - val_loss: 0.0392 - val_mse: 0.0212 - 41ms/epoch - 8ms/step\n",
      "iteration :59 Target train: tf.Tensor(0.0233355, shape=(), dtype=float32) loss1 tf.Tensor(0.6109891, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.6343246, shape=(), dtype=float32) loss2   tf.Tensor(0.6338857, shape=(), dtype=float32) loss3  tf.Tensor(0.94652176, shape=(), dtype=float32) Target test: tf.Tensor(0.025584294, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0390 - mse: 0.0238 - val_loss: 0.0387 - val_mse: 0.0207 - 43ms/epoch - 9ms/step\n",
      "iteration :60 Target train: tf.Tensor(0.022792652, shape=(), dtype=float32) loss1 tf.Tensor(0.6143711, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.63716376, shape=(), dtype=float32) loss2   tf.Tensor(0.6367263, shape=(), dtype=float32) loss3  tf.Tensor(0.944162, shape=(), dtype=float32) Target test: tf.Tensor(0.0249784, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0385 - mse: 0.0233 - val_loss: 0.0381 - val_mse: 0.0202 - 38ms/epoch - 8ms/step\n",
      "iteration :61 Target train: tf.Tensor(0.022270301, shape=(), dtype=float32) loss1 tf.Tensor(0.6175949, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.6398652, shape=(), dtype=float32) loss2   tf.Tensor(0.6394294, shape=(), dtype=float32) loss3  tf.Tensor(0.94179744, shape=(), dtype=float32) Target test: tf.Tensor(0.024396788, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0380 - mse: 0.0227 - val_loss: 0.0376 - val_mse: 0.0198 - 43ms/epoch - 9ms/step\n",
      "iteration :62 Target train: tf.Tensor(0.021767247, shape=(), dtype=float32) loss1 tf.Tensor(0.6206687, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.64243597, shape=(), dtype=float32) loss2   tf.Tensor(0.6420017, shape=(), dtype=float32) loss3  tf.Tensor(0.93942904, shape=(), dtype=float32) Target test: tf.Tensor(0.023837952, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0375 - mse: 0.0222 - val_loss: 0.0372 - val_mse: 0.0193 - 34ms/epoch - 7ms/step\n",
      "iteration :63 Target train: tf.Tensor(0.021282388, shape=(), dtype=float32) loss1 tf.Tensor(0.6236, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.6448824, shape=(), dtype=float32) loss2   tf.Tensor(0.6444498, shape=(), dtype=float32) loss3  tf.Tensor(0.9370578, shape=(), dtype=float32) Target test: tf.Tensor(0.023300515, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0370 - mse: 0.0218 - val_loss: 0.0367 - val_mse: 0.0189 - 36ms/epoch - 7ms/step\n",
      "iteration :64 Target train: tf.Tensor(0.020814704, shape=(), dtype=float32) loss1 tf.Tensor(0.6263963, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.647211, shape=(), dtype=float32) loss2   tf.Tensor(0.64678, shape=(), dtype=float32) loss3  tf.Tensor(0.9346843, shape=(), dtype=float32) Target test: tf.Tensor(0.022783205, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0365 - mse: 0.0213 - val_loss: 0.0362 - val_mse: 0.0185 - 46ms/epoch - 9ms/step\n",
      "iteration :65 Target train: tf.Tensor(0.02036326, shape=(), dtype=float32) loss1 tf.Tensor(0.62906456, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.64942783, shape=(), dtype=float32) loss2   tf.Tensor(0.6489984, shape=(), dtype=float32) loss3  tf.Tensor(0.9323093, shape=(), dtype=float32) Target test: tf.Tensor(0.022284875, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0361 - mse: 0.0208 - val_loss: 0.0358 - val_mse: 0.0181 - 40ms/epoch - 8ms/step\n",
      "iteration :66 Target train: tf.Tensor(0.019927202, shape=(), dtype=float32) loss1 tf.Tensor(0.6316113, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.6515385, shape=(), dtype=float32) loss2   tf.Tensor(0.65111077, shape=(), dtype=float32) loss3  tf.Tensor(0.9299335, shape=(), dtype=float32) Target test: tf.Tensor(0.021804431, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0356 - mse: 0.0204 - val_loss: 0.0354 - val_mse: 0.0177 - 38ms/epoch - 8ms/step\n",
      "iteration :67 Target train: tf.Tensor(0.019505728, shape=(), dtype=float32) loss1 tf.Tensor(0.634043, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.6535487, shape=(), dtype=float32) loss2   tf.Tensor(0.65312266, shape=(), dtype=float32) loss3  tf.Tensor(0.92755747, shape=(), dtype=float32) Target test: tf.Tensor(0.021340903, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0352 - mse: 0.0200 - val_loss: 0.0350 - val_mse: 0.0173 - 36ms/epoch - 7ms/step\n",
      "iteration :68 Target train: tf.Tensor(0.019098101, shape=(), dtype=float32) loss1 tf.Tensor(0.6363658, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.6554639, shape=(), dtype=float32) loss2   tf.Tensor(0.6550395, shape=(), dtype=float32) loss3  tf.Tensor(0.9251817, shape=(), dtype=float32) Target test: tf.Tensor(0.020893369, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0348 - mse: 0.0195 - val_loss: 0.0346 - val_mse: 0.0170 - 44ms/epoch - 9ms/step\n",
      "iteration :69 Target train: tf.Tensor(0.018703638, shape=(), dtype=float32) loss1 tf.Tensor(0.63858557, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.6572892, shape=(), dtype=float32) loss2   tf.Tensor(0.65686655, shape=(), dtype=float32) loss3  tf.Tensor(0.9228068, shape=(), dtype=float32) Target test: tf.Tensor(0.020460978, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0344 - mse: 0.0191 - val_loss: 0.0342 - val_mse: 0.0166 - 42ms/epoch - 8ms/step\n",
      "iteration :70 Target train: tf.Tensor(0.018321687, shape=(), dtype=float32) loss1 tf.Tensor(0.64070797, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.65902966, shape=(), dtype=float32) loss2   tf.Tensor(0.6586086, shape=(), dtype=float32) loss3  tf.Tensor(0.920433, shape=(), dtype=float32) Target test: tf.Tensor(0.020042965, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0340 - mse: 0.0187 - val_loss: 0.0338 - val_mse: 0.0163 - 36ms/epoch - 7ms/step\n",
      "iteration :71 Target train: tf.Tensor(0.01795168, shape=(), dtype=float32) loss1 tf.Tensor(0.64273816, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.66068983, shape=(), dtype=float32) loss2   tf.Tensor(0.6602705, shape=(), dtype=float32) loss3  tf.Tensor(0.91806084, shape=(), dtype=float32) Target test: tf.Tensor(0.019638592, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0337 - mse: 0.0183 - val_loss: 0.0334 - val_mse: 0.0160 - 37ms/epoch - 7ms/step\n",
      "iteration :72 Target train: tf.Tensor(0.017593058, shape=(), dtype=float32) loss1 tf.Tensor(0.64468116, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.66227424, shape=(), dtype=float32) loss2   tf.Tensor(0.6618566, shape=(), dtype=float32) loss3  tf.Tensor(0.91569054, shape=(), dtype=float32) Target test: tf.Tensor(0.019247197, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0333 - mse: 0.0180 - val_loss: 0.0331 - val_mse: 0.0157 - 39ms/epoch - 8ms/step\n",
      "iteration :73 Target train: tf.Tensor(0.0172453, shape=(), dtype=float32) loss1 tf.Tensor(0.64654195, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.66378725, shape=(), dtype=float32) loss2   tf.Tensor(0.66337126, shape=(), dtype=float32) loss3  tf.Tensor(0.91332257, shape=(), dtype=float32) Target test: tf.Tensor(0.018868146, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0329 - mse: 0.0177 - val_loss: 0.0327 - val_mse: 0.0154 - 42ms/epoch - 8ms/step\n",
      "iteration :74 Target train: tf.Tensor(0.016907945, shape=(), dtype=float32) loss1 tf.Tensor(0.64832497, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.6652329, shape=(), dtype=float32) loss2   tf.Tensor(0.6648185, shape=(), dtype=float32) loss3  tf.Tensor(0.910957, shape=(), dtype=float32) Target test: tf.Tensor(0.018500866, shape=(), dtype=float32)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "5/5 - 0s - loss: 0.0326 - mse: 0.0173 - val_loss: 0.0324 - val_mse: 0.0151 - 38ms/epoch - 8ms/step\n",
      "iteration :75 Target train: tf.Tensor(0.016580524, shape=(), dtype=float32) loss1 tf.Tensor(0.6500345, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.666615, shape=(), dtype=float32) loss2   tf.Tensor(0.6662024, shape=(), dtype=float32) loss3  tf.Tensor(0.90859425, shape=(), dtype=float32) Target test: tf.Tensor(0.018144805, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0323 - mse: 0.0170 - val_loss: 0.0321 - val_mse: 0.0148 - 38ms/epoch - 8ms/step\n",
      "iteration :76 Target train: tf.Tensor(0.016262613, shape=(), dtype=float32) loss1 tf.Tensor(0.6516748, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.6679374, shape=(), dtype=float32) loss2   tf.Tensor(0.6675264, shape=(), dtype=float32) loss3  tf.Tensor(0.9062345, shape=(), dtype=float32) Target test: tf.Tensor(0.017799454, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0319 - mse: 0.0166 - val_loss: 0.0317 - val_mse: 0.0145 - 38ms/epoch - 8ms/step\n",
      "iteration :77 Target train: tf.Tensor(0.015953837, shape=(), dtype=float32) loss1 tf.Tensor(0.6532496, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.66920346, shape=(), dtype=float32) loss2   tf.Tensor(0.6687941, shape=(), dtype=float32) loss3  tf.Tensor(0.9038779, shape=(), dtype=float32) Target test: tf.Tensor(0.017464355, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0316 - mse: 0.0163 - val_loss: 0.0314 - val_mse: 0.0142 - 44ms/epoch - 9ms/step\n",
      "iteration :78 Target train: tf.Tensor(0.015653819, shape=(), dtype=float32) loss1 tf.Tensor(0.6547626, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.6704164, shape=(), dtype=float32) loss2   tf.Tensor(0.6700087, shape=(), dtype=float32) loss3  tf.Tensor(0.9015247, shape=(), dtype=float32) Target test: tf.Tensor(0.017139064, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0313 - mse: 0.0160 - val_loss: 0.0311 - val_mse: 0.0140 - 39ms/epoch - 8ms/step\n",
      "iteration :79 Target train: tf.Tensor(0.015362209, shape=(), dtype=float32) loss1 tf.Tensor(0.6562173, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.6715795, shape=(), dtype=float32) loss2   tf.Tensor(0.6711735, shape=(), dtype=float32) loss3  tf.Tensor(0.8991749, shape=(), dtype=float32) Target test: tf.Tensor(0.016823161, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0310 - mse: 0.0157 - val_loss: 0.0308 - val_mse: 0.0137 - 40ms/epoch - 8ms/step\n",
      "iteration :80 Target train: tf.Tensor(0.015078677, shape=(), dtype=float32) loss1 tf.Tensor(0.6576169, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.6726956, shape=(), dtype=float32) loss2   tf.Tensor(0.6722913, shape=(), dtype=float32) loss3  tf.Tensor(0.8968289, shape=(), dtype=float32) Target test: tf.Tensor(0.016516257, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0307 - mse: 0.0154 - val_loss: 0.0305 - val_mse: 0.0135 - 41ms/epoch - 8ms/step\n",
      "iteration :81 Target train: tf.Tensor(0.014802916, shape=(), dtype=float32) loss1 tf.Tensor(0.65896463, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.67376757, shape=(), dtype=float32) loss2   tf.Tensor(0.67336476, shape=(), dtype=float32) loss3  tf.Tensor(0.8944865, shape=(), dtype=float32) Target test: tf.Tensor(0.016217988, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0304 - mse: 0.0151 - val_loss: 0.0303 - val_mse: 0.0132 - 44ms/epoch - 9ms/step\n",
      "iteration :82 Target train: tf.Tensor(0.014534616, shape=(), dtype=float32) loss1 tf.Tensor(0.66026336, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.67479795, shape=(), dtype=float32) loss2   tf.Tensor(0.6743968, shape=(), dtype=float32) loss3  tf.Tensor(0.89214796, shape=(), dtype=float32) Target test: tf.Tensor(0.015928, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0302 - mse: 0.0149 - val_loss: 0.0300 - val_mse: 0.0130 - 46ms/epoch - 9ms/step\n",
      "iteration :83 Target train: tf.Tensor(0.014273514, shape=(), dtype=float32) loss1 tf.Tensor(0.6615158, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.6757893, shape=(), dtype=float32) loss2   tf.Tensor(0.67538977, shape=(), dtype=float32) loss3  tf.Tensor(0.88981324, shape=(), dtype=float32) Target test: tf.Tensor(0.015645973, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0299 - mse: 0.0146 - val_loss: 0.0297 - val_mse: 0.0128 - 43ms/epoch - 9ms/step\n",
      "iteration :84 Target train: tf.Tensor(0.014019342, shape=(), dtype=float32) loss1 tf.Tensor(0.6627246, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.676744, shape=(), dtype=float32) loss2   tf.Tensor(0.67634594, shape=(), dtype=float32) loss3  tf.Tensor(0.88748276, shape=(), dtype=float32) Target test: tf.Tensor(0.015371605, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0296 - mse: 0.0143 - val_loss: 0.0295 - val_mse: 0.0126 - 43ms/epoch - 9ms/step\n",
      "iteration :85 Target train: tf.Tensor(0.01377185, shape=(), dtype=float32) loss1 tf.Tensor(0.66389227, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.6776641, shape=(), dtype=float32) loss2   tf.Tensor(0.6772677, shape=(), dtype=float32) loss3  tf.Tensor(0.8851562, shape=(), dtype=float32) Target test: tf.Tensor(0.015104592, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0294 - mse: 0.0141 - val_loss: 0.0292 - val_mse: 0.0124 - 44ms/epoch - 9ms/step\n",
      "iteration :86 Target train: tf.Tensor(0.013530792, shape=(), dtype=float32) loss1 tf.Tensor(0.6650212, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.678552, shape=(), dtype=float32) loss2   tf.Tensor(0.6781571, shape=(), dtype=float32) loss3  tf.Tensor(0.88283384, shape=(), dtype=float32) Target test: tf.Tensor(0.014844662, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0291 - mse: 0.0138 - val_loss: 0.0290 - val_mse: 0.0122 - 47ms/epoch - 9ms/step\n",
      "iteration :87 Target train: tf.Tensor(0.013295945, shape=(), dtype=float32) loss1 tf.Tensor(0.6661134, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.6794093, shape=(), dtype=float32) loss2   tf.Tensor(0.67901593, shape=(), dtype=float32) loss3  tf.Tensor(0.8805156, shape=(), dtype=float32) Target test: tf.Tensor(0.014591556, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0289 - mse: 0.0136 - val_loss: 0.0287 - val_mse: 0.0119 - 49ms/epoch - 10ms/step\n",
      "iteration :88 Target train: tf.Tensor(0.013067098, shape=(), dtype=float32) loss1 tf.Tensor(0.6671708, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.68023795, shape=(), dtype=float32) loss2   tf.Tensor(0.67984605, shape=(), dtype=float32) loss3  tf.Tensor(0.87820154, shape=(), dtype=float32) Target test: tf.Tensor(0.014345031, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0286 - mse: 0.0133 - val_loss: 0.0285 - val_mse: 0.0118 - 38ms/epoch - 8ms/step\n",
      "iteration :89 Target train: tf.Tensor(0.012844049, shape=(), dtype=float32) loss1 tf.Tensor(0.6681956, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.68103963, shape=(), dtype=float32) loss2   tf.Tensor(0.6806493, shape=(), dtype=float32) loss3  tf.Tensor(0.8758919, shape=(), dtype=float32) Target test: tf.Tensor(0.014104858, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0284 - mse: 0.0131 - val_loss: 0.0282 - val_mse: 0.0116 - 40ms/epoch - 8ms/step\n",
      "iteration :90 Target train: tf.Tensor(0.012626597, shape=(), dtype=float32) loss1 tf.Tensor(0.66918933, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.6818159, shape=(), dtype=float32) loss2   tf.Tensor(0.6814272, shape=(), dtype=float32) loss3  tf.Tensor(0.8735865, shape=(), dtype=float32) Target test: tf.Tensor(0.013870802, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0282 - mse: 0.0129 - val_loss: 0.0280 - val_mse: 0.0114 - 39ms/epoch - 8ms/step\n",
      "iteration :91 Target train: tf.Tensor(0.012414551, shape=(), dtype=float32) loss1 tf.Tensor(0.67015374, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.6825683, shape=(), dtype=float32) loss2   tf.Tensor(0.682181, shape=(), dtype=float32) loss3  tf.Tensor(0.87128514, shape=(), dtype=float32) Target test: tf.Tensor(0.0136426585, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0279 - mse: 0.0127 - val_loss: 0.0278 - val_mse: 0.0112 - 39ms/epoch - 8ms/step\n",
      "iteration :92 Target train: tf.Tensor(0.012207743, shape=(), dtype=float32) loss1 tf.Tensor(0.6710906, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.68329835, shape=(), dtype=float32) loss2   tf.Tensor(0.6829124, shape=(), dtype=float32) loss3  tf.Tensor(0.8689881, shape=(), dtype=float32) Target test: tf.Tensor(0.0134202195, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0277 - mse: 0.0125 - val_loss: 0.0276 - val_mse: 0.0110 - 40ms/epoch - 8ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iteration :93 Target train: tf.Tensor(0.0120059885, shape=(), dtype=float32) loss1 tf.Tensor(0.6720012, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.68400717, shape=(), dtype=float32) loss2   tf.Tensor(0.68362254, shape=(), dtype=float32) loss3  tf.Tensor(0.86669517, shape=(), dtype=float32) Target test: tf.Tensor(0.0132032875, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0275 - mse: 0.0123 - val_loss: 0.0274 - val_mse: 0.0108 - 41ms/epoch - 8ms/step\n",
      "iteration :94 Target train: tf.Tensor(0.01180913, shape=(), dtype=float32) loss1 tf.Tensor(0.672887, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.68469614, shape=(), dtype=float32) loss2   tf.Tensor(0.68431306, shape=(), dtype=float32) loss3  tf.Tensor(0.8644065, shape=(), dtype=float32) Target test: tf.Tensor(0.012991686, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0273 - mse: 0.0121 - val_loss: 0.0272 - val_mse: 0.0107 - 35ms/epoch - 7ms/step\n",
      "iteration :95 Target train: tf.Tensor(0.01161701, shape=(), dtype=float32) loss1 tf.Tensor(0.67374927, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.6853663, shape=(), dtype=float32) loss2   tf.Tensor(0.6849847, shape=(), dtype=float32) loss3  tf.Tensor(0.8621222, shape=(), dtype=float32) Target test: tf.Tensor(0.012785238, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0271 - mse: 0.0119 - val_loss: 0.0270 - val_mse: 0.0105 - 44ms/epoch - 9ms/step\n",
      "iteration :96 Target train: tf.Tensor(0.0114303315, shape=(), dtype=float32) loss1 tf.Tensor(0.67456, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.68599033, shape=(), dtype=float32) loss2   tf.Tensor(0.68561, shape=(), dtype=float32) loss3  tf.Tensor(0.860792, shape=(), dtype=float32) Target test: tf.Tensor(0.012583396, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0269 - mse: 0.0117 - val_loss: 0.0268 - val_mse: 0.0104 - 38ms/epoch - 8ms/step\n",
      "iteration :97 Target train: tf.Tensor(0.011250603, shape=(), dtype=float32) loss1 tf.Tensor(0.6752697, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.68652034, shape=(), dtype=float32) loss2   tf.Tensor(0.68614125, shape=(), dtype=float32) loss3  tf.Tensor(0.85926974, shape=(), dtype=float32) Target test: tf.Tensor(0.012385212, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0267 - mse: 0.0115 - val_loss: 0.0266 - val_mse: 0.0102 - 36ms/epoch - 7ms/step\n",
      "iteration :98 Target train: tf.Tensor(0.0110762715, shape=(), dtype=float32) loss1 tf.Tensor(0.6759414, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.6870177, shape=(), dtype=float32) loss2   tf.Tensor(0.68663996, shape=(), dtype=float32) loss3  tf.Tensor(0.85724473, shape=(), dtype=float32) Target test: tf.Tensor(0.012191034, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0265 - mse: 0.0113 - val_loss: 0.0264 - val_mse: 0.0100 - 41ms/epoch - 8ms/step\n",
      "iteration :99 Target train: tf.Tensor(0.0109053105, shape=(), dtype=float32) loss1 tf.Tensor(0.67663676, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.6875421, shape=(), dtype=float32) loss2   tf.Tensor(0.68716586, shape=(), dtype=float32) loss3  tf.Tensor(0.8557684, shape=(), dtype=float32) Target test: tf.Tensor(0.012001647, shape=(), dtype=float32)\n",
      "5/5 - 0s - loss: 0.0263 - mse: 0.0111 - val_loss: 0.0262 - val_mse: 0.0099 - 41ms/epoch - 8ms/step\n",
      "iteration :100 Target train: tf.Tensor(0.010735667, shape=(), dtype=float32) loss1 tf.Tensor(0.6773996, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.68813527, shape=(), dtype=float32) loss2   tf.Tensor(0.6877608, shape=(), dtype=float32) loss3  tf.Tensor(0.8541542, shape=(), dtype=float32) Target test: tf.Tensor(0.011818498, 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=32, 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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\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.010735667, shape=(), dtype=float32)\n",
      "Target test:  tf.Tensor(0.011818498, 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.80036104, -0.04071287,  0.        ,  0.        ],\n",
      "       [ 0.09161148,  0.9121865 ,  0.        ,  0.        ]],\n",
      "      dtype=float32)]\n",
      "Weights (kernel_P2):\n",
      " [array([[ 0.80427724, -0.03292644,  0.        ,  0.        ],\n",
      "       [ 0.13193356,  0.9090766 ,  0.        ,  0.        ],\n",
      "       [ 0.        ,  0.        ,  1.        ,  0.        ],\n",
      "       [ 0.        ,  0.        ,  0.        ,  1.        ]],\n",
      "      dtype=float32)]\n",
      "Weights (kernel_P3):\n",
      " [array([[ 0.8093533 , -0.02317254],\n",
      "       [ 0.16672926,  0.87524116],\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.8408121  -0.19054934 -0.12041373  0.          0.          0.\n",
      "   0.          0.        ]\n",
      " [ 0.06670039  0.97590727 -0.00313102  0.          0.          0.\n",
      "   0.          0.        ]\n",
      " [ 0.0639885   0.06141125  0.97561836  0.          0.          0.\n",
      "   0.          0.        ]]\n",
      "Weights (kernel_I2):\n",
      " [[ 0.8352835  -0.16388807 -0.0765553   0.          0.          0.\n",
      "   0.          0.        ]\n",
      " [ 0.10973819  1.1256732  -0.01542444  0.          0.          0.\n",
      "   0.          0.        ]\n",
      " [ 0.09978965  0.11228783  0.9803698   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.8357852  -0.12849769 -0.02431819]\n",
      " [ 0.15012544  1.1359764  -0.08890962]\n",
      " [ 0.12860991  0.12026316  0.9323707 ]\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.80036104 -0.04071287  0.          0.        ]\n",
      " [ 0.09161148  0.9121865   0.          0.        ]]\n",
      "Weights (kernel_P2):\n",
      " [[ 0.80427724 -0.03292644  0.          0.        ]\n",
      " [ 0.13193356  0.9090766   0.          0.        ]\n",
      " [ 0.          0.          1.          0.        ]\n",
      " [ 0.          0.          0.          1.        ]]\n",
      "Weights (kernel_P3):\n",
      " [[ 0.8093533  -0.02317254]\n",
      " [ 0.16672926  0.87524116]\n",
      " [ 0.          0.        ]\n",
      " [ 0.          0.        ]]\n",
      "Weights Final input P:\n",
      " [[ 0.48146492 -0.52315855 -0.15109518]\n",
      " [ 0.2960508   1.2114389  -0.12227804]\n",
      " [ 0.27918237  0.28514287  0.867546  ]]\n",
      "Weights Final output Q:\n",
      " [[ 0.50607854 -0.0702509 ]\n",
      " [ 0.29479492  0.71865517]]\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": [
      "5/5 - 0s - loss: 0.0104 - mse: 0.0104 - val_loss: 0.0085 - val_mse: 0.0085 - 240ms/epoch - 48ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0091 - mse: 0.0091\n",
      "4/4 [==============================] - 0s 758us/step - loss: 0.0100 - mse: 0.0100\n",
      "5/5 - 0s - loss: 0.0089 - mse: 0.0089 - val_loss: 0.0078 - val_mse: 0.0078 - 31ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 13ms/step - loss: 0.0079 - mse: 0.0079\n",
      "4/4 [==============================] - 0s 756us/step - loss: 0.0090 - mse: 0.0090\n",
      "5/5 - 0s - loss: 0.0077 - mse: 0.0077 - val_loss: 0.0070 - val_mse: 0.0070 - 34ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0070 - mse: 0.0070\n",
      "4/4 [==============================] - 0s 887us/step - loss: 0.0080 - mse: 0.0080\n",
      "5/5 - 0s - loss: 0.0066 - mse: 0.0066 - val_loss: 0.0060 - val_mse: 0.0060 - 39ms/epoch - 8ms/step\n",
      "1/1 [==============================] - 0s 14ms/step - loss: 0.0060 - mse: 0.0060\n",
      "4/4 [==============================] - 0s 2ms/step - loss: 0.0069 - mse: 0.0069\n",
      "5/5 - 0s - loss: 0.0058 - mse: 0.0058 - val_loss: 0.0051 - val_mse: 0.0051 - 34ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0052 - mse: 0.0052\n",
      "4/4 [==============================] - 0s 646us/step - loss: 0.0060 - mse: 0.0060\n",
      "5/5 - 0s - loss: 0.0051 - mse: 0.0051 - val_loss: 0.0044 - val_mse: 0.0044 - 29ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 15ms/step - loss: 0.0046 - mse: 0.0046\n",
      "4/4 [==============================] - 0s 2ms/step - loss: 0.0053 - mse: 0.0053\n",
      "5/5 - 0s - loss: 0.0045 - mse: 0.0045 - val_loss: 0.0041 - val_mse: 0.0041 - 39ms/epoch - 8ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0041 - mse: 0.0041\n",
      "4/4 [==============================] - 0s 749us/step - loss: 0.0048 - mse: 0.0048\n",
      "5/5 - 0s - loss: 0.0040 - mse: 0.0040 - val_loss: 0.0038 - val_mse: 0.0038 - 29ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 13ms/step - loss: 0.0037 - mse: 0.0037\n",
      "4/4 [==============================] - 0s 649us/step - loss: 0.0044 - mse: 0.0044\n",
      "5/5 - 0s - loss: 0.0036 - mse: 0.0036 - val_loss: 0.0034 - val_mse: 0.0034 - 30ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 14ms/step - loss: 0.0034 - mse: 0.0034\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0040 - mse: 0.0040\n",
      "5/5 - 0s - loss: 0.0032 - mse: 0.0032 - val_loss: 0.0031 - val_mse: 0.0031 - 31ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0031 - mse: 0.0031\n",
      "4/4 [==============================] - 0s 825us/step - loss: 0.0037 - mse: 0.0037\n",
      "5/5 - 0s - loss: 0.0030 - mse: 0.0030 - val_loss: 0.0030 - val_mse: 0.0030 - 30ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 13ms/step - loss: 0.0028 - mse: 0.0028\n",
      "4/4 [==============================] - 0s 835us/step - loss: 0.0034 - mse: 0.0034\n",
      "5/5 - 0s - loss: 0.0027 - mse: 0.0027 - val_loss: 0.0028 - val_mse: 0.0028 - 36ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0026 - mse: 0.0026\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0032 - mse: 0.0032\n",
      "5/5 - 0s - loss: 0.0025 - mse: 0.0025 - val_loss: 0.0026 - val_mse: 0.0026 - 32ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0024 - mse: 0.0024\n",
      "4/4 [==============================] - 0s 680us/step - loss: 0.0030 - mse: 0.0030\n",
      "5/5 - 0s - loss: 0.0023 - mse: 0.0023 - val_loss: 0.0025 - val_mse: 0.0025 - 29ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0023 - mse: 0.0023\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0028 - mse: 0.0028\n",
      "5/5 - 0s - loss: 0.0022 - mse: 0.0022 - val_loss: 0.0024 - val_mse: 0.0024 - 30ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 13ms/step - loss: 0.0021 - mse: 0.0021\n",
      "4/4 [==============================] - 0s 607us/step - loss: 0.0026 - mse: 0.0026\n",
      "5/5 - 0s - loss: 0.0020 - mse: 0.0020 - val_loss: 0.0022 - val_mse: 0.0022 - 31ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0020 - mse: 0.0020\n",
      "4/4 [==============================] - 0s 661us/step - loss: 0.0025 - mse: 0.0025\n",
      "5/5 - 0s - loss: 0.0019 - mse: 0.0019 - val_loss: 0.0021 - val_mse: 0.0021 - 34ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0019 - mse: 0.0019\n",
      "4/4 [==============================] - 0s 734us/step - loss: 0.0024 - mse: 0.0024\n",
      "5/5 - 0s - loss: 0.0018 - mse: 0.0018 - val_loss: 0.0020 - val_mse: 0.0020 - 29ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0018 - mse: 0.0018\n",
      "4/4 [==============================] - 0s 659us/step - loss: 0.0023 - mse: 0.0023\n",
      "5/5 - 0s - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0020 - val_mse: 0.0020 - 30ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0018 - mse: 0.0018\n",
      "4/4 [==============================] - 0s 592us/step - loss: 0.0023 - mse: 0.0023\n",
      "5/5 - 0s - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0019 - val_mse: 0.0019 - 34ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0017 - mse: 0.0017\n",
      "4/4 [==============================] - 0s 906us/step - loss: 0.0022 - mse: 0.0022\n",
      "5/5 - 0s - loss: 0.0016 - mse: 0.0016 - val_loss: 0.0018 - val_mse: 0.0018 - 36ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 14ms/step - loss: 0.0016 - mse: 0.0016\n",
      "4/4 [==============================] - 0s 931us/step - loss: 0.0021 - mse: 0.0021\n",
      "5/5 - 0s - loss: 0.0016 - mse: 0.0016 - val_loss: 0.0019 - val_mse: 0.0019 - 30ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0016 - mse: 0.0016\n",
      "4/4 [==============================] - 0s 700us/step - loss: 0.0021 - mse: 0.0021\n",
      "5/5 - 0s - loss: 0.0016 - mse: 0.0016 - val_loss: 0.0018 - val_mse: 0.0018 - 30ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 13ms/step - loss: 0.0016 - mse: 0.0016\n",
      "4/4 [==============================] - 0s 728us/step - loss: 0.0020 - mse: 0.0020\n",
      "5/5 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0018 - val_mse: 0.0018 - 34ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 13ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 748us/step - loss: 0.0020 - mse: 0.0020\n",
      "5/5 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0017 - val_mse: 0.0017 - 27ms/epoch - 5ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0015 - mse: 0.0015\n",
      "4/4 [==============================] - 0s 961us/step - loss: 0.0019 - mse: 0.0019\n",
      "5/5 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0017 - val_mse: 0.0017 - 30ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 13ms/step - loss: 0.0014 - mse: 0.0014\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0019 - mse: 0.0019\n",
      "5/5 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0017 - val_mse: 0.0017 - 34ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0014 - mse: 0.0014\n",
      "4/4 [==============================] - 0s 676us/step - loss: 0.0019 - mse: 0.0019\n",
      "5/5 - 0s - loss: 0.0013 - mse: 0.0013 - val_loss: 0.0016 - val_mse: 0.0016 - 31ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0014 - mse: 0.0014\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0018 - mse: 0.0018\n",
      "5/5 - 0s - loss: 0.0013 - mse: 0.0013 - val_loss: 0.0016 - val_mse: 0.0016 - 30ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 14ms/step - loss: 0.0014 - mse: 0.0014\n",
      "4/4 [==============================] - 0s 846us/step - loss: 0.0018 - mse: 0.0018\n",
      "5/5 - 0s - loss: 0.0013 - mse: 0.0013 - val_loss: 0.0016 - val_mse: 0.0016 - 36ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0013 - mse: 0.0013\n",
      "4/4 [==============================] - 0s 688us/step - loss: 0.0018 - mse: 0.0018\n",
      "5/5 - 0s - loss: 0.0013 - mse: 0.0013 - val_loss: 0.0016 - val_mse: 0.0016 - 35ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0013 - mse: 0.0013\n",
      "4/4 [==============================] - 0s 942us/step - loss: 0.0018 - mse: 0.0018\n",
      "5/5 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0015 - val_mse: 0.0015 - 31ms/epoch - 6ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0013 - mse: 0.0013\n",
      "4/4 [==============================] - 0s 686us/step - loss: 0.0017 - mse: 0.0017\n",
      "5/5 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0015 - val_mse: 0.0015 - 27ms/epoch - 5ms/step\n",
      "1/1 [==============================] - 0s 14ms/step - loss: 0.0013 - mse: 0.0013\n",
      "4/4 [==============================] - 0s 746us/step - loss: 0.0017 - mse: 0.0017\n",
      "5/5 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0015 - val_mse: 0.0015 - 34ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 13ms/step - loss: 0.0013 - mse: 0.0013\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0017 - mse: 0.0017\n",
      "5/5 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0015 - val_mse: 0.0015 - 30ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0013 - mse: 0.0013\n",
      "4/4 [==============================] - 0s 714us/step - loss: 0.0017 - mse: 0.0017\n",
      "5/5 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0015 - val_mse: 0.0015 - 33ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 13ms/step - loss: 0.0012 - mse: 0.0012\n",
      "4/4 [==============================] - 0s 632us/step - loss: 0.0017 - mse: 0.0017\n",
      "5/5 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0015 - val_mse: 0.0015 - 29ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 13ms/step - loss: 0.0012 - mse: 0.0012\n",
      "4/4 [==============================] - 0s 824us/step - loss: 0.0017 - mse: 0.0017\n",
      "5/5 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0015 - val_mse: 0.0015 - 34ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0012 - mse: 0.0012\n",
      "4/4 [==============================] - 0s 805us/step - loss: 0.0017 - mse: 0.0017\n",
      "5/5 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0014 - val_mse: 0.0014 - 34ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 13ms/step - loss: 0.0012 - mse: 0.0012\n",
      "4/4 [==============================] - 0s 659us/step - loss: 0.0016 - mse: 0.0016\n",
      "5/5 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0014 - val_mse: 0.0014 - 30ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 14ms/step - loss: 0.0012 - mse: 0.0012\n",
      "4/4 [==============================] - 0s 595us/step - loss: 0.0016 - mse: 0.0016\n",
      "5/5 - 0s - loss: 0.0012 - mse: 0.0012 - val_loss: 0.0015 - val_mse: 0.0015 - 31ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0012 - mse: 0.0012\n",
      "4/4 [==============================] - 0s 992us/step - loss: 0.0016 - mse: 0.0016\n",
      "5/5 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0014 - val_mse: 0.0014 - 32ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 13ms/step - loss: 0.0012 - mse: 0.0012\n",
      "4/4 [==============================] - 0s 730us/step - loss: 0.0016 - mse: 0.0016\n",
      "5/5 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0014 - val_mse: 0.0014 - 27ms/epoch - 5ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0012 - mse: 0.0012\n",
      "4/4 [==============================] - 0s 663us/step - loss: 0.0016 - mse: 0.0016\n",
      "5/5 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0014 - val_mse: 0.0014 - 31ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 15ms/step - loss: 0.0012 - mse: 0.0012\n",
      "4/4 [==============================] - 0s 757us/step - loss: 0.0016 - mse: 0.0016\n",
      "5/5 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0014 - val_mse: 0.0014 - 35ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0012 - mse: 0.0012\n",
      "4/4 [==============================] - 0s 740us/step - loss: 0.0016 - mse: 0.0016\n",
      "5/5 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0014 - val_mse: 0.0014 - 32ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 15ms/step - loss: 0.0012 - mse: 0.0012\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0016 - mse: 0.0016\n",
      "5/5 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0013 - val_mse: 0.0013 - 33ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 13ms/step - loss: 0.0012 - mse: 0.0012\n",
      "4/4 [==============================] - 0s 717us/step - loss: 0.0016 - mse: 0.0016\n",
      "5/5 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0013 - val_mse: 0.0013 - 35ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0012 - mse: 0.0012\n",
      "4/4 [==============================] - 0s 682us/step - loss: 0.0016 - mse: 0.0016\n",
      "5/5 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0014 - val_mse: 0.0014 - 32ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0012 - mse: 0.0012\n",
      "4/4 [==============================] - 0s 781us/step - loss: 0.0016 - mse: 0.0016\n",
      "5/5 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0013 - val_mse: 0.0013 - 29ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 14ms/step - loss: 0.0011 - mse: 0.0011\n",
      "4/4 [==============================] - 0s 642us/step - loss: 0.0015 - mse: 0.0015\n",
      "5/5 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0013 - val_mse: 0.0013 - 32ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0011 - mse: 0.0011\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0015 - mse: 0.0015\n",
      "5/5 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0013 - val_mse: 0.0013 - 33ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0011 - mse: 0.0011\n",
      "4/4 [==============================] - 0s 685us/step - loss: 0.0016 - mse: 0.0016\n",
      "5/5 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0013 - val_mse: 0.0013 - 29ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 13ms/step - loss: 0.0011 - mse: 0.0011\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0016 - mse: 0.0016\n",
      "5/5 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0014 - val_mse: 0.0014 - 32ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0011 - mse: 0.0011\n",
      "4/4 [==============================] - 0s 585us/step - loss: 0.0016 - mse: 0.0016\n",
      "5/5 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0013 - val_mse: 0.0013 - 41ms/epoch - 8ms/step\n",
      "1/1 [==============================] - 0s 20ms/step - loss: 0.0011 - mse: 0.0011\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0015 - mse: 0.0015\n",
      "5/5 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0013 - val_mse: 0.0013 - 31ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 17ms/step - loss: 0.0011 - mse: 0.0011\n",
      "4/4 [==============================] - 0s 886us/step - loss: 0.0015 - mse: 0.0015\n",
      "5/5 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0013 - val_mse: 0.0013 - 37ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0011 - mse: 0.0011\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0015 - mse: 0.0015\n",
      "5/5 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0013 - val_mse: 0.0013 - 30ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0012 - mse: 0.0012\n",
      "4/4 [==============================] - 0s 731us/step - loss: 0.0015 - mse: 0.0015\n",
      "5/5 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0013 - val_mse: 0.0013 - 30ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0011 - mse: 0.0011\n",
      "4/4 [==============================] - 0s 815us/step - loss: 0.0016 - mse: 0.0016\n",
      "5/5 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0013 - val_mse: 0.0013 - 29ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0011 - mse: 0.0011\n",
      "4/4 [==============================] - 0s 959us/step - loss: 0.0015 - mse: 0.0015\n",
      "5/5 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0013 - val_mse: 0.0013 - 36ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0011 - mse: 0.0011\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0015 - mse: 0.0015\n",
      "5/5 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0013 - val_mse: 0.0013 - 32ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0011 - mse: 0.0011\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0015 - mse: 0.0015\n",
      "5/5 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0013 - val_mse: 0.0013 - 29ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0011 - mse: 0.0011\n",
      "4/4 [==============================] - 0s 837us/step - loss: 0.0015 - mse: 0.0015\n",
      "5/5 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0013 - val_mse: 0.0013 - 33ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0011 - mse: 0.0011\n",
      "4/4 [==============================] - 0s 654us/step - loss: 0.0015 - mse: 0.0015\n",
      "5/5 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0013 - val_mse: 0.0013 - 33ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0011 - mse: 0.0011\n",
      "4/4 [==============================] - 0s 686us/step - loss: 0.0015 - mse: 0.0015\n",
      "5/5 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0013 - val_mse: 0.0013 - 32ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0011 - mse: 0.0011\n",
      "4/4 [==============================] - 0s 619us/step - loss: 0.0015 - mse: 0.0015\n",
      "5/5 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0013 - val_mse: 0.0013 - 34ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0011 - mse: 0.0011\n",
      "4/4 [==============================] - 0s 762us/step - loss: 0.0015 - mse: 0.0015\n",
      "5/5 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0013 - val_mse: 0.0013 - 36ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 13ms/step - loss: 0.0011 - mse: 0.0011\n",
      "4/4 [==============================] - 0s 712us/step - loss: 0.0015 - mse: 0.0015\n",
      "5/5 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0013 - val_mse: 0.0013 - 29ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0011 - mse: 0.0011\n",
      "4/4 [==============================] - 0s 878us/step - loss: 0.0015 - mse: 0.0015\n",
      "5/5 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0012 - val_mse: 0.0012 - 31ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 15ms/step - loss: 0.0011 - mse: 0.0011\n",
      "4/4 [==============================] - 0s 786us/step - loss: 0.0015 - mse: 0.0015\n",
      "5/5 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0012 - val_mse: 0.0012 - 36ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0011 - mse: 0.0011\n",
      "4/4 [==============================] - 0s 649us/step - loss: 0.0015 - mse: 0.0015\n",
      "5/5 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0013 - val_mse: 0.0013 - 32ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0011 - mse: 0.0011\n",
      "4/4 [==============================] - 0s 770us/step - loss: 0.0015 - mse: 0.0015\n",
      "5/5 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0013 - val_mse: 0.0013 - 30ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0011 - mse: 0.0011\n",
      "4/4 [==============================] - 0s 629us/step - loss: 0.0015 - mse: 0.0015\n",
      "5/5 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0013 - val_mse: 0.0013 - 28ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0011 - mse: 0.0011\n",
      "4/4 [==============================] - 0s 621us/step - loss: 0.0015 - mse: 0.0015\n",
      "5/5 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0013 - val_mse: 0.0013 - 41ms/epoch - 8ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0011 - mse: 0.0011\n",
      "4/4 [==============================] - 0s 652us/step - loss: 0.0015 - mse: 0.0015\n",
      "5/5 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0013 - val_mse: 0.0013 - 29ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0011 - mse: 0.0011\n",
      "4/4 [==============================] - 0s 760us/step - loss: 0.0015 - mse: 0.0015\n",
      "5/5 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0012 - val_mse: 0.0012 - 29ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0011 - mse: 0.0011\n",
      "4/4 [==============================] - 0s 945us/step - loss: 0.0015 - mse: 0.0015\n",
      "5/5 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0012 - val_mse: 0.0012 - 31ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0011 - mse: 0.0011\n",
      "4/4 [==============================] - 0s 857us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0012 - val_mse: 0.0012 - 33ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0011 - mse: 0.0011\n",
      "4/4 [==============================] - 0s 625us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0013 - val_mse: 0.0013 - 31ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0011 - mse: 0.0011\n",
      "4/4 [==============================] - 0s 686us/step - loss: 0.0015 - mse: 0.0015\n",
      "5/5 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0012 - val_mse: 0.0012 - 30ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0011 - mse: 0.0011\n",
      "4/4 [==============================] - 0s 938us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0012 - val_mse: 0.0012 - 28ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 15ms/step - loss: 0.0011 - mse: 0.0011\n",
      "4/4 [==============================] - 0s 640us/step - loss: 0.0015 - mse: 0.0015\n",
      "5/5 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0013 - val_mse: 0.0013 - 35ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0011 - mse: 0.0011\n",
      "4/4 [==============================] - 0s 640us/step - loss: 0.0015 - mse: 0.0015\n",
      "5/5 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0012 - val_mse: 0.0012 - 37ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0011 - mse: 0.0011\n",
      "4/4 [==============================] - 0s 758us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0012 - val_mse: 0.0012 - 29ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0011 - mse: 0.0011\n",
      "4/4 [==============================] - 0s 807us/step - loss: 0.0015 - mse: 0.0015\n",
      "5/5 - 0s - loss: 9.9835e-04 - mse: 9.9835e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 29ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 14ms/step - loss: 0.0011 - mse: 0.0011\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0015 - mse: 0.0015\n",
      "5/5 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0012 - val_mse: 0.0012 - 30ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 778us/step - loss: 0.0015 - mse: 0.0015\n",
      "5/5 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0013 - val_mse: 0.0013 - 38ms/epoch - 8ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0011 - mse: 0.0011\n",
      "4/4 [==============================] - 0s 653us/step - loss: 0.0015 - mse: 0.0015\n",
      "5/5 - 0s - loss: 9.8162e-04 - mse: 9.8162e-04 - val_loss: 0.0013 - val_mse: 0.0013 - 36ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0011 - mse: 0.0011\n",
      "4/4 [==============================] - 0s 961us/step - loss: 0.0015 - mse: 0.0015\n",
      "5/5 - 0s - loss: 0.0011 - mse: 0.0011 - val_loss: 0.0012 - val_mse: 0.0012 - 29ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 671us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0012 - val_mse: 0.0012 - 31ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0011 - mse: 0.0011\n",
      "4/4 [==============================] - 0s 853us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0012 - val_mse: 0.0012 - 33ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0011 - mse: 0.0011\n",
      "4/4 [==============================] - 0s 693us/step - loss: 0.0015 - mse: 0.0015\n",
      "5/5 - 0s - loss: 9.9858e-04 - mse: 9.9858e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 37ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0011 - mse: 0.0011\n",
      "4/4 [==============================] - 0s 894us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0012 - val_mse: 0.0012 - 32ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0010 - mse: 0.0010\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "4/4 [==============================] - 0s 925us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.9927e-04 - mse: 9.9927e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 32ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0011 - mse: 0.0011\n",
      "4/4 [==============================] - 0s 653us/step - loss: 0.0015 - mse: 0.0015\n",
      "5/5 - 0s - loss: 9.9300e-04 - mse: 9.9300e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 32ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 818us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0012 - val_mse: 0.0012 - 30ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 2ms/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0012 - val_mse: 0.0012 - 29ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 858us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.9011e-04 - mse: 9.9011e-04 - val_loss: 0.0013 - val_mse: 0.0013 - 31ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0011 - mse: 0.0011\n",
      "4/4 [==============================] - 0s 892us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0012 - val_mse: 0.0012 - 31ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 870us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0012 - val_mse: 0.0012 - 29ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 901us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0013 - val_mse: 0.0013 - 34ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0011 - mse: 0.0011\n",
      "4/4 [==============================] - 0s 641us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0012 - val_mse: 0.0012 - 32ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 905us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.9095e-04 - mse: 9.9095e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 33ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 722us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0012 - val_mse: 0.0012 - 32ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 647us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.9015e-04 - mse: 9.9015e-04 - val_loss: 0.0013 - val_mse: 0.0013 - 30ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0011 - mse: 0.0011\n",
      "4/4 [==============================] - 0s 689us/step - loss: 0.0015 - mse: 0.0015\n",
      "5/5 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0012 - val_mse: 0.0012 - 30ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 13ms/step - loss: 0.0011 - mse: 0.0011\n",
      "4/4 [==============================] - 0s 648us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0012 - val_mse: 0.0012 - 31ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 779us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.9533e-04 - mse: 9.9533e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 27ms/epoch - 5ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0012 - val_mse: 0.0012 - 28ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 697us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.9888e-04 - mse: 9.9888e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 62ms/epoch - 12ms/step\n",
      "1/1 [==============================] - 0s 13ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 887us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.8759e-04 - mse: 9.8759e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 28ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 623us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.8886e-04 - mse: 9.8886e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 29ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 974us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.8126e-04 - mse: 9.8126e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 33ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 641us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.9053e-04 - mse: 9.9053e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 31ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 2ms/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.9743e-04 - mse: 9.9743e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 30ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.8900e-04 - mse: 9.8900e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 34ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 650us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.9297e-04 - mse: 9.9297e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 29ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 765us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.8681e-04 - mse: 9.8681e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 29ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 634us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.9400e-04 - mse: 9.9400e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 43ms/epoch - 9ms/step\n",
      "1/1 [==============================] - 0s 14ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 930us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.8979e-04 - mse: 9.8979e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 33ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 593us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.9421e-04 - mse: 9.9421e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 28ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 14ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 683us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0012 - val_mse: 0.0012 - 29ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 16ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 625us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.8724e-04 - mse: 9.8724e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 35ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0011 - mse: 0.0011\n",
      "4/4 [==============================] - 0s 977us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.9694e-04 - mse: 9.9694e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 30ms/epoch - 6ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0012 - val_mse: 0.0012 - 31ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 741us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0012 - val_mse: 0.0012 - 30ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0011 - mse: 0.0011\n",
      "4/4 [==============================] - 0s 954us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.8468e-04 - mse: 9.8468e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 36ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 684us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.8732e-04 - mse: 9.8732e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 33ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 635us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.7415e-04 - mse: 9.7415e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 29ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 14ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 707us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.8377e-04 - mse: 9.8377e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 28ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 13ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 631us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.9234e-04 - mse: 9.9234e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 32ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 573us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0012 - val_mse: 0.0012 - 26ms/epoch - 5ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 2ms/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.8024e-04 - mse: 9.8024e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 33ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 15ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 748us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.7817e-04 - mse: 9.7817e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 31ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 924us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.9010e-04 - mse: 9.9010e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 29ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 14ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0012 - val_mse: 0.0012 - 31ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 667us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.7767e-04 - mse: 9.7767e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 34ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 682us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.7572e-04 - mse: 9.7572e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 33ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 631us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.8159e-04 - mse: 9.8159e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 28ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 722us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.7541e-04 - mse: 9.7541e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 31ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.7540e-04 - mse: 9.7540e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 31ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 645us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.9391e-04 - mse: 9.9391e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 36ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 619us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.6214e-04 - mse: 9.6214e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 28ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 15ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 765us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.7733e-04 - mse: 9.7733e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 29ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 15ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 829us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.9889e-04 - mse: 9.9889e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 31ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 901us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0012 - val_mse: 0.0012 - 39ms/epoch - 8ms/step\n",
      "1/1 [==============================] - 0s 13ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 947us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.8540e-04 - mse: 9.8540e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 30ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 637us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.9374e-04 - mse: 9.9374e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 29ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 16ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 901us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.9187e-04 - mse: 9.9187e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 31ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 896us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.8095e-04 - mse: 9.8095e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 34ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 625us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.9615e-04 - mse: 9.9615e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 30ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 2ms/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.9073e-04 - mse: 9.9073e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 32ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 14ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 675us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.9698e-04 - mse: 9.9698e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 36ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 13ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 703us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.8218e-04 - mse: 9.8218e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 29ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 13ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.7910e-04 - mse: 9.7910e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 35ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 13ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 697us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.7427e-04 - mse: 9.7427e-04 - val_loss: 0.0011 - val_mse: 0.0011 - 33ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 13ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 612us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0012 - val_mse: 0.0012 - 31ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 623us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.7191e-04 - mse: 9.7191e-04 - val_loss: 0.0011 - val_mse: 0.0011 - 28ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 623us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0012 - val_mse: 0.0012 - 28ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 660us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.6378e-04 - mse: 9.6378e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 34ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 655us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.8149e-04 - mse: 9.8149e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 32ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 13ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 638us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.7257e-04 - mse: 9.7257e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 28ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.6325e-04 - mse: 9.6325e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 33ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 13ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.7017e-04 - mse: 9.7017e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 39ms/epoch - 8ms/step\n",
      "1/1 [==============================] - 0s 13ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 753us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.7424e-04 - mse: 9.7424e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 31ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 659us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.7036e-04 - mse: 9.7036e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 29ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 758us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.7637e-04 - mse: 9.7637e-04 - val_loss: 0.0011 - val_mse: 0.0011 - 33ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 13ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 725us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.8604e-04 - mse: 9.8604e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 29ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 10ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 665us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.7752e-04 - mse: 9.7752e-04 - val_loss: 0.0011 - val_mse: 0.0011 - 30ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 15ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 673us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.7728e-04 - mse: 9.7728e-04 - val_loss: 0.0011 - val_mse: 0.0011 - 30ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 13ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 703us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.6767e-04 - mse: 9.6767e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 29ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.7041e-04 - mse: 9.7041e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 28ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 646us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.7286e-04 - mse: 9.7286e-04 - val_loss: 0.0011 - val_mse: 0.0011 - 35ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 2ms/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.9165e-04 - mse: 9.9165e-04 - val_loss: 0.0011 - val_mse: 0.0011 - 31ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 13ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0012 - val_mse: 0.0012 - 33ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 16ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 612us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0012 - val_mse: 0.0012 - 31ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 14ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 651us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.5949e-04 - mse: 9.5949e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 35ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 917us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.7656e-04 - mse: 9.7656e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 35ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 914us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.6450e-04 - mse: 9.6450e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 33ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 686us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0011 - val_mse: 0.0011 - 33ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 677us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.8698e-04 - mse: 9.8698e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 29ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.8407e-04 - mse: 9.8407e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 36ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 14ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 624us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.5496e-04 - mse: 9.5496e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 29ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 13ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.6554e-04 - mse: 9.6554e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 32ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 15ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.6051e-04 - mse: 9.6051e-04 - val_loss: 0.0011 - val_mse: 0.0011 - 35ms/epoch - 7ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1/1 [==============================] - 0s 16ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 612us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.8173e-04 - mse: 9.8173e-04 - val_loss: 0.0011 - val_mse: 0.0011 - 30ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 659us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0012 - val_mse: 0.0012 - 33ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 14ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 868us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0012 - val_mse: 0.0012 - 29ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0012 - val_mse: 0.0012 - 38ms/epoch - 8ms/step\n",
      "1/1 [==============================] - 0s 15ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.7363e-04 - mse: 9.7363e-04 - val_loss: 0.0011 - val_mse: 0.0011 - 32ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 13ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 663us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 0.0010 - mse: 0.0010 - val_loss: 0.0012 - val_mse: 0.0012 - 37ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 15ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 640us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.7269e-04 - mse: 9.7269e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 34ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 13ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 660us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.6302e-04 - mse: 9.6302e-04 - val_loss: 0.0011 - val_mse: 0.0011 - 29ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 13ms/step - loss: 9.9937e-04 - mse: 9.9937e-04\n",
      "4/4 [==============================] - 0s 735us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.6807e-04 - mse: 9.6807e-04 - val_loss: 0.0011 - val_mse: 0.0011 - 49ms/epoch - 10ms/step\n",
      "1/1 [==============================] - 0s 18ms/step - loss: 9.9700e-04 - mse: 9.9700e-04\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.6688e-04 - mse: 9.6688e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 31ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 13ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 683us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.5926e-04 - mse: 9.5926e-04 - val_loss: 0.0011 - val_mse: 0.0011 - 36ms/epoch - 7ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 708us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.6393e-04 - mse: 9.6393e-04 - val_loss: 0.0011 - val_mse: 0.0011 - 45ms/epoch - 9ms/step\n",
      "1/1 [==============================] - 0s 17ms/step - loss: 9.9780e-04 - mse: 9.9780e-04\n",
      "4/4 [==============================] - 0s 1ms/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.7365e-04 - mse: 9.7365e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 42ms/epoch - 8ms/step\n",
      "1/1 [==============================] - 0s 13ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 675us/step - loss: 0.0014 - mse: 0.0014\n",
      "5/5 - 0s - loss: 9.9096e-04 - mse: 9.9096e-04 - val_loss: 0.0012 - val_mse: 0.0012 - 30ms/epoch - 6ms/step\n",
      "1/1 [==============================] - 0s 12ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 651us/step - loss: 0.0014 - mse: 0.0014\n",
      "26.47899889945984\n"
     ]
    }
   ],
   "source": [
    "t0 = time.time()\n",
    "history_F = [] #collect data for figures\n",
    "for i in range(200):\n",
    "    history = final_model_PQ.fit(X_train, Y_train, epochs=1, batch_size=32, 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 12ms/step - loss: 0.0010 - mse: 0.0010\n",
      "4/4 [==============================] - 0s 2ms/step - loss: 0.0014 - mse: 0.0014\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": "iVBORw0KGgoAAAANSUhEUgAAAsgAAAGoCAYAAABbtxOxAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4xLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy8li6FKAAAgAElEQVR4nOzdeXjdZZ3//+edvdmbdKULrbRQKEtpC62KUAaQZWSVrwgiMDoi4jIuM6OjX2fGZb6jM+NPZVwQFRQFy6IIMmzCWBABhRZBtkIpSze6b2mSZrt/f3xOSpKm6SnkbMnzcV3nyjmf9X3u9I9X7t6f+w4xRiRJkiQlinJdgCRJkpRPDMiSJElSDwZkSZIkqQcDsiRJktSDAVmSJEnqwYAsSZIk9WBAljQkhBAmhxCaQgjFua5lb0IIV4YQvpjmsYtCCH+7h31TQggxhFAyuBUOHyGEn4QQvprrOiTlFwOypIISQng5hNCSCsPdr/1ijK/GGKtjjJ2DeK+3hhB2hBBq+tn3eAjhY2/kujHGy2KMX3nzFQ4tIYR/DSG09/ndbsl1XZKGHwOypEJ0eioMd79WZ+ImMcaHgZXAu3tuDyEcChwC/GJfr1kIPdzZMECv9w19frf1WS1MkjAgSxoieg43CCG8N4TwWJ/9nwoh3JZ6Xx5C+K8QwqshhLWpIQ8j9nDpnwIX9dl2EfA/McaNqevdFEJ4LYSwNYTwQAhhZo/7/iSE8P0Qwh0hhB3A8T3/Wz+EMDKEcHsIYX0IYXPq/cQ+9zsghPCn1PVvDSE07KEN6kIIPw4hrAkhrAohfLU7kIcQpoUQ7k9dY0MI4YYB2vKMEMLTIYQtqSEeB6e2fy6EcHOfY78dQrgijftfEkL4QwjhmyGETcC/7un+A9QVQwifCCEsT32H/wwhFKX2FYUQ/m8I4ZUQwroQwrUhhLoe5x4TQngo9Z1WhBAu6XHpkSGE/wkhbA8h/DGEcEDqnJCqd12q3Z5M/XEkaYgzIEsaim4DDgohTO+x7QLg+tT7rwMHArOAacAE4J/3cK2fAe8IIUyGJIilrnVtj2PuBKYDY4AlwHV9rnEB8G9ADfBgn31FwDXA/sBkoAX4Tp9jLgI+AOwHdABX7KHWn6b2TwOOBN4JdI9f/gpwDzASmAj8d38XCCEcSNIz/klgNHAH8JsQQllq+2khhNrUscXAe3i9XQe6P8A8YDlJO/3bHr7D3pwNzAVmA2eStAvAJanX8cBbgGpS7Zj63d2Z+s6jSX7vf+5xzfOBL5G0zbIetb0TOJbk30o9cB6w8Q3WLamQxBh9+fLlq2BewMtAE7Al9fp1avsUIAIlqc8/B/459X46sB2oBAKwAzigxzXfCrw0wD3vBT6fen8SsAEo3cOx9ak66lKffwJc2+eYnwBf3cP5s4DNPT4vAr7W4/MhQBtQ3PM7A2OBncCIHseeD/wu9f5a4Cpg4l7a94vAjT0+FwGrgAWpzw8CF/VoixdT7/d2/0uAV/dy739NfbctPV6/67E/Aqf0+Hw5cF/q/X3A5T32HQS0p9rmn4Bb9nDPnwA/6vH5NOC51Pu/Ap4H5gNFuf6378uXr+y97EGWVIjOijHWp15n7eGY60kCGiQ9uL+OMTaT9CBWAotT/92+BbgrtX1Peg6zeD9wfYyxHZJe1BDC10IIL4YQtpEEeIBRPc5fsacLhxAqQwg/SA0N2AY8ANT3Gavc8/xXgNI+14ekB7oUWNPje/2ApLcW4B9J/jj4U2r4xAfo336pewAQY+xK3X9CalPfdu3uPd7b/Qdshx5u7PG7rY8xHt9nf9+22K+/ulPvu/9wmAS8OMA9X+vxvpmk95kY4/+S9EJ/F1gbQriqu/dc0tBmQJY0VN0DjAohzCIJdN1BbgPJMIaZPUJYXYyxeoBr/QqYEEI4HjiH3sMrLiD5r/4TgTqSXl1Iwmi3OMC1P0PS2zkvxlhL8l/6fc+f1OP9ZJKe0Q19rrOCpAd3VI/vVRtjnAkQY3wtxvihGON+wIeB74UQpvVTz2qSsJsUEUJI3X9VatNNwILUOOmzeb1dB7x/Gu2Qrr5t0f2AZq+6U/s6gLWp2g54IzeLMV4RY5wDzCQZavEPb+Q6kgqLAVnSkBRj7ABuBv4TaAB+m9reBfwQ+GYIYQxACGFCCOHkAa61I3Wta4BXYow9HwCsIQmGG0l6pv/fPpZaQxLYt6QevvuXfo65MIRwSAihEvgycHPsM51djHENyR8F3wgh1KYeWjsghHBc6jv+nx4P/20mCav9TYl3I/DXIYQTQgilJAF+J/BQ6j7rSYZ9XEMyLOXZdO4/iP4h9WDjJODvgO6HDX8BfCqEMDWEUE3ye7gh9e/gOuDEEMJ7QvIQZ2PqD6cBhRCOCiHMS7XDDqCV/ttM0hBjQJY0lF1P0rN7UyoodfssycNYj6SGNdxL0os7kJ+S9FBe22f7tST/nb8KeAZ4ZB9r/BYwgqRH+BGS4R59/YxkrOxrQAXwiT1c6yKgLFXHZpJQPz617yjgjyGEJpKHGP8uxvhS3wvEGJcCF5I80LYBOJ1kWr22Hod1t+v1fU4f6P7pOi/0nge5qfsPmZRbgcUkD9n9D/Dj1ParSdrpAeAlkjD78dR3epVkbPFngE2pc49Io5Zakj+mNpP8jjcC/7WP30dSAQoxDsb/eEmSlFkhhAhMjzEuy3UtkoY2e5AlSZKkHgzIkiRJUg8OsZAkSZJ6sAdZkiRJ6qEk1wVkw6hRo+KUKVOyes8dO3ZQVVWV1XsWKtsqPbZTemyn9NhO6bGd0mM7pcd2Sk8222nx4sUbYoy7LRQ1LALylClTeOyxx/Z+4CBatGgRCxYsyOo9C5VtlR7bKT22U3psp/TYTumxndJjO6Unm+0UQnilv+0OsZAkSZJ6MCBLkiRJPRiQJUmSpB6GxRhkSZKkQtDe3s7KlStpbW3NdSk5U1dXx7PPPjuo16yoqGDixImUlpamdbwBWZIkKU+sXLmSmpoapkyZQggh1+XkxPbt26mpqRm068UY2bhxIytXrmTq1KlpneMQC0mSpDzR2tpKY2PjsA3HmRBCoLGxcZ965Q3IkiRJecRwPPj2tU0NyJIkSVIPBmRJkiQBsGDBAu6+++5e2771rW9x+eWX79N1TjvtNLZs2TLgMdXV1f1uv+yyy7j55pvTvtfOnTs577zzmDZtGvPmzePll1/el1L7ZUCWJEkSAOeffz4LFy7stW3hwoWcf/75aZ0fY6Srq4s77riD+vr6TJS4mx//+MeMHDmSZcuW8alPfYrPfvazb/qaBmRJkiQBcO6553L77bezc+dOAF5++WVWr17NMcccQ1NTEyeccAKzZ8/msMMO49Zbb911zMEHH8zll1/O7NmzWbFiBVOmTGHDhg0AnHXWWcyZM4eZM2dy1VVX9brfZz7zGWbPns0JJ5zA+vXrd6tn8eLFHHfcccyZM4eTTz6ZNWvW7HbMrbfeysUXX7yr/vvuu48Y45tqh4xO8xZCOAX4NlAM/CjG+LU++0Nq/2lAM3BJjHFJat/VwLuAdTHGQ3uc0wDcAEwBXgbeE2PcnMnvIUmSlG1f+s3TPLN626Be85D9avmX02fucX9jYyNHH300d911F2eeeSYLFy7kvPPOI4RARUUFt9xyC7W1tWzYsIH58+dzxhlnALB06VKuueYavve97+12zauvvpqGhgZaWlo46qijePe7301jYyM7duxg9uzZfOMb3+DLX/4yX/rSl/jOd76z67z29nY+/vGPc+uttzJ69GhuuOEGvvCFL3D11Vf3uv6qVauYNGkSACUlJdTV1bFx40ZGjRr1htspYz3IIYRi4LvAqcAhwPkhhEP6HHYqMD31uhT4fo99PwFO6efSnwPuizFOB+5LfZYkSdIg6DnMoufwihgjn//85zn88MM58cQTWbVqFWvXrgVg//33Z/78+f1e74orruCII45g/vz5rFixghdeeAGAoqIizjvvPAAuvPBCHnzwwV7nLV26lKeeeoqTTjqJWbNm8dWvfpWVK1fudv3+eovf7EwgmexBPhpYFmNcDhBCWAicCTzT45gzgWtj8s0eCSHUhxDGxxjXxBgfCCFM6ee6ZwILUu9/CiwC3vxgE0mSpDwyUE9vJp111ll8+tOfZsmSJbS0tDB79mwArrvuOtavX8/ixYspLS1lypQpu+YWrqqq6vdaixYt4t577+Xhhx+msrKSBQsW7HE+4r6hNsbIzJkzefjhhwesd+LEiaxYsYKJEyfS0dHB1q1baWho2Nev3UsmA/IEYEWPzyuBeWkcMwHYfYDJ68bGGNcAxBjXhBDG9HdQCOFSkl5pxo4dy6JFi/ap+Ddj5KbHmfv8D/hj87/QUjk+a/ctVE1NTVn9/RQq2yk9tlN6bKf02E7psZ3Sk0471dXVsX379uwUNIBjjjmGSy65hHPOOWdXPWvXrqW+vp7W1lbuueceXnnlFZqamgDo6urqVXeMkaamJl577TVqamro7Oxk8eLFPPLIIzQ3N7N9+3a6urr42c9+xrnnnss111zD0Ucfzfbt24kx0tLSwn777cfatWu59957mTdvHu3t7SxbtoyDDz64V63vfOc7+dGPfsShhx7KzTffzLHHHrurrp5aW1vT/neayYDcX9923z7wdI55Q2KMVwFXAcydOzcuWLBgMC6bnmUd8OQa5h06FSb3/98Net2iRYvI6u+nQNlO6bGd0mM7pcd2So/tlJ502unZZ58d1GWW36j3v//9nHPOOdx444276vngBz/I6aefzvHHH8+sWbOYMWPG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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
}
