{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "539ebd7b",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import pandas as pd\n",
    "from tensorflow.keras.models import Sequential\n",
    "from tensorflow.keras.layers import Dense\n",
    "from sklearn.preprocessing import StandardScaler\n",
    "from sklearn.model_selection import train_test_split\n",
    "\n",
    "from keras.models import Sequential\n",
    "from keras.layers import LSTM, Dense, SimpleRNN, Input, Activation, Dropout\n",
    "from keras import backend as K\n",
    "from tensorflow.keras.optimizers import Adam,SGD\n",
    "import tensorflow as tf\n",
    "from keras.models import Model\n",
    "from keras.models import load_model\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import time "
   ]
  },
  {
   "cell_type": "markdown",
   "id": "069e2e34",
   "metadata": {},
   "source": [
    "# import target dataset, use the first trajectory"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "3a4a2d8e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Keys in file: ['measured_velocities', 'index', 'constrained_torques', 'measured_torques', 'measured_angles', 'desired_torques']\n",
      "Input shape: (14999, 12)\n",
      "Output shape: (14999, 9)\n"
     ]
    }
   ],
   "source": [
    "# Load the npz file\n",
    "data = np.load('Sines_full.npz', allow_pickle=True)\n",
    "\n",
    "keys = list(data.keys())\n",
    "print(\"Keys in file:\", keys) #index is not needed\n",
    "\n",
    "# Assume correct order of keys: s1, u1, s2, s3, u2\n",
    "s1 = data[keys[0]]\n",
    "u1 = data[keys[2]]\n",
    "s2 = data[keys[3]]\n",
    "s3 = data[keys[4]]\n",
    "u2 = data[keys[5]]\n",
    "\n",
    "#we should use constrained_torques as input, which is the derised_torques under the actua condition\n",
    "\n",
    "# # Concatenate input at time t: [s1, s2, s3, u1, u2] → shape: (38, 14000, 15)\n",
    "# X_full = np.concatenate([s1, s2, s3, u1, u2], axis=-1)\n",
    "\n",
    "# Concatenate input at time t: [s1, s2, s3, u1] → shape: (38, 14000, 14)\n",
    "X_full = np.concatenate([s1, s2, s3, u1], axis=-1)\n",
    "\n",
    "# Concatenate states for next step (output at t+1): [s1, s2, s3]\n",
    "Y_full = np.concatenate([s1, s2, s3], axis=-1)  # shape: (38, 14000, 9)\n",
    "\n",
    "# Build training data from t and t+1\n",
    "X_list = []\n",
    "Y_list = []\n",
    "\n",
    "for i in range(1):  # 38 trajectories\n",
    "    X_t = X_full[i, :-1, :]   # inputs at time t, shape: (13999, 14)\n",
    "    Y_tp1 = Y_full[i, 1:, :]  # next states at time t+1, shape: (13999, 9)\n",
    "\n",
    "    X_list.append(X_t)\n",
    "    Y_list.append(Y_tp1)\n",
    "\n",
    "# Stack across all trajectories\n",
    "X = np.vstack(X_list)  # shape: (38*13999, 14)\n",
    "Y = np.vstack(Y_list)  # shape: (38*13999, 9)\n",
    "\n",
    "print(\"Input shape:\", X.shape)   # → (531962, 14)\n",
    "print(\"Output shape:\", Y.shape)  # → (531962, 9)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "a7948aac",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Load your preprocessed X and Y from earlier\n",
    "# X: shape (N, 15), Y: shape (N, 9)\n",
    "\n",
    "# Step 1: Normalize using sklearn StandardScaler\n",
    "x_scaler = StandardScaler()\n",
    "y_scaler = StandardScaler()\n",
    "\n",
    "X_norm = x_scaler.fit_transform(X)\n",
    "Y_norm = y_scaler.fit_transform(Y)\n",
    "\n",
    "# Step 2: Split into train and test\n",
    "X_train, X_test, Y_train, Y_test = train_test_split(X_norm, Y_norm, test_size=0.95, random_state=42)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "898ea542",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(749, 12) (749, 9) (14250, 12) (14250, 9)\n"
     ]
    }
   ],
   "source": [
    "print(X_train.shape, Y_train.shape, X_test.shape, Y_test.shape)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ec0cb9e6",
   "metadata": {},
   "source": [
    "# Standard NN model as benchmark"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "118fa7f5",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/400\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-07-20 14:14:58.331224: 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-20 14:14:58.331273: 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-20 14:14:58.331918: I tensorflow/core/platform/cpu_feature_guard.cc:151] This TensorFlow binary is optimized with oneAPI Deep Neural Network Library (oneDNN) to use the following CPU instructions in performance-critical operations:  AVX2 AVX512F FMA\n",
      "To enable them in other operations, rebuild TensorFlow with the appropriate compiler flags.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "11/11 [==============================] - 0s 8ms/step - loss: 1.4052 - mse: 1.4052 - val_loss: 1.2690 - val_mse: 1.2690\n",
      "Epoch 2/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 1.1222 - mse: 1.1222 - val_loss: 1.0447 - val_mse: 1.0447\n",
      "Epoch 3/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.9363 - mse: 0.9363 - val_loss: 0.8716 - val_mse: 0.8716\n",
      "Epoch 4/400\n",
      "11/11 [==============================] - 0s 3ms/step - loss: 0.7883 - mse: 0.7883 - val_loss: 0.7304 - val_mse: 0.7304\n",
      "Epoch 5/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.6663 - mse: 0.6663 - val_loss: 0.6147 - val_mse: 0.6147\n",
      "Epoch 6/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.5653 - mse: 0.5653 - val_loss: 0.5182 - val_mse: 0.5182\n",
      "Epoch 7/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.4811 - mse: 0.4811 - val_loss: 0.4390 - val_mse: 0.4390\n",
      "Epoch 8/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.4111 - mse: 0.4111 - val_loss: 0.3737 - val_mse: 0.3737\n",
      "Epoch 9/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.3538 - mse: 0.3538 - val_loss: 0.3209 - val_mse: 0.3209\n",
      "Epoch 10/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.3059 - mse: 0.3059 - val_loss: 0.2755 - val_mse: 0.2755\n",
      "Epoch 11/400\n",
      "11/11 [==============================] - 0s 3ms/step - loss: 0.2660 - mse: 0.2660 - val_loss: 0.2395 - val_mse: 0.2395\n",
      "Epoch 12/400\n",
      "11/11 [==============================] - 0s 3ms/step - loss: 0.2325 - mse: 0.2325 - val_loss: 0.2089 - val_mse: 0.2089\n",
      "Epoch 13/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.2041 - mse: 0.2041 - val_loss: 0.1836 - val_mse: 0.1836\n",
      "Epoch 14/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.1801 - mse: 0.1801 - val_loss: 0.1624 - val_mse: 0.1624\n",
      "Epoch 15/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.1596 - mse: 0.1596 - val_loss: 0.1442 - val_mse: 0.1442\n",
      "Epoch 16/400\n",
      "11/11 [==============================] - 0s 8ms/step - loss: 0.1417 - mse: 0.1417 - val_loss: 0.1285 - val_mse: 0.1285\n",
      "Epoch 17/400\n",
      "11/11 [==============================] - 0s 4ms/step - loss: 0.1263 - mse: 0.1263 - val_loss: 0.1143 - val_mse: 0.1143\n",
      "Epoch 18/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.1129 - mse: 0.1129 - val_loss: 0.1025 - val_mse: 0.1025\n",
      "Epoch 19/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.1016 - mse: 0.1016 - val_loss: 0.0924 - val_mse: 0.0924\n",
      "Epoch 20/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0922 - mse: 0.0922 - val_loss: 0.0841 - val_mse: 0.0841\n",
      "Epoch 21/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0843 - mse: 0.0843 - val_loss: 0.0773 - val_mse: 0.0773\n",
      "Epoch 22/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0778 - mse: 0.0778 - val_loss: 0.0718 - val_mse: 0.0718\n",
      "Epoch 23/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0724 - mse: 0.0724 - val_loss: 0.0669 - val_mse: 0.0669\n",
      "Epoch 24/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0680 - mse: 0.0680 - val_loss: 0.0633 - val_mse: 0.0633\n",
      "Epoch 25/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0642 - mse: 0.0642 - val_loss: 0.0593 - val_mse: 0.0593\n",
      "Epoch 26/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0609 - mse: 0.0609 - val_loss: 0.0564 - val_mse: 0.0564\n",
      "Epoch 27/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0580 - mse: 0.0580 - val_loss: 0.0542 - val_mse: 0.0542\n",
      "Epoch 28/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0552 - mse: 0.0552 - val_loss: 0.0512 - val_mse: 0.0512\n",
      "Epoch 29/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0529 - mse: 0.0529 - val_loss: 0.0489 - val_mse: 0.0489\n",
      "Epoch 30/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0504 - mse: 0.0504 - val_loss: 0.0467 - val_mse: 0.0467\n",
      "Epoch 31/400\n",
      "11/11 [==============================] - 0s 3ms/step - loss: 0.0484 - mse: 0.0484 - val_loss: 0.0453 - val_mse: 0.0453\n",
      "Epoch 32/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0465 - mse: 0.0465 - val_loss: 0.0433 - val_mse: 0.0433\n",
      "Epoch 33/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0445 - mse: 0.0445 - val_loss: 0.0415 - val_mse: 0.0415\n",
      "Epoch 34/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0428 - mse: 0.0428 - val_loss: 0.0401 - val_mse: 0.0401\n",
      "Epoch 35/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0412 - mse: 0.0412 - val_loss: 0.0383 - val_mse: 0.0383\n",
      "Epoch 36/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0397 - mse: 0.0397 - val_loss: 0.0371 - val_mse: 0.0371\n",
      "Epoch 37/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0384 - mse: 0.0384 - val_loss: 0.0361 - val_mse: 0.0361\n",
      "Epoch 38/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0370 - mse: 0.0370 - val_loss: 0.0349 - val_mse: 0.0349\n",
      "Epoch 39/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0359 - mse: 0.0359 - val_loss: 0.0335 - val_mse: 0.0335\n",
      "Epoch 40/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0347 - mse: 0.0347 - val_loss: 0.0327 - val_mse: 0.0327\n",
      "Epoch 41/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0337 - mse: 0.0337 - val_loss: 0.0313 - val_mse: 0.0313\n",
      "Epoch 42/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0326 - mse: 0.0326 - val_loss: 0.0308 - val_mse: 0.0308\n",
      "Epoch 43/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0317 - mse: 0.0317 - val_loss: 0.0298 - val_mse: 0.0298\n",
      "Epoch 44/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0308 - mse: 0.0308 - val_loss: 0.0288 - val_mse: 0.0288\n",
      "Epoch 45/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0298 - mse: 0.0298 - val_loss: 0.0283 - val_mse: 0.0283\n",
      "Epoch 46/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0290 - mse: 0.0290 - val_loss: 0.0274 - val_mse: 0.0274\n",
      "Epoch 47/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0281 - mse: 0.0281 - val_loss: 0.0263 - val_mse: 0.0263\n",
      "Epoch 48/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0273 - mse: 0.0273 - val_loss: 0.0260 - val_mse: 0.0260\n",
      "Epoch 49/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0264 - mse: 0.0264 - val_loss: 0.0249 - val_mse: 0.0249\n",
      "Epoch 50/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0256 - mse: 0.0256 - val_loss: 0.0243 - val_mse: 0.0243\n",
      "Epoch 51/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0248 - mse: 0.0248 - val_loss: 0.0237 - val_mse: 0.0237\n",
      "Epoch 52/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0240 - mse: 0.0240 - val_loss: 0.0224 - val_mse: 0.0224\n",
      "Epoch 53/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0232 - mse: 0.0232 - val_loss: 0.0219 - val_mse: 0.0219\n",
      "Epoch 54/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0225 - mse: 0.0225 - val_loss: 0.0211 - val_mse: 0.0211\n",
      "Epoch 55/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0217 - mse: 0.0217 - val_loss: 0.0198 - val_mse: 0.0198\n",
      "Epoch 56/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0210 - mse: 0.0210 - val_loss: 0.0196 - val_mse: 0.0196\n",
      "Epoch 57/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0204 - mse: 0.0204 - val_loss: 0.0188 - val_mse: 0.0188\n",
      "Epoch 58/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0196 - mse: 0.0196 - val_loss: 0.0187 - val_mse: 0.0187\n",
      "Epoch 59/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0190 - mse: 0.0190 - val_loss: 0.0176 - val_mse: 0.0176\n",
      "Epoch 60/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0183 - mse: 0.0183 - val_loss: 0.0169 - val_mse: 0.0169\n",
      "Epoch 61/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0178 - mse: 0.0178 - val_loss: 0.0167 - val_mse: 0.0167\n",
      "Epoch 62/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0173 - mse: 0.0173 - val_loss: 0.0161 - val_mse: 0.0161\n",
      "Epoch 63/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0168 - mse: 0.0168 - val_loss: 0.0158 - val_mse: 0.0158\n",
      "Epoch 64/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0163 - mse: 0.0163 - val_loss: 0.0150 - val_mse: 0.0150\n",
      "Epoch 65/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0159 - mse: 0.0159 - val_loss: 0.0146 - val_mse: 0.0146\n",
      "Epoch 66/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0155 - mse: 0.0155 - val_loss: 0.0143 - val_mse: 0.0143\n",
      "Epoch 67/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0153 - mse: 0.0153 - val_loss: 0.0140 - val_mse: 0.0140\n",
      "Epoch 68/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0149 - mse: 0.0149 - val_loss: 0.0143 - val_mse: 0.0143\n",
      "Epoch 69/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0146 - mse: 0.0146 - val_loss: 0.0139 - val_mse: 0.0139\n",
      "Epoch 70/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0143 - mse: 0.0143 - val_loss: 0.0135 - val_mse: 0.0135\n",
      "Epoch 71/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0141 - mse: 0.0141 - val_loss: 0.0129 - val_mse: 0.0129\n",
      "Epoch 72/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0139 - mse: 0.0139 - val_loss: 0.0129 - val_mse: 0.0129\n",
      "Epoch 73/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0137 - mse: 0.0137 - val_loss: 0.0129 - val_mse: 0.0129\n",
      "Epoch 74/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0135 - mse: 0.0135 - val_loss: 0.0128 - val_mse: 0.0128\n",
      "Epoch 75/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0133 - mse: 0.0133 - val_loss: 0.0129 - val_mse: 0.0129\n",
      "Epoch 76/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0132 - mse: 0.0132 - val_loss: 0.0127 - val_mse: 0.0127\n",
      "Epoch 77/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0130 - mse: 0.0130 - val_loss: 0.0123 - val_mse: 0.0123\n",
      "Epoch 78/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0128 - mse: 0.0128 - val_loss: 0.0118 - val_mse: 0.0118\n",
      "Epoch 79/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0127 - mse: 0.0127 - val_loss: 0.0118 - val_mse: 0.0118\n",
      "Epoch 80/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0125 - mse: 0.0125 - val_loss: 0.0117 - val_mse: 0.0117\n",
      "Epoch 81/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0124 - mse: 0.0124 - val_loss: 0.0116 - val_mse: 0.0116\n",
      "Epoch 82/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0122 - mse: 0.0122 - val_loss: 0.0113 - val_mse: 0.0113\n",
      "Epoch 83/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0121 - mse: 0.0121 - val_loss: 0.0112 - val_mse: 0.0112\n",
      "Epoch 84/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0120 - mse: 0.0120 - val_loss: 0.0111 - val_mse: 0.0111\n",
      "Epoch 85/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0118 - mse: 0.0118 - val_loss: 0.0112 - val_mse: 0.0112\n",
      "Epoch 86/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0117 - mse: 0.0117 - val_loss: 0.0110 - val_mse: 0.0110\n",
      "Epoch 87/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0116 - mse: 0.0116 - val_loss: 0.0109 - val_mse: 0.0109\n",
      "Epoch 88/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0114 - mse: 0.0114 - val_loss: 0.0104 - val_mse: 0.0104\n",
      "Epoch 89/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0113 - mse: 0.0113 - val_loss: 0.0103 - val_mse: 0.0103\n",
      "Epoch 90/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0112 - mse: 0.0112 - val_loss: 0.0105 - val_mse: 0.0105\n",
      "Epoch 91/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0111 - mse: 0.0111 - val_loss: 0.0101 - val_mse: 0.0101\n",
      "Epoch 92/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0109 - mse: 0.0109 - val_loss: 0.0106 - val_mse: 0.0106\n",
      "Epoch 93/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0109 - mse: 0.0109 - val_loss: 0.0103 - val_mse: 0.0103\n",
      "Epoch 94/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0108 - mse: 0.0108 - val_loss: 0.0104 - val_mse: 0.0104\n",
      "Epoch 95/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0107 - mse: 0.0107 - val_loss: 0.0100 - val_mse: 0.0100\n",
      "Epoch 96/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0106 - mse: 0.0106 - val_loss: 0.0099 - val_mse: 0.0099\n",
      "Epoch 97/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0105 - mse: 0.0105 - val_loss: 0.0100 - val_mse: 0.0100\n",
      "Epoch 98/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0104 - mse: 0.0104 - val_loss: 0.0096 - val_mse: 0.0096\n",
      "Epoch 99/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0103 - mse: 0.0103 - val_loss: 0.0095 - val_mse: 0.0095\n",
      "Epoch 100/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0102 - mse: 0.0102 - val_loss: 0.0097 - val_mse: 0.0097\n",
      "Epoch 101/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0102 - mse: 0.0102 - val_loss: 0.0094 - val_mse: 0.0094\n",
      "Epoch 102/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0101 - mse: 0.0101 - val_loss: 0.0094 - val_mse: 0.0094\n",
      "Epoch 103/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0100 - mse: 0.0100 - val_loss: 0.0095 - val_mse: 0.0095\n",
      "Epoch 104/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0098 - mse: 0.0098 - val_loss: 0.0095 - val_mse: 0.0095\n",
      "Epoch 105/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0099 - mse: 0.0099 - val_loss: 0.0096 - val_mse: 0.0096\n",
      "Epoch 106/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0097 - mse: 0.0097 - val_loss: 0.0090 - val_mse: 0.0090\n",
      "Epoch 107/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0097 - mse: 0.0097 - val_loss: 0.0096 - val_mse: 0.0096\n",
      "Epoch 108/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0096 - mse: 0.0096 - val_loss: 0.0088 - val_mse: 0.0088\n",
      "Epoch 109/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0095 - mse: 0.0095 - val_loss: 0.0088 - val_mse: 0.0088\n",
      "Epoch 110/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0096 - mse: 0.0096 - val_loss: 0.0089 - val_mse: 0.0089\n",
      "Epoch 111/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0094 - mse: 0.0094 - val_loss: 0.0091 - val_mse: 0.0091\n",
      "Epoch 112/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0093 - mse: 0.0093 - val_loss: 0.0087 - val_mse: 0.0087\n",
      "Epoch 113/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0093 - mse: 0.0093 - val_loss: 0.0088 - val_mse: 0.0088\n",
      "Epoch 114/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0092 - mse: 0.0092 - val_loss: 0.0089 - val_mse: 0.0089\n",
      "Epoch 115/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0092 - mse: 0.0092 - val_loss: 0.0088 - val_mse: 0.0088\n",
      "Epoch 116/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0091 - mse: 0.0091 - val_loss: 0.0088 - val_mse: 0.0088\n",
      "Epoch 117/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0091 - mse: 0.0091 - val_loss: 0.0090 - val_mse: 0.0090\n",
      "Epoch 118/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0090 - mse: 0.0090 - val_loss: 0.0086 - val_mse: 0.0086\n",
      "Epoch 119/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0090 - mse: 0.0090 - val_loss: 0.0086 - val_mse: 0.0086\n",
      "Epoch 120/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0089 - mse: 0.0089 - val_loss: 0.0085 - val_mse: 0.0085\n",
      "Epoch 121/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0088 - mse: 0.0088 - val_loss: 0.0088 - val_mse: 0.0088\n",
      "Epoch 122/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0088 - mse: 0.0088 - val_loss: 0.0079 - val_mse: 0.0079\n",
      "Epoch 123/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0087 - mse: 0.0087 - val_loss: 0.0087 - val_mse: 0.0087\n",
      "Epoch 124/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0087 - mse: 0.0087 - val_loss: 0.0080 - val_mse: 0.0080\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 125/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0086 - mse: 0.0086 - val_loss: 0.0082 - val_mse: 0.0082\n",
      "Epoch 126/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0086 - mse: 0.0086 - val_loss: 0.0088 - val_mse: 0.0088\n",
      "Epoch 127/400\n",
      "11/11 [==============================] - 0s 3ms/step - loss: 0.0085 - mse: 0.0085 - val_loss: 0.0078 - val_mse: 0.0078\n",
      "Epoch 128/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0086 - mse: 0.0086 - val_loss: 0.0081 - val_mse: 0.0081\n",
      "Epoch 129/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0084 - mse: 0.0084 - val_loss: 0.0079 - val_mse: 0.0079\n",
      "Epoch 130/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0084 - mse: 0.0084 - val_loss: 0.0082 - val_mse: 0.0082\n",
      "Epoch 131/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0084 - mse: 0.0084 - val_loss: 0.0082 - val_mse: 0.0082\n",
      "Epoch 132/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0083 - mse: 0.0083 - val_loss: 0.0078 - val_mse: 0.0078\n",
      "Epoch 133/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0083 - mse: 0.0083 - val_loss: 0.0084 - val_mse: 0.0084\n",
      "Epoch 134/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0082 - mse: 0.0082 - val_loss: 0.0080 - val_mse: 0.0080\n",
      "Epoch 135/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0081 - mse: 0.0081 - val_loss: 0.0078 - val_mse: 0.0078\n",
      "Epoch 136/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0081 - mse: 0.0081 - val_loss: 0.0078 - val_mse: 0.0078\n",
      "Epoch 137/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0081 - mse: 0.0081 - val_loss: 0.0082 - val_mse: 0.0082\n",
      "Epoch 138/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0081 - mse: 0.0081 - val_loss: 0.0075 - val_mse: 0.0075\n",
      "Epoch 139/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0079 - mse: 0.0079 - val_loss: 0.0076 - val_mse: 0.0076\n",
      "Epoch 140/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0080 - mse: 0.0080 - val_loss: 0.0075 - val_mse: 0.0075\n",
      "Epoch 141/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0079 - mse: 0.0079 - val_loss: 0.0076 - val_mse: 0.0076\n",
      "Epoch 142/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0079 - mse: 0.0079 - val_loss: 0.0075 - val_mse: 0.0075\n",
      "Epoch 143/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0078 - mse: 0.0078 - val_loss: 0.0073 - val_mse: 0.0073\n",
      "Epoch 144/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0078 - mse: 0.0078 - val_loss: 0.0078 - val_mse: 0.0078\n",
      "Epoch 145/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0079 - mse: 0.0079 - val_loss: 0.0073 - val_mse: 0.0073\n",
      "Epoch 146/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0078 - mse: 0.0078 - val_loss: 0.0074 - val_mse: 0.0074\n",
      "Epoch 147/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0078 - mse: 0.0078 - val_loss: 0.0075 - val_mse: 0.0075\n",
      "Epoch 148/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0077 - mse: 0.0077 - val_loss: 0.0075 - val_mse: 0.0075\n",
      "Epoch 149/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0077 - mse: 0.0077 - val_loss: 0.0075 - val_mse: 0.0075\n",
      "Epoch 150/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0076 - mse: 0.0076 - val_loss: 0.0073 - val_mse: 0.0073\n",
      "Epoch 151/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0076 - mse: 0.0076 - val_loss: 0.0068 - val_mse: 0.0068\n",
      "Epoch 152/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0076 - mse: 0.0076 - val_loss: 0.0082 - val_mse: 0.0082\n",
      "Epoch 153/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0075 - mse: 0.0075 - val_loss: 0.0070 - val_mse: 0.0070\n",
      "Epoch 154/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0076 - mse: 0.0076 - val_loss: 0.0071 - val_mse: 0.0071\n",
      "Epoch 155/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0076 - mse: 0.0076 - val_loss: 0.0069 - val_mse: 0.0069\n",
      "Epoch 156/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0074 - mse: 0.0074 - val_loss: 0.0073 - val_mse: 0.0073\n",
      "Epoch 157/400\n",
      "11/11 [==============================] - 0s 3ms/step - loss: 0.0074 - mse: 0.0074 - val_loss: 0.0071 - val_mse: 0.0071\n",
      "Epoch 158/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0074 - mse: 0.0074 - val_loss: 0.0073 - val_mse: 0.0073\n",
      "Epoch 159/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0074 - mse: 0.0074 - val_loss: 0.0068 - val_mse: 0.0068\n",
      "Epoch 160/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0074 - mse: 0.0074 - val_loss: 0.0076 - val_mse: 0.0076\n",
      "Epoch 161/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0073 - mse: 0.0073 - val_loss: 0.0070 - val_mse: 0.0070\n",
      "Epoch 162/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0073 - mse: 0.0073 - val_loss: 0.0074 - val_mse: 0.0074\n",
      "Epoch 163/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0073 - mse: 0.0073 - val_loss: 0.0069 - val_mse: 0.0069\n",
      "Epoch 164/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0072 - mse: 0.0072 - val_loss: 0.0070 - val_mse: 0.0070\n",
      "Epoch 165/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0072 - mse: 0.0072 - val_loss: 0.0071 - val_mse: 0.0071\n",
      "Epoch 166/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0072 - mse: 0.0072 - val_loss: 0.0069 - val_mse: 0.0069\n",
      "Epoch 167/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0072 - mse: 0.0072 - val_loss: 0.0069 - val_mse: 0.0069\n",
      "Epoch 168/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0072 - mse: 0.0072 - val_loss: 0.0067 - val_mse: 0.0067\n",
      "Epoch 169/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0071 - mse: 0.0071 - val_loss: 0.0069 - val_mse: 0.0069\n",
      "Epoch 170/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0070 - mse: 0.0070 - val_loss: 0.0069 - val_mse: 0.0069\n",
      "Epoch 171/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0071 - mse: 0.0071 - val_loss: 0.0069 - val_mse: 0.0069\n",
      "Epoch 172/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0071 - mse: 0.0071 - val_loss: 0.0068 - val_mse: 0.0068\n",
      "Epoch 173/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0070 - mse: 0.0070 - val_loss: 0.0067 - val_mse: 0.0067\n",
      "Epoch 174/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0071 - mse: 0.0071 - val_loss: 0.0065 - val_mse: 0.0065\n",
      "Epoch 175/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0069 - mse: 0.0069 - val_loss: 0.0067 - val_mse: 0.0067\n",
      "Epoch 176/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0069 - mse: 0.0069 - val_loss: 0.0069 - val_mse: 0.0069\n",
      "Epoch 177/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0070 - mse: 0.0070 - val_loss: 0.0072 - val_mse: 0.0072\n",
      "Epoch 178/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0068 - mse: 0.0068 - val_loss: 0.0064 - val_mse: 0.0064\n",
      "Epoch 179/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0069 - mse: 0.0069 - val_loss: 0.0072 - val_mse: 0.0072\n",
      "Epoch 180/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0069 - mse: 0.0069 - val_loss: 0.0064 - val_mse: 0.0064\n",
      "Epoch 181/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0069 - mse: 0.0069 - val_loss: 0.0064 - val_mse: 0.0064\n",
      "Epoch 182/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0069 - mse: 0.0069 - val_loss: 0.0068 - val_mse: 0.0068\n",
      "Epoch 183/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0068 - mse: 0.0068 - val_loss: 0.0065 - val_mse: 0.0065\n",
      "Epoch 184/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0068 - mse: 0.0068 - val_loss: 0.0067 - val_mse: 0.0067\n",
      "Epoch 185/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0068 - mse: 0.0068 - val_loss: 0.0070 - val_mse: 0.0070\n",
      "Epoch 186/400\n",
      "11/11 [==============================] - 0s 3ms/step - loss: 0.0068 - mse: 0.0068 - val_loss: 0.0066 - val_mse: 0.0066\n",
      "Epoch 187/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0067 - mse: 0.0067 - val_loss: 0.0071 - val_mse: 0.0071\n",
      "Epoch 188/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0068 - mse: 0.0068 - val_loss: 0.0066 - val_mse: 0.0066\n",
      "Epoch 189/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0067 - mse: 0.0067 - val_loss: 0.0067 - val_mse: 0.0067\n",
      "Epoch 190/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0066 - mse: 0.0066 - val_loss: 0.0067 - val_mse: 0.0067\n",
      "Epoch 191/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0066 - mse: 0.0066 - val_loss: 0.0068 - val_mse: 0.0068\n",
      "Epoch 192/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0067 - mse: 0.0067 - val_loss: 0.0064 - val_mse: 0.0064\n",
      "Epoch 193/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0067 - mse: 0.0067 - val_loss: 0.0066 - val_mse: 0.0066\n",
      "Epoch 194/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0067 - mse: 0.0067 - val_loss: 0.0065 - val_mse: 0.0065\n",
      "Epoch 195/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0066 - mse: 0.0066 - val_loss: 0.0071 - val_mse: 0.0071\n",
      "Epoch 196/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0065 - mse: 0.0065 - val_loss: 0.0067 - val_mse: 0.0067\n",
      "Epoch 197/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0066 - mse: 0.0066 - val_loss: 0.0066 - val_mse: 0.0066\n",
      "Epoch 198/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0066 - mse: 0.0066 - val_loss: 0.0068 - val_mse: 0.0068\n",
      "Epoch 199/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0064 - mse: 0.0064 - val_loss: 0.0064 - val_mse: 0.0064\n",
      "Epoch 200/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0066 - mse: 0.0066 - val_loss: 0.0066 - val_mse: 0.0066\n",
      "Epoch 201/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0065 - mse: 0.0065 - val_loss: 0.0064 - val_mse: 0.0064\n",
      "Epoch 202/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0066 - mse: 0.0066 - val_loss: 0.0065 - val_mse: 0.0065\n",
      "Epoch 203/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0064 - mse: 0.0064 - val_loss: 0.0069 - val_mse: 0.0069\n",
      "Epoch 204/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0064 - mse: 0.0064 - val_loss: 0.0066 - val_mse: 0.0066\n",
      "Epoch 205/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0065 - mse: 0.0065 - val_loss: 0.0063 - val_mse: 0.0063\n",
      "Epoch 206/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0064 - mse: 0.0064 - val_loss: 0.0064 - val_mse: 0.0064\n",
      "Epoch 207/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0064 - mse: 0.0064 - val_loss: 0.0062 - val_mse: 0.0062\n",
      "Epoch 208/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0063 - mse: 0.0063 - val_loss: 0.0069 - val_mse: 0.0069\n",
      "Epoch 209/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0064 - mse: 0.0064 - val_loss: 0.0063 - val_mse: 0.0063\n",
      "Epoch 210/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0064 - mse: 0.0064 - val_loss: 0.0065 - val_mse: 0.0065\n",
      "Epoch 211/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0064 - mse: 0.0064 - val_loss: 0.0065 - val_mse: 0.0065\n",
      "Epoch 212/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0062 - mse: 0.0062 - val_loss: 0.0062 - val_mse: 0.0062\n",
      "Epoch 213/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0063 - mse: 0.0063 - val_loss: 0.0061 - val_mse: 0.0061\n",
      "Epoch 214/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0063 - mse: 0.0063 - val_loss: 0.0061 - val_mse: 0.0061\n",
      "Epoch 215/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0063 - mse: 0.0063 - val_loss: 0.0067 - val_mse: 0.0067\n",
      "Epoch 216/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0063 - mse: 0.0063 - val_loss: 0.0065 - val_mse: 0.0065\n",
      "Epoch 217/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0062 - mse: 0.0062 - val_loss: 0.0064 - val_mse: 0.0064\n",
      "Epoch 218/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0063 - mse: 0.0063 - val_loss: 0.0060 - val_mse: 0.0060\n",
      "Epoch 219/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0063 - mse: 0.0063 - val_loss: 0.0060 - val_mse: 0.0060\n",
      "Epoch 220/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0062 - mse: 0.0062 - val_loss: 0.0057 - val_mse: 0.0057\n",
      "Epoch 221/400\n",
      "11/11 [==============================] - 0s 3ms/step - loss: 0.0062 - mse: 0.0062 - val_loss: 0.0062 - val_mse: 0.0062\n",
      "Epoch 222/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0062 - mse: 0.0062 - val_loss: 0.0059 - val_mse: 0.0059\n",
      "Epoch 223/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0063 - mse: 0.0063 - val_loss: 0.0060 - val_mse: 0.0060\n",
      "Epoch 224/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0062 - mse: 0.0062 - val_loss: 0.0059 - val_mse: 0.0059\n",
      "Epoch 225/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0062 - mse: 0.0062 - val_loss: 0.0063 - val_mse: 0.0063\n",
      "Epoch 226/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0061 - mse: 0.0061 - val_loss: 0.0066 - val_mse: 0.0066\n",
      "Epoch 227/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0061 - mse: 0.0061 - val_loss: 0.0059 - val_mse: 0.0059\n",
      "Epoch 228/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0062 - mse: 0.0062 - val_loss: 0.0061 - val_mse: 0.0061\n",
      "Epoch 229/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0062 - mse: 0.0062 - val_loss: 0.0065 - val_mse: 0.0065\n",
      "Epoch 230/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0061 - mse: 0.0061 - val_loss: 0.0059 - val_mse: 0.0059\n",
      "Epoch 231/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0062 - mse: 0.0062 - val_loss: 0.0061 - val_mse: 0.0061\n",
      "Epoch 232/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0061 - mse: 0.0061 - val_loss: 0.0062 - val_mse: 0.0062\n",
      "Epoch 233/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0061 - mse: 0.0061 - val_loss: 0.0063 - val_mse: 0.0063\n",
      "Epoch 234/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0061 - mse: 0.0061 - val_loss: 0.0059 - val_mse: 0.0059\n",
      "Epoch 235/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0061 - mse: 0.0061 - val_loss: 0.0060 - val_mse: 0.0060\n",
      "Epoch 236/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0060 - mse: 0.0060 - val_loss: 0.0060 - val_mse: 0.0060\n",
      "Epoch 237/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0061 - mse: 0.0061 - val_loss: 0.0058 - val_mse: 0.0058\n",
      "Epoch 238/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0061 - mse: 0.0061 - val_loss: 0.0060 - val_mse: 0.0060\n",
      "Epoch 239/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0060 - mse: 0.0060 - val_loss: 0.0058 - val_mse: 0.0058\n",
      "Epoch 240/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0060 - mse: 0.0060 - val_loss: 0.0060 - val_mse: 0.0060\n",
      "Epoch 241/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0061 - mse: 0.0061 - val_loss: 0.0059 - val_mse: 0.0059\n",
      "Epoch 242/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0059 - mse: 0.0059 - val_loss: 0.0063 - val_mse: 0.0063\n",
      "Epoch 243/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0060 - mse: 0.0060 - val_loss: 0.0060 - val_mse: 0.0060\n",
      "Epoch 244/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0060 - mse: 0.0060 - val_loss: 0.0066 - val_mse: 0.0066\n",
      "Epoch 245/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0060 - mse: 0.0060 - val_loss: 0.0069 - val_mse: 0.0069\n",
      "Epoch 246/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0059 - mse: 0.0059 - val_loss: 0.0063 - val_mse: 0.0063\n",
      "Epoch 247/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0059 - mse: 0.0059 - val_loss: 0.0060 - val_mse: 0.0060\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 248/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0059 - mse: 0.0059 - val_loss: 0.0058 - val_mse: 0.0058\n",
      "Epoch 249/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0060 - mse: 0.0060 - val_loss: 0.0057 - val_mse: 0.0057\n",
      "Epoch 250/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0059 - mse: 0.0059 - val_loss: 0.0063 - val_mse: 0.0063\n",
      "Epoch 251/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0059 - mse: 0.0059 - val_loss: 0.0056 - val_mse: 0.0056\n",
      "Epoch 252/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0058 - mse: 0.0058 - val_loss: 0.0061 - val_mse: 0.0061\n",
      "Epoch 253/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0060 - mse: 0.0060 - val_loss: 0.0061 - val_mse: 0.0061\n",
      "Epoch 254/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0059 - mse: 0.0059 - val_loss: 0.0062 - val_mse: 0.0062\n",
      "Epoch 255/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0060 - mse: 0.0060 - val_loss: 0.0063 - val_mse: 0.0063\n",
      "Epoch 256/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0058 - mse: 0.0058 - val_loss: 0.0059 - val_mse: 0.0059\n",
      "Epoch 257/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0059 - mse: 0.0059 - val_loss: 0.0058 - val_mse: 0.0058\n",
      "Epoch 258/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0059 - mse: 0.0059 - val_loss: 0.0057 - val_mse: 0.0057\n",
      "Epoch 259/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0058 - mse: 0.0058 - val_loss: 0.0059 - val_mse: 0.0059\n",
      "Epoch 260/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0058 - mse: 0.0058 - val_loss: 0.0060 - val_mse: 0.0060\n",
      "Epoch 261/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0059 - mse: 0.0059 - val_loss: 0.0061 - val_mse: 0.0061\n",
      "Epoch 262/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0058 - mse: 0.0058 - val_loss: 0.0060 - val_mse: 0.0060\n",
      "Epoch 263/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0058 - mse: 0.0058 - val_loss: 0.0057 - val_mse: 0.0057\n",
      "Epoch 264/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0057 - mse: 0.0057 - val_loss: 0.0056 - val_mse: 0.0056\n",
      "Epoch 265/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0057 - mse: 0.0057 - val_loss: 0.0061 - val_mse: 0.0061\n",
      "Epoch 266/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0058 - mse: 0.0058 - val_loss: 0.0057 - val_mse: 0.0057\n",
      "Epoch 267/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0057 - mse: 0.0057 - val_loss: 0.0058 - val_mse: 0.0058\n",
      "Epoch 268/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0058 - mse: 0.0058 - val_loss: 0.0057 - val_mse: 0.0057\n",
      "Epoch 269/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0059 - mse: 0.0059 - val_loss: 0.0055 - val_mse: 0.0055\n",
      "Epoch 270/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0058 - mse: 0.0058 - val_loss: 0.0053 - val_mse: 0.0053\n",
      "Epoch 271/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0057 - mse: 0.0057 - val_loss: 0.0055 - val_mse: 0.0055\n",
      "Epoch 272/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0058 - mse: 0.0058 - val_loss: 0.0059 - val_mse: 0.0059\n",
      "Epoch 273/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0057 - mse: 0.0057 - val_loss: 0.0071 - val_mse: 0.0071\n",
      "Epoch 274/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0057 - mse: 0.0057 - val_loss: 0.0058 - val_mse: 0.0058\n",
      "Epoch 275/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0058 - mse: 0.0058 - val_loss: 0.0056 - val_mse: 0.0056\n",
      "Epoch 276/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0056 - mse: 0.0056 - val_loss: 0.0056 - val_mse: 0.0056\n",
      "Epoch 277/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0057 - mse: 0.0057 - val_loss: 0.0056 - val_mse: 0.0056\n",
      "Epoch 278/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0057 - mse: 0.0057 - val_loss: 0.0056 - val_mse: 0.0056\n",
      "Epoch 279/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0058 - mse: 0.0058 - val_loss: 0.0063 - val_mse: 0.0063\n",
      "Epoch 280/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0056 - mse: 0.0056 - val_loss: 0.0058 - val_mse: 0.0058\n",
      "Epoch 281/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0057 - mse: 0.0057 - val_loss: 0.0056 - val_mse: 0.0056\n",
      "Epoch 282/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0057 - mse: 0.0057 - val_loss: 0.0061 - val_mse: 0.0061\n",
      "Epoch 283/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0057 - mse: 0.0057 - val_loss: 0.0058 - val_mse: 0.0058\n",
      "Epoch 284/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0057 - mse: 0.0057 - val_loss: 0.0059 - val_mse: 0.0059\n",
      "Epoch 285/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0058 - mse: 0.0058 - val_loss: 0.0058 - val_mse: 0.0058\n",
      "Epoch 286/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0057 - mse: 0.0057 - val_loss: 0.0061 - val_mse: 0.0061\n",
      "Epoch 287/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0057 - mse: 0.0057 - val_loss: 0.0067 - val_mse: 0.0067\n",
      "Epoch 288/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0056 - mse: 0.0056 - val_loss: 0.0057 - val_mse: 0.0057\n",
      "Epoch 289/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0057 - mse: 0.0057 - val_loss: 0.0057 - val_mse: 0.0057\n",
      "Epoch 290/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0056 - mse: 0.0056 - val_loss: 0.0058 - val_mse: 0.0058\n",
      "Epoch 291/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0055 - mse: 0.0055 - val_loss: 0.0057 - val_mse: 0.0057\n",
      "Epoch 292/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0058 - mse: 0.0058 - val_loss: 0.0057 - val_mse: 0.0057\n",
      "Epoch 293/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0056 - mse: 0.0056 - val_loss: 0.0060 - val_mse: 0.0060\n",
      "Epoch 294/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0056 - mse: 0.0056 - val_loss: 0.0062 - val_mse: 0.0062\n",
      "Epoch 295/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0056 - mse: 0.0056 - val_loss: 0.0064 - val_mse: 0.0064\n",
      "Epoch 296/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0056 - mse: 0.0056 - val_loss: 0.0055 - val_mse: 0.0055\n",
      "Epoch 297/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0056 - mse: 0.0056 - val_loss: 0.0065 - val_mse: 0.0065\n",
      "Epoch 298/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0058 - mse: 0.0058 - val_loss: 0.0057 - val_mse: 0.0057\n",
      "Epoch 299/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0055 - mse: 0.0055 - val_loss: 0.0052 - val_mse: 0.0052\n",
      "Epoch 300/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0056 - mse: 0.0056 - val_loss: 0.0057 - val_mse: 0.0057\n",
      "Epoch 301/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0055 - mse: 0.0055 - val_loss: 0.0055 - val_mse: 0.0055\n",
      "Epoch 302/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0056 - mse: 0.0056 - val_loss: 0.0058 - val_mse: 0.0058\n",
      "Epoch 303/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0056 - mse: 0.0056 - val_loss: 0.0054 - val_mse: 0.0054\n",
      "Epoch 304/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0056 - mse: 0.0056 - val_loss: 0.0053 - val_mse: 0.0053\n",
      "Epoch 305/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0055 - mse: 0.0055 - val_loss: 0.0053 - val_mse: 0.0053\n",
      "Epoch 306/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0055 - mse: 0.0055 - val_loss: 0.0054 - val_mse: 0.0054\n",
      "Epoch 307/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0056 - mse: 0.0056 - val_loss: 0.0054 - val_mse: 0.0054\n",
      "Epoch 308/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0056 - mse: 0.0056 - val_loss: 0.0053 - val_mse: 0.0053\n",
      "Epoch 309/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0056 - mse: 0.0056 - val_loss: 0.0054 - val_mse: 0.0054\n",
      "Epoch 310/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0055 - mse: 0.0055 - val_loss: 0.0058 - val_mse: 0.0058\n",
      "Epoch 311/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0056 - mse: 0.0056 - val_loss: 0.0060 - val_mse: 0.0060\n",
      "Epoch 312/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0055 - mse: 0.0055 - val_loss: 0.0056 - val_mse: 0.0056\n",
      "Epoch 313/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0056 - mse: 0.0056 - val_loss: 0.0057 - val_mse: 0.0057\n",
      "Epoch 314/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0055 - mse: 0.0055 - val_loss: 0.0056 - val_mse: 0.0056\n",
      "Epoch 315/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0056 - mse: 0.0056 - val_loss: 0.0053 - val_mse: 0.0053\n",
      "Epoch 316/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0055 - mse: 0.0055 - val_loss: 0.0064 - val_mse: 0.0064\n",
      "Epoch 317/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0056 - mse: 0.0056 - val_loss: 0.0055 - val_mse: 0.0055\n",
      "Epoch 318/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0054 - mse: 0.0054 - val_loss: 0.0057 - val_mse: 0.0057\n",
      "Epoch 319/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0055 - mse: 0.0055 - val_loss: 0.0057 - val_mse: 0.0057\n",
      "Epoch 320/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0055 - mse: 0.0055 - val_loss: 0.0062 - val_mse: 0.0062\n",
      "Epoch 321/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0055 - mse: 0.0055 - val_loss: 0.0055 - val_mse: 0.0055\n",
      "Epoch 322/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0055 - mse: 0.0055 - val_loss: 0.0053 - val_mse: 0.0053\n",
      "Epoch 323/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0055 - mse: 0.0055 - val_loss: 0.0057 - val_mse: 0.0057\n",
      "Epoch 324/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0055 - mse: 0.0055 - val_loss: 0.0055 - val_mse: 0.0055\n",
      "Epoch 325/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0055 - mse: 0.0055 - val_loss: 0.0052 - val_mse: 0.0052\n",
      "Epoch 326/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0054 - mse: 0.0054 - val_loss: 0.0058 - val_mse: 0.0058\n",
      "Epoch 327/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0054 - mse: 0.0054 - val_loss: 0.0051 - val_mse: 0.0051\n",
      "Epoch 328/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0054 - mse: 0.0054 - val_loss: 0.0049 - val_mse: 0.0049\n",
      "Epoch 329/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0055 - mse: 0.0055 - val_loss: 0.0053 - val_mse: 0.0053\n",
      "Epoch 330/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0054 - mse: 0.0054 - val_loss: 0.0053 - val_mse: 0.0053\n",
      "Epoch 331/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0055 - mse: 0.0055 - val_loss: 0.0052 - val_mse: 0.0052\n",
      "Epoch 332/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0055 - mse: 0.0055 - val_loss: 0.0050 - val_mse: 0.0050\n",
      "Epoch 333/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0055 - mse: 0.0055 - val_loss: 0.0059 - val_mse: 0.0059\n",
      "Epoch 334/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0054 - mse: 0.0054 - val_loss: 0.0057 - val_mse: 0.0057\n",
      "Epoch 335/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0054 - mse: 0.0054 - val_loss: 0.0062 - val_mse: 0.0062\n",
      "Epoch 336/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0055 - mse: 0.0055 - val_loss: 0.0055 - val_mse: 0.0055\n",
      "Epoch 337/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0054 - mse: 0.0054 - val_loss: 0.0051 - val_mse: 0.0051\n",
      "Epoch 338/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0054 - mse: 0.0054 - val_loss: 0.0057 - val_mse: 0.0057\n",
      "Epoch 339/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0054 - mse: 0.0054 - val_loss: 0.0063 - val_mse: 0.0063\n",
      "Epoch 340/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0054 - mse: 0.0054 - val_loss: 0.0057 - val_mse: 0.0057\n",
      "Epoch 341/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0053 - mse: 0.0053 - val_loss: 0.0053 - val_mse: 0.0053\n",
      "Epoch 342/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0054 - mse: 0.0054 - val_loss: 0.0053 - val_mse: 0.0053\n",
      "Epoch 343/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0053 - mse: 0.0053 - val_loss: 0.0052 - val_mse: 0.0052\n",
      "Epoch 344/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0054 - mse: 0.0054 - val_loss: 0.0056 - val_mse: 0.0056\n",
      "Epoch 345/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0055 - mse: 0.0055 - val_loss: 0.0055 - val_mse: 0.0055\n",
      "Epoch 346/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0054 - mse: 0.0054 - val_loss: 0.0058 - val_mse: 0.0058\n",
      "Epoch 347/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0054 - mse: 0.0054 - val_loss: 0.0062 - val_mse: 0.0062\n",
      "Epoch 348/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0054 - mse: 0.0054 - val_loss: 0.0053 - val_mse: 0.0053\n",
      "Epoch 349/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0054 - mse: 0.0054 - val_loss: 0.0054 - val_mse: 0.0054\n",
      "Epoch 350/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0054 - mse: 0.0054 - val_loss: 0.0059 - val_mse: 0.0059\n",
      "Epoch 351/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0053 - mse: 0.0053 - val_loss: 0.0054 - val_mse: 0.0054\n",
      "Epoch 352/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0054 - mse: 0.0054 - val_loss: 0.0050 - val_mse: 0.0050\n",
      "Epoch 353/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0053 - mse: 0.0053 - val_loss: 0.0051 - val_mse: 0.0051\n",
      "Epoch 354/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0053 - mse: 0.0053 - val_loss: 0.0053 - val_mse: 0.0053\n",
      "Epoch 355/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0054 - mse: 0.0054 - val_loss: 0.0061 - val_mse: 0.0061\n",
      "Epoch 356/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0053 - mse: 0.0053 - val_loss: 0.0053 - val_mse: 0.0053\n",
      "Epoch 357/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0054 - mse: 0.0054 - val_loss: 0.0050 - val_mse: 0.0050\n",
      "Epoch 358/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0053 - mse: 0.0053 - val_loss: 0.0058 - val_mse: 0.0058\n",
      "Epoch 359/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0054 - mse: 0.0054 - val_loss: 0.0055 - val_mse: 0.0055\n",
      "Epoch 360/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0052 - mse: 0.0052 - val_loss: 0.0050 - val_mse: 0.0050\n",
      "Epoch 361/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0053 - mse: 0.0053 - val_loss: 0.0053 - val_mse: 0.0053\n",
      "Epoch 362/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0054 - mse: 0.0054 - val_loss: 0.0051 - val_mse: 0.0051\n",
      "Epoch 363/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0053 - mse: 0.0053 - val_loss: 0.0049 - val_mse: 0.0049\n",
      "Epoch 364/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0053 - mse: 0.0053 - val_loss: 0.0050 - val_mse: 0.0050\n",
      "Epoch 365/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0052 - mse: 0.0052 - val_loss: 0.0054 - val_mse: 0.0054\n",
      "Epoch 366/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0053 - mse: 0.0053 - val_loss: 0.0052 - val_mse: 0.0052\n",
      "Epoch 367/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0055 - mse: 0.0055 - val_loss: 0.0052 - val_mse: 0.0052\n",
      "Epoch 368/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0052 - mse: 0.0052 - val_loss: 0.0051 - val_mse: 0.0051\n",
      "Epoch 369/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0052 - mse: 0.0052 - val_loss: 0.0056 - val_mse: 0.0056\n",
      "Epoch 370/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0053 - mse: 0.0053 - val_loss: 0.0052 - val_mse: 0.0052\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 371/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0053 - mse: 0.0053 - val_loss: 0.0050 - val_mse: 0.0050\n",
      "Epoch 372/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0052 - mse: 0.0052 - val_loss: 0.0050 - val_mse: 0.0050\n",
      "Epoch 373/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0053 - mse: 0.0053 - val_loss: 0.0048 - val_mse: 0.0048\n",
      "Epoch 374/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0052 - mse: 0.0052 - val_loss: 0.0050 - val_mse: 0.0050\n",
      "Epoch 375/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0054 - mse: 0.0054 - val_loss: 0.0049 - val_mse: 0.0049\n",
      "Epoch 376/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0052 - mse: 0.0052 - val_loss: 0.0051 - val_mse: 0.0051\n",
      "Epoch 377/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0052 - mse: 0.0052 - val_loss: 0.0054 - val_mse: 0.0054\n",
      "Epoch 378/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0052 - mse: 0.0052 - val_loss: 0.0056 - val_mse: 0.0056\n",
      "Epoch 379/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0052 - mse: 0.0052 - val_loss: 0.0049 - val_mse: 0.0049\n",
      "Epoch 380/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0053 - mse: 0.0053 - val_loss: 0.0052 - val_mse: 0.0052\n",
      "Epoch 381/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0052 - mse: 0.0052 - val_loss: 0.0047 - val_mse: 0.0047\n",
      "Epoch 382/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0052 - mse: 0.0052 - val_loss: 0.0057 - val_mse: 0.0057\n",
      "Epoch 383/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0052 - mse: 0.0052 - val_loss: 0.0051 - val_mse: 0.0051\n",
      "Epoch 384/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0052 - mse: 0.0052 - val_loss: 0.0047 - val_mse: 0.0047\n",
      "Epoch 385/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0052 - mse: 0.0052 - val_loss: 0.0049 - val_mse: 0.0049\n",
      "Epoch 386/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0051 - mse: 0.0051 - val_loss: 0.0052 - val_mse: 0.0052\n",
      "Epoch 387/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0054 - mse: 0.0054 - val_loss: 0.0050 - val_mse: 0.0050\n",
      "Epoch 388/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0052 - mse: 0.0052 - val_loss: 0.0050 - val_mse: 0.0050\n",
      "Epoch 389/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0052 - mse: 0.0052 - val_loss: 0.0054 - val_mse: 0.0054\n",
      "Epoch 390/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0053 - mse: 0.0053 - val_loss: 0.0049 - val_mse: 0.0049\n",
      "Epoch 391/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0053 - mse: 0.0053 - val_loss: 0.0053 - val_mse: 0.0053\n",
      "Epoch 392/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0051 - mse: 0.0051 - val_loss: 0.0059 - val_mse: 0.0059\n",
      "Epoch 393/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0051 - mse: 0.0051 - val_loss: 0.0052 - val_mse: 0.0052\n",
      "Epoch 394/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0052 - mse: 0.0052 - val_loss: 0.0051 - val_mse: 0.0051\n",
      "Epoch 395/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0052 - mse: 0.0052 - val_loss: 0.0048 - val_mse: 0.0048\n",
      "Epoch 396/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0052 - mse: 0.0052 - val_loss: 0.0053 - val_mse: 0.0053\n",
      "Epoch 397/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0053 - mse: 0.0053 - val_loss: 0.0053 - val_mse: 0.0053\n",
      "Epoch 398/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0052 - mse: 0.0052 - val_loss: 0.0051 - val_mse: 0.0051\n",
      "Epoch 399/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0052 - mse: 0.0052 - val_loss: 0.0059 - val_mse: 0.0059\n",
      "Epoch 400/400\n",
      "11/11 [==============================] - 0s 2ms/step - loss: 0.0052 - mse: 0.0052 - val_loss: 0.0053 - val_mse: 0.0053\n",
      "9.31876826286316\n"
     ]
    }
   ],
   "source": [
    "# Step 3: Define the neural network\n",
    "model = Sequential([\n",
    "    Dense(16, activation='tanh', input_shape=(X.shape[1],)),  # input: 15\n",
    "    Dense(16, activation='tanh'),\n",
    "    Dense(Y.shape[1], activation='linear')  # output: 9\n",
    "])\n",
    "\n",
    "model.compile(loss='mse', metrics=['mse'])\n",
    "\n",
    "\n",
    "t0 = time.time()\n",
    "# Step 4: Train the model\n",
    "history = model.fit(X_train, Y_train, epochs=400, batch_size=64, validation_split=0.1, verbose=1)\n",
    "t1 = time.time()\n",
    "print(t1-t0)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "e48f5901",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "12/12 [==============================] - 0s 470us/step - loss: 0.0053 - mse: 0.0053\n",
      "223/223 [==============================] - 0s 352us/step - loss: 0.0076 - mse: 0.0076\n",
      "[0.007573769427835941, 0.007573769427835941]\n",
      "9.31876826286316\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=64)\n",
    "\n",
    "loss_and_metrics = model.evaluate(X_test, Y_test, batch_size=64)\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": 7,
   "id": "d659a2af",
   "metadata": {},
   "outputs": [],
   "source": [
    "model = load_model(\"Pretrain_sim.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": 8,
   "id": "4687c4cf",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1969/1969 [==============================] - 1s 335us/step - loss: 0.0058 - mse: 0.0058\n",
      "24/24 [==============================] - 0s 395us/step - loss: 4.7827 - mse: 4.7827\n",
      "996/996 [==============================] - 1s 507us/step - loss: 0.0619 - mse: 0.0619\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=64)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "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=(12))  # Replace input_dim with your actual input feature dimension\n",
    "new_input_layer = Dense(32, activation='linear', use_bias=False)  # New front layer\n",
    "new_input_layer1 = Dense(32, activation='linear', use_bias=False)  # New front layer\n",
    "new_input_layer2 = Dense(12, 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(16, activation='linear', use_bias=False)  # Replace output_dim with your desired final output size\n",
    "new_output_layer1 = Dense(16, activation='linear', use_bias=False)  # Replace output_dim with your desired final output size\n",
    "new_output_layer2 = Dense(9, 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": 10,
   "id": "e9a742b1",
   "metadata": {},
   "outputs": [],
   "source": [
    "#assign parameters\n",
    "# Define A: 12x32 matrix [I_12 | 0]\n",
    "# Identity matrix of size 12×12\n",
    "I = np.eye(12, dtype=np.float32)\n",
    "# Zero matrix of size 12×20\n",
    "Z = np.zeros((12, 20), dtype=np.float32)\n",
    "\n",
    "# Concatenate horizontally to get 12×32 matrix\n",
    "A = np.hstack((I, Z))\n",
    "\n",
    "\n",
    "# Define B: 32x32 identity matrix\n",
    "B = np.array(np.eye(32), dtype=np.float32)\n",
    "\n",
    "# Define C: 32x12 matrix [I_12; 0]\n",
    "# 20×12 zero matrix\n",
    "Z1 = np.zeros((20, 12), dtype=np.float32)\n",
    "C = np.vstack((I, Z1))\n",
    "\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": 11,
   "id": "a5792001",
   "metadata": {},
   "outputs": [],
   "source": [
    "# A: 9x16 matrix [I_9 | 0]\n",
    "# 9×9 identity matrix\n",
    "I = np.eye(9, dtype=np.float32)\n",
    "# 9×7 zero matrix\n",
    "Z = np.zeros((9, 7), dtype=np.float32)\n",
    "\n",
    "# Concatenate horizontally\n",
    "Ao = np.hstack((I, Z))\n",
    "\n",
    "# B: 16x16 identity\n",
    "Bo = np.array(np.eye(16), dtype=np.float32)\n",
    "\n",
    "# C: 16x9 matrix [I_9; 0]\n",
    "# 7×9 zero matrix\n",
    "Z2 = np.zeros((7, 9), dtype=np.float32)\n",
    "Co = np.vstack((I, Z2))\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": 12,
   "id": "4b514281",
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "# Step 5: Custom loss function\n",
    "def custom_loss(y_true, y_pred):\n",
    "    Num = 749 #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": 13,
   "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, 12)]              0         \n",
      "                                                                 \n",
      " dense_3 (Dense)             (None, 32)                384       \n",
      "                                                                 \n",
      " dense_4 (Dense)             (None, 32)                1024      \n",
      "                                                                 \n",
      " dense_5 (Dense)             (None, 12)                384       \n",
      "                                                                 \n",
      " sequential (Sequential)     (None, 9)                 633       \n",
      "                                                                 \n",
      " dense_6 (Dense)             (None, 16)                144       \n",
      "                                                                 \n",
      " dense_7 (Dense)             (None, 16)                256       \n",
      "                                                                 \n",
      " dense_8 (Dense)             (None, 9)                 144       \n",
      "                                                                 \n",
      "=================================================================\n",
      "Total params: 2,969\n",
      "Trainable params: 2,336\n",
      "Non-trainable params: 633\n",
      "_________________________________________________________________\n",
      "None\n"
     ]
    }
   ],
   "source": [
    "# Step 6: Compile\n",
    "#final_model.compile(optimizer='adam', loss=custom_loss, metrics=['mse'])\n",
    "final_model.compile(optimizer='adam', loss=custom_loss, metrics=['mse'])\n",
    "print(final_model.summary())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "c34f6e3f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "9/9 - 1s - loss: 3.8431 - mse: 3.8014 - val_loss: 2.8654 - val_mse: 2.9395 - 752ms/epoch - 84ms/step\n",
      "iteration :1 Target train: tf.Tensor(2.8538818, shape=(), dtype=float32) loss1 tf.Tensor(2.7199738, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.1339081, shape=(), dtype=float32) loss2   tf.Tensor(0.12720771, shape=(), dtype=float32) loss3  tf.Tensor(1.0002934, shape=(), dtype=float32) Target test: tf.Tensor(2.794865, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 2.3981 - mse: 2.3539 - val_loss: 1.9059 - val_mse: 1.9702 - 219ms/epoch - 24ms/step\n",
      "iteration :2 Target train: tf.Tensor(1.8938257, shape=(), dtype=float32) loss1 tf.Tensor(1.6959662, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.19785947, shape=(), dtype=float32) loss2   tf.Tensor(0.19029045, shape=(), dtype=float32) loss3  tf.Tensor(1.001348, shape=(), dtype=float32) Target test: tf.Tensor(1.8405162, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 1.6569 - mse: 1.6253 - val_loss: 1.3862 - val_mse: 1.4441 - 217ms/epoch - 24ms/step\n",
      "iteration :3 Target train: tf.Tensor(1.3735502, shape=(), dtype=float32) loss1 tf.Tensor(1.120198, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.2533521, shape=(), dtype=float32) loss2   tf.Tensor(0.24587123, shape=(), dtype=float32) loss3  tf.Tensor(1.0037497, shape=(), dtype=float32) Target test: tf.Tensor(1.3296962, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 1.2423 - mse: 1.2078 - val_loss: 1.0839 - val_mse: 1.1380 - 230ms/epoch - 26ms/step\n",
      "iteration :4 Target train: tf.Tensor(1.0709947, shape=(), dtype=float32) loss1 tf.Tensor(0.7891297, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.28186506, shape=(), dtype=float32) loss2   tf.Tensor(0.27500242, shape=(), dtype=float32) loss3  tf.Tensor(1.0052247, shape=(), dtype=float32) Target test: tf.Tensor(1.0363182, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.9973 - mse: 0.9614 - val_loss: 0.9002 - val_mse: 0.9466 - 222ms/epoch - 25ms/step\n",
      "iteration :5 Target train: tf.Tensor(0.8872988, shape=(), dtype=float32) loss1 tf.Tensor(0.59555525, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.29174358, shape=(), dtype=float32) loss2   tf.Tensor(0.2852109, shape=(), dtype=float32) loss3  tf.Tensor(1.0033535, shape=(), dtype=float32) Target test: tf.Tensor(0.8596648, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.8453 - mse: 0.8147 - val_loss: 0.7827 - val_mse: 0.8215 - 223ms/epoch - 25ms/step\n",
      "iteration :6 Target train: tf.Tensor(0.7698308, shape=(), dtype=float32) loss1 tf.Tensor(0.4788144, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.29101643, shape=(), dtype=float32) loss2   tf.Tensor(0.28449833, shape=(), dtype=float32) loss3  tf.Tensor(0.9991471, shape=(), dtype=float32) Target test: tf.Tensor(0.7479044, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.7458 - mse: 0.7163 - val_loss: 0.7028 - val_mse: 0.7359 - 215ms/epoch - 24ms/step\n",
      "iteration :7 Target train: tf.Tensor(0.6900979, shape=(), dtype=float32) loss1 tf.Tensor(0.4096375, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.28046042, shape=(), dtype=float32) loss2   tf.Tensor(0.27393502, shape=(), dtype=float32) loss3  tf.Tensor(0.99436665, shape=(), dtype=float32) Target test: tf.Tensor(0.6727009, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.6764 - mse: 0.6500 - val_loss: 0.6449 - val_mse: 0.6729 - 228ms/epoch - 25ms/step\n",
      "iteration :8 Target train: tf.Tensor(0.6322872, shape=(), dtype=float32) loss1 tf.Tensor(0.36524618, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.26704103, shape=(), dtype=float32) loss2   tf.Tensor(0.26055312, shape=(), dtype=float32) loss3  tf.Tensor(0.9924869, shape=(), dtype=float32) Target test: tf.Tensor(0.61836845, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.6247 - mse: 0.5995 - val_loss: 0.6004 - val_mse: 0.6241 - 225ms/epoch - 25ms/step\n",
      "iteration :9 Target train: tf.Tensor(0.58796084, shape=(), dtype=float32) loss1 tf.Tensor(0.33370453, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.2542563, shape=(), dtype=float32) loss2   tf.Tensor(0.24781208, shape=(), dtype=float32) loss3  tf.Tensor(0.9903388, shape=(), dtype=float32) Target test: tf.Tensor(0.57692677, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.5843 - mse: 0.5601 - val_loss: 0.5646 - val_mse: 0.5844 - 227ms/epoch - 25ms/step\n",
      "iteration :10 Target train: tf.Tensor(0.55232203, shape=(), dtype=float32) loss1 tf.Tensor(0.30941826, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.24290375, shape=(), dtype=float32) loss2   tf.Tensor(0.23647757, shape=(), dtype=float32) loss3  tf.Tensor(0.98793304, shape=(), dtype=float32) Target test: tf.Tensor(0.5437081, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.5512 - mse: 0.5290 - val_loss: 0.5346 - val_mse: 0.5507 - 226ms/epoch - 25ms/step\n",
      "iteration :11 Target train: tf.Tensor(0.5224429, shape=(), dtype=float32) loss1 tf.Tensor(0.2888449, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.23359796, shape=(), dtype=float32) loss2   tf.Tensor(0.22716795, shape=(), dtype=float32) loss3  tf.Tensor(0.98520696, shape=(), dtype=float32) Target test: tf.Tensor(0.51573634, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.5230 - mse: 0.5018 - val_loss: 0.5085 - val_mse: 0.5213 - 222ms/epoch - 25ms/step\n",
      "iteration :12 Target train: tf.Tensor(0.49648443, shape=(), dtype=float32) loss1 tf.Tensor(0.27049825, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.22598618, shape=(), dtype=float32) loss2   tf.Tensor(0.21953748, shape=(), dtype=float32) loss3  tf.Tensor(0.9827356, shape=(), dtype=float32) Target test: tf.Tensor(0.49127114, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.4983 - mse: 0.4777 - val_loss: 0.4853 - val_mse: 0.4952 - 229ms/epoch - 25ms/step\n",
      "iteration :13 Target train: tf.Tensor(0.47331667, shape=(), dtype=float32) loss1 tf.Tensor(0.25342453, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.21989216, shape=(), dtype=float32) loss2   tf.Tensor(0.2134062, shape=(), dtype=float32) loss3  tf.Tensor(0.98007023, shape=(), dtype=float32) Target test: tf.Tensor(0.46930143, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.4760 - mse: 0.4575 - val_loss: 0.4641 - val_mse: 0.4715 - 230ms/epoch - 26ms/step\n",
      "iteration :14 Target train: tf.Tensor(0.45222554, shape=(), dtype=float32) loss1 tf.Tensor(0.23698793, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.2152376, shape=(), dtype=float32) loss2   tf.Tensor(0.20871021, shape=(), dtype=float32) loss3  tf.Tensor(0.9773039, shape=(), dtype=float32) Target test: tf.Tensor(0.4491825, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.4555 - mse: 0.4376 - val_loss: 0.4446 - val_mse: 0.4498 - 227ms/epoch - 25ms/step\n",
      "iteration :15 Target train: tf.Tensor(0.43275174, shape=(), dtype=float32) loss1 tf.Tensor(0.22098935, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.2117624, shape=(), dtype=float32) loss2   tf.Tensor(0.20519777, shape=(), dtype=float32) loss3  tf.Tensor(0.97448415, shape=(), dtype=float32) Target test: tf.Tensor(0.43051034, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.4366 - mse: 0.4196 - val_loss: 0.4264 - val_mse: 0.4297 - 229ms/epoch - 25ms/step\n",
      "iteration :16 Target train: tf.Tensor(0.41458786, shape=(), dtype=float32) loss1 tf.Tensor(0.2052603, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.20932755, shape=(), dtype=float32) loss2   tf.Tensor(0.20272131, shape=(), dtype=float32) loss3  tf.Tensor(0.97161883, shape=(), dtype=float32) Target test: tf.Tensor(0.4130198, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.4189 - mse: 0.4023 - val_loss: 0.4092 - val_mse: 0.4109 - 240ms/epoch - 27ms/step\n",
      "iteration :17 Target train: tf.Tensor(0.3975234, shape=(), dtype=float32) loss1 tf.Tensor(0.18970586, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.20781754, shape=(), dtype=float32) loss2   tf.Tensor(0.20116232, shape=(), dtype=float32) loss3  tf.Tensor(0.968703, shape=(), dtype=float32) Target test: tf.Tensor(0.39652613, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.4022 - mse: 0.3861 - val_loss: 0.3931 - val_mse: 0.3933 - 230ms/epoch - 26ms/step\n",
      "iteration :18 Target train: tf.Tensor(0.38141614, shape=(), dtype=float32) loss1 tf.Tensor(0.17431101, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.20710513, shape=(), dtype=float32) loss2   tf.Tensor(0.20039691, shape=(), dtype=float32) loss3  tf.Tensor(0.9657219, shape=(), dtype=float32) Target test: tf.Tensor(0.38090113, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.3864 - mse: 0.3708 - val_loss: 0.3778 - val_mse: 0.3768 - 219ms/epoch - 24ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iteration :19 Target train: tf.Tensor(0.3661722, shape=(), dtype=float32) loss1 tf.Tensor(0.15906264, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.20710956, shape=(), dtype=float32) loss2   tf.Tensor(0.20034657, shape=(), dtype=float32) loss3  tf.Tensor(0.96265626, shape=(), dtype=float32) Target test: tf.Tensor(0.3660623, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.3715 - mse: 0.3563 - val_loss: 0.3634 - val_mse: 0.3612 - 232ms/epoch - 26ms/step\n",
      "iteration :20 Target train: tf.Tensor(0.351733, shape=(), dtype=float32) loss1 tf.Tensor(0.14396073, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.20777227, shape=(), dtype=float32) loss2   tf.Tensor(0.2009545, shape=(), dtype=float32) loss3  tf.Tensor(0.9594884, shape=(), dtype=float32) Target test: tf.Tensor(0.35196173, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.3574 - mse: 0.3423 - val_loss: 0.3497 - val_mse: 0.3466 - 232ms/epoch - 26ms/step\n",
      "iteration :21 Target train: tf.Tensor(0.33806324, shape=(), dtype=float32) loss1 tf.Tensor(0.12901562, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.20904762, shape=(), dtype=float32) loss2   tf.Tensor(0.20217678, shape=(), dtype=float32) loss3  tf.Tensor(0.9562042, shape=(), dtype=float32) Target test: tf.Tensor(0.33857283, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.3440 - mse: 0.3297 - val_loss: 0.3367 - val_mse: 0.3328 - 228ms/epoch - 25ms/step\n",
      "iteration :22 Target train: tf.Tensor(0.32514063, shape=(), dtype=float32) loss1 tf.Tensor(0.114246964, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.21089366, shape=(), dtype=float32) loss2   tf.Tensor(0.2039728, shape=(), dtype=float32) loss3  tf.Tensor(0.9527934, shape=(), dtype=float32) Target test: tf.Tensor(0.32588208, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.3314 - mse: 0.3174 - val_loss: 0.3245 - val_mse: 0.3199 - 222ms/epoch - 25ms/step\n",
      "iteration :23 Target train: tf.Tensor(0.31294712, shape=(), dtype=float32) loss1 tf.Tensor(0.09968917, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.21325795, shape=(), dtype=float32) loss2   tf.Tensor(0.20628987, shape=(), dtype=float32) loss3  tf.Tensor(0.94941527, shape=(), dtype=float32) Target test: tf.Tensor(0.31388152, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.3195 - mse: 0.3059 - val_loss: 0.3130 - val_mse: 0.3078 - 232ms/epoch - 26ms/step\n",
      "iteration :24 Target train: tf.Tensor(0.3014669, shape=(), dtype=float32) loss1 tf.Tensor(0.08538556, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.21608135, shape=(), dtype=float32) loss2   tf.Tensor(0.20906952, shape=(), dtype=float32) loss3  tf.Tensor(0.9464075, shape=(), dtype=float32) Target test: tf.Tensor(0.30256426, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.3083 - mse: 0.2945 - val_loss: 0.3022 - val_mse: 0.2966 - 222ms/epoch - 25ms/step\n",
      "iteration :25 Target train: tf.Tensor(0.2906781, shape=(), dtype=float32) loss1 tf.Tensor(0.0713678, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.21931031, shape=(), dtype=float32) loss2   tf.Tensor(0.2122573, shape=(), dtype=float32) loss3  tf.Tensor(0.9432537, shape=(), dtype=float32) Target test: tf.Tensor(0.29191667, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.2978 - mse: 0.2843 - val_loss: 0.2921 - val_mse: 0.2860 - 227ms/epoch - 25ms/step\n",
      "iteration :26 Target train: tf.Tensor(0.28055167, shape=(), dtype=float32) loss1 tf.Tensor(0.057660505, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.22289117, shape=(), dtype=float32) loss2   tf.Tensor(0.21579775, shape=(), dtype=float32) loss3  tf.Tensor(0.94003147, shape=(), dtype=float32) Target test: tf.Tensor(0.28191587, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.2880 - mse: 0.2745 - val_loss: 0.2826 - val_mse: 0.2762 - 228ms/epoch - 25ms/step\n",
      "iteration :27 Target train: tf.Tensor(0.2710537, shape=(), dtype=float32) loss1 tf.Tensor(0.044308007, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.2267457, shape=(), dtype=float32) loss2   tf.Tensor(0.21961083, shape=(), dtype=float32) loss3  tf.Tensor(0.9367739, shape=(), dtype=float32) Target test: tf.Tensor(0.2725322, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.2787 - mse: 0.2653 - val_loss: 0.2737 - val_mse: 0.2670 - 222ms/epoch - 25ms/step\n",
      "iteration :28 Target train: tf.Tensor(0.26214778, shape=(), dtype=float32) loss1 tf.Tensor(0.031366676, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.23078111, shape=(), dtype=float32) loss2   tf.Tensor(0.22360443, shape=(), dtype=float32) loss3  tf.Tensor(0.9337132, shape=(), dtype=float32) Target test: tf.Tensor(0.26373038, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.2701 - mse: 0.2570 - val_loss: 0.2654 - val_mse: 0.2585 - 226ms/epoch - 25ms/step\n",
      "iteration :29 Target train: tf.Tensor(0.2537936, shape=(), dtype=float32) loss1 tf.Tensor(0.018868431, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.23492517, shape=(), dtype=float32) loss2   tf.Tensor(0.2277034, shape=(), dtype=float32) loss3  tf.Tensor(0.9306494, shape=(), dtype=float32) Target test: tf.Tensor(0.25547394, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.2619 - mse: 0.2489 - val_loss: 0.2575 - val_mse: 0.2505 - 228ms/epoch - 25ms/step\n",
      "iteration :30 Target train: tf.Tensor(0.24595088, shape=(), dtype=float32) loss1 tf.Tensor(0.006851107, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.23909977, shape=(), dtype=float32) loss2   tf.Tensor(0.2318293, shape=(), dtype=float32) loss3  tf.Tensor(0.9275691, shape=(), dtype=float32) Target test: tf.Tensor(0.24772076, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.2543 - mse: 0.2411 - val_loss: 0.2502 - val_mse: 0.2430 - 224ms/epoch - 25ms/step\n",
      "iteration :31 Target train: tf.Tensor(0.23858102, shape=(), dtype=float32) loss1 tf.Tensor(0.0046396255, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.24322064, shape=(), dtype=float32) loss2   tf.Tensor(0.23589838, shape=(), dtype=float32) loss3  tf.Tensor(0.92452586, shape=(), dtype=float32) Target test: tf.Tensor(0.24043031, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.2472 - mse: 0.2341 - val_loss: 0.2433 - val_mse: 0.2360 - 221ms/epoch - 25ms/step\n",
      "iteration :32 Target train: tf.Tensor(0.2316467, shape=(), dtype=float32) loss1 tf.Tensor(0.015565604, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.2472123, shape=(), dtype=float32) loss2   tf.Tensor(0.23983566, shape=(), dtype=float32) loss3  tf.Tensor(0.92146236, shape=(), dtype=float32) Target test: tf.Tensor(0.23356363, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.2404 - mse: 0.2272 - val_loss: 0.2367 - val_mse: 0.2295 - 227ms/epoch - 25ms/step\n",
      "iteration :33 Target train: tf.Tensor(0.22511181, shape=(), dtype=float32) loss1 tf.Tensor(0.025930673, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.2510425, shape=(), dtype=float32) loss2   tf.Tensor(0.24361016, shape=(), dtype=float32) loss3  tf.Tensor(0.91843724, shape=(), dtype=float32) Target test: tf.Tensor(0.22708364, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.2340 - mse: 0.2209 - val_loss: 0.2306 - val_mse: 0.2233 - 237ms/epoch - 26ms/step\n",
      "iteration :34 Target train: tf.Tensor(0.21894199, shape=(), dtype=float32) loss1 tf.Tensor(0.035747886, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.25468987, shape=(), dtype=float32) loss2   tf.Tensor(0.24720086, shape=(), dtype=float32) loss3  tf.Tensor(0.91541564, shape=(), dtype=float32) Target test: tf.Tensor(0.22095595, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.2280 - mse: 0.2150 - val_loss: 0.2247 - val_mse: 0.2175 - 228ms/epoch - 25ms/step\n",
      "iteration :35 Target train: tf.Tensor(0.21310586, shape=(), dtype=float32) loss1 tf.Tensor(0.045028, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.25813386, shape=(), dtype=float32) loss2   tf.Tensor(0.25058824, shape=(), dtype=float32) loss3  tf.Tensor(0.9124096, shape=(), dtype=float32) Target test: tf.Tensor(0.2151487, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.2223 - mse: 0.2093 - val_loss: 0.2192 - val_mse: 0.2120 - 227ms/epoch - 25ms/step\n",
      "iteration :36 Target train: tf.Tensor(0.20757492, shape=(), dtype=float32) loss1 tf.Tensor(0.05377917, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.2613541, shape=(), dtype=float32) loss2   tf.Tensor(0.25375307, shape=(), dtype=float32) loss3  tf.Tensor(0.9097485, shape=(), dtype=float32) Target test: tf.Tensor(0.2096327, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.2169 - mse: 0.2039 - val_loss: 0.2140 - val_mse: 0.2068 - 228ms/epoch - 25ms/step\n",
      "iteration :37 Target train: tf.Tensor(0.20232484, shape=(), dtype=float32) loss1 tf.Tensor(0.061986864, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.2643117, shape=(), dtype=float32) loss2   tf.Tensor(0.25665748, shape=(), dtype=float32) loss3  tf.Tensor(0.9067723, shape=(), dtype=float32) Target test: tf.Tensor(0.20438223, shape=(), dtype=float32)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "9/9 - 0s - loss: 0.2118 - mse: 0.1987 - val_loss: 0.2090 - val_mse: 0.2019 - 220ms/epoch - 24ms/step\n",
      "iteration :38 Target train: tf.Tensor(0.19732724, shape=(), dtype=float32) loss1 tf.Tensor(0.06972079, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.26704803, shape=(), dtype=float32) loss2   tf.Tensor(0.2593377, shape=(), dtype=float32) loss3  tf.Tensor(0.9039574, shape=(), dtype=float32) Target test: tf.Tensor(0.1993765, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.2069 - mse: 0.1937 - val_loss: 0.2042 - val_mse: 0.1972 - 225ms/epoch - 25ms/step\n",
      "iteration :39 Target train: tf.Tensor(0.19256262, shape=(), dtype=float32) loss1 tf.Tensor(0.076997325, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.26955995, shape=(), dtype=float32) loss2   tf.Tensor(0.2618019, shape=(), dtype=float32) loss3  tf.Tensor(0.9012156, shape=(), dtype=float32) Target test: tf.Tensor(0.19458726, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.2022 - mse: 0.1890 - val_loss: 0.1996 - val_mse: 0.1927 - 221ms/epoch - 25ms/step\n",
      "iteration :40 Target train: tf.Tensor(0.18800949, shape=(), dtype=float32) loss1 tf.Tensor(0.083802715, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.2718122, shape=(), dtype=float32) loss2   tf.Tensor(0.2640058, shape=(), dtype=float32) loss3  tf.Tensor(0.898439, shape=(), dtype=float32) Target test: tf.Tensor(0.19000268, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.1977 - mse: 0.1845 - val_loss: 0.1953 - val_mse: 0.1885 - 228ms/epoch - 25ms/step\n",
      "iteration :41 Target train: tf.Tensor(0.1836501, shape=(), dtype=float32) loss1 tf.Tensor(0.090186924, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.27383703, shape=(), dtype=float32) loss2   tf.Tensor(0.26598877, shape=(), dtype=float32) loss3  tf.Tensor(0.89573604, shape=(), dtype=float32) Target test: tf.Tensor(0.18559895, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.1934 - mse: 0.1801 - val_loss: 0.1911 - val_mse: 0.1844 - 234ms/epoch - 26ms/step\n",
      "iteration :42 Target train: tf.Tensor(0.1794675, shape=(), dtype=float32) loss1 tf.Tensor(0.09614414, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.27561164, shape=(), dtype=float32) loss2   tf.Tensor(0.26772356, shape=(), dtype=float32) loss3  tf.Tensor(0.8929919, shape=(), dtype=float32) Target test: tf.Tensor(0.18136631, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.1893 - mse: 0.1760 - val_loss: 0.1871 - val_mse: 0.1806 - 226ms/epoch - 25ms/step\n",
      "iteration :43 Target train: tf.Tensor(0.17544666, shape=(), dtype=float32) loss1 tf.Tensor(0.101707846, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.2771545, shape=(), dtype=float32) loss2   tf.Tensor(0.26923165, shape=(), dtype=float32) loss3  tf.Tensor(0.89029735, shape=(), dtype=float32) Target test: tf.Tensor(0.17728625, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.1854 - mse: 0.1721 - val_loss: 0.1832 - val_mse: 0.1768 - 230ms/epoch - 26ms/step\n",
      "iteration :44 Target train: tf.Tensor(0.17157367, shape=(), dtype=float32) loss1 tf.Tensor(0.1068843, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.27845797, shape=(), dtype=float32) loss2   tf.Tensor(0.2705038, shape=(), dtype=float32) loss3  tf.Tensor(0.88752484, shape=(), dtype=float32) Target test: tf.Tensor(0.17334893, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.1815 - mse: 0.1682 - val_loss: 0.1794 - val_mse: 0.1732 - 231ms/epoch - 26ms/step\n",
      "iteration :45 Target train: tf.Tensor(0.16783538, shape=(), dtype=float32) loss1 tf.Tensor(0.11169842, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.2795338, shape=(), dtype=float32) loss2   tf.Tensor(0.2715522, shape=(), dtype=float32) loss3  tf.Tensor(0.88484263, shape=(), dtype=float32) Target test: tf.Tensor(0.16954121, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.1778 - mse: 0.1644 - val_loss: 0.1758 - val_mse: 0.1698 - 236ms/epoch - 26ms/step\n",
      "iteration :46 Target train: tf.Tensor(0.16421981, shape=(), dtype=float32) loss1 tf.Tensor(0.11616184, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.28038165, shape=(), dtype=float32) loss2   tf.Tensor(0.27237678, shape=(), dtype=float32) loss3  tf.Tensor(0.88206905, shape=(), dtype=float32) Target test: tf.Tensor(0.16585147, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.1742 - mse: 0.1609 - val_loss: 0.1723 - val_mse: 0.1665 - 229ms/epoch - 25ms/step\n",
      "iteration :47 Target train: tf.Tensor(0.1607164, shape=(), dtype=float32) loss1 tf.Tensor(0.120288715, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.2810051, shape=(), dtype=float32) loss2   tf.Tensor(0.27298033, shape=(), dtype=float32) loss3  tf.Tensor(0.8800222, shape=(), dtype=float32) Target test: tf.Tensor(0.16227108, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.1708 - mse: 0.1574 - val_loss: 0.1689 - val_mse: 0.1632 - 228ms/epoch - 25ms/step\n",
      "iteration :48 Target train: tf.Tensor(0.157319, shape=(), dtype=float32) loss1 tf.Tensor(0.12410839, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.28142738, shape=(), dtype=float32) loss2   tf.Tensor(0.27338582, shape=(), dtype=float32) loss3  tf.Tensor(0.87913257, shape=(), dtype=float32) Target test: tf.Tensor(0.15879527, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.1674 - mse: 0.1539 - val_loss: 0.1655 - val_mse: 0.1601 - 229ms/epoch - 25ms/step\n",
      "iteration :49 Target train: tf.Tensor(0.15401581, shape=(), dtype=float32) loss1 tf.Tensor(0.1276344, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.28165022, shape=(), dtype=float32) loss2   tf.Tensor(0.27359635, shape=(), dtype=float32) loss3  tf.Tensor(0.8781061, shape=(), dtype=float32) Target test: tf.Tensor(0.15541153, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.1641 - mse: 0.1506 - val_loss: 0.1623 - val_mse: 0.1570 - 221ms/epoch - 25ms/step\n",
      "iteration :50 Target train: tf.Tensor(0.15079568, shape=(), dtype=float32) loss1 tf.Tensor(0.13086544, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.28166112, shape=(), dtype=float32) loss2   tf.Tensor(0.27359805, shape=(), dtype=float32) loss3  tf.Tensor(0.877021, shape=(), dtype=float32) Target test: tf.Tensor(0.1521096, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.1609 - mse: 0.1473 - val_loss: 0.1592 - val_mse: 0.1541 - 226ms/epoch - 25ms/step\n",
      "iteration :51 Target train: tf.Tensor(0.14764832, shape=(), dtype=float32) loss1 tf.Tensor(0.13381483, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.28146315, shape=(), dtype=float32) loss2   tf.Tensor(0.27339318, shape=(), dtype=float32) loss3  tf.Tensor(0.8759076, shape=(), dtype=float32) Target test: tf.Tensor(0.14888018, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.1578 - mse: 0.1441 - val_loss: 0.1561 - val_mse: 0.1512 - 235ms/epoch - 26ms/step\n",
      "iteration :52 Target train: tf.Tensor(0.14456455, shape=(), dtype=float32) loss1 tf.Tensor(0.13649662, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.28106117, shape=(), dtype=float32) loss2   tf.Tensor(0.27298662, shape=(), dtype=float32) loss3  tf.Tensor(0.8747772, shape=(), dtype=float32) Target test: tf.Tensor(0.14571513, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.1547 - mse: 0.1410 - val_loss: 0.1530 - val_mse: 0.1483 - 229ms/epoch - 25ms/step\n",
      "iteration :53 Target train: tf.Tensor(0.1415356, shape=(), dtype=float32) loss1 tf.Tensor(0.13892703, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.28046262, shape=(), dtype=float32) loss2   tf.Tensor(0.27238548, shape=(), dtype=float32) loss3  tf.Tensor(0.8736345, shape=(), dtype=float32) Target test: tf.Tensor(0.14260605, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.1517 - mse: 0.1379 - val_loss: 0.1500 - val_mse: 0.1455 - 218ms/epoch - 24ms/step\n",
      "iteration :54 Target train: tf.Tensor(0.13855325, shape=(), dtype=float32) loss1 tf.Tensor(0.14112054, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.27967378, shape=(), dtype=float32) loss2   tf.Tensor(0.2715955, shape=(), dtype=float32) loss3  tf.Tensor(0.8724814, shape=(), dtype=float32) Target test: tf.Tensor(0.13954508, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.1487 - mse: 0.1349 - val_loss: 0.1470 - val_mse: 0.1427 - 231ms/epoch - 26ms/step\n",
      "iteration :55 Target train: tf.Tensor(0.1356097, shape=(), dtype=float32) loss1 tf.Tensor(0.14309232, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.27870202, shape=(), dtype=float32) loss2   tf.Tensor(0.270624, shape=(), dtype=float32) loss3  tf.Tensor(0.8713192, shape=(), dtype=float32) Target test: tf.Tensor(0.13652444, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.1458 - mse: 0.1319 - val_loss: 0.1441 - val_mse: 0.1400 - 233ms/epoch - 26ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iteration :56 Target train: tf.Tensor(0.13269879, shape=(), dtype=float32) loss1 tf.Tensor(0.14486228, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.27756107, shape=(), dtype=float32) loss2   tf.Tensor(0.2694844, shape=(), dtype=float32) loss3  tf.Tensor(0.8707488, shape=(), dtype=float32) Target test: tf.Tensor(0.13353735, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.1429 - mse: 0.1290 - val_loss: 0.1412 - val_mse: 0.1373 - 225ms/epoch - 25ms/step\n",
      "iteration :57 Target train: tf.Tensor(0.12981455, shape=(), dtype=float32) loss1 tf.Tensor(0.14644445, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.276259, shape=(), dtype=float32) loss2   tf.Tensor(0.26818445, shape=(), dtype=float32) loss3  tf.Tensor(0.8700366, shape=(), dtype=float32) Target test: tf.Tensor(0.130578, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.1400 - mse: 0.1261 - val_loss: 0.1383 - val_mse: 0.1346 - 240ms/epoch - 27ms/step\n",
      "iteration :58 Target train: tf.Tensor(0.12695044, shape=(), dtype=float32) loss1 tf.Tensor(0.14785036, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.2748008, shape=(), dtype=float32) loss2   tf.Tensor(0.26672888, shape=(), dtype=float32) loss3  tf.Tensor(0.869275, shape=(), dtype=float32) Target test: tf.Tensor(0.1276411, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.1371 - mse: 0.1231 - val_loss: 0.1355 - val_mse: 0.1319 - 227ms/epoch - 25ms/step\n",
      "iteration :59 Target train: tf.Tensor(0.124100946, shape=(), dtype=float32) loss1 tf.Tensor(0.14909503, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.27319598, shape=(), dtype=float32) loss2   tf.Tensor(0.2651271, shape=(), dtype=float32) loss3  tf.Tensor(0.8685109, shape=(), dtype=float32) Target test: tf.Tensor(0.12472176, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.1342 - mse: 0.1202 - val_loss: 0.1326 - val_mse: 0.1292 - 234ms/epoch - 26ms/step\n",
      "iteration :60 Target train: tf.Tensor(0.12126164, shape=(), dtype=float32) loss1 tf.Tensor(0.15019397, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.27145562, shape=(), dtype=float32) loss2   tf.Tensor(0.2633898, shape=(), dtype=float32) loss3  tf.Tensor(0.8677627, shape=(), dtype=float32) Target test: tf.Tensor(0.121815994, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.1314 - mse: 0.1174 - val_loss: 0.1297 - val_mse: 0.1266 - 227ms/epoch - 25ms/step\n",
      "iteration :61 Target train: tf.Tensor(0.11842921, shape=(), dtype=float32) loss1 tf.Tensor(0.15116307, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.2695923, shape=(), dtype=float32) loss2   tf.Tensor(0.26152942, shape=(), dtype=float32) loss3  tf.Tensor(0.8670364, shape=(), dtype=float32) Target test: tf.Tensor(0.11892084, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.1285 - mse: 0.1145 - val_loss: 0.1269 - val_mse: 0.1239 - 242ms/epoch - 27ms/step\n",
      "iteration :62 Target train: tf.Tensor(0.11560154, shape=(), dtype=float32) loss1 tf.Tensor(0.15201858, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.26762012, shape=(), dtype=float32) loss2   tf.Tensor(0.2595598, shape=(), dtype=float32) loss3  tf.Tensor(0.8663334, shape=(), dtype=float32) Target test: tf.Tensor(0.11603443, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.1256 - mse: 0.1116 - val_loss: 0.1240 - val_mse: 0.1212 - 226ms/epoch - 25ms/step\n",
      "iteration :63 Target train: tf.Tensor(0.11277788, shape=(), dtype=float32) loss1 tf.Tensor(0.15277734, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.26555523, shape=(), dtype=float32) loss2   tf.Tensor(0.25749683, shape=(), dtype=float32) loss3  tf.Tensor(0.86565286, shape=(), dtype=float32) Target test: tf.Tensor(0.113156386, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.1228 - mse: 0.1087 - val_loss: 0.1212 - val_mse: 0.1186 - 234ms/epoch - 26ms/step\n",
      "iteration :64 Target train: tf.Tensor(0.1099589, shape=(), dtype=float32) loss1 tf.Tensor(0.1534559, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.2634148, shape=(), dtype=float32) loss2   tf.Tensor(0.2553574, shape=(), dtype=float32) loss3  tf.Tensor(0.86499226, shape=(), dtype=float32) Target test: tf.Tensor(0.11028774, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.1199 - mse: 0.1059 - val_loss: 0.1183 - val_mse: 0.1159 - 224ms/epoch - 25ms/step\n",
      "iteration :65 Target train: tf.Tensor(0.10714675, shape=(), dtype=float32) loss1 tf.Tensor(0.15406972, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.26121646, shape=(), dtype=float32) loss2   tf.Tensor(0.25315908, shape=(), dtype=float32) loss3  tf.Tensor(0.8643488, shape=(), dtype=float32) Target test: tf.Tensor(0.107430995, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.1171 - mse: 0.1030 - val_loss: 0.1155 - val_mse: 0.1132 - 228ms/epoch - 25ms/step\n",
      "iteration :66 Target train: tf.Tensor(0.10434509, shape=(), dtype=float32) loss1 tf.Tensor(0.15463343, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.25897852, shape=(), dtype=float32) loss2   tf.Tensor(0.2509196, shape=(), dtype=float32) loss3  tf.Tensor(0.86371917, shape=(), dtype=float32) Target test: tf.Tensor(0.104590155, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.1143 - mse: 0.1002 - val_loss: 0.1127 - val_mse: 0.1106 - 229ms/epoch - 25ms/step\n",
      "iteration :67 Target train: tf.Tensor(0.101559065, shape=(), dtype=float32) loss1 tf.Tensor(0.15516016, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.25671923, shape=(), dtype=float32) loss2   tf.Tensor(0.24865724, shape=(), dtype=float32) loss3  tf.Tensor(0.8630994, shape=(), dtype=float32) Target test: tf.Tensor(0.101770684, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.1115 - mse: 0.0973 - val_loss: 0.1099 - val_mse: 0.1079 - 236ms/epoch - 26ms/step\n",
      "iteration :68 Target train: tf.Tensor(0.09879519, shape=(), dtype=float32) loss1 tf.Tensor(0.15566163, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.25445682, shape=(), dtype=float32) loss2   tf.Tensor(0.24639003, shape=(), dtype=float32) loss3  tf.Tensor(0.86248523, shape=(), dtype=float32) Target test: tf.Tensor(0.09897935, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.1087 - mse: 0.0945 - val_loss: 0.1071 - val_mse: 0.1053 - 220ms/epoch - 24ms/step\n",
      "iteration :69 Target train: tf.Tensor(0.09606125, shape=(), dtype=float32) loss1 tf.Tensor(0.15614796, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.25220922, shape=(), dtype=float32) loss2   tf.Tensor(0.24413575, shape=(), dtype=float32) loss3  tf.Tensor(0.86187184, shape=(), dtype=float32) Target test: tf.Tensor(0.09622413, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.1060 - mse: 0.0918 - val_loss: 0.1044 - val_mse: 0.1026 - 230ms/epoch - 26ms/step\n",
      "iteration :70 Target train: tf.Tensor(0.093366005, shape=(), dtype=float32) loss1 tf.Tensor(0.15662766, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.24999367, shape=(), dtype=float32) loss2   tf.Tensor(0.24191147, shape=(), dtype=float32) loss3  tf.Tensor(0.8612546, shape=(), dtype=float32) Target test: tf.Tensor(0.0935139, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.1033 - mse: 0.0891 - val_loss: 0.1017 - val_mse: 0.1001 - 227ms/epoch - 25ms/step\n",
      "iteration :71 Target train: tf.Tensor(0.09071894, shape=(), dtype=float32) loss1 tf.Tensor(0.15710719, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.24782613, shape=(), dtype=float32) loss2   tf.Tensor(0.23973314, shape=(), dtype=float32) loss3  tf.Tensor(0.8606283, shape=(), dtype=float32) Target test: tf.Tensor(0.09085817, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.1006 - mse: 0.0864 - val_loss: 0.0991 - val_mse: 0.0975 - 225ms/epoch - 25ms/step\n",
      "iteration :72 Target train: tf.Tensor(0.088129885, shape=(), dtype=float32) loss1 tf.Tensor(0.1575914, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.24572128, shape=(), dtype=float32) loss2   tf.Tensor(0.23761539, shape=(), dtype=float32) loss3  tf.Tensor(0.859988, shape=(), dtype=float32) Target test: tf.Tensor(0.088266745, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.0980 - mse: 0.0840 - val_loss: 0.0966 - val_mse: 0.0951 - 236ms/epoch - 26ms/step\n",
      "iteration :73 Target train: tf.Tensor(0.08560876, shape=(), dtype=float32) loss1 tf.Tensor(0.15808308, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.24369185, shape=(), dtype=float32) loss2   tf.Tensor(0.23557103, shape=(), dtype=float32) loss3  tf.Tensor(0.8593286, shape=(), dtype=float32) Target test: tf.Tensor(0.08574934, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.0955 - mse: 0.0814 - val_loss: 0.0941 - val_mse: 0.0927 - 232ms/epoch - 26ms/step\n",
      "iteration :74 Target train: tf.Tensor(0.08316505, shape=(), dtype=float32) loss1 tf.Tensor(0.15858352, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.24174857, shape=(), dtype=float32) loss2   tf.Tensor(0.23361081, shape=(), dtype=float32) loss3  tf.Tensor(0.8586453, shape=(), dtype=float32) Target test: tf.Tensor(0.083315216, shape=(), dtype=float32)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "9/9 - 0s - loss: 0.0931 - mse: 0.0789 - val_loss: 0.0917 - val_mse: 0.0903 - 229ms/epoch - 25ms/step\n",
      "iteration :75 Target train: tf.Tensor(0.08080761, shape=(), dtype=float32) loss1 tf.Tensor(0.15909232, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.23989993, shape=(), dtype=float32) loss2   tf.Tensor(0.23174332, shape=(), dtype=float32) loss3  tf.Tensor(0.8579335, shape=(), dtype=float32) Target test: tf.Tensor(0.08097285, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.0907 - mse: 0.0766 - val_loss: 0.0894 - val_mse: 0.0881 - 233ms/epoch - 26ms/step\n",
      "iteration :76 Target train: tf.Tensor(0.07854422, shape=(), dtype=float32) loss1 tf.Tensor(0.15960774, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.23815195, shape=(), dtype=float32) loss2   tf.Tensor(0.2299747, shape=(), dtype=float32) loss3  tf.Tensor(0.8571893, shape=(), dtype=float32) Target test: tf.Tensor(0.07872956, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.0885 - mse: 0.0744 - val_loss: 0.0872 - val_mse: 0.0859 - 220ms/epoch - 24ms/step\n",
      "iteration :77 Target train: tf.Tensor(0.076381356, shape=(), dtype=float32) loss1 tf.Tensor(0.16012694, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.2365083, shape=(), dtype=float32) loss2   tf.Tensor(0.22830883, shape=(), dtype=float32) loss3  tf.Tensor(0.8564088, shape=(), dtype=float32) Target test: tf.Tensor(0.07659134, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.0863 - mse: 0.0723 - val_loss: 0.0852 - val_mse: 0.0838 - 233ms/epoch - 26ms/step\n",
      "iteration :78 Target train: tf.Tensor(0.07432401, shape=(), dtype=float32) loss1 tf.Tensor(0.16064633, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.23497035, shape=(), dtype=float32) loss2   tf.Tensor(0.22674726, shape=(), dtype=float32) loss3  tf.Tensor(0.8555891, shape=(), dtype=float32) Target test: tf.Tensor(0.07456264, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.0843 - mse: 0.0702 - val_loss: 0.0832 - val_mse: 0.0819 - 230ms/epoch - 26ms/step\n",
      "iteration :79 Target train: tf.Tensor(0.072375596, shape=(), dtype=float32) loss1 tf.Tensor(0.1611618, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.23353739, shape=(), dtype=float32) loss2   tf.Tensor(0.22528951, shape=(), dtype=float32) loss3  tf.Tensor(0.85472786, shape=(), dtype=float32) Target test: tf.Tensor(0.072646275, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.0824 - mse: 0.0683 - val_loss: 0.0813 - val_mse: 0.0800 - 238ms/epoch - 26ms/step\n",
      "iteration :80 Target train: tf.Tensor(0.070537895, shape=(), dtype=float32) loss1 tf.Tensor(0.16166897, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.23220687, shape=(), dtype=float32) loss2   tf.Tensor(0.22393334, shape=(), dtype=float32) loss3  tf.Tensor(0.85382354, shape=(), dtype=float32) Target test: tf.Tensor(0.070843436, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.0806 - mse: 0.0666 - val_loss: 0.0796 - val_mse: 0.0782 - 227ms/epoch - 25ms/step\n",
      "iteration :81 Target train: tf.Tensor(0.06881113, shape=(), dtype=float32) loss1 tf.Tensor(0.16216372, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.23097485, shape=(), dtype=float32) loss2   tf.Tensor(0.22267485, shape=(), dtype=float32) loss3  tf.Tensor(0.85287523, shape=(), dtype=float32) Target test: tf.Tensor(0.069153786, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.0789 - mse: 0.0649 - val_loss: 0.0779 - val_mse: 0.0766 - 236ms/epoch - 26ms/step\n",
      "iteration :82 Target train: tf.Tensor(0.06719408, shape=(), dtype=float32) loss1 tf.Tensor(0.16264203, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.2298361, shape=(), dtype=float32) loss2   tf.Tensor(0.22150917, shape=(), dtype=float32) loss3  tf.Tensor(0.8518827, shape=(), dtype=float32) Target test: tf.Tensor(0.06757555, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.0773 - mse: 0.0634 - val_loss: 0.0764 - val_mse: 0.0750 - 232ms/epoch - 26ms/step\n",
      "iteration :83 Target train: tf.Tensor(0.06568419, shape=(), dtype=float32) loss1 tf.Tensor(0.16310042, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.2287846, shape=(), dtype=float32) loss2   tf.Tensor(0.22043051, shape=(), dtype=float32) loss3  tf.Tensor(0.8508465, shape=(), dtype=float32) Target test: tf.Tensor(0.06610571, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.0758 - mse: 0.0619 - val_loss: 0.0750 - val_mse: 0.0736 - 227ms/epoch - 25ms/step\n",
      "iteration :84 Target train: tf.Tensor(0.06427792, shape=(), dtype=float32) loss1 tf.Tensor(0.163536, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.22781391, shape=(), dtype=float32) loss2   tf.Tensor(0.21943256, shape=(), dtype=float32) loss3  tf.Tensor(0.8497678, shape=(), dtype=float32) Target test: tf.Tensor(0.064740226, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.0744 - mse: 0.0606 - val_loss: 0.0737 - val_mse: 0.0722 - 227ms/epoch - 25ms/step\n",
      "iteration :85 Target train: tf.Tensor(0.06297081, shape=(), dtype=float32) loss1 tf.Tensor(0.16394645, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.22691725, shape=(), dtype=float32) loss2   tf.Tensor(0.21850877, shape=(), dtype=float32) loss3  tf.Tensor(0.8486481, shape=(), dtype=float32) Target test: tf.Tensor(0.06347429, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.0731 - mse: 0.0594 - val_loss: 0.0724 - val_mse: 0.0710 - 236ms/epoch - 26ms/step\n",
      "iteration :86 Target train: tf.Tensor(0.061757848, shape=(), dtype=float32) loss1 tf.Tensor(0.16433118, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.22608903, shape=(), dtype=float32) loss2   tf.Tensor(0.21765365, shape=(), dtype=float32) loss3  tf.Tensor(0.84768444, shape=(), dtype=float32) Target test: tf.Tensor(0.062302534, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.0719 - mse: 0.0582 - val_loss: 0.0713 - val_mse: 0.0698 - 226ms/epoch - 25ms/step\n",
      "iteration :87 Target train: tf.Tensor(0.060635045, shape=(), dtype=float32) loss1 tf.Tensor(0.16472541, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.22536045, shape=(), dtype=float32) loss2   tf.Tensor(0.21689656, shape=(), dtype=float32) loss3  tf.Tensor(0.8467642, shape=(), dtype=float32) Target test: tf.Tensor(0.06122044, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.0708 - mse: 0.0571 - val_loss: 0.0702 - val_mse: 0.0687 - 225ms/epoch - 25ms/step\n",
      "iteration :88 Target train: tf.Tensor(0.059596103, shape=(), dtype=float32) loss1 tf.Tensor(0.1650865, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.2246826, shape=(), dtype=float32) loss2   tf.Tensor(0.21619102, shape=(), dtype=float32) loss3  tf.Tensor(0.84570634, shape=(), dtype=float32) Target test: tf.Tensor(0.06022169, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.0698 - mse: 0.0561 - val_loss: 0.0693 - val_mse: 0.0677 - 233ms/epoch - 26ms/step\n",
      "iteration :89 Target train: tf.Tensor(0.058633916, shape=(), dtype=float32) loss1 tf.Tensor(0.16540512, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.22403903, shape=(), dtype=float32) loss2   tf.Tensor(0.21552286, shape=(), dtype=float32) loss3  tf.Tensor(0.84473145, shape=(), dtype=float32) Target test: tf.Tensor(0.05929886, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.0689 - mse: 0.0552 - val_loss: 0.0683 - val_mse: 0.0668 - 239ms/epoch - 27ms/step\n",
      "iteration :90 Target train: tf.Tensor(0.0577434, shape=(), dtype=float32) loss1 tf.Tensor(0.16569954, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.22344294, shape=(), dtype=float32) loss2   tf.Tensor(0.21490243, shape=(), dtype=float32) loss3  tf.Tensor(0.8437664, shape=(), dtype=float32) Target test: tf.Tensor(0.0584472, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.0680 - mse: 0.0543 - val_loss: 0.0675 - val_mse: 0.0659 - 224ms/epoch - 25ms/step\n",
      "iteration :91 Target train: tf.Tensor(0.05691897, shape=(), dtype=float32) loss1 tf.Tensor(0.16596404, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.222883, shape=(), dtype=float32) loss2   tf.Tensor(0.2143184, shape=(), dtype=float32) loss3  tf.Tensor(0.8427464, shape=(), dtype=float32) Target test: tf.Tensor(0.057660338, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.0672 - mse: 0.0536 - val_loss: 0.0667 - val_mse: 0.0651 - 227ms/epoch - 25ms/step\n",
      "iteration :92 Target train: tf.Tensor(0.056155127, shape=(), dtype=float32) loss1 tf.Tensor(0.16620174, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.22235687, shape=(), dtype=float32) loss2   tf.Tensor(0.21376944, shape=(), dtype=float32) loss3  tf.Tensor(0.8417008, shape=(), dtype=float32) Target test: tf.Tensor(0.056932826, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.0664 - mse: 0.0528 - val_loss: 0.0660 - val_mse: 0.0644 - 231ms/epoch - 26ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iteration :93 Target train: tf.Tensor(0.055446606, shape=(), dtype=float32) loss1 tf.Tensor(0.16641147, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.22185808, shape=(), dtype=float32) loss2   tf.Tensor(0.21324876, shape=(), dtype=float32) loss3  tf.Tensor(0.8406629, shape=(), dtype=float32) Target test: tf.Tensor(0.056259517, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.0657 - mse: 0.0522 - val_loss: 0.0653 - val_mse: 0.0637 - 228ms/epoch - 25ms/step\n",
      "iteration :94 Target train: tf.Tensor(0.05478873, shape=(), dtype=float32) loss1 tf.Tensor(0.16659826, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.221387, shape=(), dtype=float32) loss2   tf.Tensor(0.21275666, shape=(), dtype=float32) loss3  tf.Tensor(0.8396102, shape=(), dtype=float32) Target test: tf.Tensor(0.055635665, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.0651 - mse: 0.0516 - val_loss: 0.0647 - val_mse: 0.0630 - 226ms/epoch - 25ms/step\n",
      "iteration :95 Target train: tf.Tensor(0.054177117, shape=(), dtype=float32) loss1 tf.Tensor(0.16676424, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.22094136, shape=(), dtype=float32) loss2   tf.Tensor(0.21229103, shape=(), dtype=float32) loss3  tf.Tensor(0.8385242, shape=(), dtype=float32) Target test: tf.Tensor(0.055056937, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.0644 - mse: 0.0510 - val_loss: 0.0641 - val_mse: 0.0624 - 236ms/epoch - 26ms/step\n",
      "iteration :96 Target train: tf.Tensor(0.053607572, shape=(), dtype=float32) loss1 tf.Tensor(0.16690919, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.22051676, shape=(), dtype=float32) loss2   tf.Tensor(0.21184738, shape=(), dtype=float32) loss3  tf.Tensor(0.8374434, shape=(), dtype=float32) Target test: tf.Tensor(0.054519087, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.0639 - mse: 0.0504 - val_loss: 0.0636 - val_mse: 0.0618 - 228ms/epoch - 25ms/step\n",
      "iteration :97 Target train: tf.Tensor(0.053076286, shape=(), dtype=float32) loss1 tf.Tensor(0.16703297, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.22010925, shape=(), dtype=float32) loss2   tf.Tensor(0.21142188, shape=(), dtype=float32) loss3  tf.Tensor(0.8363415, shape=(), dtype=float32) Target test: tf.Tensor(0.05401826, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.0633 - mse: 0.0499 - val_loss: 0.0631 - val_mse: 0.0613 - 233ms/epoch - 26ms/step\n",
      "iteration :98 Target train: tf.Tensor(0.052579865, shape=(), dtype=float32) loss1 tf.Tensor(0.1671382, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.21971807, shape=(), dtype=float32) loss2   tf.Tensor(0.21101369, shape=(), dtype=float32) loss3  tf.Tensor(0.8355111, shape=(), dtype=float32) Target test: tf.Tensor(0.05355104, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.0629 - mse: 0.0495 - val_loss: 0.0626 - val_mse: 0.0608 - 236ms/epoch - 26ms/step\n",
      "iteration :99 Target train: tf.Tensor(0.052115418, shape=(), dtype=float32) loss1 tf.Tensor(0.16722822, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.21934363, shape=(), dtype=float32) loss2   tf.Tensor(0.21062289, shape=(), dtype=float32) loss3  tf.Tensor(0.8347979, shape=(), dtype=float32) Target test: tf.Tensor(0.053114217, shape=(), dtype=float32)\n",
      "9/9 - 0s - loss: 0.0624 - mse: 0.0490 - val_loss: 0.0621 - val_mse: 0.0603 - 241ms/epoch - 27ms/step\n",
      "iteration :100 Target train: tf.Tensor(0.051679928, shape=(), dtype=float32) loss1 tf.Tensor(0.16730106, shape=(), dtype=float32)\n",
      "loss 12  tf.Tensor(0.21898098, shape=(), dtype=float32) loss2   tf.Tensor(0.21024525, shape=(), dtype=float32) loss3  tf.Tensor(0.83398587, shape=(), dtype=float32) Target test: tf.Tensor(0.052705005, 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=64, validation_split=0.25, verbose=2)\n",
    "    i += 1\n",
    "    \n",
    "    Num = 749\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": 16,
   "id": "4bd4e1d5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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HnvslDLXrFnDxIkT6ezs5LLLLuOmm26iurqa9vZ26urqePjhh3nwwQd54IEHWLVqVea8eDzO3XffzebNm5k0aRIbN27k/vvvZ82aNTnlHzhwgHPPPReAQCBAZWUlR48epaamZsjfkwKyiIiIiGT0dLPoCcg9gdQ5x3333cfWrVvx+XwcOHCAw4cPAzBjxgwWLlzYZ3mPPvoomzZtAqCpqYm9e/dSXV2Nz+dj2bJlANx2220sXbo057w9e/awa9currrqKgCSySRTp049pfy+WouHOxKIArKIiIjIGWiglt5CWrJkCXfddRfbt2+ns7OTuro6ANatW0dzczNvvvkmwWCQ2trazNjCkUikz7IaGxvZsmUL27Zto6ysjIaGhn7HI+4dap1zzJo1i9dff33A+k6fPp2mpiamT59OIpGgtbWViRMnDvZj51Af5Dw889p7/Kefdgy7P4uIiIjImS4ajdLQ0MAdd9yR83Bea2srkydPJhgM8sorr/Dee++dtqzW1laqqqooKytj9+7dvPbaa5l9qVQqM1rF+vXrWbRoUc65M2fOpKWlhW3btgFel4udO3eeco3rr7+ep556CoBnn32WT33qU2pBHg3t3QkOtTs6TiSJhPWViYiISHFbvnw5S5cuzRnR4tZbb+W6665jwYIFzJ8/n1mzZp22nGuuuYbHH3+cefPmMXPmzJxuGJFIhJ07d1JfX09lZSUbN27MOTcUCvHMM89w77330traSiKR4M4772TOnNyW9S9+8Yt8/vOf58ILL2TixImnjMIxFEp7eYimQ3GsO6GALCIiIkXvxhtvPOUv5zU1NZnW3N527NiR8z57LOIXX3yxz3NisRgADz30UM72tWvXZtbnzZvH1q1bB6xrSUkJ3//+9wc8ZrDUxSIP5SVeKG7rSoxxTURERESk0BSQ85DdgiwiIiIixU0BOQ+ZgKwWZBEREZGip4Cch2hJABzEuuNjXRURERERKTAF5Dwc+vlhVraWqA+yiIiIyFlAATkPpaUBfBixthNjXRURERERKTAF5DxEoyEA2tsVkEVERKR4NTQ08PLLL+dse+SRR1ixYsWgyrn22ms5duzYgMdEo9E+t99+++2ZCUTysXXrVurq6ggEAoM6byAKyHkoiwQBaG9XH2QREREpXsuXLz9loo0NGzbkzKg3EOccqVSKF154gQkTJhSiiqc4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Oac3M8t575xj1qxZvP766/3Wta2tjR07dtDQ0ADABx98wPXXX8/zzz/PggULBvvRM9QHeTDC3igWAecjptn0REREpAhFo1EaGhq44447ch7Oa21tZfLkyQSDQV555RXee++905bV2tpKVVUVZWVl7N69m9deey2zL5VKZUarWL9+PYsWLco5d+bMmbS0tLBt2zbA63Kxc+fOnGMqKytpaWlh37597Nu3j4ULFw47HINakAcnFCXk6/ACcnd8rGsjIiIiUhDLly9n6dKlOSNa3HrrrVx33XUsWLCA+fPnM2vWrNOWc8011/D4448zb8qndVMAACAASURBVN48Zs6cmdMNIxKJsHPnTurr66msrGTjxo0554ZCIZ555hnuvfdeWltbSSQS3HnnncyZM2fkPmg/FJAHI+x1sfDh53i7ArKIiIgUpxtvvPGUIW1ramoyrbm97dixI+f9vn37Musvvvhin+fEYt4DiA899FDO9uz+xPPmzWPr1q35VpvGxsa8jx2IulgMRricoHUCEGs/McaVEREREZFCUEAejJA3DjJAe0wtyCIiIiLFSAF5MAJhQn5v4OwOdbEQERGRAtBsvSNvsN+pAvJgmBEKeaudnQrIIiIiMrJKSko4evSoQvIIcs5x9OjRQc2yp4f0BikU9sbo6+7QVNMiIiIysqZPn87+/fv7nHb5bNTV1TUi00eXlJQwffr0vI9XQB6kUNgPQFzjIIuIiMgICwaDnH/++WNdjTNGY2Mjl1566ahfV10sBilUmg7I3WpBFhERESlGCsiDFCwNApBUQBYREREpSupiMUjB0jCQIqVhkEVERESKklqQB8nC5QStC+Kpsa6KiIiIiBSAAvJghcsJ+TqxhIZfERERESlGCsiDFY4SsnYCKUd3Qv2QRURERIqNAvJghaKErYMS54hpqDcRERGRoqOAPFjhckLWQalzxLoVkEVERESKjQLyYIWihHwdhB20qQVZREREpOgoIA9WOErIOgk5UwuyiIiISBFSQB6sUJSgdRB0PvVBFhERESlCCsiDFS4n5OvAj5+2zvhY10ZERERERpgC8mCFvC4WAG0xTacnIiIiUmwUkAcrHCVkHQDEYmpBFhERESk2CsiDlZ5JD6CjQy3IIiIiIsVGAXmwQidbkDvb9ZCeiIiISLFRQB4sn59QMAVAlx7SExERESk6CshDEAwb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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": 17,
   "id": "8f14a2c7",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Target train:  tf.Tensor(0.051679928, shape=(), dtype=float32)\n",
      "Target test:  tf.Tensor(0.052705005, 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": 18,
   "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": 19,
   "id": "b90b3b96",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Weights (kernel_P1):\n",
      " [array([[ 0.91283256, -0.13033795, -0.02020617, -0.04345624, -0.10414486,\n",
      "         0.00928202,  0.13990454,  0.05673765,  0.10229909,  0.        ,\n",
      "         0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
      "         0.        ],\n",
      "       [-0.02251838,  0.9363225 , -0.10538974,  0.04978235,  0.00829706,\n",
      "        -0.02837832,  0.022534  , -0.00263487, -0.07129861,  0.        ,\n",
      "         0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
      "         0.        ],\n",
      "       [-0.03217423, -0.07416397,  0.8967619 ,  0.03322119, -0.06251745,\n",
      "         0.09777734,  0.02131172,  0.04042773, -0.0965428 ,  0.        ,\n",
      "         0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
      "         0.        ],\n",
      "       [-0.1182214 , -0.04621164,  0.07062286,  0.87443835, -0.15948398,\n",
      "         0.25990647, -0.02561089,  0.12966006, -0.24245405,  0.        ,\n",
      "         0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
      "         0.        ],\n",
      "       [-0.00923884, -0.14580718,  0.07709824, -0.10567585,  0.86381096,\n",
      "        -0.050656  , -0.05444686,  0.04965172,  0.10496499,  0.        ,\n",
      "         0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
      "         0.        ],\n",
      "       [-0.01667915, -0.15185277,  0.1136939 , -0.08546367, -0.12606005,\n",
      "         0.8618431 , -0.04298848, -0.02981956,  0.17476131,  0.        ,\n",
      "         0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
      "         0.        ],\n",
      "       [-0.02136445, -0.04564244, -0.05359921, -0.03645007, -0.1369633 ,\n",
      "         0.05918097,  0.89056253,  0.01355841, -0.14108789,  0.        ,\n",
      "         0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
      "         0.        ],\n",
      "       [ 0.0030686 , -0.00275636, -0.03235063,  0.07472044,  0.09219715,\n",
      "        -0.0176636 ,  0.00519205,  0.9102002 , -0.07792183,  0.        ,\n",
      "         0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
      "         0.        ],\n",
      "       [-0.11257944, -0.18237697,  0.0393223 , -0.0519105 , -0.19771624,\n",
      "         0.08284251,  0.01281192, -0.08239908,  0.90963995,  0.        ,\n",
      "         0.        ,  0.        ,  0.        ,  0.        ,  0.        ,\n",
      "         0.        ]], dtype=float32)]\n",
      "Weights (kernel_P2):\n",
      " [array([[ 8.99607956e-01, -1.16113231e-01, -1.23092001e-02,\n",
      "         1.23015326e-02, -7.01704845e-02, -6.38126358e-02,\n",
      "         1.31000131e-01,  6.89897463e-02,  1.64801344e-01,\n",
      "         0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
      "         0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
      "         0.00000000e+00],\n",
      "       [-3.16953957e-02,  9.41232324e-01, -1.09408416e-01,\n",
      "         6.81378245e-02,  6.37128726e-02,  1.24316901e-01,\n",
      "        -1.86143629e-03, -3.44137778e-03, -6.20819293e-02,\n",
      "         0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
      "         0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
      "         0.00000000e+00],\n",
      "       [-5.98355010e-02, -8.54098424e-02,  9.00085807e-01,\n",
      "         2.18271441e-03, -6.75156638e-02,  1.53082982e-01,\n",
      "         1.06515712e-03,  2.57180966e-02, -9.72962677e-02,\n",
      "         0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
      "         0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
      "         0.00000000e+00],\n",
      "       [-1.52252600e-01, -3.08750402e-02,  3.04432064e-02,\n",
      "         8.42932940e-01, -1.41559422e-01,  2.32890829e-01,\n",
      "         3.80495712e-02,  1.06106348e-01, -3.26560497e-01,\n",
      "         0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
      "         0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
      "         0.00000000e+00],\n",
      "       [-1.41784707e-02, -2.76392121e-02,  5.97595610e-02,\n",
      "        -6.52082860e-02,  9.02600348e-01, -1.69447228e-01,\n",
      "        -4.54113260e-02,  5.58259673e-02,  1.35904670e-01,\n",
      "         0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
      "         0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
      "         0.00000000e+00],\n",
      "       [-1.32219315e-01, -1.84350550e-01,  1.16203949e-01,\n",
      "        -1.30384803e-01, -1.96788803e-01,  8.20066333e-01,\n",
      "         5.37832826e-03, -1.77837908e-02,  7.35779405e-02,\n",
      "         0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
      "         0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
      "         0.00000000e+00],\n",
      "       [ 5.45159392e-02, -9.86349285e-02, -7.60974213e-02,\n",
      "        -8.97972509e-02, -4.42456342e-02,  3.53879891e-02,\n",
      "         8.74469459e-01, -1.09626055e-02, -1.36004239e-01,\n",
      "         0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
      "         0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
      "         0.00000000e+00],\n",
      "       [ 1.16181290e-02, -5.13871349e-02, -3.43251266e-02,\n",
      "        -8.58155414e-02,  5.56617565e-02,  3.10435668e-02,\n",
      "        -6.24838940e-05,  9.14065659e-01, -8.24618638e-02,\n",
      "         0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
      "         0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
      "         0.00000000e+00],\n",
      "       [-1.37926146e-01, -1.69129789e-01,  7.62153193e-02,\n",
      "        -1.59595301e-03, -1.71697751e-01,  5.95607841e-03,\n",
      "         1.23928022e-02, -9.12905186e-02,  9.27690148e-01,\n",
      "         0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
      "         0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
      "         0.00000000e+00],\n",
      "       [ 0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
      "         0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
      "         0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
      "         1.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
      "         0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
      "         0.00000000e+00],\n",
      "       [ 0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
      "         0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
      "         0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
      "         0.00000000e+00,  1.00000000e+00,  0.00000000e+00,\n",
      "         0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
      "         0.00000000e+00],\n",
      "       [ 0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
      "         0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
      "         0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
      "         0.00000000e+00,  0.00000000e+00,  1.00000000e+00,\n",
      "         0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
      "         0.00000000e+00],\n",
      "       [ 0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
      "         0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
      "         0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
      "         0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
      "         1.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
      "         0.00000000e+00],\n",
      "       [ 0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
      "         0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
      "         0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
      "         0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
      "         0.00000000e+00,  1.00000000e+00,  0.00000000e+00,\n",
      "         0.00000000e+00],\n",
      "       [ 0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
      "         0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
      "         0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
      "         0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
      "         0.00000000e+00,  0.00000000e+00,  1.00000000e+00,\n",
      "         0.00000000e+00],\n",
      "       [ 0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
      "         0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
      "         0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
      "         0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
      "         0.00000000e+00,  0.00000000e+00,  0.00000000e+00,\n",
      "         1.00000000e+00]], dtype=float32)]\n",
      "Weights (kernel_P3):\n",
      " [array([[ 8.8277668e-01, -9.7418949e-02,  3.3561189e-03,  1.5148069e-01,\n",
      "        -1.6046096e-02, -4.7861315e-02,  1.4179018e-01,  1.1406150e-01,\n",
      "         3.6753184e-01],\n",
      "       [-5.2210558e-02,  9.1868573e-01, -1.1555409e-01,  8.4810309e-02,\n",
      "         1.1486777e-01,  3.6080489e-01, -1.0927184e-02,  1.0324646e-02,\n",
      "        -4.6860170e-02],\n",
      "       [-8.2351580e-02, -9.4331890e-02,  9.0272379e-01, -2.4923425e-02,\n",
      "        -7.1769997e-02,  1.0943880e-01, -9.2021376e-03, -9.0182549e-04,\n",
      "        -1.0839964e-01],\n",
      "       [ 1.4551829e-01, -2.1560995e-02, -1.0205199e-02,  8.1894410e-01,\n",
      "        -1.0728772e-01,  1.9491552e-01, -2.2483446e-01,  3.1918503e-02,\n",
      "        -3.3187130e-01],\n",
      "       [-2.1027165e-02,  7.4646719e-02,  4.1265205e-02, -4.4139861e-03,\n",
      "         9.2056811e-01, -1.1854335e-01, -2.2386607e-02,  8.6342722e-02,\n",
      "         1.8742846e-01],\n",
      "       [-1.2852237e-01, -1.9358017e-01,  7.8584477e-02, -2.0177843e-01,\n",
      "        -2.2129552e-01,  7.3627669e-01, -3.6962898e-03, -5.5511400e-02,\n",
      "        -6.7842968e-02],\n",
      "       [ 2.5458008e-01, -1.8725444e-01, -9.2041306e-02, -2.8911415e-01,\n",
      "        -3.2292966e-02,  1.7710119e-02,  8.1727821e-01, -6.3335814e-02,\n",
      "        -1.3817237e-01],\n",
      "       [ 4.2777088e-02, -9.5830902e-02, -4.5931324e-02, -2.8835154e-01,\n",
      "         4.3879617e-02,  4.9751483e-02, -1.3740539e-02,  9.0047258e-01,\n",
      "        -9.0931758e-02],\n",
      "       [-2.8905153e-01, -6.7506656e-02,  1.3311999e-01,  1.8082324e-01,\n",
      "        -1.7646052e-01, -7.3018603e-02,  6.5273665e-02, -5.4180991e-02,\n",
      "         9.2050421e-01],\n",
      "       [ 0.0000000e+00,  0.0000000e+00,  0.0000000e+00,  0.0000000e+00,\n",
      "         0.0000000e+00,  0.0000000e+00,  0.0000000e+00,  0.0000000e+00,\n",
      "         0.0000000e+00],\n",
      "       [ 0.0000000e+00,  0.0000000e+00,  0.0000000e+00,  0.0000000e+00,\n",
      "         0.0000000e+00,  0.0000000e+00,  0.0000000e+00,  0.0000000e+00,\n",
      "         0.0000000e+00],\n",
      "       [ 0.0000000e+00,  0.0000000e+00,  0.0000000e+00,  0.0000000e+00,\n",
      "         0.0000000e+00,  0.0000000e+00,  0.0000000e+00,  0.0000000e+00,\n",
      "         0.0000000e+00],\n",
      "       [ 0.0000000e+00,  0.0000000e+00,  0.0000000e+00,  0.0000000e+00,\n",
      "         0.0000000e+00,  0.0000000e+00,  0.0000000e+00,  0.0000000e+00,\n",
      "         0.0000000e+00],\n",
      "       [ 0.0000000e+00,  0.0000000e+00,  0.0000000e+00,  0.0000000e+00,\n",
      "         0.0000000e+00,  0.0000000e+00,  0.0000000e+00,  0.0000000e+00,\n",
      "         0.0000000e+00],\n",
      "       [ 0.0000000e+00,  0.0000000e+00,  0.0000000e+00,  0.0000000e+00,\n",
      "         0.0000000e+00,  0.0000000e+00,  0.0000000e+00,  0.0000000e+00,\n",
      "         0.0000000e+00],\n",
      "       [ 0.0000000e+00,  0.0000000e+00,  0.0000000e+00,  0.0000000e+00,\n",
      "         0.0000000e+00,  0.0000000e+00,  0.0000000e+00,  0.0000000e+00,\n",
      "         0.0000000e+00]], 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": 20,
   "id": "e2032c68",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Weights (kernel_I1):\n",
      " [[ 8.64869297e-01 -3.28007825e-02 -1.45138010e-01  8.82112160e-02\n",
      "   3.58268470e-02  1.36155441e-01  2.60836612e-02 -1.67681072e-02\n",
      "  -3.33395116e-02 -1.15516931e-02 -6.09059371e-02 -8.08129162e-02\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [ 1.80085406e-01  9.05946970e-01  5.77733852e-02  9.96543467e-02\n",
      "   4.49862108e-02 -3.27926837e-02 -1.68324590e-01 -4.95189056e-02\n",
      "   4.89050348e-04 -7.75516778e-02 -1.85808092e-02 -2.34208237e-02\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [-1.51557386e-01  4.03020382e-02  8.78399432e-01 -1.04368024e-01\n",
      "  -3.01356707e-02  2.33430322e-03  5.55911846e-02  2.72364877e-02\n",
      "   1.19695002e-02  1.22989431e-01  7.49332411e-03 -1.20938420e-02\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [ 1.23572588e-01  8.63545164e-02  7.20661953e-02  7.21690238e-01\n",
      "   9.63375438e-03 -2.32075956e-02  1.34577647e-01  9.31783989e-02\n",
      "   4.52868268e-02  1.81404829e-01  5.68994246e-02  3.65747772e-02\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [ 9.08854157e-02  1.74633749e-02 -7.78067484e-02  9.61063989e-03\n",
      "   8.84626031e-01  4.22465354e-02 -2.06744149e-01  3.32426839e-02\n",
      "  -1.51551468e-02  2.46735886e-02 -2.00932119e-02 -1.46553740e-02\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [ 2.46237665e-01  1.17247663e-01  1.73616752e-01 -2.46589288e-01\n",
      "   3.83460112e-02  8.96298528e-01  1.28460407e-01  8.85670260e-03\n",
      "  -5.22850407e-03 -1.45497262e-01  7.64483437e-02  2.56892852e-02\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [-2.92304754e-02  1.79092437e-02 -1.17027320e-01  7.41510093e-02\n",
      "  -6.28989041e-02 -4.69559543e-02  8.29073489e-01 -1.15792379e-02\n",
      "  -1.53006110e-02 -9.81683508e-02  1.31661864e-02  7.06931651e-02\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [-1.15001453e-02 -1.11830002e-03 -1.92210689e-01  7.55721703e-02\n",
      "   6.95000263e-03  7.75960088e-02 -1.60445482e-01  8.74759376e-01\n",
      "   1.98652968e-01 -8.68270844e-02 -8.64875168e-02 -6.76480755e-02\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [ 1.04861453e-01  5.39277531e-02  2.39260927e-01 -8.53977203e-02\n",
      "  -5.49928583e-02 -8.20655301e-02  9.60673541e-02  9.49346572e-02\n",
      "   9.05886590e-01  1.00938559e-01  6.35666326e-02  1.58962552e-02\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [ 1.46528676e-01  9.92784500e-02 -5.68042733e-02  2.37285137e-01\n",
      "   1.05739720e-02 -1.02053575e-01 -2.76990205e-01 -7.26535991e-02\n",
      "  -5.24890190e-03  6.72176301e-01  2.44905353e-02  9.04815719e-02\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [-2.82721758e-01 -2.34560728e-01 -2.89058179e-01  8.34878683e-02\n",
      "   6.33025691e-02  8.56686160e-02  1.77496716e-01 -5.70444725e-02\n",
      "  -2.23490712e-03  5.68830259e-02  8.57722282e-01  4.28918116e-02\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [-7.53239021e-02  1.46852180e-01  1.47633672e-01  4.41347696e-02\n",
      "   2.79393252e-02 -3.50562260e-02  1.51188016e-01  9.18537751e-03\n",
      "  -3.31911407e-02 -5.24912924e-02  7.00426176e-02  7.23432600e-01\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]]\n",
      "Weights (kernel_I2):\n",
      " [[ 9.7812688e-01 -7.5484271e-04  1.5583438e-02 ...  0.0000000e+00\n",
      "   0.0000000e+00  0.0000000e+00]\n",
      " [ 1.6679983e-01  9.3536693e-01  6.9917031e-02 ...  0.0000000e+00\n",
      "   0.0000000e+00  0.0000000e+00]\n",
      " [-1.8245320e-01  5.5866860e-02  9.0625519e-01 ...  0.0000000e+00\n",
      "   0.0000000e+00  0.0000000e+00]\n",
      " ...\n",
      " [ 0.0000000e+00  0.0000000e+00  0.0000000e+00 ...  1.0000000e+00\n",
      "   0.0000000e+00  0.0000000e+00]\n",
      " [ 0.0000000e+00  0.0000000e+00  0.0000000e+00 ...  0.0000000e+00\n",
      "   1.0000000e+00  0.0000000e+00]\n",
      " [ 0.0000000e+00  0.0000000e+00  0.0000000e+00 ...  0.0000000e+00\n",
      "   0.0000000e+00  1.0000000e+00]]\n",
      "Weights (kernel_I3):\n",
      " [[ 0.9883231  -0.02992141  0.07847861  0.04915015  0.04693078 -0.11455819\n",
      "   0.00172698  0.01133726 -0.03036114 -0.02152013  0.05392974 -0.17907937]\n",
      " [ 0.09675559  0.9318124   0.07398514  0.05900211  0.04080272 -0.11637159\n",
      "  -0.14428395 -0.03568247  0.00162698 -0.06304996  0.07416613 -0.09319911]\n",
      " [-0.05327243  0.06177257  0.9142487  -0.12800609 -0.02040659 -0.0380194\n",
      "  -0.19891393  0.03211419 -0.0048161   0.12083735  0.04064821  0.1534651 ]\n",
      " [ 0.22793604 -0.10591231 -0.04481165  1.0022782  -0.0255649   0.09743678\n",
      "  -0.03684985  0.01408878  0.04578905 -0.00715917 -0.05809391 -0.03836053]\n",
      " [ 0.07244863 -0.02744042  0.01596458  0.05208277  0.9130032   0.05130761\n",
      "  -0.13466859  0.01861914 -0.00564615 -0.00348053 -0.01483066  0.00594029]\n",
      " [ 0.0105796   0.03251024 -0.03395267  0.05502065  0.06751708  0.89940035\n",
      "   0.08922806 -0.00978848 -0.00959598 -0.12150566  0.06470598 -0.19294412]\n",
      " [-0.09896427  0.05446372  0.03160036 -0.04969845  0.00931409 -0.02867088\n",
      "   1.0275903   0.04447799 -0.05640602  0.05694349 -0.01077787  0.15532948]\n",
      " [ 0.03904748  0.00555547 -0.09277561  0.03438784 -0.02183353 -0.02162299\n",
      "  -0.01835698  0.86199605  0.23565054 -0.0420169   0.06690125 -0.06385541]\n",
      " [ 0.04059663  0.04715641  0.0872945  -0.0798566   0.02522086 -0.0877325\n",
      "  -0.03776173  0.11368897  0.8861639   0.07128832  0.07966576 -0.04062781]\n",
      " [-0.06464781 -0.03963072 -0.04965695  0.08753017 -0.03202429 -0.01146223\n",
      "  -0.16669324  0.09597994 -0.08104363  0.86168504 -0.0546888   0.27101374]\n",
      " [-0.05046915 -0.10650647  0.12826106  0.00381714  0.04694995  0.09807633\n",
      "   0.17132284 -0.04442203  0.02379889  0.03043728  0.84480864  0.17712757]\n",
      " [-0.16022953  0.0654363   0.10486129  0.06271435  0.01819517 -0.04053989\n",
      "  -0.00969315  0.0087122  -0.03312695 -0.01264127  0.05264386  0.6812658 ]\n",
      " [ 0.          0.          0.          0.          0.          0.\n",
      "   0.          0.          0.          0.          0.          0.        ]\n",
      " [ 0.          0.          0.          0.          0.          0.\n",
      "   0.          0.          0.          0.          0.          0.        ]\n",
      " [ 0.          0.          0.          0.          0.          0.\n",
      "   0.          0.          0.          0.          0.          0.        ]\n",
      " [ 0.          0.          0.          0.          0.          0.\n",
      "   0.          0.          0.          0.          0.          0.        ]\n",
      " [ 0.          0.          0.          0.          0.          0.\n",
      "   0.          0.          0.          0.          0.          0.        ]\n",
      " [ 0.          0.          0.          0.          0.          0.\n",
      "   0.          0.          0.          0.          0.          0.        ]\n",
      " [ 0.          0.          0.          0.          0.          0.\n",
      "   0.          0.          0.          0.          0.          0.        ]\n",
      " [ 0.          0.          0.          0.          0.          0.\n",
      "   0.          0.          0.          0.          0.          0.        ]\n",
      " [ 0.          0.          0.          0.          0.          0.\n",
      "   0.          0.          0.          0.          0.          0.        ]\n",
      " [ 0.          0.          0.          0.          0.          0.\n",
      "   0.          0.          0.          0.          0.          0.        ]\n",
      " [ 0.          0.          0.          0.          0.          0.\n",
      "   0.          0.          0.          0.          0.          0.        ]\n",
      " [ 0.          0.          0.          0.          0.          0.\n",
      "   0.          0.          0.          0.          0.          0.        ]\n",
      " [ 0.          0.          0.          0.          0.          0.\n",
      "   0.          0.          0.          0.          0.          0.        ]\n",
      " [ 0.          0.          0.          0.          0.          0.\n",
      "   0.          0.          0.          0.          0.          0.        ]\n",
      " [ 0.          0.          0.          0.          0.          0.\n",
      "   0.          0.          0.          0.          0.          0.        ]\n",
      " [ 0.          0.          0.          0.          0.          0.\n",
      "   0.          0.          0.          0.          0.          0.        ]\n",
      " [ 0.          0.          0.          0.          0.          0.\n",
      "   0.          0.          0.          0.          0.          0.        ]\n",
      " [ 0.          0.          0.          0.          0.          0.\n",
      "   0.          0.          0.          0.          0.          0.        ]\n",
      " [ 0.          0.          0.          0.          0.          0.\n",
      "   0.          0.          0.          0.          0.          0.        ]\n",
      " [ 0.          0.          0.          0.          0.          0.\n",
      "   0.          0.          0.          0.          0.          0.        ]]\n",
      "Weights (kernel_P1):\n",
      " [[ 0.91283256 -0.13033795 -0.02020617 -0.04345624 -0.10414486  0.00928202\n",
      "   0.13990454  0.05673765  0.10229909  0.          0.          0.\n",
      "   0.          0.          0.          0.        ]\n",
      " [-0.02251838  0.9363225  -0.10538974  0.04978235  0.00829706 -0.02837832\n",
      "   0.022534   -0.00263487 -0.07129861  0.          0.          0.\n",
      "   0.          0.          0.          0.        ]\n",
      " [-0.03217423 -0.07416397  0.8967619   0.03322119 -0.06251745  0.09777734\n",
      "   0.02131172  0.04042773 -0.0965428   0.          0.          0.\n",
      "   0.          0.          0.          0.        ]\n",
      " [-0.1182214  -0.04621164  0.07062286  0.87443835 -0.15948398  0.25990647\n",
      "  -0.02561089  0.12966006 -0.24245405  0.          0.          0.\n",
      "   0.          0.          0.          0.        ]\n",
      " [-0.00923884 -0.14580718  0.07709824 -0.10567585  0.86381096 -0.050656\n",
      "  -0.05444686  0.04965172  0.10496499  0.          0.          0.\n",
      "   0.          0.          0.          0.        ]\n",
      " [-0.01667915 -0.15185277  0.1136939  -0.08546367 -0.12606005  0.8618431\n",
      "  -0.04298848 -0.02981956  0.17476131  0.          0.          0.\n",
      "   0.          0.          0.          0.        ]\n",
      " [-0.02136445 -0.04564244 -0.05359921 -0.03645007 -0.1369633   0.05918097\n",
      "   0.89056253  0.01355841 -0.14108789  0.          0.          0.\n",
      "   0.          0.          0.          0.        ]\n",
      " [ 0.0030686  -0.00275636 -0.03235063  0.07472044  0.09219715 -0.0176636\n",
      "   0.00519205  0.9102002  -0.07792183  0.          0.          0.\n",
      "   0.          0.          0.          0.        ]\n",
      " [-0.11257944 -0.18237697  0.0393223  -0.0519105  -0.19771624  0.08284251\n",
      "   0.01281192 -0.08239908  0.90963995  0.          0.          0.\n",
      "   0.          0.          0.          0.        ]]\n",
      "Weights (kernel_P2):\n",
      " [[ 8.99607956e-01 -1.16113231e-01 -1.23092001e-02  1.23015326e-02\n",
      "  -7.01704845e-02 -6.38126358e-02  1.31000131e-01  6.89897463e-02\n",
      "   1.64801344e-01  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [-3.16953957e-02  9.41232324e-01 -1.09408416e-01  6.81378245e-02\n",
      "   6.37128726e-02  1.24316901e-01 -1.86143629e-03 -3.44137778e-03\n",
      "  -6.20819293e-02  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [-5.98355010e-02 -8.54098424e-02  9.00085807e-01  2.18271441e-03\n",
      "  -6.75156638e-02  1.53082982e-01  1.06515712e-03  2.57180966e-02\n",
      "  -9.72962677e-02  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [-1.52252600e-01 -3.08750402e-02  3.04432064e-02  8.42932940e-01\n",
      "  -1.41559422e-01  2.32890829e-01  3.80495712e-02  1.06106348e-01\n",
      "  -3.26560497e-01  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [-1.41784707e-02 -2.76392121e-02  5.97595610e-02 -6.52082860e-02\n",
      "   9.02600348e-01 -1.69447228e-01 -4.54113260e-02  5.58259673e-02\n",
      "   1.35904670e-01  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [-1.32219315e-01 -1.84350550e-01  1.16203949e-01 -1.30384803e-01\n",
      "  -1.96788803e-01  8.20066333e-01  5.37832826e-03 -1.77837908e-02\n",
      "   7.35779405e-02  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [ 5.45159392e-02 -9.86349285e-02 -7.60974213e-02 -8.97972509e-02\n",
      "  -4.42456342e-02  3.53879891e-02  8.74469459e-01 -1.09626055e-02\n",
      "  -1.36004239e-01  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [ 1.16181290e-02 -5.13871349e-02 -3.43251266e-02 -8.58155414e-02\n",
      "   5.56617565e-02  3.10435668e-02 -6.24838940e-05  9.14065659e-01\n",
      "  -8.24618638e-02  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [-1.37926146e-01 -1.69129789e-01  7.62153193e-02 -1.59595301e-03\n",
      "  -1.71697751e-01  5.95607841e-03  1.23928022e-02 -9.12905186e-02\n",
      "   9.27690148e-01  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  1.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  1.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  1.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   1.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  1.00000000e+00  0.00000000e+00  0.00000000e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  1.00000000e+00  0.00000000e+00]\n",
      " [ 0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  0.00000000e+00\n",
      "   0.00000000e+00  0.00000000e+00  0.00000000e+00  1.00000000e+00]]\n",
      "Weights (kernel_P3):\n",
      " [[ 8.8277668e-01 -9.7418949e-02  3.3561189e-03  1.5148069e-01\n",
      "  -1.6046096e-02 -4.7861315e-02  1.4179018e-01  1.1406150e-01\n",
      "   3.6753184e-01]\n",
      " [-5.2210558e-02  9.1868573e-01 -1.1555409e-01  8.4810309e-02\n",
      "   1.1486777e-01  3.6080489e-01 -1.0927184e-02  1.0324646e-02\n",
      "  -4.6860170e-02]\n",
      " [-8.2351580e-02 -9.4331890e-02  9.0272379e-01 -2.4923425e-02\n",
      "  -7.1769997e-02  1.0943880e-01 -9.2021376e-03 -9.0182549e-04\n",
      "  -1.0839964e-01]\n",
      " [ 1.4551829e-01 -2.1560995e-02 -1.0205199e-02  8.1894410e-01\n",
      "  -1.0728772e-01  1.9491552e-01 -2.2483446e-01  3.1918503e-02\n",
      "  -3.3187130e-01]\n",
      " [-2.1027165e-02  7.4646719e-02  4.1265205e-02 -4.4139861e-03\n",
      "   9.2056811e-01 -1.1854335e-01 -2.2386607e-02  8.6342722e-02\n",
      "   1.8742846e-01]\n",
      " [-1.2852237e-01 -1.9358017e-01  7.8584477e-02 -2.0177843e-01\n",
      "  -2.2129552e-01  7.3627669e-01 -3.6962898e-03 -5.5511400e-02\n",
      "  -6.7842968e-02]\n",
      " [ 2.5458008e-01 -1.8725444e-01 -9.2041306e-02 -2.8911415e-01\n",
      "  -3.2292966e-02  1.7710119e-02  8.1727821e-01 -6.3335814e-02\n",
      "  -1.3817237e-01]\n",
      " [ 4.2777088e-02 -9.5830902e-02 -4.5931324e-02 -2.8835154e-01\n",
      "   4.3879617e-02  4.9751483e-02 -1.3740539e-02  9.0047258e-01\n",
      "  -9.0931758e-02]\n",
      " [-2.8905153e-01 -6.7506656e-02  1.3311999e-01  1.8082324e-01\n",
      "  -1.7646052e-01 -7.3018603e-02  6.5273665e-02 -5.4180991e-02\n",
      "   9.2050421e-01]\n",
      " [ 0.0000000e+00  0.0000000e+00  0.0000000e+00  0.0000000e+00\n",
      "   0.0000000e+00  0.0000000e+00  0.0000000e+00  0.0000000e+00\n",
      "   0.0000000e+00]\n",
      " [ 0.0000000e+00  0.0000000e+00  0.0000000e+00  0.0000000e+00\n",
      "   0.0000000e+00  0.0000000e+00  0.0000000e+00  0.0000000e+00\n",
      "   0.0000000e+00]\n",
      " [ 0.0000000e+00  0.0000000e+00  0.0000000e+00  0.0000000e+00\n",
      "   0.0000000e+00  0.0000000e+00  0.0000000e+00  0.0000000e+00\n",
      "   0.0000000e+00]\n",
      " [ 0.0000000e+00  0.0000000e+00  0.0000000e+00  0.0000000e+00\n",
      "   0.0000000e+00  0.0000000e+00  0.0000000e+00  0.0000000e+00\n",
      "   0.0000000e+00]\n",
      " [ 0.0000000e+00  0.0000000e+00  0.0000000e+00  0.0000000e+00\n",
      "   0.0000000e+00  0.0000000e+00  0.0000000e+00  0.0000000e+00\n",
      "   0.0000000e+00]\n",
      " [ 0.0000000e+00  0.0000000e+00  0.0000000e+00  0.0000000e+00\n",
      "   0.0000000e+00  0.0000000e+00  0.0000000e+00  0.0000000e+00\n",
      "   0.0000000e+00]\n",
      " [ 0.0000000e+00  0.0000000e+00  0.0000000e+00  0.0000000e+00\n",
      "   0.0000000e+00  0.0000000e+00  0.0000000e+00  0.0000000e+00\n",
      "   0.0000000e+00]]\n",
      "Weights Final input P:\n",
      " [[ 9.93882239e-01 -7.82460496e-02 -6.92423731e-02  1.68685809e-01\n",
      "   1.06877603e-01  4.19833288e-02  6.09903969e-02 -9.87859536e-03\n",
      "  -6.53949231e-02 -9.35716778e-02 -1.63061917e-02 -3.49895924e-01]\n",
      " [ 5.09541392e-01  7.39721835e-01  1.46853492e-01  2.09228203e-01\n",
      "   1.19051471e-01 -1.81224436e-01 -4.61832404e-01 -1.10810645e-01\n",
      "   1.78073123e-02 -1.52453139e-01  7.80427381e-02 -2.50686884e-01]\n",
      " [-4.57544148e-01  1.67483434e-01  7.56828070e-01 -2.86211163e-01\n",
      "  -7.93075785e-02 -7.03232437e-02 -1.35615781e-01  8.00249875e-02\n",
      "  -6.11035211e-05  2.86175191e-01  6.02628589e-02  4.04074699e-01]\n",
      " [ 3.33223641e-01 -4.12293188e-02  9.22104716e-03  7.08826303e-01\n",
      "  -6.77610701e-03  1.91872437e-02  1.41481478e-02  1.58059940e-01\n",
      "   8.75584334e-02  2.06275523e-01  6.52839476e-03  5.93363754e-02]\n",
      " [ 3.41766119e-01 -5.93542457e-02 -1.38818368e-01  1.50591388e-01\n",
      "   7.56517172e-01  1.20934233e-01 -4.64400500e-01  3.21550667e-02\n",
      "   1.38602974e-02 -5.77706844e-02 -3.74424383e-02 -1.87881887e-01]\n",
      " [ 3.62796366e-01  2.45213941e-01  3.19885850e-01 -3.43864411e-01\n",
      "   1.89104363e-01  6.16045892e-01  3.04696351e-01 -3.67013961e-02\n",
      "  -3.98159288e-02 -2.89676279e-01  2.47277841e-01 -2.77866095e-01]\n",
      " [-1.69451326e-01  8.20389241e-02  1.00565836e-01  5.23453904e-03\n",
      "  -6.17818162e-02 -8.44098181e-02  8.61893356e-01  2.57194936e-02\n",
      "  -7.24318698e-02  5.04940050e-03  1.49041470e-02  2.21481353e-01]\n",
      " [ 2.83250421e-01 -3.12852149e-04 -3.21236044e-01  1.19190641e-01\n",
      "  -9.90623143e-03  3.65885012e-02 -1.99352160e-01  6.86656475e-01\n",
      "   5.56256890e-01 -1.89512014e-01 -2.22318526e-02 -3.81776363e-01]\n",
      " [ 3.81351337e-02  1.57554120e-01  4.81736928e-01 -2.44430766e-01\n",
      "  -5.84636554e-02 -2.83859581e-01 -5.81800984e-03  2.73429275e-01\n",
      "   7.42514610e-01  2.83996463e-01  1.99559078e-01  1.77977681e-01]\n",
      " [ 2.34130472e-01 -6.30298853e-02 -1.05297394e-01  4.61317033e-01\n",
      "  -8.62109847e-03 -7.88336992e-02 -5.28529465e-01 -5.44670457e-03\n",
      "  -5.37806451e-02  4.41380799e-01 -4.29263189e-02  1.44153267e-01]\n",
      " [-4.77189511e-01 -4.37693864e-01 -3.28164160e-01  1.33037567e-01\n",
      "   1.10440925e-01  3.37105483e-01  6.29603446e-01 -8.33926052e-02\n",
      "  -2.69821230e-02  6.94794133e-02  5.42204618e-01  2.95075864e-01]\n",
      " [-2.89681196e-01  2.36830175e-01  2.96057343e-01  7.32812509e-02\n",
      "   4.61346954e-02 -7.36740828e-02  9.96716097e-02  5.03699761e-03\n",
      "  -5.14879562e-02 -7.53078517e-03  1.26394942e-01  4.72448438e-01]]\n",
      "Weights Final output Q:\n",
      " [[ 0.74995697 -0.38822815  0.00141029  0.02190952 -0.23565464 -0.17181765\n",
      "   0.35046524  0.1334887   0.47566292]\n",
      " [-0.01650284  0.84862196 -0.3007005   0.11542165  0.1909291   0.3928872\n",
      "  -0.03589339  0.02007462 -0.18827519]\n",
      " [-0.09321623 -0.25524586  0.73356074 -0.14210647 -0.20485404  0.24388443\n",
      "  -0.01618078  0.03295171 -0.34308505]\n",
      " [-0.00153479 -0.15726356  0.02968598  0.27746037 -0.32929108  0.5530664\n",
      "  -0.22497211  0.1675933  -0.9297381 ]\n",
      " [-0.11717341 -0.07050125  0.19888978 -0.05155685  0.71350896 -0.34273046\n",
      "  -0.0437065   0.13183668  0.4320301 ]\n",
      " [-0.31831732 -0.46833584  0.3243715  -0.27102995 -0.52515346  0.41450247\n",
      "   0.01833236 -0.168081    0.1225207 ]\n",
      " [ 0.30970058 -0.24440278 -0.20323339 -0.3778231  -0.12195091  0.03244352\n",
      "   0.65895945 -0.05092231 -0.29508582]\n",
      " [ 0.09653187 -0.09117053 -0.10408227 -0.29237735  0.19543011  0.02017358\n",
      "  -0.01559716  0.7879998  -0.1761863 ]\n",
      " [-0.4466096  -0.36805934  0.2588007   0.07783319 -0.5377487  -0.06781542\n",
      "   0.05939248 -0.27650478  0.64621276]]\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": 21,
   "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=(12))  # Replace input_dim with your actual input feature dimension\n",
    "new_input_layer = Dense(12, 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(9, 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": 22,
   "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": 23,
   "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, 12)]              0         \n",
      "                                                                 \n",
      " dense_9 (Dense)             (None, 12)                144       \n",
      "                                                                 \n",
      " sequential (Sequential)     (None, 9)                 633       \n",
      "                                                                 \n",
      " dense_10 (Dense)            (None, 9)                 81        \n",
      "                                                                 \n",
      "=================================================================\n",
      "Total params: 858\n",
      "Trainable params: 858\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": 24,
   "id": "55fbdca2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "9/9 - 0s - loss: 0.0497 - mse: 0.0497 - val_loss: 0.0608 - val_mse: 0.0608 - 227ms/epoch - 25ms/step\n",
      "12/12 [==============================] - 0s 690us/step - loss: 0.0512 - mse: 0.0512\n",
      "223/223 [==============================] - 0s 376us/step - loss: 0.0522 - mse: 0.0522\n",
      "9/9 - 0s - loss: 0.0471 - mse: 0.0471 - val_loss: 0.0589 - val_mse: 0.0589 - 33ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 473us/step - loss: 0.0489 - mse: 0.0489\n",
      "223/223 [==============================] - 0s 381us/step - loss: 0.0501 - mse: 0.0501\n",
      "9/9 - 0s - loss: 0.0452 - mse: 0.0452 - val_loss: 0.0570 - val_mse: 0.0570 - 29ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 607us/step - loss: 0.0474 - mse: 0.0474\n",
      "223/223 [==============================] - 0s 365us/step - loss: 0.0487 - mse: 0.0487\n",
      "9/9 - 0s - loss: 0.0439 - mse: 0.0439 - val_loss: 0.0566 - val_mse: 0.0566 - 34ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 412us/step - loss: 0.0465 - mse: 0.0465\n",
      "223/223 [==============================] - 0s 384us/step - loss: 0.0478 - mse: 0.0478\n",
      "9/9 - 0s - loss: 0.0428 - mse: 0.0428 - val_loss: 0.0550 - val_mse: 0.0550 - 33ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 466us/step - loss: 0.0452 - mse: 0.0452\n",
      "223/223 [==============================] - 0s 376us/step - loss: 0.0467 - mse: 0.0467\n",
      "9/9 - 0s - loss: 0.0417 - mse: 0.0417 - val_loss: 0.0536 - val_mse: 0.0536 - 38ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 516us/step - loss: 0.0440 - mse: 0.0440\n",
      "223/223 [==============================] - 0s 395us/step - loss: 0.0455 - mse: 0.0455\n",
      "9/9 - 0s - loss: 0.0409 - mse: 0.0409 - val_loss: 0.0529 - val_mse: 0.0529 - 32ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 516us/step - loss: 0.0433 - mse: 0.0433\n",
      "223/223 [==============================] - 0s 400us/step - loss: 0.0449 - mse: 0.0449\n",
      "9/9 - 0s - loss: 0.0398 - mse: 0.0398 - val_loss: 0.0518 - val_mse: 0.0518 - 34ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 406us/step - loss: 0.0422 - mse: 0.0422\n",
      "223/223 [==============================] - 0s 376us/step - loss: 0.0438 - mse: 0.0438\n",
      "9/9 - 0s - loss: 0.0389 - mse: 0.0389 - val_loss: 0.0508 - val_mse: 0.0508 - 32ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 463us/step - loss: 0.0414 - mse: 0.0414\n",
      "223/223 [==============================] - 0s 385us/step - loss: 0.0430 - mse: 0.0430\n",
      "9/9 - 0s - loss: 0.0383 - mse: 0.0383 - val_loss: 0.0500 - val_mse: 0.0500 - 32ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 430us/step - loss: 0.0407 - mse: 0.0407\n",
      "223/223 [==============================] - 0s 396us/step - loss: 0.0423 - mse: 0.0423\n",
      "9/9 - 0s - loss: 0.0374 - mse: 0.0374 - val_loss: 0.0493 - val_mse: 0.0493 - 33ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 450us/step - loss: 0.0400 - mse: 0.0400\n",
      "223/223 [==============================] - 0s 394us/step - loss: 0.0417 - mse: 0.0417\n",
      "9/9 - 0s - loss: 0.0369 - mse: 0.0369 - val_loss: 0.0485 - val_mse: 0.0485 - 31ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 631us/step - loss: 0.0393 - mse: 0.0393\n",
      "223/223 [==============================] - 0s 382us/step - loss: 0.0411 - mse: 0.0411\n",
      "9/9 - 0s - loss: 0.0363 - mse: 0.0363 - val_loss: 0.0476 - val_mse: 0.0476 - 37ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 437us/step - loss: 0.0388 - mse: 0.0388\n",
      "223/223 [==============================] - 0s 385us/step - loss: 0.0405 - mse: 0.0405\n",
      "9/9 - 0s - loss: 0.0359 - mse: 0.0359 - val_loss: 0.0468 - val_mse: 0.0468 - 34ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 430us/step - loss: 0.0381 - mse: 0.0381\n",
      "223/223 [==============================] - 0s 379us/step - loss: 0.0397 - mse: 0.0397\n",
      "9/9 - 0s - loss: 0.0353 - mse: 0.0353 - val_loss: 0.0466 - val_mse: 0.0466 - 31ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 449us/step - loss: 0.0379 - mse: 0.0379\n",
      "223/223 [==============================] - 0s 403us/step - loss: 0.0395 - mse: 0.0395\n",
      "9/9 - 0s - loss: 0.0348 - mse: 0.0348 - val_loss: 0.0460 - val_mse: 0.0460 - 34ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 515us/step - loss: 0.0373 - mse: 0.0373\n",
      "223/223 [==============================] - 0s 381us/step - loss: 0.0391 - mse: 0.0391\n",
      "9/9 - 0s - loss: 0.0344 - mse: 0.0344 - val_loss: 0.0452 - val_mse: 0.0452 - 33ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 531us/step - loss: 0.0367 - mse: 0.0367\n",
      "223/223 [==============================] - 0s 405us/step - loss: 0.0384 - mse: 0.0384\n",
      "9/9 - 0s - loss: 0.0338 - mse: 0.0338 - val_loss: 0.0449 - val_mse: 0.0449 - 32ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 441us/step - loss: 0.0365 - mse: 0.0365\n",
      "223/223 [==============================] - 0s 383us/step - loss: 0.0384 - mse: 0.0384\n",
      "9/9 - 0s - loss: 0.0335 - mse: 0.0335 - val_loss: 0.0440 - val_mse: 0.0440 - 30ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 620us/step - loss: 0.0357 - mse: 0.0357\n",
      "223/223 [==============================] - 0s 407us/step - loss: 0.0375 - mse: 0.0375\n",
      "9/9 - 0s - loss: 0.0328 - mse: 0.0328 - val_loss: 0.0432 - val_mse: 0.0432 - 32ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 468us/step - loss: 0.0352 - mse: 0.0352\n",
      "223/223 [==============================] - 0s 408us/step - loss: 0.0370 - mse: 0.0370\n",
      "9/9 - 0s - loss: 0.0324 - mse: 0.0324 - val_loss: 0.0425 - val_mse: 0.0425 - 29ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 505us/step - loss: 0.0346 - mse: 0.0346\n",
      "223/223 [==============================] - 0s 387us/step - loss: 0.0364 - mse: 0.0364\n",
      "9/9 - 0s - loss: 0.0319 - mse: 0.0319 - val_loss: 0.0417 - val_mse: 0.0417 - 35ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 406us/step - loss: 0.0340 - mse: 0.0340\n",
      "223/223 [==============================] - 0s 396us/step - loss: 0.0360 - mse: 0.0360\n",
      "9/9 - 0s - loss: 0.0315 - mse: 0.0315 - val_loss: 0.0411 - val_mse: 0.0411 - 30ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 425us/step - loss: 0.0336 - mse: 0.0336\n",
      "223/223 [==============================] - 0s 382us/step - loss: 0.0355 - mse: 0.0355\n",
      "9/9 - 0s - loss: 0.0310 - mse: 0.0310 - val_loss: 0.0400 - val_mse: 0.0400 - 31ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 481us/step - loss: 0.0329 - mse: 0.0329\n",
      "223/223 [==============================] - 0s 411us/step - loss: 0.0349 - mse: 0.0349\n",
      "9/9 - 0s - loss: 0.0303 - mse: 0.0303 - val_loss: 0.0390 - val_mse: 0.0390 - 30ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 574us/step - loss: 0.0319 - mse: 0.0319\n",
      "223/223 [==============================] - 0s 419us/step - loss: 0.0339 - mse: 0.0339\n",
      "9/9 - 0s - loss: 0.0294 - mse: 0.0294 - val_loss: 0.0380 - val_mse: 0.0380 - 33ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 535us/step - loss: 0.0312 - mse: 0.0312\n",
      "223/223 [==============================] - 0s 415us/step - loss: 0.0332 - mse: 0.0332\n",
      "9/9 - 0s - loss: 0.0288 - mse: 0.0288 - val_loss: 0.0371 - val_mse: 0.0371 - 32ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 613us/step - loss: 0.0305 - mse: 0.0305\n",
      "223/223 [==============================] - 0s 405us/step - loss: 0.0325 - mse: 0.0325\n",
      "9/9 - 0s - loss: 0.0280 - mse: 0.0280 - val_loss: 0.0354 - val_mse: 0.0354 - 32ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 494us/step - loss: 0.0294 - mse: 0.0294\n",
      "223/223 [==============================] - 0s 425us/step - loss: 0.0314 - mse: 0.0314\n",
      "9/9 - 0s - loss: 0.0272 - mse: 0.0272 - val_loss: 0.0343 - val_mse: 0.0343 - 32ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 530us/step - loss: 0.0285 - mse: 0.0285\n",
      "223/223 [==============================] - 0s 416us/step - loss: 0.0306 - mse: 0.0306\n",
      "9/9 - 0s - loss: 0.0264 - mse: 0.0264 - val_loss: 0.0330 - val_mse: 0.0330 - 30ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 462us/step - loss: 0.0275 - mse: 0.0275\n",
      "223/223 [==============================] - 0s 387us/step - loss: 0.0297 - mse: 0.0297\n",
      "9/9 - 0s - loss: 0.0256 - mse: 0.0256 - val_loss: 0.0318 - val_mse: 0.0318 - 35ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 453us/step - loss: 0.0266 - mse: 0.0266\n",
      "223/223 [==============================] - 0s 402us/step - loss: 0.0289 - mse: 0.0289\n",
      "9/9 - 0s - loss: 0.0246 - mse: 0.0246 - val_loss: 0.0307 - val_mse: 0.0307 - 30ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 429us/step - loss: 0.0260 - mse: 0.0260\n",
      "223/223 [==============================] - 0s 392us/step - loss: 0.0282 - mse: 0.0282\n",
      "9/9 - 0s - loss: 0.0240 - mse: 0.0240 - val_loss: 0.0290 - val_mse: 0.0290 - 29ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 516us/step - loss: 0.0247 - mse: 0.0247\n",
      "223/223 [==============================] - 0s 415us/step - loss: 0.0269 - mse: 0.0269\n",
      "9/9 - 0s - loss: 0.0230 - mse: 0.0230 - val_loss: 0.0276 - val_mse: 0.0276 - 30ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 439us/step - loss: 0.0237 - mse: 0.0237\n",
      "223/223 [==============================] - 0s 398us/step - loss: 0.0259 - mse: 0.0259\n",
      "9/9 - 0s - loss: 0.0221 - mse: 0.0221 - val_loss: 0.0264 - val_mse: 0.0264 - 28ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 453us/step - loss: 0.0227 - mse: 0.0227\n",
      "223/223 [==============================] - 0s 434us/step - loss: 0.0250 - mse: 0.0250\n",
      "9/9 - 0s - loss: 0.0213 - mse: 0.0213 - val_loss: 0.0255 - val_mse: 0.0255 - 40ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 446us/step - loss: 0.0222 - mse: 0.0222\n",
      "223/223 [==============================] - 0s 405us/step - loss: 0.0244 - mse: 0.0244\n",
      "9/9 - 0s - loss: 0.0209 - mse: 0.0209 - val_loss: 0.0244 - val_mse: 0.0244 - 30ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 440us/step - loss: 0.0214 - mse: 0.0214\n",
      "223/223 [==============================] - 0s 390us/step - loss: 0.0235 - mse: 0.0235\n",
      "9/9 - 0s - loss: 0.0202 - mse: 0.0202 - val_loss: 0.0239 - val_mse: 0.0239 - 30ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 483us/step - loss: 0.0209 - mse: 0.0209\n",
      "223/223 [==============================] - 0s 409us/step - loss: 0.0231 - mse: 0.0231\n",
      "9/9 - 0s - loss: 0.0197 - mse: 0.0197 - val_loss: 0.0230 - val_mse: 0.0230 - 29ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 482us/step - loss: 0.0201 - mse: 0.0201\n",
      "223/223 [==============================] - 0s 443us/step - loss: 0.0222 - mse: 0.0222\n",
      "9/9 - 0s - loss: 0.0191 - mse: 0.0191 - val_loss: 0.0226 - val_mse: 0.0226 - 35ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 426us/step - loss: 0.0198 - mse: 0.0198\n",
      "223/223 [==============================] - 0s 414us/step - loss: 0.0218 - mse: 0.0218\n",
      "9/9 - 0s - loss: 0.0188 - mse: 0.0188 - val_loss: 0.0221 - val_mse: 0.0221 - 35ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 413us/step - loss: 0.0193 - mse: 0.0193\n",
      "223/223 [==============================] - 0s 411us/step - loss: 0.0214 - mse: 0.0214\n",
      "9/9 - 0s - loss: 0.0184 - mse: 0.0184 - val_loss: 0.0218 - val_mse: 0.0218 - 31ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 540us/step - loss: 0.0191 - mse: 0.0191\n",
      "223/223 [==============================] - 0s 414us/step - loss: 0.0211 - mse: 0.0211\n",
      "9/9 - 0s - loss: 0.0182 - mse: 0.0182 - val_loss: 0.0215 - val_mse: 0.0215 - 29ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 468us/step - loss: 0.0188 - mse: 0.0188\n",
      "223/223 [==============================] - 0s 405us/step - loss: 0.0207 - mse: 0.0207\n",
      "9/9 - 0s - loss: 0.0180 - mse: 0.0180 - val_loss: 0.0214 - val_mse: 0.0214 - 29ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 414us/step - loss: 0.0187 - mse: 0.0187\n",
      "223/223 [==============================] - 0s 395us/step - loss: 0.0206 - mse: 0.0206\n",
      "9/9 - 0s - loss: 0.0179 - mse: 0.0179 - val_loss: 0.0216 - val_mse: 0.0216 - 29ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 539us/step - loss: 0.0188 - mse: 0.0188\n",
      "223/223 [==============================] - 0s 468us/step - loss: 0.0207 - mse: 0.0207\n",
      "9/9 - 0s - loss: 0.0177 - mse: 0.0177 - val_loss: 0.0210 - val_mse: 0.0210 - 31ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 490us/step - loss: 0.0183 - mse: 0.0183\n",
      "223/223 [==============================] - 0s 377us/step - loss: 0.0201 - mse: 0.0201\n",
      "9/9 - 0s - loss: 0.0175 - mse: 0.0175 - val_loss: 0.0213 - val_mse: 0.0213 - 35ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 801us/step - loss: 0.0184 - mse: 0.0184\n",
      "223/223 [==============================] - 0s 384us/step - loss: 0.0202 - mse: 0.0202\n",
      "9/9 - 0s - loss: 0.0174 - mse: 0.0174 - val_loss: 0.0209 - val_mse: 0.0209 - 30ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 615us/step - loss: 0.0180 - mse: 0.0180\n",
      "223/223 [==============================] - 0s 387us/step - loss: 0.0200 - mse: 0.0200\n",
      "9/9 - 0s - loss: 0.0173 - mse: 0.0173 - val_loss: 0.0209 - val_mse: 0.0209 - 37ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 560us/step - loss: 0.0181 - mse: 0.0181\n",
      "223/223 [==============================] - 0s 390us/step - loss: 0.0199 - mse: 0.0199\n",
      "9/9 - 0s - loss: 0.0175 - mse: 0.0175 - val_loss: 0.0208 - val_mse: 0.0208 - 29ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 433us/step - loss: 0.0179 - mse: 0.0179\n",
      "223/223 [==============================] - 0s 399us/step - loss: 0.0197 - mse: 0.0197\n",
      "9/9 - 0s - loss: 0.0173 - mse: 0.0173 - val_loss: 0.0208 - val_mse: 0.0208 - 28ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 562us/step - loss: 0.0179 - mse: 0.0179\n",
      "223/223 [==============================] - 0s 403us/step - loss: 0.0196 - mse: 0.0196\n",
      "9/9 - 0s - loss: 0.0170 - mse: 0.0170 - val_loss: 0.0206 - val_mse: 0.0206 - 30ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 577us/step - loss: 0.0177 - mse: 0.0177\n",
      "223/223 [==============================] - 0s 383us/step - loss: 0.0193 - mse: 0.0193\n",
      "9/9 - 0s - loss: 0.0169 - mse: 0.0169 - val_loss: 0.0207 - val_mse: 0.0207 - 29ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 482us/step - loss: 0.0177 - mse: 0.0177\n",
      "223/223 [==============================] - 0s 381us/step - loss: 0.0194 - mse: 0.0194\n",
      "9/9 - 0s - loss: 0.0168 - mse: 0.0168 - val_loss: 0.0208 - val_mse: 0.0208 - 31ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 472us/step - loss: 0.0177 - mse: 0.0177\n",
      "223/223 [==============================] - 0s 405us/step - loss: 0.0194 - mse: 0.0194\n",
      "9/9 - 0s - loss: 0.0167 - mse: 0.0167 - val_loss: 0.0207 - val_mse: 0.0207 - 29ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 440us/step - loss: 0.0177 - mse: 0.0177\n",
      "223/223 [==============================] - 0s 391us/step - loss: 0.0193 - mse: 0.0193\n",
      "9/9 - 0s - loss: 0.0168 - mse: 0.0168 - val_loss: 0.0206 - val_mse: 0.0206 - 31ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 612us/step - loss: 0.0175 - mse: 0.0175\n",
      "223/223 [==============================] - 0s 387us/step - loss: 0.0192 - mse: 0.0192\n",
      "9/9 - 0s - loss: 0.0166 - mse: 0.0166 - val_loss: 0.0205 - val_mse: 0.0205 - 30ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 547us/step - loss: 0.0175 - mse: 0.0175\n",
      "223/223 [==============================] - 0s 415us/step - loss: 0.0190 - mse: 0.0190\n",
      "9/9 - 0s - loss: 0.0165 - mse: 0.0165 - val_loss: 0.0207 - val_mse: 0.0207 - 32ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 408us/step - loss: 0.0175 - mse: 0.0175\n",
      "223/223 [==============================] - 0s 402us/step - loss: 0.0191 - mse: 0.0191\n",
      "9/9 - 0s - loss: 0.0166 - mse: 0.0166 - val_loss: 0.0205 - val_mse: 0.0205 - 31ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 472us/step - loss: 0.0174 - mse: 0.0174\n",
      "223/223 [==============================] - 0s 390us/step - loss: 0.0190 - mse: 0.0190\n",
      "9/9 - 0s - loss: 0.0164 - mse: 0.0164 - val_loss: 0.0204 - val_mse: 0.0204 - 30ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 518us/step - loss: 0.0172 - mse: 0.0172\n",
      "223/223 [==============================] - 0s 375us/step - loss: 0.0188 - mse: 0.0188\n",
      "9/9 - 0s - loss: 0.0163 - mse: 0.0163 - val_loss: 0.0203 - val_mse: 0.0203 - 30ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 479us/step - loss: 0.0171 - mse: 0.0171\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "223/223 [==============================] - 0s 400us/step - loss: 0.0187 - mse: 0.0187\n",
      "9/9 - 0s - loss: 0.0162 - mse: 0.0162 - val_loss: 0.0202 - val_mse: 0.0202 - 28ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 489us/step - loss: 0.0171 - mse: 0.0171\n",
      "223/223 [==============================] - 0s 389us/step - loss: 0.0185 - mse: 0.0185\n",
      "9/9 - 0s - loss: 0.0162 - mse: 0.0162 - val_loss: 0.0204 - val_mse: 0.0204 - 30ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 430us/step - loss: 0.0172 - mse: 0.0172\n",
      "223/223 [==============================] - 0s 376us/step - loss: 0.0186 - mse: 0.0186\n",
      "9/9 - 0s - loss: 0.0161 - mse: 0.0161 - val_loss: 0.0203 - val_mse: 0.0203 - 34ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 419us/step - loss: 0.0171 - mse: 0.0171\n",
      "223/223 [==============================] - 0s 378us/step - loss: 0.0187 - mse: 0.0187\n",
      "9/9 - 0s - loss: 0.0161 - mse: 0.0161 - val_loss: 0.0202 - val_mse: 0.0202 - 29ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 433us/step - loss: 0.0170 - mse: 0.0170\n",
      "223/223 [==============================] - 0s 382us/step - loss: 0.0185 - mse: 0.0185\n",
      "9/9 - 0s - loss: 0.0160 - mse: 0.0160 - val_loss: 0.0199 - val_mse: 0.0199 - 33ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 407us/step - loss: 0.0168 - mse: 0.0168\n",
      "223/223 [==============================] - 0s 387us/step - loss: 0.0182 - mse: 0.0182\n",
      "9/9 - 0s - loss: 0.0159 - mse: 0.0159 - val_loss: 0.0200 - val_mse: 0.0200 - 35ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 408us/step - loss: 0.0168 - mse: 0.0168\n",
      "223/223 [==============================] - 0s 395us/step - loss: 0.0182 - mse: 0.0182\n",
      "9/9 - 0s - loss: 0.0158 - mse: 0.0158 - val_loss: 0.0199 - val_mse: 0.0199 - 31ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 402us/step - loss: 0.0166 - mse: 0.0166\n",
      "223/223 [==============================] - 0s 379us/step - loss: 0.0180 - mse: 0.0180\n",
      "9/9 - 0s - loss: 0.0157 - mse: 0.0157 - val_loss: 0.0199 - val_mse: 0.0199 - 30ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 452us/step - loss: 0.0167 - mse: 0.0167\n",
      "223/223 [==============================] - 0s 387us/step - loss: 0.0181 - mse: 0.0181\n",
      "9/9 - 0s - loss: 0.0157 - mse: 0.0157 - val_loss: 0.0197 - val_mse: 0.0197 - 29ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 420us/step - loss: 0.0165 - mse: 0.0165\n",
      "223/223 [==============================] - 0s 381us/step - loss: 0.0179 - mse: 0.0179\n",
      "9/9 - 0s - loss: 0.0156 - mse: 0.0156 - val_loss: 0.0199 - val_mse: 0.0199 - 29ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 445us/step - loss: 0.0165 - mse: 0.0165\n",
      "223/223 [==============================] - 0s 398us/step - loss: 0.0179 - mse: 0.0179\n",
      "9/9 - 0s - loss: 0.0156 - mse: 0.0156 - val_loss: 0.0200 - val_mse: 0.0200 - 30ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 468us/step - loss: 0.0167 - mse: 0.0167\n",
      "223/223 [==============================] - 0s 384us/step - loss: 0.0180 - mse: 0.0180\n",
      "9/9 - 0s - loss: 0.0156 - mse: 0.0156 - val_loss: 0.0198 - val_mse: 0.0198 - 30ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 474us/step - loss: 0.0165 - mse: 0.0165\n",
      "223/223 [==============================] - 0s 388us/step - loss: 0.0178 - mse: 0.0178\n",
      "9/9 - 0s - loss: 0.0155 - mse: 0.0155 - val_loss: 0.0198 - val_mse: 0.0198 - 32ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 503us/step - loss: 0.0165 - mse: 0.0165\n",
      "223/223 [==============================] - 0s 393us/step - loss: 0.0179 - mse: 0.0179\n",
      "9/9 - 0s - loss: 0.0154 - mse: 0.0154 - val_loss: 0.0196 - val_mse: 0.0196 - 32ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 396us/step - loss: 0.0164 - mse: 0.0164\n",
      "223/223 [==============================] - 0s 394us/step - loss: 0.0176 - mse: 0.0176\n",
      "9/9 - 0s - loss: 0.0153 - mse: 0.0153 - val_loss: 0.0195 - val_mse: 0.0195 - 35ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 437us/step - loss: 0.0162 - mse: 0.0162\n",
      "223/223 [==============================] - 0s 381us/step - loss: 0.0175 - mse: 0.0175\n",
      "9/9 - 0s - loss: 0.0153 - mse: 0.0153 - val_loss: 0.0197 - val_mse: 0.0197 - 31ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 432us/step - loss: 0.0163 - mse: 0.0163\n",
      "223/223 [==============================] - 0s 369us/step - loss: 0.0176 - mse: 0.0176\n",
      "9/9 - 0s - loss: 0.0152 - mse: 0.0152 - val_loss: 0.0194 - val_mse: 0.0194 - 32ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 449us/step - loss: 0.0162 - mse: 0.0162\n",
      "223/223 [==============================] - 0s 400us/step - loss: 0.0175 - mse: 0.0175\n",
      "9/9 - 0s - loss: 0.0151 - mse: 0.0151 - val_loss: 0.0195 - val_mse: 0.0195 - 30ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 448us/step - loss: 0.0162 - mse: 0.0162\n",
      "223/223 [==============================] - 0s 409us/step - loss: 0.0175 - mse: 0.0175\n",
      "9/9 - 0s - loss: 0.0152 - mse: 0.0152 - val_loss: 0.0195 - val_mse: 0.0195 - 34ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 428us/step - loss: 0.0162 - mse: 0.0162\n",
      "223/223 [==============================] - 0s 381us/step - loss: 0.0174 - mse: 0.0174\n",
      "9/9 - 0s - loss: 0.0151 - mse: 0.0151 - val_loss: 0.0197 - val_mse: 0.0197 - 31ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 411us/step - loss: 0.0163 - mse: 0.0163\n",
      "223/223 [==============================] - 0s 391us/step - loss: 0.0174 - mse: 0.0174\n",
      "9/9 - 0s - loss: 0.0150 - mse: 0.0150 - val_loss: 0.0193 - val_mse: 0.0193 - 33ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 418us/step - loss: 0.0160 - mse: 0.0160\n",
      "223/223 [==============================] - 0s 642us/step - loss: 0.0173 - mse: 0.0173\n",
      "9/9 - 0s - loss: 0.0150 - mse: 0.0150 - val_loss: 0.0194 - val_mse: 0.0194 - 50ms/epoch - 6ms/step\n",
      "12/12 [==============================] - 0s 869us/step - loss: 0.0160 - mse: 0.0160\n",
      "223/223 [==============================] - 0s 690us/step - loss: 0.0173 - mse: 0.0173\n",
      "9/9 - 0s - loss: 0.0148 - mse: 0.0148 - val_loss: 0.0192 - val_mse: 0.0192 - 49ms/epoch - 5ms/step\n",
      "12/12 [==============================] - 0s 813us/step - loss: 0.0158 - mse: 0.0158\n",
      "223/223 [==============================] - 0s 666us/step - loss: 0.0170 - mse: 0.0170\n",
      "9/9 - 0s - loss: 0.0148 - mse: 0.0148 - val_loss: 0.0190 - val_mse: 0.0190 - 52ms/epoch - 6ms/step\n",
      "12/12 [==============================] - 0s 868us/step - loss: 0.0157 - mse: 0.0157\n",
      "223/223 [==============================] - 0s 392us/step - loss: 0.0169 - mse: 0.0169\n",
      "9/9 - 0s - loss: 0.0147 - mse: 0.0147 - val_loss: 0.0189 - val_mse: 0.0189 - 32ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 496us/step - loss: 0.0156 - mse: 0.0156\n",
      "223/223 [==============================] - 0s 435us/step - loss: 0.0168 - mse: 0.0168\n",
      "9/9 - 0s - loss: 0.0146 - mse: 0.0146 - val_loss: 0.0190 - val_mse: 0.0190 - 29ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 494us/step - loss: 0.0156 - mse: 0.0156\n",
      "223/223 [==============================] - 0s 370us/step - loss: 0.0169 - mse: 0.0169\n",
      "9/9 - 0s - loss: 0.0145 - mse: 0.0145 - val_loss: 0.0187 - val_mse: 0.0187 - 33ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 669us/step - loss: 0.0154 - mse: 0.0154\n",
      "223/223 [==============================] - 0s 388us/step - loss: 0.0166 - mse: 0.0166\n",
      "9/9 - 0s - loss: 0.0144 - mse: 0.0144 - val_loss: 0.0188 - val_mse: 0.0188 - 31ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 555us/step - loss: 0.0154 - mse: 0.0154\n",
      "223/223 [==============================] - 0s 395us/step - loss: 0.0166 - mse: 0.0166\n",
      "9/9 - 0s - loss: 0.0143 - mse: 0.0143 - val_loss: 0.0186 - val_mse: 0.0186 - 31ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 460us/step - loss: 0.0152 - mse: 0.0152\n",
      "223/223 [==============================] - 0s 372us/step - loss: 0.0163 - mse: 0.0163\n",
      "9/9 - 0s - loss: 0.0142 - mse: 0.0142 - val_loss: 0.0186 - val_mse: 0.0186 - 32ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 555us/step - loss: 0.0154 - mse: 0.0154\n",
      "223/223 [==============================] - 0s 369us/step - loss: 0.0166 - mse: 0.0166\n",
      "9/9 - 0s - loss: 0.0142 - mse: 0.0142 - val_loss: 0.0185 - val_mse: 0.0185 - 33ms/epoch - 4ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "12/12 [==============================] - 0s 496us/step - loss: 0.0151 - mse: 0.0151\n",
      "223/223 [==============================] - 0s 374us/step - loss: 0.0162 - mse: 0.0162\n",
      "9/9 - 0s - loss: 0.0140 - mse: 0.0140 - val_loss: 0.0182 - val_mse: 0.0182 - 32ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 457us/step - loss: 0.0150 - mse: 0.0150\n",
      "223/223 [==============================] - 0s 381us/step - loss: 0.0160 - mse: 0.0160\n",
      "9/9 - 0s - loss: 0.0140 - mse: 0.0140 - val_loss: 0.0182 - val_mse: 0.0182 - 36ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 426us/step - loss: 0.0149 - mse: 0.0149\n",
      "223/223 [==============================] - 0s 365us/step - loss: 0.0160 - mse: 0.0160\n",
      "9/9 - 0s - loss: 0.0138 - mse: 0.0138 - val_loss: 0.0181 - val_mse: 0.0181 - 31ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 464us/step - loss: 0.0148 - mse: 0.0148\n",
      "223/223 [==============================] - 0s 370us/step - loss: 0.0160 - mse: 0.0160\n",
      "9/9 - 0s - loss: 0.0137 - mse: 0.0137 - val_loss: 0.0180 - val_mse: 0.0180 - 32ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 556us/step - loss: 0.0147 - mse: 0.0147\n",
      "223/223 [==============================] - 0s 374us/step - loss: 0.0158 - mse: 0.0158\n",
      "9/9 - 0s - loss: 0.0135 - mse: 0.0135 - val_loss: 0.0178 - val_mse: 0.0178 - 35ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 458us/step - loss: 0.0145 - mse: 0.0145\n",
      "223/223 [==============================] - 0s 392us/step - loss: 0.0156 - mse: 0.0156\n",
      "9/9 - 0s - loss: 0.0134 - mse: 0.0134 - val_loss: 0.0173 - val_mse: 0.0173 - 34ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 412us/step - loss: 0.0141 - mse: 0.0141\n",
      "223/223 [==============================] - 0s 376us/step - loss: 0.0152 - mse: 0.0152\n",
      "9/9 - 0s - loss: 0.0131 - mse: 0.0131 - val_loss: 0.0171 - val_mse: 0.0171 - 31ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 437us/step - loss: 0.0139 - mse: 0.0139\n",
      "223/223 [==============================] - 0s 402us/step - loss: 0.0150 - mse: 0.0150\n",
      "9/9 - 0s - loss: 0.0129 - mse: 0.0129 - val_loss: 0.0170 - val_mse: 0.0170 - 31ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 508us/step - loss: 0.0137 - mse: 0.0137\n",
      "223/223 [==============================] - 0s 397us/step - loss: 0.0147 - mse: 0.0147\n",
      "9/9 - 0s - loss: 0.0127 - mse: 0.0127 - val_loss: 0.0168 - val_mse: 0.0168 - 31ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 453us/step - loss: 0.0136 - mse: 0.0136\n",
      "223/223 [==============================] - 0s 396us/step - loss: 0.0147 - mse: 0.0147\n",
      "9/9 - 0s - loss: 0.0125 - mse: 0.0125 - val_loss: 0.0165 - val_mse: 0.0165 - 30ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 493us/step - loss: 0.0133 - mse: 0.0133\n",
      "223/223 [==============================] - 0s 379us/step - loss: 0.0144 - mse: 0.0144\n",
      "9/9 - 0s - loss: 0.0123 - mse: 0.0123 - val_loss: 0.0162 - val_mse: 0.0162 - 32ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 459us/step - loss: 0.0130 - mse: 0.0130\n",
      "223/223 [==============================] - 0s 366us/step - loss: 0.0140 - mse: 0.0140\n",
      "9/9 - 0s - loss: 0.0120 - mse: 0.0120 - val_loss: 0.0159 - val_mse: 0.0159 - 30ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 432us/step - loss: 0.0127 - mse: 0.0127\n",
      "223/223 [==============================] - 0s 371us/step - loss: 0.0137 - mse: 0.0137\n",
      "9/9 - 0s - loss: 0.0117 - mse: 0.0117 - val_loss: 0.0154 - val_mse: 0.0154 - 35ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 547us/step - loss: 0.0123 - mse: 0.0123\n",
      "223/223 [==============================] - 0s 398us/step - loss: 0.0133 - mse: 0.0133\n",
      "9/9 - 0s - loss: 0.0113 - mse: 0.0113 - val_loss: 0.0151 - val_mse: 0.0151 - 30ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 661us/step - loss: 0.0121 - mse: 0.0121\n",
      "223/223 [==============================] - 0s 380us/step - loss: 0.0131 - mse: 0.0131\n",
      "9/9 - 0s - loss: 0.0110 - mse: 0.0110 - val_loss: 0.0148 - val_mse: 0.0148 - 29ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 464us/step - loss: 0.0118 - mse: 0.0118\n",
      "223/223 [==============================] - 0s 377us/step - loss: 0.0129 - mse: 0.0129\n",
      "9/9 - 0s - loss: 0.0106 - mse: 0.0106 - val_loss: 0.0140 - val_mse: 0.0140 - 30ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 459us/step - loss: 0.0112 - mse: 0.0112\n",
      "223/223 [==============================] - 0s 359us/step - loss: 0.0122 - mse: 0.0122\n",
      "9/9 - 0s - loss: 0.0101 - mse: 0.0101 - val_loss: 0.0137 - val_mse: 0.0137 - 31ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 629us/step - loss: 0.0109 - mse: 0.0109\n",
      "223/223 [==============================] - 0s 377us/step - loss: 0.0119 - mse: 0.0119\n",
      "9/9 - 0s - loss: 0.0099 - mse: 0.0099 - val_loss: 0.0134 - val_mse: 0.0134 - 30ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 498us/step - loss: 0.0105 - mse: 0.0105\n",
      "223/223 [==============================] - 0s 381us/step - loss: 0.0114 - mse: 0.0114\n",
      "9/9 - 0s - loss: 0.0093 - mse: 0.0093 - val_loss: 0.0125 - val_mse: 0.0125 - 31ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 472us/step - loss: 0.0099 - mse: 0.0099\n",
      "223/223 [==============================] - 0s 359us/step - loss: 0.0109 - mse: 0.0109\n",
      "9/9 - 0s - loss: 0.0089 - mse: 0.0089 - val_loss: 0.0121 - val_mse: 0.0121 - 31ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 439us/step - loss: 0.0094 - mse: 0.0094\n",
      "223/223 [==============================] - 0s 395us/step - loss: 0.0104 - mse: 0.0104\n",
      "9/9 - 0s - loss: 0.0084 - mse: 0.0084 - val_loss: 0.0115 - val_mse: 0.0115 - 33ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 481us/step - loss: 0.0090 - mse: 0.0090\n",
      "223/223 [==============================] - 0s 376us/step - loss: 0.0100 - mse: 0.0100\n",
      "9/9 - 0s - loss: 0.0082 - mse: 0.0082 - val_loss: 0.0111 - val_mse: 0.0111 - 36ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 440us/step - loss: 0.0087 - mse: 0.0087\n",
      "223/223 [==============================] - 0s 366us/step - loss: 0.0097 - mse: 0.0097\n",
      "9/9 - 0s - loss: 0.0077 - mse: 0.0077 - val_loss: 0.0106 - val_mse: 0.0106 - 30ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 515us/step - loss: 0.0082 - mse: 0.0082\n",
      "223/223 [==============================] - 0s 364us/step - loss: 0.0092 - mse: 0.0092\n",
      "9/9 - 0s - loss: 0.0074 - mse: 0.0074 - val_loss: 0.0103 - val_mse: 0.0103 - 32ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 406us/step - loss: 0.0079 - mse: 0.0079\n",
      "223/223 [==============================] - 0s 382us/step - loss: 0.0087 - mse: 0.0087\n",
      "9/9 - 0s - loss: 0.0072 - mse: 0.0072 - val_loss: 0.0098 - val_mse: 0.0098 - 29ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 452us/step - loss: 0.0076 - mse: 0.0076\n",
      "223/223 [==============================] - 0s 388us/step - loss: 0.0084 - mse: 0.0084\n",
      "9/9 - 0s - loss: 0.0070 - mse: 0.0070 - val_loss: 0.0096 - val_mse: 0.0096 - 31ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 462us/step - loss: 0.0075 - mse: 0.0075\n",
      "223/223 [==============================] - 0s 397us/step - loss: 0.0083 - mse: 0.0083\n",
      "9/9 - 0s - loss: 0.0068 - mse: 0.0068 - val_loss: 0.0097 - val_mse: 0.0097 - 35ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 455us/step - loss: 0.0075 - mse: 0.0075\n",
      "223/223 [==============================] - 0s 383us/step - loss: 0.0085 - mse: 0.0085\n",
      "9/9 - 0s - loss: 0.0066 - mse: 0.0066 - val_loss: 0.0092 - val_mse: 0.0092 - 33ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 520us/step - loss: 0.0070 - mse: 0.0070\n",
      "223/223 [==============================] - 0s 375us/step - loss: 0.0079 - mse: 0.0079\n",
      "9/9 - 0s - loss: 0.0064 - mse: 0.0064 - val_loss: 0.0090 - val_mse: 0.0090 - 35ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 453us/step - loss: 0.0068 - mse: 0.0068\n",
      "223/223 [==============================] - 0s 373us/step - loss: 0.0077 - mse: 0.0077\n",
      "9/9 - 0s - loss: 0.0063 - mse: 0.0063 - val_loss: 0.0090 - val_mse: 0.0090 - 33ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 413us/step - loss: 0.0068 - mse: 0.0068\n",
      "223/223 [==============================] - 0s 372us/step - loss: 0.0076 - mse: 0.0076\n",
      "9/9 - 0s - loss: 0.0061 - mse: 0.0061 - val_loss: 0.0089 - val_mse: 0.0089 - 38ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 425us/step - loss: 0.0067 - mse: 0.0067\n",
      "223/223 [==============================] - 0s 376us/step - loss: 0.0076 - mse: 0.0076\n",
      "9/9 - 0s - loss: 0.0061 - mse: 0.0061 - val_loss: 0.0088 - val_mse: 0.0088 - 31ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 555us/step - loss: 0.0067 - mse: 0.0067\n",
      "223/223 [==============================] - 0s 370us/step - loss: 0.0076 - mse: 0.0076\n",
      "9/9 - 0s - loss: 0.0060 - mse: 0.0060 - val_loss: 0.0087 - val_mse: 0.0087 - 31ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 525us/step - loss: 0.0066 - mse: 0.0066\n",
      "223/223 [==============================] - 0s 385us/step - loss: 0.0074 - mse: 0.0074\n",
      "9/9 - 0s - loss: 0.0060 - mse: 0.0060 - val_loss: 0.0084 - val_mse: 0.0084 - 34ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 396us/step - loss: 0.0064 - mse: 0.0064\n",
      "223/223 [==============================] - 0s 373us/step - loss: 0.0073 - mse: 0.0073\n",
      "9/9 - 0s - loss: 0.0059 - mse: 0.0059 - val_loss: 0.0084 - val_mse: 0.0084 - 31ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 440us/step - loss: 0.0064 - mse: 0.0064\n",
      "223/223 [==============================] - 0s 381us/step - loss: 0.0072 - mse: 0.0072\n",
      "9/9 - 0s - loss: 0.0059 - mse: 0.0059 - val_loss: 0.0086 - val_mse: 0.0086 - 34ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 485us/step - loss: 0.0064 - mse: 0.0064\n",
      "223/223 [==============================] - 0s 398us/step - loss: 0.0073 - mse: 0.0073\n",
      "9/9 - 0s - loss: 0.0058 - mse: 0.0058 - val_loss: 0.0085 - val_mse: 0.0085 - 30ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 457us/step - loss: 0.0063 - mse: 0.0063\n",
      "223/223 [==============================] - 0s 389us/step - loss: 0.0072 - mse: 0.0072\n",
      "9/9 - 0s - loss: 0.0057 - mse: 0.0057 - val_loss: 0.0083 - val_mse: 0.0083 - 37ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 477us/step - loss: 0.0062 - mse: 0.0062\n",
      "223/223 [==============================] - 0s 392us/step - loss: 0.0071 - mse: 0.0071\n",
      "9/9 - 0s - loss: 0.0056 - mse: 0.0056 - val_loss: 0.0083 - val_mse: 0.0083 - 31ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 582us/step - loss: 0.0062 - mse: 0.0062\n",
      "223/223 [==============================] - 0s 376us/step - loss: 0.0071 - mse: 0.0071\n",
      "9/9 - 0s - loss: 0.0056 - mse: 0.0056 - val_loss: 0.0085 - val_mse: 0.0085 - 35ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 663us/step - loss: 0.0064 - mse: 0.0064\n",
      "223/223 [==============================] - 0s 397us/step - loss: 0.0073 - mse: 0.0073\n",
      "9/9 - 0s - loss: 0.0057 - mse: 0.0057 - val_loss: 0.0084 - val_mse: 0.0084 - 32ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 496us/step - loss: 0.0064 - mse: 0.0064\n",
      "223/223 [==============================] - 0s 409us/step - loss: 0.0073 - mse: 0.0073\n",
      "9/9 - 0s - loss: 0.0056 - mse: 0.0056 - val_loss: 0.0085 - val_mse: 0.0085 - 30ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 440us/step - loss: 0.0063 - mse: 0.0063\n",
      "223/223 [==============================] - 0s 387us/step - loss: 0.0073 - mse: 0.0073\n",
      "9/9 - 0s - loss: 0.0056 - mse: 0.0056 - val_loss: 0.0082 - val_mse: 0.0082 - 30ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 460us/step - loss: 0.0062 - mse: 0.0062\n",
      "223/223 [==============================] - 0s 377us/step - loss: 0.0071 - mse: 0.0071\n",
      "9/9 - 0s - loss: 0.0054 - mse: 0.0054 - val_loss: 0.0083 - val_mse: 0.0083 - 29ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 466us/step - loss: 0.0061 - mse: 0.0061\n",
      "223/223 [==============================] - 0s 393us/step - loss: 0.0071 - mse: 0.0071\n",
      "9/9 - 0s - loss: 0.0055 - mse: 0.0055 - val_loss: 0.0080 - val_mse: 0.0080 - 31ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 446us/step - loss: 0.0060 - mse: 0.0060\n",
      "223/223 [==============================] - 0s 383us/step - loss: 0.0069 - mse: 0.0069\n",
      "9/9 - 0s - loss: 0.0054 - mse: 0.0054 - val_loss: 0.0082 - val_mse: 0.0082 - 29ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 458us/step - loss: 0.0061 - mse: 0.0061\n",
      "223/223 [==============================] - 0s 375us/step - loss: 0.0070 - mse: 0.0070\n",
      "9/9 - 0s - loss: 0.0054 - mse: 0.0054 - val_loss: 0.0082 - val_mse: 0.0082 - 30ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 495us/step - loss: 0.0061 - mse: 0.0061\n",
      "223/223 [==============================] - 0s 367us/step - loss: 0.0070 - mse: 0.0070\n",
      "9/9 - 0s - loss: 0.0054 - mse: 0.0054 - val_loss: 0.0080 - val_mse: 0.0080 - 29ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 536us/step - loss: 0.0060 - mse: 0.0060\n",
      "223/223 [==============================] - 0s 368us/step - loss: 0.0069 - mse: 0.0069\n",
      "9/9 - 0s - loss: 0.0053 - mse: 0.0053 - val_loss: 0.0080 - val_mse: 0.0080 - 34ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 502us/step - loss: 0.0059 - mse: 0.0059\n",
      "223/223 [==============================] - 0s 375us/step - loss: 0.0068 - mse: 0.0068\n",
      "9/9 - 0s - loss: 0.0053 - mse: 0.0053 - val_loss: 0.0081 - val_mse: 0.0081 - 30ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 517us/step - loss: 0.0060 - mse: 0.0060\n",
      "223/223 [==============================] - 0s 378us/step - loss: 0.0069 - mse: 0.0069\n",
      "9/9 - 0s - loss: 0.0053 - mse: 0.0053 - val_loss: 0.0081 - val_mse: 0.0081 - 29ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 504us/step - loss: 0.0059 - mse: 0.0059\n",
      "223/223 [==============================] - 0s 370us/step - loss: 0.0069 - mse: 0.0069\n",
      "9/9 - 0s - loss: 0.0053 - mse: 0.0053 - val_loss: 0.0079 - val_mse: 0.0079 - 30ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 466us/step - loss: 0.0059 - mse: 0.0059\n",
      "223/223 [==============================] - 0s 386us/step - loss: 0.0067 - mse: 0.0067\n",
      "9/9 - 0s - loss: 0.0053 - mse: 0.0053 - val_loss: 0.0081 - val_mse: 0.0081 - 34ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 402us/step - loss: 0.0059 - mse: 0.0059\n",
      "223/223 [==============================] - 0s 361us/step - loss: 0.0068 - mse: 0.0068\n",
      "9/9 - 0s - loss: 0.0052 - mse: 0.0052 - val_loss: 0.0080 - val_mse: 0.0080 - 31ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 490us/step - loss: 0.0058 - mse: 0.0058\n",
      "223/223 [==============================] - 0s 382us/step - loss: 0.0067 - mse: 0.0067\n",
      "9/9 - 0s - loss: 0.0053 - mse: 0.0053 - val_loss: 0.0079 - val_mse: 0.0079 - 29ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 523us/step - loss: 0.0059 - mse: 0.0059\n",
      "223/223 [==============================] - 0s 389us/step - loss: 0.0069 - mse: 0.0069\n",
      "9/9 - 0s - loss: 0.0053 - mse: 0.0053 - val_loss: 0.0080 - val_mse: 0.0080 - 32ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 454us/step - loss: 0.0059 - mse: 0.0059\n",
      "223/223 [==============================] - 0s 399us/step - loss: 0.0068 - mse: 0.0068\n",
      "9/9 - 0s - loss: 0.0052 - mse: 0.0052 - val_loss: 0.0080 - val_mse: 0.0080 - 29ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 515us/step - loss: 0.0059 - mse: 0.0059\n",
      "223/223 [==============================] - 0s 381us/step - loss: 0.0069 - mse: 0.0069\n",
      "9/9 - 0s - loss: 0.0053 - mse: 0.0053 - val_loss: 0.0082 - val_mse: 0.0082 - 35ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 515us/step - loss: 0.0060 - mse: 0.0060\n",
      "223/223 [==============================] - 0s 401us/step - loss: 0.0070 - mse: 0.0070\n",
      "9/9 - 0s - loss: 0.0052 - mse: 0.0052 - val_loss: 0.0079 - val_mse: 0.0079 - 29ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 573us/step - loss: 0.0058 - mse: 0.0058\n",
      "223/223 [==============================] - 0s 378us/step - loss: 0.0068 - mse: 0.0068\n",
      "9/9 - 0s - loss: 0.0052 - mse: 0.0052 - val_loss: 0.0080 - val_mse: 0.0080 - 31ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 659us/step - loss: 0.0059 - mse: 0.0059\n",
      "223/223 [==============================] - 0s 397us/step - loss: 0.0069 - mse: 0.0069\n",
      "9/9 - 0s - loss: 0.0053 - mse: 0.0053 - val_loss: 0.0080 - val_mse: 0.0080 - 30ms/epoch - 3ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "12/12 [==============================] - 0s 470us/step - loss: 0.0058 - mse: 0.0058\n",
      "223/223 [==============================] - 0s 372us/step - loss: 0.0068 - mse: 0.0068\n",
      "9/9 - 0s - loss: 0.0052 - mse: 0.0052 - val_loss: 0.0078 - val_mse: 0.0078 - 29ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 443us/step - loss: 0.0057 - mse: 0.0057\n",
      "223/223 [==============================] - 0s 380us/step - loss: 0.0067 - mse: 0.0067\n",
      "9/9 - 0s - loss: 0.0051 - mse: 0.0051 - val_loss: 0.0079 - val_mse: 0.0079 - 32ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 600us/step - loss: 0.0057 - mse: 0.0057\n",
      "223/223 [==============================] - 0s 367us/step - loss: 0.0067 - mse: 0.0067\n",
      "9/9 - 0s - loss: 0.0051 - mse: 0.0051 - val_loss: 0.0078 - val_mse: 0.0078 - 31ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 512us/step - loss: 0.0057 - mse: 0.0057\n",
      "223/223 [==============================] - 0s 381us/step - loss: 0.0066 - mse: 0.0066\n",
      "9/9 - 0s - loss: 0.0051 - mse: 0.0051 - val_loss: 0.0078 - val_mse: 0.0078 - 31ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 633us/step - loss: 0.0057 - mse: 0.0057\n",
      "223/223 [==============================] - 0s 383us/step - loss: 0.0067 - mse: 0.0067\n",
      "9/9 - 0s - loss: 0.0052 - mse: 0.0052 - val_loss: 0.0079 - val_mse: 0.0079 - 29ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 512us/step - loss: 0.0057 - mse: 0.0057\n",
      "223/223 [==============================] - 0s 379us/step - loss: 0.0066 - mse: 0.0066\n",
      "9/9 - 0s - loss: 0.0052 - mse: 0.0052 - val_loss: 0.0077 - val_mse: 0.0077 - 33ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 601us/step - loss: 0.0056 - mse: 0.0056\n",
      "223/223 [==============================] - 0s 382us/step - loss: 0.0066 - mse: 0.0066\n",
      "9/9 - 0s - loss: 0.0051 - mse: 0.0051 - val_loss: 0.0079 - val_mse: 0.0079 - 30ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 618us/step - loss: 0.0058 - mse: 0.0058\n",
      "223/223 [==============================] - 0s 357us/step - loss: 0.0068 - mse: 0.0068\n",
      "9/9 - 0s - loss: 0.0051 - mse: 0.0051 - val_loss: 0.0078 - val_mse: 0.0078 - 31ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 447us/step - loss: 0.0057 - mse: 0.0057\n",
      "223/223 [==============================] - 0s 366us/step - loss: 0.0067 - mse: 0.0067\n",
      "9/9 - 0s - loss: 0.0051 - mse: 0.0051 - val_loss: 0.0079 - val_mse: 0.0079 - 32ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 475us/step - loss: 0.0058 - mse: 0.0058\n",
      "223/223 [==============================] - 0s 387us/step - loss: 0.0067 - mse: 0.0067\n",
      "9/9 - 0s - loss: 0.0051 - mse: 0.0051 - val_loss: 0.0078 - val_mse: 0.0078 - 33ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 464us/step - loss: 0.0056 - mse: 0.0056\n",
      "223/223 [==============================] - 0s 384us/step - loss: 0.0066 - mse: 0.0066\n",
      "9/9 - 0s - loss: 0.0050 - mse: 0.0050 - val_loss: 0.0078 - val_mse: 0.0078 - 31ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 522us/step - loss: 0.0057 - mse: 0.0057\n",
      "223/223 [==============================] - 0s 391us/step - loss: 0.0066 - mse: 0.0066\n",
      "9/9 - 0s - loss: 0.0051 - mse: 0.0051 - val_loss: 0.0080 - val_mse: 0.0080 - 30ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 532us/step - loss: 0.0058 - mse: 0.0058\n",
      "223/223 [==============================] - 0s 375us/step - loss: 0.0067 - mse: 0.0067\n",
      "9/9 - 0s - loss: 0.0050 - mse: 0.0050 - val_loss: 0.0077 - val_mse: 0.0077 - 29ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 600us/step - loss: 0.0056 - mse: 0.0056\n",
      "223/223 [==============================] - 0s 386us/step - loss: 0.0065 - mse: 0.0065\n",
      "9/9 - 0s - loss: 0.0050 - mse: 0.0050 - val_loss: 0.0079 - val_mse: 0.0079 - 30ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 407us/step - loss: 0.0058 - mse: 0.0058\n",
      "223/223 [==============================] - 0s 376us/step - loss: 0.0067 - mse: 0.0067\n",
      "9/9 - 0s - loss: 0.0051 - mse: 0.0051 - val_loss: 0.0078 - val_mse: 0.0078 - 33ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 511us/step - loss: 0.0057 - mse: 0.0057\n",
      "223/223 [==============================] - 0s 371us/step - loss: 0.0066 - mse: 0.0066\n",
      "9/9 - 0s - loss: 0.0051 - mse: 0.0051 - val_loss: 0.0079 - val_mse: 0.0079 - 30ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 556us/step - loss: 0.0057 - mse: 0.0057\n",
      "223/223 [==============================] - 0s 381us/step - loss: 0.0067 - mse: 0.0067\n",
      "9/9 - 0s - loss: 0.0051 - mse: 0.0051 - val_loss: 0.0078 - val_mse: 0.0078 - 31ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 553us/step - loss: 0.0056 - mse: 0.0056\n",
      "223/223 [==============================] - 0s 384us/step - loss: 0.0065 - mse: 0.0065\n",
      "9/9 - 0s - loss: 0.0051 - mse: 0.0051 - val_loss: 0.0078 - val_mse: 0.0078 - 32ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 688us/step - loss: 0.0056 - mse: 0.0056\n",
      "223/223 [==============================] - 0s 397us/step - loss: 0.0066 - mse: 0.0066\n",
      "9/9 - 0s - loss: 0.0051 - mse: 0.0051 - val_loss: 0.0078 - val_mse: 0.0078 - 30ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 766us/step - loss: 0.0056 - mse: 0.0056\n",
      "223/223 [==============================] - 0s 404us/step - loss: 0.0066 - mse: 0.0066\n",
      "9/9 - 0s - loss: 0.0050 - mse: 0.0050 - val_loss: 0.0078 - val_mse: 0.0078 - 31ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 504us/step - loss: 0.0056 - mse: 0.0056\n",
      "223/223 [==============================] - 0s 393us/step - loss: 0.0065 - mse: 0.0065\n",
      "9/9 - 0s - loss: 0.0050 - mse: 0.0050 - val_loss: 0.0078 - val_mse: 0.0078 - 30ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 473us/step - loss: 0.0056 - mse: 0.0056\n",
      "223/223 [==============================] - 0s 407us/step - loss: 0.0065 - mse: 0.0065\n",
      "9/9 - 0s - loss: 0.0050 - mse: 0.0050 - val_loss: 0.0079 - val_mse: 0.0079 - 31ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 448us/step - loss: 0.0057 - mse: 0.0057\n",
      "223/223 [==============================] - 0s 415us/step - loss: 0.0067 - mse: 0.0067\n",
      "9/9 - 0s - loss: 0.0051 - mse: 0.0051 - val_loss: 0.0079 - val_mse: 0.0079 - 34ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 472us/step - loss: 0.0057 - mse: 0.0057\n",
      "223/223 [==============================] - 0s 393us/step - loss: 0.0066 - mse: 0.0066\n",
      "9/9 - 0s - loss: 0.0052 - mse: 0.0052 - val_loss: 0.0080 - val_mse: 0.0080 - 37ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 449us/step - loss: 0.0058 - mse: 0.0058\n",
      "223/223 [==============================] - 0s 395us/step - loss: 0.0068 - mse: 0.0068\n",
      "9/9 - 0s - loss: 0.0051 - mse: 0.0051 - val_loss: 0.0084 - val_mse: 0.0084 - 32ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 421us/step - loss: 0.0061 - mse: 0.0061\n",
      "223/223 [==============================] - 0s 404us/step - loss: 0.0070 - mse: 0.0070\n",
      "9/9 - 0s - loss: 0.0050 - mse: 0.0050 - val_loss: 0.0077 - val_mse: 0.0077 - 29ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 413us/step - loss: 0.0056 - mse: 0.0056\n",
      "223/223 [==============================] - 0s 398us/step - loss: 0.0066 - mse: 0.0066\n",
      "9/9 - 0s - loss: 0.0049 - mse: 0.0049 - val_loss: 0.0078 - val_mse: 0.0078 - 30ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 570us/step - loss: 0.0056 - mse: 0.0056\n",
      "223/223 [==============================] - 0s 397us/step - loss: 0.0066 - mse: 0.0066\n",
      "9/9 - 0s - loss: 0.0050 - mse: 0.0050 - val_loss: 0.0081 - val_mse: 0.0081 - 29ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 431us/step - loss: 0.0058 - mse: 0.0058\n",
      "223/223 [==============================] - 0s 410us/step - loss: 0.0067 - mse: 0.0067\n",
      "9/9 - 0s - loss: 0.0051 - mse: 0.0051 - val_loss: 0.0079 - val_mse: 0.0079 - 29ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 651us/step - loss: 0.0057 - mse: 0.0057\n",
      "223/223 [==============================] - 0s 418us/step - loss: 0.0067 - mse: 0.0067\n",
      "9/9 - 0s - loss: 0.0050 - mse: 0.0050 - val_loss: 0.0078 - val_mse: 0.0078 - 29ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 459us/step - loss: 0.0056 - mse: 0.0056\n",
      "223/223 [==============================] - 0s 411us/step - loss: 0.0066 - mse: 0.0066\n",
      "9/9 - 0s - loss: 0.0050 - mse: 0.0050 - val_loss: 0.0080 - val_mse: 0.0080 - 32ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 446us/step - loss: 0.0057 - mse: 0.0057\n",
      "223/223 [==============================] - 0s 371us/step - loss: 0.0066 - mse: 0.0066\n",
      "9/9 - 0s - loss: 0.0049 - mse: 0.0049 - val_loss: 0.0076 - val_mse: 0.0076 - 31ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 528us/step - loss: 0.0054 - mse: 0.0054\n",
      "223/223 [==============================] - 0s 387us/step - loss: 0.0063 - mse: 0.0063\n",
      "9/9 - 0s - loss: 0.0048 - mse: 0.0048 - val_loss: 0.0076 - val_mse: 0.0076 - 35ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 412us/step - loss: 0.0054 - mse: 0.0054\n",
      "223/223 [==============================] - 0s 407us/step - loss: 0.0065 - mse: 0.0065\n",
      "9/9 - 0s - loss: 0.0048 - mse: 0.0048 - val_loss: 0.0078 - val_mse: 0.0078 - 30ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 395us/step - loss: 0.0056 - mse: 0.0056\n",
      "223/223 [==============================] - 0s 401us/step - loss: 0.0065 - mse: 0.0065\n",
      "9/9 - 0s - loss: 0.0049 - mse: 0.0049 - val_loss: 0.0077 - val_mse: 0.0077 - 30ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 474us/step - loss: 0.0055 - mse: 0.0055\n",
      "223/223 [==============================] - 0s 380us/step - loss: 0.0065 - mse: 0.0065\n",
      "9/9 - 0s - loss: 0.0049 - mse: 0.0049 - val_loss: 0.0078 - val_mse: 0.0078 - 30ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 524us/step - loss: 0.0056 - mse: 0.0056\n",
      "223/223 [==============================] - 0s 387us/step - loss: 0.0066 - mse: 0.0066\n",
      "9/9 - 0s - loss: 0.0050 - mse: 0.0050 - val_loss: 0.0076 - val_mse: 0.0076 - 31ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 587us/step - loss: 0.0055 - mse: 0.0055\n",
      "223/223 [==============================] - 0s 392us/step - loss: 0.0065 - mse: 0.0065\n",
      "9/9 - 0s - loss: 0.0048 - mse: 0.0048 - val_loss: 0.0075 - val_mse: 0.0075 - 30ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 455us/step - loss: 0.0054 - mse: 0.0054\n",
      "223/223 [==============================] - 0s 387us/step - loss: 0.0063 - mse: 0.0063\n",
      "9/9 - 0s - loss: 0.0048 - mse: 0.0048 - val_loss: 0.0076 - val_mse: 0.0076 - 32ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 597us/step - loss: 0.0054 - mse: 0.0054\n",
      "223/223 [==============================] - 0s 405us/step - loss: 0.0064 - mse: 0.0064\n",
      "9/9 - 0s - loss: 0.0049 - mse: 0.0049 - val_loss: 0.0076 - val_mse: 0.0076 - 33ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 415us/step - loss: 0.0055 - mse: 0.0055\n",
      "223/223 [==============================] - 0s 395us/step - loss: 0.0065 - mse: 0.0065\n",
      "9/9 - 0s - loss: 0.0049 - mse: 0.0049 - val_loss: 0.0079 - val_mse: 0.0079 - 32ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 566us/step - loss: 0.0057 - mse: 0.0057\n",
      "223/223 [==============================] - 0s 388us/step - loss: 0.0066 - mse: 0.0066\n",
      "9/9 - 0s - loss: 0.0049 - mse: 0.0049 - val_loss: 0.0076 - val_mse: 0.0076 - 39ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 428us/step - loss: 0.0054 - mse: 0.0054\n",
      "223/223 [==============================] - 0s 368us/step - loss: 0.0064 - mse: 0.0064\n",
      "9/9 - 0s - loss: 0.0048 - mse: 0.0048 - val_loss: 0.0077 - val_mse: 0.0077 - 33ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 490us/step - loss: 0.0055 - mse: 0.0055\n",
      "223/223 [==============================] - 0s 417us/step - loss: 0.0064 - mse: 0.0064\n",
      "9/9 - 0s - loss: 0.0048 - mse: 0.0048 - val_loss: 0.0076 - val_mse: 0.0076 - 32ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 464us/step - loss: 0.0055 - mse: 0.0055\n",
      "223/223 [==============================] - 0s 382us/step - loss: 0.0064 - mse: 0.0064\n",
      "9/9 - 0s - loss: 0.0048 - mse: 0.0048 - val_loss: 0.0076 - val_mse: 0.0076 - 32ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 393us/step - loss: 0.0054 - mse: 0.0054\n",
      "223/223 [==============================] - 0s 397us/step - loss: 0.0064 - mse: 0.0064\n",
      "9/9 - 0s - loss: 0.0048 - mse: 0.0048 - val_loss: 0.0078 - val_mse: 0.0078 - 31ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 433us/step - loss: 0.0056 - mse: 0.0056\n",
      "223/223 [==============================] - 0s 382us/step - loss: 0.0065 - mse: 0.0065\n",
      "9/9 - 0s - loss: 0.0049 - mse: 0.0049 - val_loss: 0.0076 - val_mse: 0.0076 - 31ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 446us/step - loss: 0.0054 - mse: 0.0054\n",
      "223/223 [==============================] - 0s 406us/step - loss: 0.0064 - mse: 0.0064\n",
      "9/9 - 0s - loss: 0.0047 - mse: 0.0047 - val_loss: 0.0076 - val_mse: 0.0076 - 29ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 484us/step - loss: 0.0054 - mse: 0.0054\n",
      "223/223 [==============================] - 0s 388us/step - loss: 0.0064 - mse: 0.0064\n",
      "9/9 - 0s - loss: 0.0047 - mse: 0.0047 - val_loss: 0.0075 - val_mse: 0.0075 - 32ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 422us/step - loss: 0.0054 - mse: 0.0054\n",
      "223/223 [==============================] - 0s 393us/step - loss: 0.0064 - mse: 0.0064\n",
      "9/9 - 0s - loss: 0.0047 - mse: 0.0047 - val_loss: 0.0075 - val_mse: 0.0075 - 32ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 458us/step - loss: 0.0053 - mse: 0.0053\n",
      "223/223 [==============================] - 0s 387us/step - loss: 0.0063 - mse: 0.0063\n",
      "9/9 - 0s - loss: 0.0048 - mse: 0.0048 - val_loss: 0.0078 - val_mse: 0.0078 - 35ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 477us/step - loss: 0.0056 - mse: 0.0056\n",
      "223/223 [==============================] - 0s 401us/step - loss: 0.0066 - mse: 0.0066\n",
      "9/9 - 0s - loss: 0.0049 - mse: 0.0049 - val_loss: 0.0076 - val_mse: 0.0076 - 32ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 406us/step - loss: 0.0054 - mse: 0.0054\n",
      "223/223 [==============================] - 0s 388us/step - loss: 0.0063 - mse: 0.0063\n",
      "9/9 - 0s - loss: 0.0047 - mse: 0.0047 - val_loss: 0.0075 - val_mse: 0.0075 - 33ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 561us/step - loss: 0.0054 - mse: 0.0054\n",
      "223/223 [==============================] - 0s 402us/step - loss: 0.0064 - mse: 0.0064\n",
      "9/9 - 0s - loss: 0.0047 - mse: 0.0047 - val_loss: 0.0075 - val_mse: 0.0075 - 29ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 518us/step - loss: 0.0054 - mse: 0.0054\n",
      "223/223 [==============================] - 0s 406us/step - loss: 0.0063 - mse: 0.0063\n",
      "9/9 - 0s - loss: 0.0047 - mse: 0.0047 - val_loss: 0.0076 - val_mse: 0.0076 - 29ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 474us/step - loss: 0.0054 - mse: 0.0054\n",
      "223/223 [==============================] - 0s 389us/step - loss: 0.0063 - mse: 0.0063\n",
      "9/9 - 0s - loss: 0.0047 - mse: 0.0047 - val_loss: 0.0077 - val_mse: 0.0077 - 30ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 486us/step - loss: 0.0055 - mse: 0.0055\n",
      "223/223 [==============================] - 0s 386us/step - loss: 0.0065 - mse: 0.0065\n",
      "9/9 - 0s - loss: 0.0050 - mse: 0.0050 - val_loss: 0.0078 - val_mse: 0.0078 - 30ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 464us/step - loss: 0.0056 - mse: 0.0056\n",
      "223/223 [==============================] - 0s 386us/step - loss: 0.0066 - mse: 0.0066\n",
      "9/9 - 0s - loss: 0.0049 - mse: 0.0049 - val_loss: 0.0077 - val_mse: 0.0077 - 31ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 409us/step - loss: 0.0055 - mse: 0.0055\n",
      "223/223 [==============================] - 0s 364us/step - loss: 0.0065 - mse: 0.0065\n",
      "9/9 - 0s - loss: 0.0048 - mse: 0.0048 - val_loss: 0.0076 - val_mse: 0.0076 - 31ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 437us/step - loss: 0.0054 - mse: 0.0054\n",
      "223/223 [==============================] - 0s 381us/step - loss: 0.0064 - mse: 0.0064\n",
      "9/9 - 0s - loss: 0.0048 - mse: 0.0048 - val_loss: 0.0076 - val_mse: 0.0076 - 36ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 435us/step - loss: 0.0054 - mse: 0.0054\n",
      "223/223 [==============================] - 0s 386us/step - loss: 0.0063 - mse: 0.0063\n",
      "9/9 - 0s - loss: 0.0047 - mse: 0.0047 - val_loss: 0.0074 - val_mse: 0.0074 - 32ms/epoch - 4ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "12/12 [==============================] - 0s 563us/step - loss: 0.0053 - mse: 0.0053\n",
      "223/223 [==============================] - 0s 382us/step - loss: 0.0063 - mse: 0.0063\n",
      "9/9 - 0s - loss: 0.0048 - mse: 0.0048 - val_loss: 0.0076 - val_mse: 0.0076 - 35ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 523us/step - loss: 0.0055 - mse: 0.0055\n",
      "223/223 [==============================] - 0s 389us/step - loss: 0.0065 - mse: 0.0065\n",
      "9/9 - 0s - loss: 0.0049 - mse: 0.0049 - val_loss: 0.0077 - val_mse: 0.0077 - 31ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 534us/step - loss: 0.0055 - mse: 0.0055\n",
      "223/223 [==============================] - 0s 382us/step - loss: 0.0065 - mse: 0.0065\n",
      "9/9 - 0s - loss: 0.0048 - mse: 0.0048 - val_loss: 0.0075 - val_mse: 0.0075 - 28ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 488us/step - loss: 0.0054 - mse: 0.0054\n",
      "223/223 [==============================] - 0s 380us/step - loss: 0.0063 - mse: 0.0063\n",
      "9/9 - 0s - loss: 0.0048 - mse: 0.0048 - val_loss: 0.0076 - val_mse: 0.0076 - 29ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 409us/step - loss: 0.0054 - mse: 0.0054\n",
      "223/223 [==============================] - 0s 380us/step - loss: 0.0063 - mse: 0.0063\n",
      "9/9 - 0s - loss: 0.0049 - mse: 0.0049 - val_loss: 0.0074 - val_mse: 0.0074 - 28ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 435us/step - loss: 0.0053 - mse: 0.0053\n",
      "223/223 [==============================] - 0s 367us/step - loss: 0.0062 - mse: 0.0062\n",
      "9/9 - 0s - loss: 0.0050 - mse: 0.0050 - val_loss: 0.0079 - val_mse: 0.0079 - 30ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 497us/step - loss: 0.0056 - mse: 0.0056\n",
      "223/223 [==============================] - 0s 380us/step - loss: 0.0065 - mse: 0.0065\n",
      "9/9 - 0s - loss: 0.0050 - mse: 0.0050 - val_loss: 0.0078 - val_mse: 0.0078 - 34ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 410us/step - loss: 0.0056 - mse: 0.0056\n",
      "223/223 [==============================] - 0s 368us/step - loss: 0.0065 - mse: 0.0065\n",
      "9/9 - 0s - loss: 0.0049 - mse: 0.0049 - val_loss: 0.0076 - val_mse: 0.0076 - 34ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 505us/step - loss: 0.0054 - mse: 0.0054\n",
      "223/223 [==============================] - 0s 368us/step - loss: 0.0064 - mse: 0.0064\n",
      "9/9 - 0s - loss: 0.0047 - mse: 0.0047 - val_loss: 0.0075 - val_mse: 0.0075 - 33ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 603us/step - loss: 0.0053 - mse: 0.0053\n",
      "223/223 [==============================] - 0s 375us/step - loss: 0.0064 - mse: 0.0064\n",
      "9/9 - 0s - loss: 0.0048 - mse: 0.0048 - val_loss: 0.0076 - val_mse: 0.0076 - 30ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 443us/step - loss: 0.0053 - mse: 0.0053\n",
      "223/223 [==============================] - 0s 416us/step - loss: 0.0063 - mse: 0.0063\n",
      "9/9 - 0s - loss: 0.0046 - mse: 0.0046 - val_loss: 0.0075 - val_mse: 0.0075 - 32ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 500us/step - loss: 0.0054 - mse: 0.0054\n",
      "223/223 [==============================] - 0s 375us/step - loss: 0.0063 - mse: 0.0063\n",
      "9/9 - 0s - loss: 0.0047 - mse: 0.0047 - val_loss: 0.0076 - val_mse: 0.0076 - 33ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 512us/step - loss: 0.0053 - mse: 0.0053\n",
      "223/223 [==============================] - 0s 546us/step - loss: 0.0062 - mse: 0.0062\n",
      "9/9 - 0s - loss: 0.0046 - mse: 0.0046 - val_loss: 0.0075 - val_mse: 0.0075 - 51ms/epoch - 6ms/step\n",
      "12/12 [==============================] - 0s 890us/step - loss: 0.0054 - mse: 0.0054\n",
      "223/223 [==============================] - 0s 734us/step - loss: 0.0064 - mse: 0.0064\n",
      "9/9 - 0s - loss: 0.0048 - mse: 0.0048 - val_loss: 0.0077 - val_mse: 0.0077 - 51ms/epoch - 6ms/step\n",
      "12/12 [==============================] - 0s 1ms/step - loss: 0.0055 - mse: 0.0055\n",
      "223/223 [==============================] - 0s 768us/step - loss: 0.0064 - mse: 0.0064\n",
      "9/9 - 0s - loss: 0.0049 - mse: 0.0049 - val_loss: 0.0074 - val_mse: 0.0074 - 53ms/epoch - 6ms/step\n",
      "12/12 [==============================] - 0s 798us/step - loss: 0.0054 - mse: 0.0054\n",
      "223/223 [==============================] - 0s 361us/step - loss: 0.0063 - mse: 0.0063\n",
      "9/9 - 0s - loss: 0.0048 - mse: 0.0048 - val_loss: 0.0076 - val_mse: 0.0076 - 35ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 679us/step - loss: 0.0054 - mse: 0.0054\n",
      "223/223 [==============================] - 0s 391us/step - loss: 0.0064 - mse: 0.0064\n",
      "9/9 - 0s - loss: 0.0048 - mse: 0.0048 - val_loss: 0.0077 - val_mse: 0.0077 - 31ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 435us/step - loss: 0.0055 - mse: 0.0055\n",
      "223/223 [==============================] - 0s 387us/step - loss: 0.0064 - mse: 0.0064\n",
      "9/9 - 0s - loss: 0.0047 - mse: 0.0047 - val_loss: 0.0074 - val_mse: 0.0074 - 33ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 619us/step - loss: 0.0053 - mse: 0.0053\n",
      "223/223 [==============================] - 0s 384us/step - loss: 0.0063 - mse: 0.0063\n",
      "9/9 - 0s - loss: 0.0046 - mse: 0.0046 - val_loss: 0.0074 - val_mse: 0.0074 - 42ms/epoch - 5ms/step\n",
      "12/12 [==============================] - 0s 551us/step - loss: 0.0053 - mse: 0.0053\n",
      "223/223 [==============================] - 0s 394us/step - loss: 0.0062 - mse: 0.0062\n",
      "9/9 - 0s - loss: 0.0046 - mse: 0.0046 - val_loss: 0.0074 - val_mse: 0.0074 - 34ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 427us/step - loss: 0.0052 - mse: 0.0052\n",
      "223/223 [==============================] - 0s 357us/step - loss: 0.0061 - mse: 0.0061\n",
      "9/9 - 0s - loss: 0.0046 - mse: 0.0046 - val_loss: 0.0075 - val_mse: 0.0075 - 33ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 463us/step - loss: 0.0053 - mse: 0.0053\n",
      "223/223 [==============================] - 0s 400us/step - loss: 0.0062 - mse: 0.0062\n",
      "9/9 - 0s - loss: 0.0047 - mse: 0.0047 - val_loss: 0.0073 - val_mse: 0.0073 - 30ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 552us/step - loss: 0.0052 - mse: 0.0052\n",
      "223/223 [==============================] - 0s 377us/step - loss: 0.0062 - mse: 0.0062\n",
      "9/9 - 0s - loss: 0.0046 - mse: 0.0046 - val_loss: 0.0074 - val_mse: 0.0074 - 30ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 588us/step - loss: 0.0052 - mse: 0.0052\n",
      "223/223 [==============================] - 0s 399us/step - loss: 0.0062 - mse: 0.0062\n",
      "9/9 - 0s - loss: 0.0046 - mse: 0.0046 - val_loss: 0.0075 - val_mse: 0.0075 - 33ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 434us/step - loss: 0.0053 - mse: 0.0053\n",
      "223/223 [==============================] - 0s 387us/step - loss: 0.0063 - mse: 0.0063\n",
      "9/9 - 0s - loss: 0.0047 - mse: 0.0047 - val_loss: 0.0076 - val_mse: 0.0076 - 34ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 560us/step - loss: 0.0054 - mse: 0.0054\n",
      "223/223 [==============================] - 0s 377us/step - loss: 0.0063 - mse: 0.0063\n",
      "9/9 - 0s - loss: 0.0047 - mse: 0.0047 - val_loss: 0.0074 - val_mse: 0.0074 - 31ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 733us/step - loss: 0.0053 - mse: 0.0053\n",
      "223/223 [==============================] - 0s 372us/step - loss: 0.0062 - mse: 0.0062\n",
      "9/9 - 0s - loss: 0.0048 - mse: 0.0048 - val_loss: 0.0075 - val_mse: 0.0075 - 30ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 647us/step - loss: 0.0053 - mse: 0.0053\n",
      "223/223 [==============================] - 0s 381us/step - loss: 0.0063 - mse: 0.0063\n",
      "9/9 - 0s - loss: 0.0047 - mse: 0.0047 - val_loss: 0.0076 - val_mse: 0.0076 - 36ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 451us/step - loss: 0.0054 - mse: 0.0054\n",
      "223/223 [==============================] - 0s 387us/step - loss: 0.0064 - mse: 0.0064\n",
      "9/9 - 0s - loss: 0.0046 - mse: 0.0046 - val_loss: 0.0075 - val_mse: 0.0075 - 35ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 491us/step - loss: 0.0054 - mse: 0.0054\n",
      "223/223 [==============================] - 0s 387us/step - loss: 0.0063 - mse: 0.0063\n",
      "9/9 - 0s - loss: 0.0047 - mse: 0.0047 - val_loss: 0.0076 - val_mse: 0.0076 - 30ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 476us/step - loss: 0.0054 - mse: 0.0054\n",
      "223/223 [==============================] - 0s 371us/step - loss: 0.0064 - mse: 0.0064\n",
      "9/9 - 0s - loss: 0.0047 - mse: 0.0047 - val_loss: 0.0074 - val_mse: 0.0074 - 31ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 462us/step - loss: 0.0053 - mse: 0.0053\n",
      "223/223 [==============================] - 0s 387us/step - loss: 0.0063 - mse: 0.0063\n",
      "9/9 - 0s - loss: 0.0047 - mse: 0.0047 - val_loss: 0.0076 - val_mse: 0.0076 - 32ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 444us/step - loss: 0.0054 - mse: 0.0054\n",
      "223/223 [==============================] - 0s 397us/step - loss: 0.0063 - mse: 0.0063\n",
      "9/9 - 0s - loss: 0.0046 - mse: 0.0046 - val_loss: 0.0075 - val_mse: 0.0075 - 32ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 421us/step - loss: 0.0053 - mse: 0.0053\n",
      "223/223 [==============================] - 0s 385us/step - loss: 0.0062 - mse: 0.0062\n",
      "9/9 - 0s - loss: 0.0047 - mse: 0.0047 - val_loss: 0.0073 - val_mse: 0.0073 - 33ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 461us/step - loss: 0.0052 - mse: 0.0052\n",
      "223/223 [==============================] - 0s 401us/step - loss: 0.0061 - mse: 0.0061\n",
      "9/9 - 0s - loss: 0.0045 - mse: 0.0045 - val_loss: 0.0074 - val_mse: 0.0074 - 33ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 439us/step - loss: 0.0053 - mse: 0.0053\n",
      "223/223 [==============================] - 0s 400us/step - loss: 0.0063 - mse: 0.0063\n",
      "9/9 - 0s - loss: 0.0046 - mse: 0.0046 - val_loss: 0.0074 - val_mse: 0.0074 - 33ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 507us/step - loss: 0.0053 - mse: 0.0053\n",
      "223/223 [==============================] - 0s 381us/step - loss: 0.0062 - mse: 0.0062\n",
      "9/9 - 0s - loss: 0.0046 - mse: 0.0046 - val_loss: 0.0074 - val_mse: 0.0074 - 38ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 466us/step - loss: 0.0053 - mse: 0.0053\n",
      "223/223 [==============================] - 0s 399us/step - loss: 0.0061 - mse: 0.0061\n",
      "9/9 - 0s - loss: 0.0046 - mse: 0.0046 - val_loss: 0.0074 - val_mse: 0.0074 - 31ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 684us/step - loss: 0.0054 - mse: 0.0054\n",
      "223/223 [==============================] - 0s 372us/step - loss: 0.0063 - mse: 0.0063\n",
      "9/9 - 0s - loss: 0.0046 - mse: 0.0046 - val_loss: 0.0073 - val_mse: 0.0073 - 30ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 438us/step - loss: 0.0052 - mse: 0.0052\n",
      "223/223 [==============================] - 0s 391us/step - loss: 0.0061 - mse: 0.0061\n",
      "9/9 - 0s - loss: 0.0047 - mse: 0.0047 - val_loss: 0.0076 - val_mse: 0.0076 - 31ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 534us/step - loss: 0.0054 - mse: 0.0054\n",
      "223/223 [==============================] - 0s 357us/step - loss: 0.0064 - mse: 0.0064\n",
      "9/9 - 0s - loss: 0.0047 - mse: 0.0047 - val_loss: 0.0074 - val_mse: 0.0074 - 29ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 420us/step - loss: 0.0053 - mse: 0.0053\n",
      "223/223 [==============================] - 0s 380us/step - loss: 0.0062 - mse: 0.0062\n",
      "9/9 - 0s - loss: 0.0046 - mse: 0.0046 - val_loss: 0.0074 - val_mse: 0.0074 - 32ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 502us/step - loss: 0.0052 - mse: 0.0052\n",
      "223/223 [==============================] - 0s 363us/step - loss: 0.0061 - mse: 0.0061\n",
      "9/9 - 0s - loss: 0.0046 - mse: 0.0046 - val_loss: 0.0075 - val_mse: 0.0075 - 30ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 496us/step - loss: 0.0053 - mse: 0.0053\n",
      "223/223 [==============================] - 0s 406us/step - loss: 0.0062 - mse: 0.0062\n",
      "9/9 - 0s - loss: 0.0046 - mse: 0.0046 - val_loss: 0.0074 - val_mse: 0.0074 - 38ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 540us/step - loss: 0.0053 - mse: 0.0053\n",
      "223/223 [==============================] - 0s 374us/step - loss: 0.0063 - mse: 0.0063\n",
      "9/9 - 0s - loss: 0.0046 - mse: 0.0046 - val_loss: 0.0073 - val_mse: 0.0073 - 32ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 469us/step - loss: 0.0052 - mse: 0.0052\n",
      "223/223 [==============================] - 0s 378us/step - loss: 0.0061 - mse: 0.0061\n",
      "9/9 - 0s - loss: 0.0046 - mse: 0.0046 - val_loss: 0.0073 - val_mse: 0.0073 - 35ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 528us/step - loss: 0.0052 - mse: 0.0052\n",
      "223/223 [==============================] - 0s 385us/step - loss: 0.0061 - mse: 0.0061\n",
      "9/9 - 0s - loss: 0.0046 - mse: 0.0046 - val_loss: 0.0075 - val_mse: 0.0075 - 31ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 610us/step - loss: 0.0053 - mse: 0.0053\n",
      "223/223 [==============================] - 0s 398us/step - loss: 0.0062 - mse: 0.0062\n",
      "9/9 - 0s - loss: 0.0047 - mse: 0.0047 - val_loss: 0.0077 - val_mse: 0.0077 - 30ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 495us/step - loss: 0.0055 - mse: 0.0055\n",
      "223/223 [==============================] - 0s 367us/step - loss: 0.0065 - mse: 0.0065\n",
      "9/9 - 0s - loss: 0.0049 - mse: 0.0049 - val_loss: 0.0075 - val_mse: 0.0075 - 29ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 527us/step - loss: 0.0053 - mse: 0.0053\n",
      "223/223 [==============================] - 0s 380us/step - loss: 0.0062 - mse: 0.0062\n",
      "9/9 - 0s - loss: 0.0046 - mse: 0.0046 - val_loss: 0.0076 - val_mse: 0.0076 - 29ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 516us/step - loss: 0.0054 - mse: 0.0054\n",
      "223/223 [==============================] - 0s 399us/step - loss: 0.0064 - mse: 0.0064\n",
      "9/9 - 0s - loss: 0.0047 - mse: 0.0047 - val_loss: 0.0074 - val_mse: 0.0074 - 33ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 548us/step - loss: 0.0054 - mse: 0.0054\n",
      "223/223 [==============================] - 0s 395us/step - loss: 0.0063 - mse: 0.0063\n",
      "9/9 - 0s - loss: 0.0047 - mse: 0.0047 - val_loss: 0.0075 - val_mse: 0.0075 - 34ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 521us/step - loss: 0.0054 - mse: 0.0054\n",
      "223/223 [==============================] - 0s 381us/step - loss: 0.0064 - mse: 0.0064\n",
      "9/9 - 0s - loss: 0.0047 - mse: 0.0047 - val_loss: 0.0075 - val_mse: 0.0075 - 32ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 528us/step - loss: 0.0053 - mse: 0.0053\n",
      "223/223 [==============================] - 0s 370us/step - loss: 0.0063 - mse: 0.0063\n",
      "9/9 - 0s - loss: 0.0046 - mse: 0.0046 - val_loss: 0.0073 - val_mse: 0.0073 - 32ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 433us/step - loss: 0.0052 - mse: 0.0052\n",
      "223/223 [==============================] - 0s 363us/step - loss: 0.0061 - mse: 0.0061\n",
      "9/9 - 0s - loss: 0.0045 - mse: 0.0045 - val_loss: 0.0073 - val_mse: 0.0073 - 38ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 461us/step - loss: 0.0053 - mse: 0.0053\n",
      "223/223 [==============================] - 0s 408us/step - loss: 0.0063 - mse: 0.0063\n",
      "9/9 - 0s - loss: 0.0049 - mse: 0.0049 - val_loss: 0.0077 - val_mse: 0.0077 - 32ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 530us/step - loss: 0.0055 - mse: 0.0055\n",
      "223/223 [==============================] - 0s 363us/step - loss: 0.0065 - mse: 0.0065\n",
      "9/9 - 0s - loss: 0.0048 - mse: 0.0048 - val_loss: 0.0076 - val_mse: 0.0076 - 34ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 628us/step - loss: 0.0054 - mse: 0.0054\n",
      "223/223 [==============================] - 0s 384us/step - loss: 0.0063 - mse: 0.0063\n",
      "9/9 - 0s - loss: 0.0047 - mse: 0.0047 - val_loss: 0.0075 - val_mse: 0.0075 - 32ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 464us/step - loss: 0.0053 - mse: 0.0053\n",
      "223/223 [==============================] - 0s 386us/step - loss: 0.0063 - mse: 0.0063\n",
      "9/9 - 0s - loss: 0.0046 - mse: 0.0046 - val_loss: 0.0073 - val_mse: 0.0073 - 34ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 460us/step - loss: 0.0052 - mse: 0.0052\n",
      "223/223 [==============================] - 0s 389us/step - loss: 0.0062 - mse: 0.0062\n",
      "9/9 - 0s - loss: 0.0048 - mse: 0.0048 - val_loss: 0.0075 - val_mse: 0.0075 - 32ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 472us/step - loss: 0.0054 - mse: 0.0054\n",
      "223/223 [==============================] - 0s 382us/step - loss: 0.0063 - mse: 0.0063\n",
      "9/9 - 0s - loss: 0.0048 - mse: 0.0048 - val_loss: 0.0074 - val_mse: 0.0074 - 33ms/epoch - 4ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "12/12 [==============================] - 0s 528us/step - loss: 0.0053 - mse: 0.0053\n",
      "223/223 [==============================] - 0s 378us/step - loss: 0.0063 - mse: 0.0063\n",
      "9/9 - 0s - loss: 0.0047 - mse: 0.0047 - val_loss: 0.0072 - val_mse: 0.0072 - 33ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 450us/step - loss: 0.0052 - mse: 0.0052\n",
      "223/223 [==============================] - 0s 374us/step - loss: 0.0061 - mse: 0.0061\n",
      "9/9 - 0s - loss: 0.0047 - mse: 0.0047 - val_loss: 0.0074 - val_mse: 0.0074 - 32ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 474us/step - loss: 0.0052 - mse: 0.0052\n",
      "223/223 [==============================] - 0s 375us/step - loss: 0.0061 - mse: 0.0061\n",
      "9/9 - 0s - loss: 0.0045 - mse: 0.0045 - val_loss: 0.0072 - val_mse: 0.0072 - 38ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 501us/step - loss: 0.0050 - mse: 0.0050\n",
      "223/223 [==============================] - 0s 388us/step - loss: 0.0060 - mse: 0.0060\n",
      "9/9 - 0s - loss: 0.0045 - mse: 0.0045 - val_loss: 0.0070 - val_mse: 0.0070 - 31ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 512us/step - loss: 0.0051 - mse: 0.0051\n",
      "223/223 [==============================] - 0s 385us/step - loss: 0.0060 - mse: 0.0060\n",
      "9/9 - 0s - loss: 0.0045 - mse: 0.0045 - val_loss: 0.0073 - val_mse: 0.0073 - 31ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 470us/step - loss: 0.0051 - mse: 0.0051\n",
      "223/223 [==============================] - 0s 376us/step - loss: 0.0060 - mse: 0.0060\n",
      "9/9 - 0s - loss: 0.0045 - mse: 0.0045 - val_loss: 0.0072 - val_mse: 0.0072 - 31ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 455us/step - loss: 0.0052 - mse: 0.0052\n",
      "223/223 [==============================] - 0s 385us/step - loss: 0.0061 - mse: 0.0061\n",
      "9/9 - 0s - loss: 0.0046 - mse: 0.0046 - val_loss: 0.0073 - val_mse: 0.0073 - 33ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 459us/step - loss: 0.0052 - mse: 0.0052\n",
      "223/223 [==============================] - 0s 390us/step - loss: 0.0061 - mse: 0.0061\n",
      "9/9 - 0s - loss: 0.0046 - mse: 0.0046 - val_loss: 0.0071 - val_mse: 0.0071 - 33ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 467us/step - loss: 0.0050 - mse: 0.0050\n",
      "223/223 [==============================] - 0s 378us/step - loss: 0.0059 - mse: 0.0059\n",
      "9/9 - 0s - loss: 0.0046 - mse: 0.0046 - val_loss: 0.0074 - val_mse: 0.0074 - 31ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 486us/step - loss: 0.0054 - mse: 0.0054\n",
      "223/223 [==============================] - 0s 382us/step - loss: 0.0063 - mse: 0.0063\n",
      "9/9 - 0s - loss: 0.0048 - mse: 0.0048 - val_loss: 0.0071 - val_mse: 0.0071 - 28ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 650us/step - loss: 0.0051 - mse: 0.0051\n",
      "223/223 [==============================] - 0s 377us/step - loss: 0.0060 - mse: 0.0060\n",
      "9/9 - 0s - loss: 0.0046 - mse: 0.0046 - val_loss: 0.0071 - val_mse: 0.0071 - 31ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 566us/step - loss: 0.0051 - mse: 0.0051\n",
      "223/223 [==============================] - 0s 378us/step - loss: 0.0060 - mse: 0.0060\n",
      "9/9 - 0s - loss: 0.0045 - mse: 0.0045 - val_loss: 0.0073 - val_mse: 0.0073 - 40ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 432us/step - loss: 0.0052 - mse: 0.0052\n",
      "223/223 [==============================] - 0s 363us/step - loss: 0.0061 - mse: 0.0061\n",
      "9/9 - 0s - loss: 0.0045 - mse: 0.0045 - val_loss: 0.0071 - val_mse: 0.0071 - 32ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 464us/step - loss: 0.0051 - mse: 0.0051\n",
      "223/223 [==============================] - 0s 385us/step - loss: 0.0061 - mse: 0.0061\n",
      "9/9 - 0s - loss: 0.0045 - mse: 0.0045 - val_loss: 0.0071 - val_mse: 0.0071 - 30ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 430us/step - loss: 0.0050 - mse: 0.0050\n",
      "223/223 [==============================] - 0s 376us/step - loss: 0.0060 - mse: 0.0060\n",
      "9/9 - 0s - loss: 0.0046 - mse: 0.0046 - val_loss: 0.0071 - val_mse: 0.0071 - 29ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 443us/step - loss: 0.0051 - mse: 0.0051\n",
      "223/223 [==============================] - 0s 384us/step - loss: 0.0060 - mse: 0.0060\n",
      "9/9 - 0s - loss: 0.0045 - mse: 0.0045 - val_loss: 0.0071 - val_mse: 0.0071 - 31ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 451us/step - loss: 0.0051 - mse: 0.0051\n",
      "223/223 [==============================] - 0s 379us/step - loss: 0.0060 - mse: 0.0060\n",
      "9/9 - 0s - loss: 0.0044 - mse: 0.0044 - val_loss: 0.0074 - val_mse: 0.0074 - 33ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 454us/step - loss: 0.0052 - mse: 0.0052\n",
      "223/223 [==============================] - 0s 353us/step - loss: 0.0062 - mse: 0.0062\n",
      "9/9 - 0s - loss: 0.0045 - mse: 0.0045 - val_loss: 0.0074 - val_mse: 0.0074 - 34ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 454us/step - loss: 0.0053 - mse: 0.0053\n",
      "223/223 [==============================] - 0s 373us/step - loss: 0.0062 - mse: 0.0062\n",
      "9/9 - 0s - loss: 0.0047 - mse: 0.0047 - val_loss: 0.0075 - val_mse: 0.0075 - 36ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 507us/step - loss: 0.0053 - mse: 0.0053\n",
      "223/223 [==============================] - 0s 385us/step - loss: 0.0062 - mse: 0.0062\n",
      "9/9 - 0s - loss: 0.0047 - mse: 0.0047 - val_loss: 0.0072 - val_mse: 0.0072 - 28ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 442us/step - loss: 0.0051 - mse: 0.0051\n",
      "223/223 [==============================] - 0s 374us/step - loss: 0.0060 - mse: 0.0060\n",
      "9/9 - 0s - loss: 0.0045 - mse: 0.0045 - val_loss: 0.0073 - val_mse: 0.0073 - 38ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 461us/step - loss: 0.0051 - mse: 0.0051\n",
      "223/223 [==============================] - 0s 392us/step - loss: 0.0062 - mse: 0.0062\n",
      "9/9 - 0s - loss: 0.0045 - mse: 0.0045 - val_loss: 0.0071 - val_mse: 0.0071 - 29ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 449us/step - loss: 0.0051 - mse: 0.0051\n",
      "223/223 [==============================] - 0s 385us/step - loss: 0.0060 - mse: 0.0060\n",
      "9/9 - 0s - loss: 0.0046 - mse: 0.0046 - val_loss: 0.0074 - val_mse: 0.0074 - 33ms/epoch - 4ms/step\n",
      "12/12 [==============================] - 0s 559us/step - loss: 0.0052 - mse: 0.0052\n",
      "223/223 [==============================] - 0s 362us/step - loss: 0.0062 - mse: 0.0062\n",
      "9/9 - 0s - loss: 0.0045 - mse: 0.0045 - val_loss: 0.0072 - val_mse: 0.0072 - 30ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 441us/step - loss: 0.0050 - mse: 0.0050\n",
      "223/223 [==============================] - 0s 362us/step - loss: 0.0059 - mse: 0.0059\n",
      "9/9 - 0s - loss: 0.0044 - mse: 0.0044 - val_loss: 0.0072 - val_mse: 0.0072 - 31ms/epoch - 3ms/step\n",
      "12/12 [==============================] - 0s 657us/step - loss: 0.0051 - mse: 0.0051\n",
      "223/223 [==============================] - 0s 384us/step - loss: 0.0060 - mse: 0.0060\n",
      "62.6423876285553\n"
     ]
    }
   ],
   "source": [
    "t0 = time.time()\n",
    "history_F = [] #collect data for figures\n",
    "for i in range(300):\n",
    "    history = final_model_PQ.fit(X_train, Y_train, epochs=1, batch_size=64, validation_split=0.25, verbose=2)\n",
    "    loss_and_metrics_train = final_model_PQ.evaluate(X_train, Y_train, batch_size=64)\n",
    "    loss_and_metrics_test = final_model_PQ.evaluate(X_test, Y_test, batch_size=64)\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": 25,
   "id": "388b3084",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "12/12 [==============================] - 0s 596us/step - loss: 0.0051 - mse: 0.0051\n",
      "223/223 [==============================] - 0s 409us/step - loss: 0.0060 - mse: 0.0060\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=64)\n",
    "loss_and_metrics = final_model_PQ.evaluate(X_test,Y_test, batch_size=64)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "f9ed7589",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 720x432 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "history_F = np.array(history_F)  # shape: (num_epochs, 5)\n",
    "# Plot each variable\n",
    "plt.figure(figsize=(10, 6))\n",
    "for i in range(2):\n",
    "    plt.plot(history_F[:, i], label=f'Variable {i}')\n",
    "\n",
    "plt.xlabel('Epoch')\n",
    "plt.ylabel('Value')\n",
    "plt.title('Five Variables over Epochs')\n",
    "plt.legend()\n",
    "plt.grid(True)\n",
    "plt.tight_layout()\n",
    "plt.show()\n",
    "\n",
    "savemat('history_F.mat', {'value': history_F})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c699deea",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
