{
 "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",
    "import time "
   ]
  },
  {
   "cell_type": "markdown",
   "id": "069e2e34",
   "metadata": {},
   "source": [
    "# import target dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "3a4a2d8e",
   "metadata": {},
   "outputs": [],
   "source": [
    "# === Step 1: Load data ===\n",
    "filename = 'dataBenchmark.csv'  # Replace with your filename\n",
    "df = pd.read_csv(filename, header=None)\n",
    "\n",
    "# Columns: assume 0-based indexing, so:\n",
    "# u(t) is in column 1\n",
    "# y(t) is in column 3\n",
    "u = df.iloc[1:, 1].values  # u(t) #delete the first element which shows the label\n",
    "y = df.iloc[1:, 3].values  # y(t)\n",
    "\n",
    "# === Step 2: Construct input-output pairs ===\n",
    "X = []\n",
    "Y = []\n",
    "for t in range(1, len(y)):\n",
    "    X.append([u[t], y[t-1], y[t-1]])  # input: u(t), y(t-1)\n",
    "    Y.append([y[t], y[t]])            # output: y(t)\n",
    "\n",
    "X = np.array(X)\n",
    "Y = np.array(Y).reshape(-1, 2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "a7948aac",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[['0.99921' '4.9728' '4.9728']\n",
      " ['1.0172' '4.9722' '4.9722']\n",
      " ['1.0318' '4.9703' '4.9703']\n",
      " ...\n",
      " ['0.88351' '3.7978' '3.7978']\n",
      " ['0.9162' '3.7807' '3.7807']\n",
      " ['0.94805' '3.7151' '3.7151']] [['4.9722' '4.9722']\n",
      " ['4.9703' '4.9703']\n",
      " ['4.988' '4.988']\n",
      " ...\n",
      " ['3.7807' '3.7807']\n",
      " ['3.7151' '3.7151']\n",
      " ['3.7179' '3.7179']]\n"
     ]
    }
   ],
   "source": [
    "print(X,Y)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "d8e4402d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(204, 3) (819, 3) (204, 2) (819, 2)\n"
     ]
    }
   ],
   "source": [
    "# === Step 3: Normalize data (optional but recommended) ===\n",
    "scaler_X = StandardScaler()\n",
    "scaler_Y = StandardScaler()\n",
    "\n",
    "X_scaled = scaler_X.fit_transform(X)\n",
    "Y_scaled = scaler_Y.fit_transform(Y)\n",
    "\n",
    "# === Step 4: Train-test split ===\n",
    "X_train, X_test, Y_train, Y_test = train_test_split(X_scaled, Y_scaled, test_size=0.8, random_state=42)\n",
    "\n",
    "print(X_train.shape, X_test.shape, Y_train.shape, Y_test.shape)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3d8c5f41",
   "metadata": {},
   "source": [
    "# Develop the benchmark"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "d0ab6116",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model: \"sequential\"\n",
      "_________________________________________________________________\n",
      " Layer (type)                Output Shape              Param #   \n",
      "=================================================================\n",
      " dense (Dense)               (None, 16)                64        \n",
      "                                                                 \n",
      " dense_1 (Dense)             (None, 2)                 34        \n",
      "                                                                 \n",
      "=================================================================\n",
      "Total params: 98\n",
      "Trainable params: 98\n",
      "Non-trainable params: 0\n",
      "_________________________________________________________________\n",
      "None\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2025-07-14 17:04:53.135838: 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-14 17:04:53.135866: 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-14 17:04:53.136269: I tensorflow/core/platform/cpu_feature_guard.cc:151] This TensorFlow binary is optimized with oneAPI Deep Neural Network Library (oneDNN) to use the following CPU instructions in performance-critical operations:  AVX2 AVX512F FMA\n",
      "To enable them in other operations, rebuild TensorFlow with the appropriate compiler flags.\n"
     ]
    }
   ],
   "source": [
    "# === Step 5: Define and train FNN model ===\n",
    "model = Sequential([\n",
    "    Dense(16, activation='relu', input_shape=(3,)),\n",
    "    Dense(2, activation='linear')\n",
    "])\n",
    "\n",
    "model.compile(optimizer='adam', loss='mse', metrics=['mae'])\n",
    "print(model.summary())\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "2cc77d23",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/500\n",
      "7/7 [==============================] - 0s 15ms/step - loss: 1.5967 - mae: 0.9918 - val_loss: 1.2370 - val_mae: 0.8776\n",
      "Epoch 2/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 1.4628 - mae: 0.9471 - val_loss: 1.1294 - val_mae: 0.8369\n",
      "Epoch 3/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 1.3406 - mae: 0.9035 - val_loss: 1.0276 - val_mae: 0.7963\n",
      "Epoch 4/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 1.2200 - mae: 0.8598 - val_loss: 0.9339 - val_mae: 0.7570\n",
      "Epoch 5/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 1.1072 - mae: 0.8165 - val_loss: 0.8455 - val_mae: 0.7179\n",
      "Epoch 6/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 1.0051 - mae: 0.7746 - val_loss: 0.7620 - val_mae: 0.6792\n",
      "Epoch 7/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.9096 - mae: 0.7329 - val_loss: 0.6840 - val_mae: 0.6408\n",
      "Epoch 8/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.8139 - mae: 0.6905 - val_loss: 0.6148 - val_mae: 0.6044\n",
      "Epoch 9/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.7324 - mae: 0.6512 - val_loss: 0.5498 - val_mae: 0.5685\n",
      "Epoch 10/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.6532 - mae: 0.6117 - val_loss: 0.4892 - val_mae: 0.5331\n",
      "Epoch 11/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.5814 - mae: 0.5735 - val_loss: 0.4338 - val_mae: 0.4983\n",
      "Epoch 12/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.5143 - mae: 0.5346 - val_loss: 0.3835 - val_mae: 0.4648\n",
      "Epoch 13/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.4552 - mae: 0.4980 - val_loss: 0.3369 - val_mae: 0.4320\n",
      "Epoch 14/500\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.3983 - mae: 0.4616 - val_loss: 0.2951 - val_mae: 0.4005\n",
      "Epoch 15/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.3479 - mae: 0.4268 - val_loss: 0.2569 - val_mae: 0.3703\n",
      "Epoch 16/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.3018 - mae: 0.3925 - val_loss: 0.2229 - val_mae: 0.3421\n",
      "Epoch 17/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.2623 - mae: 0.3613 - val_loss: 0.1925 - val_mae: 0.3154\n",
      "Epoch 18/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.2254 - mae: 0.3313 - val_loss: 0.1661 - val_mae: 0.2913\n",
      "Epoch 19/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.1942 - mae: 0.3056 - val_loss: 0.1432 - val_mae: 0.2696\n",
      "Epoch 20/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.1680 - mae: 0.2821 - val_loss: 0.1236 - val_mae: 0.2492\n",
      "Epoch 21/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.1446 - mae: 0.2598 - val_loss: 0.1070 - val_mae: 0.2309\n",
      "Epoch 22/500\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.1240 - mae: 0.2397 - val_loss: 0.0929 - val_mae: 0.2143\n",
      "Epoch 23/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.1074 - mae: 0.2220 - val_loss: 0.0809 - val_mae: 0.1990\n",
      "Epoch 24/500\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0931 - mae: 0.2059 - val_loss: 0.0709 - val_mae: 0.1854\n",
      "Epoch 25/500\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0811 - mae: 0.1914 - val_loss: 0.0627 - val_mae: 0.1734\n",
      "Epoch 26/500\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0708 - mae: 0.1779 - val_loss: 0.0559 - val_mae: 0.1630\n",
      "Epoch 27/500\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0626 - mae: 0.1670 - val_loss: 0.0499 - val_mae: 0.1543\n",
      "Epoch 28/500\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0554 - mae: 0.1573 - val_loss: 0.0450 - val_mae: 0.1472\n",
      "Epoch 29/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0494 - mae: 0.1497 - val_loss: 0.0411 - val_mae: 0.1413\n",
      "Epoch 30/500\n",
      "7/7 [==============================] - 0s 6ms/step - loss: 0.0446 - mae: 0.1436 - val_loss: 0.0379 - val_mae: 0.1363\n",
      "Epoch 31/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0407 - mae: 0.1381 - val_loss: 0.0351 - val_mae: 0.1317\n",
      "Epoch 32/500\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0372 - mae: 0.1332 - val_loss: 0.0327 - val_mae: 0.1273\n",
      "Epoch 33/500\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0343 - mae: 0.1285 - val_loss: 0.0307 - val_mae: 0.1232\n",
      "Epoch 34/500\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0319 - mae: 0.1240 - val_loss: 0.0289 - val_mae: 0.1195\n",
      "Epoch 35/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0298 - mae: 0.1202 - val_loss: 0.0273 - val_mae: 0.1161\n",
      "Epoch 36/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0280 - mae: 0.1168 - val_loss: 0.0258 - val_mae: 0.1130\n",
      "Epoch 37/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0261 - mae: 0.1134 - val_loss: 0.0245 - val_mae: 0.1102\n",
      "Epoch 38/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0245 - mae: 0.1103 - val_loss: 0.0234 - val_mae: 0.1076\n",
      "Epoch 39/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0232 - mae: 0.1077 - val_loss: 0.0222 - val_mae: 0.1051\n",
      "Epoch 40/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0220 - mae: 0.1051 - val_loss: 0.0212 - val_mae: 0.1026\n",
      "Epoch 41/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0208 - mae: 0.1025 - val_loss: 0.0202 - val_mae: 0.1002\n",
      "Epoch 42/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0198 - mae: 0.1001 - val_loss: 0.0193 - val_mae: 0.0980\n",
      "Epoch 43/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0187 - mae: 0.0978 - val_loss: 0.0185 - val_mae: 0.0960\n",
      "Epoch 44/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0178 - mae: 0.0955 - val_loss: 0.0177 - val_mae: 0.0940\n",
      "Epoch 45/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0170 - mae: 0.0934 - val_loss: 0.0170 - val_mae: 0.0921\n",
      "Epoch 46/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0162 - mae: 0.0913 - val_loss: 0.0163 - val_mae: 0.0904\n",
      "Epoch 47/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0155 - mae: 0.0896 - val_loss: 0.0157 - val_mae: 0.0888\n",
      "Epoch 48/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0148 - mae: 0.0879 - val_loss: 0.0151 - val_mae: 0.0874\n",
      "Epoch 49/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0141 - mae: 0.0860 - val_loss: 0.0145 - val_mae: 0.0859\n",
      "Epoch 50/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0135 - mae: 0.0843 - val_loss: 0.0140 - val_mae: 0.0845\n",
      "Epoch 51/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0130 - mae: 0.0826 - val_loss: 0.0135 - val_mae: 0.0832\n",
      "Epoch 52/500\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0124 - mae: 0.0812 - val_loss: 0.0131 - val_mae: 0.0820\n",
      "Epoch 53/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0119 - mae: 0.0798 - val_loss: 0.0126 - val_mae: 0.0809\n",
      "Epoch 54/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0114 - mae: 0.0785 - val_loss: 0.0122 - val_mae: 0.0799\n",
      "Epoch 55/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0110 - mae: 0.0773 - val_loss: 0.0119 - val_mae: 0.0789\n",
      "Epoch 56/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0106 - mae: 0.0761 - val_loss: 0.0115 - val_mae: 0.0778\n",
      "Epoch 57/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0101 - mae: 0.0748 - val_loss: 0.0112 - val_mae: 0.0769\n",
      "Epoch 58/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0098 - mae: 0.0736 - val_loss: 0.0109 - val_mae: 0.0759\n",
      "Epoch 59/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0094 - mae: 0.0724 - val_loss: 0.0106 - val_mae: 0.0749\n",
      "Epoch 60/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0091 - mae: 0.0712 - val_loss: 0.0103 - val_mae: 0.0741\n",
      "Epoch 61/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0088 - mae: 0.0702 - val_loss: 0.0101 - val_mae: 0.0734\n",
      "Epoch 62/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0085 - mae: 0.0693 - val_loss: 0.0098 - val_mae: 0.0730\n",
      "Epoch 63/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0083 - mae: 0.0686 - val_loss: 0.0096 - val_mae: 0.0724\n",
      "Epoch 64/500\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0080 - mae: 0.0677 - val_loss: 0.0094 - val_mae: 0.0717\n",
      "Epoch 65/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0078 - mae: 0.0668 - val_loss: 0.0092 - val_mae: 0.0710\n",
      "Epoch 66/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0075 - mae: 0.0658 - val_loss: 0.0090 - val_mae: 0.0702\n",
      "Epoch 67/500\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0073 - mae: 0.0648 - val_loss: 0.0088 - val_mae: 0.0694\n",
      "Epoch 68/500\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0071 - mae: 0.0639 - val_loss: 0.0087 - val_mae: 0.0686\n",
      "Epoch 69/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0069 - mae: 0.0630 - val_loss: 0.0085 - val_mae: 0.0680\n",
      "Epoch 70/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0067 - mae: 0.0621 - val_loss: 0.0083 - val_mae: 0.0674\n",
      "Epoch 71/500\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0066 - mae: 0.0614 - val_loss: 0.0082 - val_mae: 0.0668\n",
      "Epoch 72/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0064 - mae: 0.0606 - val_loss: 0.0080 - val_mae: 0.0664\n",
      "Epoch 73/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0063 - mae: 0.0601 - val_loss: 0.0079 - val_mae: 0.0661\n",
      "Epoch 74/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0061 - mae: 0.0597 - val_loss: 0.0078 - val_mae: 0.0658\n",
      "Epoch 75/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0060 - mae: 0.0592 - val_loss: 0.0077 - val_mae: 0.0653\n",
      "Epoch 76/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0058 - mae: 0.0587 - val_loss: 0.0076 - val_mae: 0.0650\n",
      "Epoch 77/500\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0057 - mae: 0.0581 - val_loss: 0.0074 - val_mae: 0.0645\n",
      "Epoch 78/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0056 - mae: 0.0575 - val_loss: 0.0073 - val_mae: 0.0640\n",
      "Epoch 79/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0055 - mae: 0.0568 - val_loss: 0.0072 - val_mae: 0.0635\n",
      "Epoch 80/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0054 - mae: 0.0562 - val_loss: 0.0071 - val_mae: 0.0630\n",
      "Epoch 81/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0052 - mae: 0.0555 - val_loss: 0.0070 - val_mae: 0.0625\n",
      "Epoch 82/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0051 - mae: 0.0550 - val_loss: 0.0069 - val_mae: 0.0621\n",
      "Epoch 83/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0050 - mae: 0.0544 - val_loss: 0.0068 - val_mae: 0.0617\n",
      "Epoch 84/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0049 - mae: 0.0539 - val_loss: 0.0068 - val_mae: 0.0613\n",
      "Epoch 85/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0048 - mae: 0.0535 - val_loss: 0.0067 - val_mae: 0.0610\n",
      "Epoch 86/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0048 - mae: 0.0532 - val_loss: 0.0066 - val_mae: 0.0607\n",
      "Epoch 87/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0047 - mae: 0.0527 - val_loss: 0.0065 - val_mae: 0.0602\n",
      "Epoch 88/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0046 - mae: 0.0522 - val_loss: 0.0064 - val_mae: 0.0599\n",
      "Epoch 89/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0045 - mae: 0.0518 - val_loss: 0.0064 - val_mae: 0.0595\n",
      "Epoch 90/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0044 - mae: 0.0513 - val_loss: 0.0063 - val_mae: 0.0592\n",
      "Epoch 91/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0044 - mae: 0.0509 - val_loss: 0.0062 - val_mae: 0.0590\n",
      "Epoch 92/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0043 - mae: 0.0505 - val_loss: 0.0062 - val_mae: 0.0586\n",
      "Epoch 93/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0042 - mae: 0.0500 - val_loss: 0.0061 - val_mae: 0.0581\n",
      "Epoch 94/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0041 - mae: 0.0495 - val_loss: 0.0060 - val_mae: 0.0578\n",
      "Epoch 95/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0041 - mae: 0.0491 - val_loss: 0.0060 - val_mae: 0.0574\n",
      "Epoch 96/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0040 - mae: 0.0488 - val_loss: 0.0059 - val_mae: 0.0572\n",
      "Epoch 97/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0040 - mae: 0.0485 - val_loss: 0.0059 - val_mae: 0.0570\n",
      "Epoch 98/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0039 - mae: 0.0482 - val_loss: 0.0058 - val_mae: 0.0567\n",
      "Epoch 99/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0039 - mae: 0.0477 - val_loss: 0.0058 - val_mae: 0.0563\n",
      "Epoch 100/500\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0038 - mae: 0.0473 - val_loss: 0.0057 - val_mae: 0.0560\n",
      "Epoch 101/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0037 - mae: 0.0469 - val_loss: 0.0057 - val_mae: 0.0557\n",
      "Epoch 102/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0037 - mae: 0.0466 - val_loss: 0.0056 - val_mae: 0.0555\n",
      "Epoch 103/500\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0036 - mae: 0.0463 - val_loss: 0.0056 - val_mae: 0.0551\n",
      "Epoch 104/500\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0036 - mae: 0.0459 - val_loss: 0.0055 - val_mae: 0.0548\n",
      "Epoch 105/500\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0035 - mae: 0.0456 - val_loss: 0.0055 - val_mae: 0.0548\n",
      "Epoch 106/500\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0035 - mae: 0.0455 - val_loss: 0.0054 - val_mae: 0.0548\n",
      "Epoch 107/500\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0035 - mae: 0.0454 - val_loss: 0.0054 - val_mae: 0.0546\n",
      "Epoch 108/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0034 - mae: 0.0450 - val_loss: 0.0054 - val_mae: 0.0541\n",
      "Epoch 109/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0034 - mae: 0.0445 - val_loss: 0.0053 - val_mae: 0.0537\n",
      "Epoch 110/500\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0033 - mae: 0.0442 - val_loss: 0.0053 - val_mae: 0.0535\n",
      "Epoch 111/500\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0033 - mae: 0.0439 - val_loss: 0.0052 - val_mae: 0.0533\n",
      "Epoch 112/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0033 - mae: 0.0436 - val_loss: 0.0052 - val_mae: 0.0530\n",
      "Epoch 113/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0032 - mae: 0.0432 - val_loss: 0.0051 - val_mae: 0.0527\n",
      "Epoch 114/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0032 - mae: 0.0430 - val_loss: 0.0051 - val_mae: 0.0526\n",
      "Epoch 115/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0031 - mae: 0.0430 - val_loss: 0.0051 - val_mae: 0.0525\n",
      "Epoch 116/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0031 - mae: 0.0429 - val_loss: 0.0050 - val_mae: 0.0523\n",
      "Epoch 117/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0031 - mae: 0.0426 - val_loss: 0.0050 - val_mae: 0.0521\n",
      "Epoch 118/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0030 - mae: 0.0424 - val_loss: 0.0050 - val_mae: 0.0519\n",
      "Epoch 119/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0030 - mae: 0.0420 - val_loss: 0.0049 - val_mae: 0.0516\n",
      "Epoch 120/500\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0030 - mae: 0.0418 - val_loss: 0.0049 - val_mae: 0.0512\n",
      "Epoch 121/500\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0029 - mae: 0.0415 - val_loss: 0.0049 - val_mae: 0.0511\n",
      "Epoch 122/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0029 - mae: 0.0413 - val_loss: 0.0048 - val_mae: 0.0508\n",
      "Epoch 123/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0029 - mae: 0.0410 - val_loss: 0.0048 - val_mae: 0.0506\n",
      "Epoch 124/500\n",
      "7/7 [==============================] - 0s 7ms/step - loss: 0.0029 - mae: 0.0407 - val_loss: 0.0048 - val_mae: 0.0503\n",
      "Epoch 125/500\n",
      "7/7 [==============================] - 0s 6ms/step - loss: 0.0028 - mae: 0.0404 - val_loss: 0.0047 - val_mae: 0.0501\n",
      "Epoch 126/500\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0028 - mae: 0.0402 - val_loss: 0.0047 - val_mae: 0.0499\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 127/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0028 - mae: 0.0401 - val_loss: 0.0047 - val_mae: 0.0499\n",
      "Epoch 128/500\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0027 - mae: 0.0400 - val_loss: 0.0046 - val_mae: 0.0497\n",
      "Epoch 129/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0027 - mae: 0.0398 - val_loss: 0.0046 - val_mae: 0.0495\n",
      "Epoch 130/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0027 - mae: 0.0395 - val_loss: 0.0046 - val_mae: 0.0492\n",
      "Epoch 131/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0027 - mae: 0.0394 - val_loss: 0.0045 - val_mae: 0.0490\n",
      "Epoch 132/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0026 - mae: 0.0392 - val_loss: 0.0045 - val_mae: 0.0488\n",
      "Epoch 133/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0026 - mae: 0.0390 - val_loss: 0.0045 - val_mae: 0.0488\n",
      "Epoch 134/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0026 - mae: 0.0389 - val_loss: 0.0045 - val_mae: 0.0486\n",
      "Epoch 135/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0025 - mae: 0.0387 - val_loss: 0.0044 - val_mae: 0.0484\n",
      "Epoch 136/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0025 - mae: 0.0386 - val_loss: 0.0044 - val_mae: 0.0482\n",
      "Epoch 137/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0025 - mae: 0.0383 - val_loss: 0.0044 - val_mae: 0.0479\n",
      "Epoch 138/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0025 - mae: 0.0381 - val_loss: 0.0044 - val_mae: 0.0477\n",
      "Epoch 139/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0025 - mae: 0.0380 - val_loss: 0.0043 - val_mae: 0.0477\n",
      "Epoch 140/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0024 - mae: 0.0379 - val_loss: 0.0043 - val_mae: 0.0475\n",
      "Epoch 141/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0024 - mae: 0.0378 - val_loss: 0.0043 - val_mae: 0.0474\n",
      "Epoch 142/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0024 - mae: 0.0377 - val_loss: 0.0043 - val_mae: 0.0473\n",
      "Epoch 143/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0024 - mae: 0.0376 - val_loss: 0.0043 - val_mae: 0.0471\n",
      "Epoch 144/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0024 - mae: 0.0374 - val_loss: 0.0042 - val_mae: 0.0469\n",
      "Epoch 145/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0023 - mae: 0.0371 - val_loss: 0.0042 - val_mae: 0.0465\n",
      "Epoch 146/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0023 - mae: 0.0367 - val_loss: 0.0042 - val_mae: 0.0463\n",
      "Epoch 147/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0023 - mae: 0.0366 - val_loss: 0.0042 - val_mae: 0.0461\n",
      "Epoch 148/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0023 - mae: 0.0365 - val_loss: 0.0042 - val_mae: 0.0461\n",
      "Epoch 149/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0023 - mae: 0.0364 - val_loss: 0.0041 - val_mae: 0.0459\n",
      "Epoch 150/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0022 - mae: 0.0363 - val_loss: 0.0041 - val_mae: 0.0458\n",
      "Epoch 151/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0022 - mae: 0.0361 - val_loss: 0.0041 - val_mae: 0.0458\n",
      "Epoch 152/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0022 - mae: 0.0361 - val_loss: 0.0041 - val_mae: 0.0456\n",
      "Epoch 153/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0022 - mae: 0.0358 - val_loss: 0.0041 - val_mae: 0.0453\n",
      "Epoch 154/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0022 - mae: 0.0357 - val_loss: 0.0040 - val_mae: 0.0453\n",
      "Epoch 155/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0022 - mae: 0.0357 - val_loss: 0.0040 - val_mae: 0.0452\n",
      "Epoch 156/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0022 - mae: 0.0356 - val_loss: 0.0040 - val_mae: 0.0449\n",
      "Epoch 157/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0021 - mae: 0.0355 - val_loss: 0.0040 - val_mae: 0.0449\n",
      "Epoch 158/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0021 - mae: 0.0355 - val_loss: 0.0040 - val_mae: 0.0448\n",
      "Epoch 159/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0021 - mae: 0.0354 - val_loss: 0.0039 - val_mae: 0.0446\n",
      "Epoch 160/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0021 - mae: 0.0350 - val_loss: 0.0039 - val_mae: 0.0443\n",
      "Epoch 161/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0021 - mae: 0.0348 - val_loss: 0.0039 - val_mae: 0.0442\n",
      "Epoch 162/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0021 - mae: 0.0349 - val_loss: 0.0039 - val_mae: 0.0442\n",
      "Epoch 163/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0020 - mae: 0.0348 - val_loss: 0.0039 - val_mae: 0.0439\n",
      "Epoch 164/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0020 - mae: 0.0345 - val_loss: 0.0039 - val_mae: 0.0436\n",
      "Epoch 165/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0020 - mae: 0.0342 - val_loss: 0.0038 - val_mae: 0.0433\n",
      "Epoch 166/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0020 - mae: 0.0340 - val_loss: 0.0038 - val_mae: 0.0434\n",
      "Epoch 167/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0020 - mae: 0.0340 - val_loss: 0.0038 - val_mae: 0.0432\n",
      "Epoch 168/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0020 - mae: 0.0339 - val_loss: 0.0038 - val_mae: 0.0432\n",
      "Epoch 169/500\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0020 - mae: 0.0337 - val_loss: 0.0038 - val_mae: 0.0431\n",
      "Epoch 170/500\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0019 - mae: 0.0336 - val_loss: 0.0038 - val_mae: 0.0430\n",
      "Epoch 171/500\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0019 - mae: 0.0335 - val_loss: 0.0037 - val_mae: 0.0427\n",
      "Epoch 172/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0019 - mae: 0.0333 - val_loss: 0.0037 - val_mae: 0.0425\n",
      "Epoch 173/500\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0019 - mae: 0.0333 - val_loss: 0.0037 - val_mae: 0.0425\n",
      "Epoch 174/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0019 - mae: 0.0330 - val_loss: 0.0037 - val_mae: 0.0422\n",
      "Epoch 175/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0019 - mae: 0.0329 - val_loss: 0.0037 - val_mae: 0.0421\n",
      "Epoch 176/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0019 - mae: 0.0327 - val_loss: 0.0037 - val_mae: 0.0419\n",
      "Epoch 177/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0019 - mae: 0.0325 - val_loss: 0.0036 - val_mae: 0.0416\n",
      "Epoch 178/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0018 - mae: 0.0322 - val_loss: 0.0036 - val_mae: 0.0415\n",
      "Epoch 179/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0018 - mae: 0.0321 - val_loss: 0.0036 - val_mae: 0.0415\n",
      "Epoch 180/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0018 - mae: 0.0321 - val_loss: 0.0036 - val_mae: 0.0415\n",
      "Epoch 181/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0018 - mae: 0.0321 - val_loss: 0.0036 - val_mae: 0.0413\n",
      "Epoch 182/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0018 - mae: 0.0319 - val_loss: 0.0036 - val_mae: 0.0412\n",
      "Epoch 183/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0018 - mae: 0.0319 - val_loss: 0.0036 - val_mae: 0.0411\n",
      "Epoch 184/500\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0018 - mae: 0.0320 - val_loss: 0.0035 - val_mae: 0.0411\n",
      "Epoch 185/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0018 - mae: 0.0319 - val_loss: 0.0035 - val_mae: 0.0408\n",
      "Epoch 186/500\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0017 - mae: 0.0316 - val_loss: 0.0035 - val_mae: 0.0406\n",
      "Epoch 187/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0017 - mae: 0.0313 - val_loss: 0.0035 - val_mae: 0.0404\n",
      "Epoch 188/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0017 - mae: 0.0311 - val_loss: 0.0035 - val_mae: 0.0403\n",
      "Epoch 189/500\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0017 - mae: 0.0312 - val_loss: 0.0035 - val_mae: 0.0402\n",
      "Epoch 190/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0017 - mae: 0.0310 - val_loss: 0.0034 - val_mae: 0.0401\n",
      "Epoch 191/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0017 - mae: 0.0308 - val_loss: 0.0034 - val_mae: 0.0399\n",
      "Epoch 192/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0017 - mae: 0.0306 - val_loss: 0.0034 - val_mae: 0.0397\n",
      "Epoch 193/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0017 - mae: 0.0307 - val_loss: 0.0034 - val_mae: 0.0397\n",
      "Epoch 194/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0017 - mae: 0.0308 - val_loss: 0.0034 - val_mae: 0.0398\n",
      "Epoch 195/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0017 - mae: 0.0308 - val_loss: 0.0034 - val_mae: 0.0396\n",
      "Epoch 196/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0016 - mae: 0.0307 - val_loss: 0.0034 - val_mae: 0.0394\n",
      "Epoch 197/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0016 - mae: 0.0304 - val_loss: 0.0034 - val_mae: 0.0392\n",
      "Epoch 198/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0016 - mae: 0.0303 - val_loss: 0.0033 - val_mae: 0.0391\n",
      "Epoch 199/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0016 - mae: 0.0302 - val_loss: 0.0033 - val_mae: 0.0390\n",
      "Epoch 200/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0016 - mae: 0.0301 - val_loss: 0.0033 - val_mae: 0.0389\n",
      "Epoch 201/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0016 - mae: 0.0299 - val_loss: 0.0033 - val_mae: 0.0388\n",
      "Epoch 202/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0016 - mae: 0.0298 - val_loss: 0.0033 - val_mae: 0.0386\n",
      "Epoch 203/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0016 - mae: 0.0297 - val_loss: 0.0033 - val_mae: 0.0384\n",
      "Epoch 204/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0016 - mae: 0.0296 - val_loss: 0.0033 - val_mae: 0.0384\n",
      "Epoch 205/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0016 - mae: 0.0297 - val_loss: 0.0033 - val_mae: 0.0384\n",
      "Epoch 206/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0016 - mae: 0.0296 - val_loss: 0.0032 - val_mae: 0.0383\n",
      "Epoch 207/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0016 - mae: 0.0294 - val_loss: 0.0032 - val_mae: 0.0381\n",
      "Epoch 208/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0015 - mae: 0.0294 - val_loss: 0.0032 - val_mae: 0.0381\n",
      "Epoch 209/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0015 - mae: 0.0294 - val_loss: 0.0032 - val_mae: 0.0380\n",
      "Epoch 210/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0015 - mae: 0.0293 - val_loss: 0.0032 - val_mae: 0.0379\n",
      "Epoch 211/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0015 - mae: 0.0292 - val_loss: 0.0032 - val_mae: 0.0378\n",
      "Epoch 212/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0015 - mae: 0.0291 - val_loss: 0.0032 - val_mae: 0.0376\n",
      "Epoch 213/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0015 - mae: 0.0291 - val_loss: 0.0032 - val_mae: 0.0375\n",
      "Epoch 214/500\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0015 - mae: 0.0290 - val_loss: 0.0032 - val_mae: 0.0374\n",
      "Epoch 215/500\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0015 - mae: 0.0289 - val_loss: 0.0032 - val_mae: 0.0373\n",
      "Epoch 216/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0015 - mae: 0.0288 - val_loss: 0.0031 - val_mae: 0.0373\n",
      "Epoch 217/500\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0015 - mae: 0.0288 - val_loss: 0.0031 - val_mae: 0.0373\n",
      "Epoch 218/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0015 - mae: 0.0287 - val_loss: 0.0031 - val_mae: 0.0371\n",
      "Epoch 219/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0015 - mae: 0.0286 - val_loss: 0.0031 - val_mae: 0.0370\n",
      "Epoch 220/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0015 - mae: 0.0286 - val_loss: 0.0031 - val_mae: 0.0370\n",
      "Epoch 221/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0015 - mae: 0.0284 - val_loss: 0.0031 - val_mae: 0.0368\n",
      "Epoch 222/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0014 - mae: 0.0283 - val_loss: 0.0031 - val_mae: 0.0367\n",
      "Epoch 223/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0014 - mae: 0.0284 - val_loss: 0.0031 - val_mae: 0.0366\n",
      "Epoch 224/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0014 - mae: 0.0283 - val_loss: 0.0030 - val_mae: 0.0364\n",
      "Epoch 225/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0014 - mae: 0.0282 - val_loss: 0.0030 - val_mae: 0.0364\n",
      "Epoch 226/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0014 - mae: 0.0282 - val_loss: 0.0030 - val_mae: 0.0363\n",
      "Epoch 227/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0014 - mae: 0.0281 - val_loss: 0.0030 - val_mae: 0.0363\n",
      "Epoch 228/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0014 - mae: 0.0282 - val_loss: 0.0030 - val_mae: 0.0362\n",
      "Epoch 229/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0014 - mae: 0.0281 - val_loss: 0.0030 - val_mae: 0.0361\n",
      "Epoch 230/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0014 - mae: 0.0280 - val_loss: 0.0030 - val_mae: 0.0360\n",
      "Epoch 231/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0014 - mae: 0.0280 - val_loss: 0.0030 - val_mae: 0.0359\n",
      "Epoch 232/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0014 - mae: 0.0280 - val_loss: 0.0030 - val_mae: 0.0359\n",
      "Epoch 233/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0014 - mae: 0.0280 - val_loss: 0.0030 - val_mae: 0.0359\n",
      "Epoch 234/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0014 - mae: 0.0279 - val_loss: 0.0030 - val_mae: 0.0357\n",
      "Epoch 235/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0014 - mae: 0.0276 - val_loss: 0.0029 - val_mae: 0.0356\n",
      "Epoch 236/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0014 - mae: 0.0275 - val_loss: 0.0029 - val_mae: 0.0355\n",
      "Epoch 237/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0014 - mae: 0.0275 - val_loss: 0.0029 - val_mae: 0.0353\n",
      "Epoch 238/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0014 - mae: 0.0274 - val_loss: 0.0029 - val_mae: 0.0352\n",
      "Epoch 239/500\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0014 - mae: 0.0273 - val_loss: 0.0029 - val_mae: 0.0351\n",
      "Epoch 240/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0013 - mae: 0.0273 - val_loss: 0.0029 - val_mae: 0.0351\n",
      "Epoch 241/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0013 - mae: 0.0274 - val_loss: 0.0029 - val_mae: 0.0352\n",
      "Epoch 242/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0013 - mae: 0.0274 - val_loss: 0.0028 - val_mae: 0.0351\n",
      "Epoch 243/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0013 - mae: 0.0274 - val_loss: 0.0028 - val_mae: 0.0350\n",
      "Epoch 244/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0013 - mae: 0.0273 - val_loss: 0.0028 - val_mae: 0.0348\n",
      "Epoch 245/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0013 - mae: 0.0272 - val_loss: 0.0028 - val_mae: 0.0347\n",
      "Epoch 246/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0013 - mae: 0.0271 - val_loss: 0.0028 - val_mae: 0.0347\n",
      "Epoch 247/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0013 - mae: 0.0270 - val_loss: 0.0028 - val_mae: 0.0345\n",
      "Epoch 248/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0013 - mae: 0.0269 - val_loss: 0.0028 - val_mae: 0.0343\n",
      "Epoch 249/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0013 - mae: 0.0268 - val_loss: 0.0028 - val_mae: 0.0342\n",
      "Epoch 250/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0013 - mae: 0.0267 - val_loss: 0.0027 - val_mae: 0.0342\n",
      "Epoch 251/500\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0013 - mae: 0.0267 - val_loss: 0.0027 - val_mae: 0.0342\n",
      "Epoch 252/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0013 - mae: 0.0267 - val_loss: 0.0027 - val_mae: 0.0341\n",
      "Epoch 253/500\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0013 - mae: 0.0267 - val_loss: 0.0027 - val_mae: 0.0341\n",
      "Epoch 254/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0013 - mae: 0.0266 - val_loss: 0.0027 - val_mae: 0.0340\n",
      "Epoch 255/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0013 - mae: 0.0265 - val_loss: 0.0027 - val_mae: 0.0340\n",
      "Epoch 256/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0013 - mae: 0.0265 - val_loss: 0.0027 - val_mae: 0.0339\n",
      "Epoch 257/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0013 - mae: 0.0264 - val_loss: 0.0027 - val_mae: 0.0338\n",
      "Epoch 258/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0013 - mae: 0.0262 - val_loss: 0.0027 - val_mae: 0.0337\n",
      "Epoch 259/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0013 - mae: 0.0261 - val_loss: 0.0027 - val_mae: 0.0335\n",
      "Epoch 260/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0012 - mae: 0.0261 - val_loss: 0.0027 - val_mae: 0.0334\n",
      "Epoch 261/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0012 - mae: 0.0260 - val_loss: 0.0026 - val_mae: 0.0334\n",
      "Epoch 262/500\n",
      "7/7 [==============================] - 0s 3ms/step - loss: 0.0012 - mae: 0.0260 - val_loss: 0.0026 - val_mae: 0.0334\n",
      "Epoch 263/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0012 - mae: 0.0261 - val_loss: 0.0026 - val_mae: 0.0333\n",
      "Epoch 264/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0012 - mae: 0.0261 - val_loss: 0.0026 - val_mae: 0.0332\n",
      "Epoch 265/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0012 - mae: 0.0262 - val_loss: 0.0026 - val_mae: 0.0331\n",
      "Epoch 266/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0012 - mae: 0.0260 - val_loss: 0.0026 - val_mae: 0.0330\n",
      "Epoch 267/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0012 - mae: 0.0258 - val_loss: 0.0026 - val_mae: 0.0329\n",
      "Epoch 268/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0012 - mae: 0.0258 - val_loss: 0.0026 - val_mae: 0.0329\n",
      "Epoch 269/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0012 - mae: 0.0258 - val_loss: 0.0026 - val_mae: 0.0329\n",
      "Epoch 270/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0012 - mae: 0.0258 - val_loss: 0.0026 - val_mae: 0.0328\n",
      "Epoch 271/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0012 - mae: 0.0257 - val_loss: 0.0026 - val_mae: 0.0327\n",
      "Epoch 272/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0012 - mae: 0.0258 - val_loss: 0.0026 - val_mae: 0.0328\n",
      "Epoch 273/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0012 - mae: 0.0258 - val_loss: 0.0025 - val_mae: 0.0327\n",
      "Epoch 274/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0012 - mae: 0.0256 - val_loss: 0.0025 - val_mae: 0.0326\n",
      "Epoch 275/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0012 - mae: 0.0256 - val_loss: 0.0025 - val_mae: 0.0324\n",
      "Epoch 276/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0012 - mae: 0.0255 - val_loss: 0.0025 - val_mae: 0.0324\n",
      "Epoch 277/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0012 - mae: 0.0256 - val_loss: 0.0025 - val_mae: 0.0324\n",
      "Epoch 278/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0012 - mae: 0.0255 - val_loss: 0.0025 - val_mae: 0.0323\n",
      "Epoch 279/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0012 - mae: 0.0254 - val_loss: 0.0025 - val_mae: 0.0322\n",
      "Epoch 280/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0012 - mae: 0.0253 - val_loss: 0.0025 - val_mae: 0.0321\n",
      "Epoch 281/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0012 - mae: 0.0252 - val_loss: 0.0025 - val_mae: 0.0320\n",
      "Epoch 282/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0011 - mae: 0.0252 - val_loss: 0.0025 - val_mae: 0.0319\n",
      "Epoch 283/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0011 - mae: 0.0253 - val_loss: 0.0025 - val_mae: 0.0319\n",
      "Epoch 284/500\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0011 - mae: 0.0253 - val_loss: 0.0024 - val_mae: 0.0319\n",
      "Epoch 285/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0011 - mae: 0.0252 - val_loss: 0.0024 - val_mae: 0.0318\n",
      "Epoch 286/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0011 - mae: 0.0251 - val_loss: 0.0024 - val_mae: 0.0317\n",
      "Epoch 287/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0011 - mae: 0.0249 - val_loss: 0.0024 - val_mae: 0.0316\n",
      "Epoch 288/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0011 - mae: 0.0249 - val_loss: 0.0024 - val_mae: 0.0316\n",
      "Epoch 289/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0011 - mae: 0.0249 - val_loss: 0.0024 - val_mae: 0.0315\n",
      "Epoch 290/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0011 - mae: 0.0250 - val_loss: 0.0024 - val_mae: 0.0315\n",
      "Epoch 291/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0011 - mae: 0.0250 - val_loss: 0.0024 - val_mae: 0.0315\n",
      "Epoch 292/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0011 - mae: 0.0250 - val_loss: 0.0024 - val_mae: 0.0314\n",
      "Epoch 293/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0011 - mae: 0.0249 - val_loss: 0.0024 - val_mae: 0.0312\n",
      "Epoch 294/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0011 - mae: 0.0247 - val_loss: 0.0024 - val_mae: 0.0311\n",
      "Epoch 295/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0011 - mae: 0.0247 - val_loss: 0.0024 - val_mae: 0.0310\n",
      "Epoch 296/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0011 - mae: 0.0248 - val_loss: 0.0023 - val_mae: 0.0311\n",
      "Epoch 297/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0011 - mae: 0.0247 - val_loss: 0.0023 - val_mae: 0.0310\n",
      "Epoch 298/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0011 - mae: 0.0248 - val_loss: 0.0023 - val_mae: 0.0311\n",
      "Epoch 299/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0011 - mae: 0.0247 - val_loss: 0.0023 - val_mae: 0.0309\n",
      "Epoch 300/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0011 - mae: 0.0246 - val_loss: 0.0023 - val_mae: 0.0308\n",
      "Epoch 301/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0011 - mae: 0.0245 - val_loss: 0.0023 - val_mae: 0.0307\n",
      "Epoch 302/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0011 - mae: 0.0245 - val_loss: 0.0023 - val_mae: 0.0306\n",
      "Epoch 303/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0011 - mae: 0.0244 - val_loss: 0.0023 - val_mae: 0.0305\n",
      "Epoch 304/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0011 - mae: 0.0244 - val_loss: 0.0023 - val_mae: 0.0305\n",
      "Epoch 305/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0011 - mae: 0.0245 - val_loss: 0.0023 - val_mae: 0.0307\n",
      "Epoch 306/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0011 - mae: 0.0247 - val_loss: 0.0023 - val_mae: 0.0307\n",
      "Epoch 307/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0011 - mae: 0.0246 - val_loss: 0.0023 - val_mae: 0.0305\n",
      "Epoch 308/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0011 - mae: 0.0244 - val_loss: 0.0023 - val_mae: 0.0303\n",
      "Epoch 309/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0011 - mae: 0.0242 - val_loss: 0.0023 - val_mae: 0.0302\n",
      "Epoch 310/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0011 - mae: 0.0242 - val_loss: 0.0022 - val_mae: 0.0302\n",
      "Epoch 311/500\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 0.0011 - mae: 0.0242 - val_loss: 0.0022 - val_mae: 0.0301\n",
      "Epoch 312/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0010 - mae: 0.0242 - val_loss: 0.0022 - val_mae: 0.0300\n",
      "Epoch 313/500\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0010 - mae: 0.0241 - val_loss: 0.0022 - val_mae: 0.0299\n",
      "Epoch 314/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0010 - mae: 0.0241 - val_loss: 0.0022 - val_mae: 0.0300\n",
      "Epoch 315/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0010 - mae: 0.0241 - val_loss: 0.0022 - val_mae: 0.0300\n",
      "Epoch 316/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0010 - mae: 0.0241 - val_loss: 0.0022 - val_mae: 0.0299\n",
      "Epoch 317/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0010 - mae: 0.0240 - val_loss: 0.0022 - val_mae: 0.0299\n",
      "Epoch 318/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0010 - mae: 0.0240 - val_loss: 0.0022 - val_mae: 0.0298\n",
      "Epoch 319/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0010 - mae: 0.0240 - val_loss: 0.0022 - val_mae: 0.0297\n",
      "Epoch 320/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0010 - mae: 0.0238 - val_loss: 0.0022 - val_mae: 0.0296\n",
      "Epoch 321/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0010 - mae: 0.0238 - val_loss: 0.0022 - val_mae: 0.0296\n",
      "Epoch 322/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0010 - mae: 0.0239 - val_loss: 0.0022 - val_mae: 0.0296\n",
      "Epoch 323/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0010 - mae: 0.0239 - val_loss: 0.0022 - val_mae: 0.0296\n",
      "Epoch 324/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0010 - mae: 0.0239 - val_loss: 0.0021 - val_mae: 0.0295\n",
      "Epoch 325/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0010 - mae: 0.0238 - val_loss: 0.0021 - val_mae: 0.0294\n",
      "Epoch 326/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0010 - mae: 0.0237 - val_loss: 0.0021 - val_mae: 0.0294\n",
      "Epoch 327/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0010 - mae: 0.0238 - val_loss: 0.0021 - val_mae: 0.0293\n",
      "Epoch 328/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0010 - mae: 0.0237 - val_loss: 0.0021 - val_mae: 0.0293\n",
      "Epoch 329/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0010 - mae: 0.0237 - val_loss: 0.0021 - val_mae: 0.0293\n",
      "Epoch 330/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 0.0010 - mae: 0.0237 - val_loss: 0.0021 - val_mae: 0.0293\n",
      "Epoch 331/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 9.9689e-04 - mae: 0.0237 - val_loss: 0.0021 - val_mae: 0.0292\n",
      "Epoch 332/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 9.9369e-04 - mae: 0.0236 - val_loss: 0.0021 - val_mae: 0.0291\n",
      "Epoch 333/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 9.9500e-04 - mae: 0.0236 - val_loss: 0.0021 - val_mae: 0.0291\n",
      "Epoch 334/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 9.9280e-04 - mae: 0.0235 - val_loss: 0.0021 - val_mae: 0.0291\n",
      "Epoch 335/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 9.8895e-04 - mae: 0.0235 - val_loss: 0.0021 - val_mae: 0.0291\n",
      "Epoch 336/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 9.8505e-04 - mae: 0.0235 - val_loss: 0.0021 - val_mae: 0.0289\n",
      "Epoch 337/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 9.8523e-04 - mae: 0.0235 - val_loss: 0.0021 - val_mae: 0.0289\n",
      "Epoch 338/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 9.8178e-04 - mae: 0.0234 - val_loss: 0.0021 - val_mae: 0.0289\n",
      "Epoch 339/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 9.8021e-04 - mae: 0.0234 - val_loss: 0.0021 - val_mae: 0.0289\n",
      "Epoch 340/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 9.8341e-04 - mae: 0.0235 - val_loss: 0.0021 - val_mae: 0.0289\n",
      "Epoch 341/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 9.7559e-04 - mae: 0.0234 - val_loss: 0.0021 - val_mae: 0.0288\n",
      "Epoch 342/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 9.7107e-04 - mae: 0.0233 - val_loss: 0.0021 - val_mae: 0.0287\n",
      "Epoch 343/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 9.7282e-04 - mae: 0.0234 - val_loss: 0.0021 - val_mae: 0.0287\n",
      "Epoch 344/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 9.6843e-04 - mae: 0.0233 - val_loss: 0.0020 - val_mae: 0.0285\n",
      "Epoch 345/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 9.6322e-04 - mae: 0.0232 - val_loss: 0.0020 - val_mae: 0.0285\n",
      "Epoch 346/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 9.6377e-04 - mae: 0.0232 - val_loss: 0.0020 - val_mae: 0.0285\n",
      "Epoch 347/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 9.5894e-04 - mae: 0.0232 - val_loss: 0.0020 - val_mae: 0.0285\n",
      "Epoch 348/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 9.5617e-04 - mae: 0.0232 - val_loss: 0.0020 - val_mae: 0.0285\n",
      "Epoch 349/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 9.5963e-04 - mae: 0.0233 - val_loss: 0.0020 - val_mae: 0.0284\n",
      "Epoch 350/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 9.5417e-04 - mae: 0.0233 - val_loss: 0.0020 - val_mae: 0.0283\n",
      "Epoch 351/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 9.5183e-04 - mae: 0.0231 - val_loss: 0.0020 - val_mae: 0.0283\n",
      "Epoch 352/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 9.4806e-04 - mae: 0.0230 - val_loss: 0.0020 - val_mae: 0.0282\n",
      "Epoch 353/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 9.4438e-04 - mae: 0.0230 - val_loss: 0.0020 - val_mae: 0.0282\n",
      "Epoch 354/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 9.5504e-04 - mae: 0.0230 - val_loss: 0.0020 - val_mae: 0.0283\n",
      "Epoch 355/500\n",
      "7/7 [==============================] - 0s 6ms/step - loss: 9.4285e-04 - mae: 0.0229 - val_loss: 0.0020 - val_mae: 0.0282\n",
      "Epoch 356/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 9.4068e-04 - mae: 0.0229 - val_loss: 0.0020 - val_mae: 0.0281\n",
      "Epoch 357/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 9.4161e-04 - mae: 0.0229 - val_loss: 0.0020 - val_mae: 0.0281\n",
      "Epoch 358/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 9.3843e-04 - mae: 0.0228 - val_loss: 0.0020 - val_mae: 0.0280\n",
      "Epoch 359/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 9.3714e-04 - mae: 0.0228 - val_loss: 0.0020 - val_mae: 0.0280\n",
      "Epoch 360/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 9.2772e-04 - mae: 0.0227 - val_loss: 0.0020 - val_mae: 0.0279\n",
      "Epoch 361/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 9.2506e-04 - mae: 0.0228 - val_loss: 0.0020 - val_mae: 0.0279\n",
      "Epoch 362/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 9.3186e-04 - mae: 0.0230 - val_loss: 0.0019 - val_mae: 0.0280\n",
      "Epoch 363/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 9.2419e-04 - mae: 0.0228 - val_loss: 0.0019 - val_mae: 0.0279\n",
      "Epoch 364/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 9.2203e-04 - mae: 0.0227 - val_loss: 0.0019 - val_mae: 0.0278\n",
      "Epoch 365/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 9.2736e-04 - mae: 0.0227 - val_loss: 0.0019 - val_mae: 0.0277\n",
      "Epoch 366/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 9.2436e-04 - mae: 0.0227 - val_loss: 0.0019 - val_mae: 0.0277\n",
      "Epoch 367/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 9.1717e-04 - mae: 0.0226 - val_loss: 0.0019 - val_mae: 0.0277\n",
      "Epoch 368/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 9.1476e-04 - mae: 0.0226 - val_loss: 0.0019 - val_mae: 0.0276\n",
      "Epoch 369/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 9.1412e-04 - mae: 0.0226 - val_loss: 0.0019 - val_mae: 0.0276\n",
      "Epoch 370/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 9.1511e-04 - mae: 0.0226 - val_loss: 0.0019 - val_mae: 0.0276\n",
      "Epoch 371/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 9.1824e-04 - mae: 0.0226 - val_loss: 0.0019 - val_mae: 0.0275\n",
      "Epoch 372/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 9.1012e-04 - mae: 0.0225 - val_loss: 0.0019 - val_mae: 0.0275\n",
      "Epoch 373/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 9.0748e-04 - mae: 0.0225 - val_loss: 0.0019 - val_mae: 0.0275\n",
      "Epoch 374/500\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "7/7 [==============================] - 0s 4ms/step - loss: 9.0867e-04 - mae: 0.0225 - val_loss: 0.0019 - val_mae: 0.0275\n",
      "Epoch 375/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 9.0618e-04 - mae: 0.0225 - val_loss: 0.0019 - val_mae: 0.0275\n",
      "Epoch 376/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 9.1076e-04 - mae: 0.0225 - val_loss: 0.0019 - val_mae: 0.0274\n",
      "Epoch 377/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 9.0378e-04 - mae: 0.0224 - val_loss: 0.0019 - val_mae: 0.0274\n",
      "Epoch 378/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.9804e-04 - mae: 0.0224 - val_loss: 0.0019 - val_mae: 0.0275\n",
      "Epoch 379/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 9.0351e-04 - mae: 0.0224 - val_loss: 0.0019 - val_mae: 0.0274\n",
      "Epoch 380/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 9.0249e-04 - mae: 0.0223 - val_loss: 0.0019 - val_mae: 0.0273\n",
      "Epoch 381/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.9998e-04 - mae: 0.0223 - val_loss: 0.0019 - val_mae: 0.0273\n",
      "Epoch 382/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.9375e-04 - mae: 0.0223 - val_loss: 0.0019 - val_mae: 0.0272\n",
      "Epoch 383/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.9269e-04 - mae: 0.0223 - val_loss: 0.0019 - val_mae: 0.0272\n",
      "Epoch 384/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.9380e-04 - mae: 0.0223 - val_loss: 0.0019 - val_mae: 0.0273\n",
      "Epoch 385/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.8814e-04 - mae: 0.0223 - val_loss: 0.0019 - val_mae: 0.0273\n",
      "Epoch 386/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.8552e-04 - mae: 0.0223 - val_loss: 0.0019 - val_mae: 0.0272\n",
      "Epoch 387/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.9729e-04 - mae: 0.0223 - val_loss: 0.0019 - val_mae: 0.0272\n",
      "Epoch 388/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.8746e-04 - mae: 0.0221 - val_loss: 0.0019 - val_mae: 0.0271\n",
      "Epoch 389/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.9787e-04 - mae: 0.0222 - val_loss: 0.0018 - val_mae: 0.0270\n",
      "Epoch 390/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.8497e-04 - mae: 0.0222 - val_loss: 0.0018 - val_mae: 0.0271\n",
      "Epoch 391/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.8175e-04 - mae: 0.0221 - val_loss: 0.0018 - val_mae: 0.0271\n",
      "Epoch 392/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.8480e-04 - mae: 0.0220 - val_loss: 0.0018 - val_mae: 0.0270\n",
      "Epoch 393/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.7685e-04 - mae: 0.0220 - val_loss: 0.0018 - val_mae: 0.0270\n",
      "Epoch 394/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.7428e-04 - mae: 0.0220 - val_loss: 0.0018 - val_mae: 0.0269\n",
      "Epoch 395/500\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 8.7180e-04 - mae: 0.0220 - val_loss: 0.0018 - val_mae: 0.0269\n",
      "Epoch 396/500\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 8.7518e-04 - mae: 0.0220 - val_loss: 0.0018 - val_mae: 0.0269\n",
      "Epoch 397/500\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 8.6826e-04 - mae: 0.0220 - val_loss: 0.0018 - val_mae: 0.0269\n",
      "Epoch 398/500\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 8.6961e-04 - mae: 0.0220 - val_loss: 0.0018 - val_mae: 0.0269\n",
      "Epoch 399/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.6935e-04 - mae: 0.0219 - val_loss: 0.0018 - val_mae: 0.0268\n",
      "Epoch 400/500\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 8.6934e-04 - mae: 0.0219 - val_loss: 0.0018 - val_mae: 0.0268\n",
      "Epoch 401/500\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 8.7107e-04 - mae: 0.0219 - val_loss: 0.0018 - val_mae: 0.0268\n",
      "Epoch 402/500\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 8.6900e-04 - mae: 0.0219 - val_loss: 0.0018 - val_mae: 0.0268\n",
      "Epoch 403/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.6688e-04 - mae: 0.0219 - val_loss: 0.0018 - val_mae: 0.0268\n",
      "Epoch 404/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.6650e-04 - mae: 0.0219 - val_loss: 0.0018 - val_mae: 0.0268\n",
      "Epoch 405/500\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 8.6670e-04 - mae: 0.0219 - val_loss: 0.0018 - val_mae: 0.0267\n",
      "Epoch 406/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.5721e-04 - mae: 0.0217 - val_loss: 0.0018 - val_mae: 0.0267\n",
      "Epoch 407/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.6037e-04 - mae: 0.0217 - val_loss: 0.0018 - val_mae: 0.0267\n",
      "Epoch 408/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.5682e-04 - mae: 0.0217 - val_loss: 0.0018 - val_mae: 0.0266\n",
      "Epoch 409/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.5370e-04 - mae: 0.0217 - val_loss: 0.0018 - val_mae: 0.0265\n",
      "Epoch 410/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.5378e-04 - mae: 0.0216 - val_loss: 0.0018 - val_mae: 0.0266\n",
      "Epoch 411/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.5014e-04 - mae: 0.0216 - val_loss: 0.0018 - val_mae: 0.0266\n",
      "Epoch 412/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.5253e-04 - mae: 0.0216 - val_loss: 0.0018 - val_mae: 0.0265\n",
      "Epoch 413/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.5972e-04 - mae: 0.0216 - val_loss: 0.0018 - val_mae: 0.0265\n",
      "Epoch 414/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.4816e-04 - mae: 0.0215 - val_loss: 0.0018 - val_mae: 0.0266\n",
      "Epoch 415/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.4862e-04 - mae: 0.0216 - val_loss: 0.0018 - val_mae: 0.0265\n",
      "Epoch 416/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.5022e-04 - mae: 0.0216 - val_loss: 0.0018 - val_mae: 0.0265\n",
      "Epoch 417/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.4585e-04 - mae: 0.0215 - val_loss: 0.0018 - val_mae: 0.0264\n",
      "Epoch 418/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.4850e-04 - mae: 0.0215 - val_loss: 0.0018 - val_mae: 0.0264\n",
      "Epoch 419/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.4831e-04 - mae: 0.0215 - val_loss: 0.0018 - val_mae: 0.0264\n",
      "Epoch 420/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.4079e-04 - mae: 0.0214 - val_loss: 0.0018 - val_mae: 0.0263\n",
      "Epoch 421/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.4524e-04 - mae: 0.0215 - val_loss: 0.0018 - val_mae: 0.0263\n",
      "Epoch 422/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.4265e-04 - mae: 0.0215 - val_loss: 0.0017 - val_mae: 0.0263\n",
      "Epoch 423/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.3760e-04 - mae: 0.0214 - val_loss: 0.0017 - val_mae: 0.0263\n",
      "Epoch 424/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.3532e-04 - mae: 0.0214 - val_loss: 0.0017 - val_mae: 0.0264\n",
      "Epoch 425/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.4512e-04 - mae: 0.0215 - val_loss: 0.0017 - val_mae: 0.0263\n",
      "Epoch 426/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.3784e-04 - mae: 0.0214 - val_loss: 0.0017 - val_mae: 0.0263\n",
      "Epoch 427/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.3484e-04 - mae: 0.0213 - val_loss: 0.0017 - val_mae: 0.0263\n",
      "Epoch 428/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.3270e-04 - mae: 0.0213 - val_loss: 0.0017 - val_mae: 0.0263\n",
      "Epoch 429/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.3695e-04 - mae: 0.0213 - val_loss: 0.0017 - val_mae: 0.0261\n",
      "Epoch 430/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.2699e-04 - mae: 0.0213 - val_loss: 0.0017 - val_mae: 0.0262\n",
      "Epoch 431/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.3052e-04 - mae: 0.0213 - val_loss: 0.0017 - val_mae: 0.0261\n",
      "Epoch 432/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.2328e-04 - mae: 0.0212 - val_loss: 0.0017 - val_mae: 0.0262\n",
      "Epoch 433/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.2686e-04 - mae: 0.0213 - val_loss: 0.0017 - val_mae: 0.0263\n",
      "Epoch 434/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.3362e-04 - mae: 0.0213 - val_loss: 0.0017 - val_mae: 0.0261\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 435/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.2580e-04 - mae: 0.0211 - val_loss: 0.0017 - val_mae: 0.0260\n",
      "Epoch 436/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.2237e-04 - mae: 0.0211 - val_loss: 0.0017 - val_mae: 0.0260\n",
      "Epoch 437/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.2218e-04 - mae: 0.0212 - val_loss: 0.0017 - val_mae: 0.0261\n",
      "Epoch 438/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.2783e-04 - mae: 0.0213 - val_loss: 0.0017 - val_mae: 0.0260\n",
      "Epoch 439/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.2011e-04 - mae: 0.0212 - val_loss: 0.0017 - val_mae: 0.0260\n",
      "Epoch 440/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.1872e-04 - mae: 0.0212 - val_loss: 0.0017 - val_mae: 0.0260\n",
      "Epoch 441/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.1530e-04 - mae: 0.0211 - val_loss: 0.0017 - val_mae: 0.0260\n",
      "Epoch 442/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.1644e-04 - mae: 0.0210 - val_loss: 0.0017 - val_mae: 0.0259\n",
      "Epoch 443/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.1835e-04 - mae: 0.0210 - val_loss: 0.0017 - val_mae: 0.0259\n",
      "Epoch 444/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.2054e-04 - mae: 0.0210 - val_loss: 0.0017 - val_mae: 0.0259\n",
      "Epoch 445/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.0965e-04 - mae: 0.0209 - val_loss: 0.0017 - val_mae: 0.0260\n",
      "Epoch 446/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.1819e-04 - mae: 0.0211 - val_loss: 0.0017 - val_mae: 0.0259\n",
      "Epoch 447/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.1019e-04 - mae: 0.0210 - val_loss: 0.0017 - val_mae: 0.0259\n",
      "Epoch 448/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.1237e-04 - mae: 0.0210 - val_loss: 0.0017 - val_mae: 0.0258\n",
      "Epoch 449/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.0957e-04 - mae: 0.0210 - val_loss: 0.0017 - val_mae: 0.0258\n",
      "Epoch 450/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.0856e-04 - mae: 0.0209 - val_loss: 0.0017 - val_mae: 0.0258\n",
      "Epoch 451/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.0959e-04 - mae: 0.0210 - val_loss: 0.0017 - val_mae: 0.0259\n",
      "Epoch 452/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.0754e-04 - mae: 0.0210 - val_loss: 0.0017 - val_mae: 0.0258\n",
      "Epoch 453/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.0455e-04 - mae: 0.0208 - val_loss: 0.0017 - val_mae: 0.0257\n",
      "Epoch 454/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.0778e-04 - mae: 0.0209 - val_loss: 0.0017 - val_mae: 0.0257\n",
      "Epoch 455/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.0602e-04 - mae: 0.0209 - val_loss: 0.0017 - val_mae: 0.0257\n",
      "Epoch 456/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.0380e-04 - mae: 0.0209 - val_loss: 0.0017 - val_mae: 0.0257\n",
      "Epoch 457/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.0761e-04 - mae: 0.0209 - val_loss: 0.0017 - val_mae: 0.0258\n",
      "Epoch 458/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.0679e-04 - mae: 0.0209 - val_loss: 0.0017 - val_mae: 0.0257\n",
      "Epoch 459/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.0469e-04 - mae: 0.0208 - val_loss: 0.0017 - val_mae: 0.0256\n",
      "Epoch 460/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.0115e-04 - mae: 0.0208 - val_loss: 0.0017 - val_mae: 0.0257\n",
      "Epoch 461/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.0540e-04 - mae: 0.0208 - val_loss: 0.0017 - val_mae: 0.0257\n",
      "Epoch 462/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 7.9675e-04 - mae: 0.0207 - val_loss: 0.0017 - val_mae: 0.0257\n",
      "Epoch 463/500\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 7.9939e-04 - mae: 0.0207 - val_loss: 0.0017 - val_mae: 0.0256\n",
      "Epoch 464/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.0152e-04 - mae: 0.0208 - val_loss: 0.0017 - val_mae: 0.0257\n",
      "Epoch 465/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 7.9662e-04 - mae: 0.0207 - val_loss: 0.0017 - val_mae: 0.0256\n",
      "Epoch 466/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 7.9645e-04 - mae: 0.0207 - val_loss: 0.0017 - val_mae: 0.0256\n",
      "Epoch 467/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 7.9586e-04 - mae: 0.0206 - val_loss: 0.0017 - val_mae: 0.0256\n",
      "Epoch 468/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 7.9764e-04 - mae: 0.0206 - val_loss: 0.0017 - val_mae: 0.0255\n",
      "Epoch 469/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.0889e-04 - mae: 0.0208 - val_loss: 0.0017 - val_mae: 0.0255\n",
      "Epoch 470/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 7.9289e-04 - mae: 0.0207 - val_loss: 0.0017 - val_mae: 0.0255\n",
      "Epoch 471/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 8.0033e-04 - mae: 0.0207 - val_loss: 0.0017 - val_mae: 0.0255\n",
      "Epoch 472/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 7.9497e-04 - mae: 0.0207 - val_loss: 0.0017 - val_mae: 0.0256\n",
      "Epoch 473/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 7.9729e-04 - mae: 0.0207 - val_loss: 0.0017 - val_mae: 0.0255\n",
      "Epoch 474/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 7.9133e-04 - mae: 0.0206 - val_loss: 0.0017 - val_mae: 0.0254\n",
      "Epoch 475/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 7.8722e-04 - mae: 0.0206 - val_loss: 0.0017 - val_mae: 0.0254\n",
      "Epoch 476/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 7.9114e-04 - mae: 0.0206 - val_loss: 0.0016 - val_mae: 0.0254\n",
      "Epoch 477/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 7.8681e-04 - mae: 0.0206 - val_loss: 0.0016 - val_mae: 0.0254\n",
      "Epoch 478/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 7.8745e-04 - mae: 0.0205 - val_loss: 0.0017 - val_mae: 0.0254\n",
      "Epoch 479/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 7.8519e-04 - mae: 0.0205 - val_loss: 0.0016 - val_mae: 0.0254\n",
      "Epoch 480/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 7.8780e-04 - mae: 0.0206 - val_loss: 0.0016 - val_mae: 0.0253\n",
      "Epoch 481/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 7.8370e-04 - mae: 0.0205 - val_loss: 0.0016 - val_mae: 0.0254\n",
      "Epoch 482/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 7.8216e-04 - mae: 0.0205 - val_loss: 0.0016 - val_mae: 0.0254\n",
      "Epoch 483/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 7.8096e-04 - mae: 0.0205 - val_loss: 0.0016 - val_mae: 0.0254\n",
      "Epoch 484/500\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 7.9079e-04 - mae: 0.0206 - val_loss: 0.0016 - val_mae: 0.0254\n",
      "Epoch 485/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 7.7819e-04 - mae: 0.0205 - val_loss: 0.0016 - val_mae: 0.0253\n",
      "Epoch 486/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 7.9468e-04 - mae: 0.0206 - val_loss: 0.0017 - val_mae: 0.0253\n",
      "Epoch 487/500\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 7.8449e-04 - mae: 0.0205 - val_loss: 0.0016 - val_mae: 0.0253\n",
      "Epoch 488/500\n",
      "7/7 [==============================] - 0s 5ms/step - loss: 7.8207e-04 - mae: 0.0205 - val_loss: 0.0016 - val_mae: 0.0253\n",
      "Epoch 489/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 7.8480e-04 - mae: 0.0206 - val_loss: 0.0016 - val_mae: 0.0253\n",
      "Epoch 490/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 7.8120e-04 - mae: 0.0205 - val_loss: 0.0016 - val_mae: 0.0253\n",
      "Epoch 491/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 7.8511e-04 - mae: 0.0205 - val_loss: 0.0016 - val_mae: 0.0252\n",
      "Epoch 492/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 7.7966e-04 - mae: 0.0204 - val_loss: 0.0016 - val_mae: 0.0252\n",
      "Epoch 493/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 7.7707e-04 - mae: 0.0204 - val_loss: 0.0016 - val_mae: 0.0252\n",
      "Epoch 494/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 7.7893e-04 - mae: 0.0205 - val_loss: 0.0016 - val_mae: 0.0253\n",
      "Epoch 495/500\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "7/7 [==============================] - 0s 4ms/step - loss: 7.7509e-04 - mae: 0.0204 - val_loss: 0.0016 - val_mae: 0.0252\n",
      "Epoch 496/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 7.8123e-04 - mae: 0.0204 - val_loss: 0.0016 - val_mae: 0.0252\n",
      "Epoch 497/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 7.7709e-04 - mae: 0.0204 - val_loss: 0.0016 - val_mae: 0.0252\n",
      "Epoch 498/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 7.7173e-04 - mae: 0.0203 - val_loss: 0.0016 - val_mae: 0.0252\n",
      "Epoch 499/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 7.7341e-04 - mae: 0.0203 - val_loss: 0.0016 - val_mae: 0.0251\n",
      "Epoch 500/500\n",
      "7/7 [==============================] - 0s 4ms/step - loss: 7.7440e-04 - mae: 0.0203 - val_loss: 0.0016 - val_mae: 0.0251\n"
     ]
    }
   ],
   "source": [
    "t0 = time.time()\n",
    "model.fit(X_train, Y_train, epochs=500, batch_size=32, validation_data=(X_test, Y_test))\n",
    "t1 = time.time()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "81f35c9a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "4/4 [==============================] - 0s 578us/step - loss: 0.0016 - mae: 0.0251\n",
      "[0.0016207403969019651, 0.025128193199634552]\n",
      "13.634231090545654\n"
     ]
    }
   ],
   "source": [
    "#use the SOURCE test data to evaluate the model\n",
    "loss_and_metrics = model.evaluate(X_test, Y_test, batch_size=256)\n",
    "print(loss_and_metrics)\n",
    "\n",
    "print(t1-t0)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e569d35c",
   "metadata": {},
   "source": [
    "# construct the NN after feature transformation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "d659a2af",
   "metadata": {},
   "outputs": [],
   "source": [
    "model = load_model(\"pretrained_model.h5\")\n",
    "X_train_S = np.load('source_input_data.npy')\n",
    "Y_train_S = np.load('source_output_data.npy')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "4687c4cf",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "375/375 [==============================] - 0s 330us/step - loss: 0.0013 - mse: 0.0013\n",
      "7/7 [==============================] - 0s 761us/step - loss: 2.4292 - mse: 2.4292\n",
      "48/48 [==============================] - 0s 548us/step - loss: 0.0419 - mse: 0.0419\n"
     ]
    }
   ],
   "source": [
    "#combine source and target for training\n",
    "#first 640 target, 3995 source\n",
    "RNN_input_final_Train = np.concatenate((X_train, X_train_S), axis=0) \n",
    "RNN_output_final_Train = np.concatenate((Y_train, Y_train_S), axis=0)\n",
    "\n",
    "NN_S = model.predict(X_train_S)\n",
    "\n",
    "#performance of the pre-trained model on train data\n",
    "loss_and_metrics = model.evaluate(X_train_S, Y_train_S)\n",
    "loss_and_metrics = model.evaluate(X_train, Y_train)\n",
    "\n",
    "loss_and_metrics = model.evaluate(RNN_input_final_Train, RNN_output_final_Train, batch_size=256)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "f2c61d08",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Step 2: Freeze the original model's weights\n",
    "for layer in model.layers:\n",
    "    layer.trainable = False\n",
    "\n",
    "# Step 3: Create new layers\n",
    "input_layer = Input(shape=(3))  # Replace input_dim with your actual input feature dimension\n",
    "new_input_layer = Dense(8, activation='linear', use_bias=False)  # New front layer\n",
    "new_input_layer1 = Dense(8, activation='linear', use_bias=False)  # New front layer\n",
    "new_input_layer2 = Dense(3, activation='linear', use_bias=False)  # New front layer\n",
    "\n",
    "# Connect the frozen original model\n",
    "x = model(new_input_layer2(new_input_layer1(new_input_layer(input_layer))))\n",
    "\n",
    "# Add new output layer\n",
    "new_output_layer = Dense(4, activation='linear', use_bias=False)  # Replace output_dim with your desired final output size\n",
    "new_output_layer1 = Dense(4, activation='linear', use_bias=False)  # Replace output_dim with your desired final output size\n",
    "new_output_layer2 = Dense(2, activation='linear', use_bias=False)  # Replace output_dim with your desired final output size\n",
    "\n",
    "output = new_output_layer2(new_output_layer1(new_output_layer(x)))\n",
    "# Step 4: Assemble final model\n",
    "final_model = Model(inputs=input_layer, outputs=output)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "e9a742b1",
   "metadata": {},
   "outputs": [],
   "source": [
    "#assign parameters\n",
    "# Define A: 3x8 matrix [I_3 | 0]\n",
    "A = np.array([\n",
    "    [1, 0, 0, 0, 0, 0, 0, 0],\n",
    "    [0, 1, 0, 0, 0, 0, 0, 0],\n",
    "    [0, 0, 1, 0, 0, 0, 0, 0]\n",
    "], dtype=np.float32)\n",
    "\n",
    "# Define B: 8x8 identity matrix\n",
    "B = np.array(np.eye(8), dtype=np.float32)\n",
    "\n",
    "# Define C: 8x3 matrix [I_3; 0]\n",
    "C = np.array([\n",
    "    [1, 0, 0],\n",
    "    [0, 1, 0],\n",
    "    [0, 0, 1],\n",
    "    [0, 0, 0],\n",
    "    [0, 0, 0],\n",
    "    [0, 0, 0],\n",
    "    [0, 0, 0],\n",
    "    [0, 0, 0]\n",
    "], dtype=np.float32)\n",
    "\n",
    "new_input_layer.set_weights([A])\n",
    "new_input_layer1.set_weights([B])\n",
    "new_input_layer2.set_weights([C])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "a5792001",
   "metadata": {},
   "outputs": [],
   "source": [
    "# A: 2x4 matrix [I_2 | 0]\n",
    "Ao = np.array([\n",
    "    [1, 0, 0, 0],\n",
    "    [0, 1, 0, 0]\n",
    "], dtype=np.float32)\n",
    "\n",
    "# B: 4x4 identity\n",
    "Bo = np.array(np.eye(4), dtype=np.float32)\n",
    "\n",
    "# C: 4x2 matrix [I_2; 0]\n",
    "Co = np.array([\n",
    "    [1, 0],\n",
    "    [0, 1],\n",
    "    [0, 0],\n",
    "    [0, 0]\n",
    "], dtype=np.float32)\n",
    "\n",
    "new_output_layer.set_weights([Ao])\n",
    "new_output_layer1.set_weights([Bo])\n",
    "new_output_layer2.set_weights([Co])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "4b514281",
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "# Step 5: Custom loss function\n",
    "def custom_loss(y_true, y_pred):\n",
    "    Num = 204 #number of training target data\n",
    "    NN_out = final_model(RNN_input_final_Train) #[[t1,ca1,cb1],[t2,ca2,cb2]]\n",
    "    \n",
    "    #first term\n",
    "    loss11 =  tf.math.reduce_mean((NN_out[:Num,:]-RNN_output_final_Train[:Num,:])**2) # prediction on target\n",
    "    loss12 =  tf.math.reduce_mean((NN_out[Num:,:]-RNN_output_final_Train[Num:,:])**2) # prediction on source\n",
    "    \n",
    "    loss1 = abs(loss11 - loss12) \n",
    "    \n",
    "    #second term\n",
    "    \n",
    "    loss2 =  tf.math.reduce_mean((NN_out[Num:,:]- NN_S)**2) # prediction error for h and h^* on source\n",
    "    \n",
    "    #last term\n",
    "    max_abs_input = tf.reduce_max(tf.abs(input_layer_weights))\n",
    "    max_abs_output = tf.reduce_max(tf.abs(output_layer_weights))\n",
    "    loss3 =  max_abs_input * max_abs_output\n",
    "    \n",
    "    #weight\n",
    "    a = 0\n",
    "    b = 0.01\n",
    "    c = 0.01\n",
    "    \n",
    "    loss = 1.0*loss11+a*loss1+b*loss2+c*loss3#100*loss11+a*loss1+b*loss2+c*loss3\n",
    "    \n",
    "    return loss  # you can modify this to include regularization if needed"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "91d741df",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model: \"model\"\n",
      "_________________________________________________________________\n",
      " Layer (type)                Output Shape              Param #   \n",
      "=================================================================\n",
      " input_1 (InputLayer)        [(None, 3)]               0         \n",
      "                                                                 \n",
      " dense_2 (Dense)             (None, 8)                 24        \n",
      "                                                                 \n",
      " dense_3 (Dense)             (None, 8)                 64        \n",
      "                                                                 \n",
      " dense_4 (Dense)             (None, 3)                 24        \n",
      "                                                                 \n",
      " sequential_1 (Sequential)   (None, 2)                 98        \n",
      "                                                                 \n",
      " dense_5 (Dense)             (None, 4)                 8         \n",
      "                                                                 \n",
      " dense_6 (Dense)             (None, 4)                 16        \n",
      "                                                                 \n",
      " dense_7 (Dense)             (None, 2)                 8         \n",
      "                                                                 \n",
      "=================================================================\n",
      "Total params: 242\n",
      "Trainable params: 144\n",
      "Non-trainable params: 98\n",
      "_________________________________________________________________\n",
      "None\n"
     ]
    }
   ],
   "source": [
    "# Step 6: Compile\n",
    "#final_model.compile(optimizer='adam', loss=custom_loss, metrics=['mse'])\n",
    "final_model.compile(optimizer='adam', loss=custom_loss, metrics=['mse'])\n",
    "print(final_model.summary())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "a2d89c02",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iteration :0     Target train: tf.Tensor(2.4291961, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 2.4392 - mse: 2.5118 - val_loss: 2.4031 - val_mse: 2.1491 - 374ms/epoch - 374ms/step\n",
      "iteration :1     Target train: tf.Tensor(2.3931017, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 2.4031 - mse: 2.4744 - val_loss: 2.3678 - val_mse: 2.1176 - 25ms/epoch - 25ms/step\n",
      "iteration :2     Target train: tf.Tensor(2.3577085, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 2.3678 - mse: 2.4377 - val_loss: 2.3331 - val_mse: 2.0867 - 25ms/epoch - 25ms/step\n",
      "iteration :3     Target train: tf.Tensor(2.3229203, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 2.3331 - mse: 2.4017 - val_loss: 2.2990 - val_mse: 2.0564 - 24ms/epoch - 24ms/step\n",
      "iteration :4     Target train: tf.Tensor(2.2886384, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 2.2990 - mse: 2.3661 - val_loss: 2.2652 - val_mse: 2.0264 - 26ms/epoch - 26ms/step\n",
      "iteration :5     Target train: tf.Tensor(2.2546165, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 2.2652 - mse: 2.3307 - val_loss: 2.2319 - val_mse: 1.9967 - 31ms/epoch - 31ms/step\n",
      "iteration :6     Target train: tf.Tensor(2.2211351, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 2.2319 - mse: 2.2960 - val_loss: 2.1992 - val_mse: 1.9676 - 25ms/epoch - 25ms/step\n",
      "iteration :7     Target train: tf.Tensor(2.1881704, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 2.1992 - mse: 2.2617 - val_loss: 2.1670 - val_mse: 1.9392 - 25ms/epoch - 25ms/step\n",
      "iteration :8     Target train: tf.Tensor(2.1556582, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 2.1670 - mse: 2.2278 - val_loss: 2.1355 - val_mse: 1.9114 - 24ms/epoch - 24ms/step\n",
      "iteration :9     Target train: tf.Tensor(2.1237454, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 2.1355 - mse: 2.1945 - val_loss: 2.1045 - val_mse: 1.8843 - 25ms/epoch - 25ms/step\n",
      "iteration :10     Target train: tf.Tensor(2.0923786, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 2.1045 - mse: 2.1618 - val_loss: 2.0740 - val_mse: 1.8577 - 25ms/epoch - 25ms/step\n",
      "iteration :11     Target train: tf.Tensor(2.0614908, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 2.0740 - mse: 2.1294 - val_loss: 2.0442 - val_mse: 1.8316 - 26ms/epoch - 26ms/step\n",
      "iteration :12     Target train: tf.Tensor(2.031142, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 2.0442 - mse: 2.0976 - val_loss: 2.0149 - val_mse: 1.8061 - 33ms/epoch - 33ms/step\n",
      "iteration :13     Target train: tf.Tensor(2.0014255, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 2.0149 - mse: 2.0665 - val_loss: 1.9862 - val_mse: 1.7805 - 35ms/epoch - 35ms/step\n",
      "iteration :14     Target train: tf.Tensor(1.9721817, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.9862 - mse: 2.0361 - val_loss: 1.9582 - val_mse: 1.7555 - 40ms/epoch - 40ms/step\n",
      "iteration :15     Target train: tf.Tensor(1.9435873, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.9582 - mse: 2.0063 - val_loss: 1.9309 - val_mse: 1.7311 - 26ms/epoch - 26ms/step\n",
      "iteration :16     Target train: tf.Tensor(1.9156504, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.9309 - mse: 1.9772 - val_loss: 1.9042 - val_mse: 1.7073 - 25ms/epoch - 25ms/step\n",
      "iteration :17     Target train: tf.Tensor(1.8883843, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.9042 - mse: 1.9488 - val_loss: 1.8782 - val_mse: 1.6840 - 27ms/epoch - 27ms/step\n",
      "iteration :18     Target train: tf.Tensor(1.8617496, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.8782 - mse: 1.9210 - val_loss: 1.8529 - val_mse: 1.6613 - 25ms/epoch - 25ms/step\n",
      "iteration :19     Target train: tf.Tensor(1.835728, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.8529 - mse: 1.8939 - val_loss: 1.8281 - val_mse: 1.6391 - 25ms/epoch - 25ms/step\n",
      "iteration :20     Target train: tf.Tensor(1.8102282, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.8281 - mse: 1.8673 - val_loss: 1.8039 - val_mse: 1.6175 - 28ms/epoch - 28ms/step\n",
      "iteration :21     Target train: tf.Tensor(1.7853007, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.8039 - mse: 1.8412 - val_loss: 1.7803 - val_mse: 1.5964 - 30ms/epoch - 30ms/step\n",
      "iteration :22     Target train: tf.Tensor(1.7609595, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.7803 - mse: 1.8158 - val_loss: 1.7573 - val_mse: 1.5759 - 27ms/epoch - 27ms/step\n",
      "iteration :23     Target train: tf.Tensor(1.7372161, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.7573 - mse: 1.7910 - val_loss: 1.7349 - val_mse: 1.5559 - 30ms/epoch - 30ms/step\n",
      "iteration :24     Target train: tf.Tensor(1.7140437, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.7349 - mse: 1.7668 - val_loss: 1.7131 - val_mse: 1.5363 - 29ms/epoch - 29ms/step\n",
      "iteration :25     Target train: tf.Tensor(1.691435, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.7131 - mse: 1.7431 - val_loss: 1.6919 - val_mse: 1.5172 - 27ms/epoch - 27ms/step\n",
      "iteration :26     Target train: tf.Tensor(1.6693645, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.6919 - mse: 1.7201 - val_loss: 1.6712 - val_mse: 1.4984 - 28ms/epoch - 28ms/step\n",
      "iteration :27     Target train: tf.Tensor(1.6477774, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.6712 - mse: 1.6976 - val_loss: 1.6510 - val_mse: 1.4800 - 28ms/epoch - 28ms/step\n",
      "iteration :28     Target train: tf.Tensor(1.6267145, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.6510 - mse: 1.6756 - val_loss: 1.6312 - val_mse: 1.4620 - 29ms/epoch - 29ms/step\n",
      "iteration :29     Target train: tf.Tensor(1.6061007, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.6312 - mse: 1.6541 - val_loss: 1.6120 - val_mse: 1.4445 - 28ms/epoch - 28ms/step\n",
      "iteration :30     Target train: tf.Tensor(1.5859866, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.6120 - mse: 1.6331 - val_loss: 1.5933 - val_mse: 1.4275 - 27ms/epoch - 27ms/step\n",
      "iteration :31     Target train: tf.Tensor(1.5663652, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.5933 - mse: 1.6127 - val_loss: 1.5750 - val_mse: 1.4108 - 26ms/epoch - 26ms/step\n",
      "iteration :32     Target train: tf.Tensor(1.5472248, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.5750 - mse: 1.5927 - val_loss: 1.5573 - val_mse: 1.3946 - 33ms/epoch - 33ms/step\n",
      "iteration :33     Target train: tf.Tensor(1.5285534, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.5573 - mse: 1.5732 - val_loss: 1.5400 - val_mse: 1.3788 - 28ms/epoch - 28ms/step\n",
      "iteration :34     Target train: tf.Tensor(1.5103401, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.5400 - mse: 1.5542 - val_loss: 1.5231 - val_mse: 1.3634 - 28ms/epoch - 28ms/step\n",
      "iteration :35     Target train: tf.Tensor(1.4925183, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.5231 - mse: 1.5356 - val_loss: 1.5066 - val_mse: 1.3484 - 27ms/epoch - 27ms/step\n",
      "iteration :36     Target train: tf.Tensor(1.4750887, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.5066 - mse: 1.5173 - val_loss: 1.4904 - val_mse: 1.3336 - 28ms/epoch - 28ms/step\n",
      "iteration :37     Target train: tf.Tensor(1.4580148, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.4904 - mse: 1.4995 - val_loss: 1.4747 - val_mse: 1.3191 - 27ms/epoch - 27ms/step\n",
      "iteration :38     Target train: tf.Tensor(1.4413443, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.4747 - mse: 1.4821 - val_loss: 1.4594 - val_mse: 1.3053 - 27ms/epoch - 27ms/step\n",
      "iteration :39     Target train: tf.Tensor(1.4250909, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.4594 - mse: 1.4650 - val_loss: 1.4445 - val_mse: 1.2918 - 28ms/epoch - 28ms/step\n",
      "iteration :40     Target train: tf.Tensor(1.4092112, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.4445 - mse: 1.4483 - val_loss: 1.4299 - val_mse: 1.2787 - 28ms/epoch - 28ms/step\n",
      "iteration :41     Target train: tf.Tensor(1.3937126, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.4299 - mse: 1.4321 - val_loss: 1.4157 - val_mse: 1.2659 - 33ms/epoch - 33ms/step\n",
      "iteration :42     Target train: tf.Tensor(1.3785553, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.4157 - mse: 1.4161 - val_loss: 1.4019 - val_mse: 1.2534 - 28ms/epoch - 28ms/step\n",
      "iteration :43     Target train: tf.Tensor(1.3637536, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.4019 - mse: 1.4005 - val_loss: 1.3884 - val_mse: 1.2412 - 27ms/epoch - 27ms/step\n",
      "iteration :44     Target train: tf.Tensor(1.349284, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.3884 - mse: 1.3853 - val_loss: 1.3752 - val_mse: 1.2294 - 27ms/epoch - 27ms/step\n",
      "iteration :45     Target train: tf.Tensor(1.3351042, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.3752 - mse: 1.3704 - val_loss: 1.3623 - val_mse: 1.2178 - 29ms/epoch - 29ms/step\n",
      "iteration :46     Target train: tf.Tensor(1.3212316, shape=(), dtype=float32)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1/1 - 0s - loss: 1.3623 - mse: 1.3557 - val_loss: 1.3496 - val_mse: 1.2065 - 27ms/epoch - 27ms/step\n",
      "iteration :47     Target train: tf.Tensor(1.3076547, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.3496 - mse: 1.3414 - val_loss: 1.3373 - val_mse: 1.1952 - 31ms/epoch - 31ms/step\n",
      "iteration :48     Target train: tf.Tensor(1.2943317, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.3373 - mse: 1.3274 - val_loss: 1.3253 - val_mse: 1.1842 - 32ms/epoch - 32ms/step\n",
      "iteration :49     Target train: tf.Tensor(1.2813486, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.3253 - mse: 1.3137 - val_loss: 1.3135 - val_mse: 1.1735 - 32ms/epoch - 32ms/step\n",
      "iteration :50     Target train: tf.Tensor(1.268613, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.3135 - mse: 1.3003 - val_loss: 1.3019 - val_mse: 1.1631 - 41ms/epoch - 41ms/step\n",
      "iteration :51     Target train: tf.Tensor(1.2561136, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.3019 - mse: 1.2871 - val_loss: 1.2907 - val_mse: 1.1530 - 28ms/epoch - 28ms/step\n",
      "iteration :52     Target train: tf.Tensor(1.2438922, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.2907 - mse: 1.2742 - val_loss: 1.2797 - val_mse: 1.1431 - 29ms/epoch - 29ms/step\n",
      "iteration :53     Target train: tf.Tensor(1.231948, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.2797 - mse: 1.2616 - val_loss: 1.2689 - val_mse: 1.1334 - 30ms/epoch - 30ms/step\n",
      "iteration :54     Target train: tf.Tensor(1.2202593, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.2689 - mse: 1.2492 - val_loss: 1.2584 - val_mse: 1.1240 - 26ms/epoch - 26ms/step\n",
      "iteration :55     Target train: tf.Tensor(1.2087543, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.2584 - mse: 1.2370 - val_loss: 1.2480 - val_mse: 1.1148 - 27ms/epoch - 27ms/step\n",
      "iteration :56     Target train: tf.Tensor(1.1974968, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.2480 - mse: 1.2251 - val_loss: 1.2380 - val_mse: 1.1058 - 27ms/epoch - 27ms/step\n",
      "iteration :57     Target train: tf.Tensor(1.1864822, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.2380 - mse: 1.2134 - val_loss: 1.2281 - val_mse: 1.0970 - 30ms/epoch - 30ms/step\n",
      "iteration :58     Target train: tf.Tensor(1.1757059, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.2281 - mse: 1.2019 - val_loss: 1.2185 - val_mse: 1.0885 - 26ms/epoch - 26ms/step\n",
      "iteration :59     Target train: tf.Tensor(1.1651629, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.2185 - mse: 1.1907 - val_loss: 1.2091 - val_mse: 1.0801 - 30ms/epoch - 30ms/step\n",
      "iteration :60     Target train: tf.Tensor(1.1548457, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.2091 - mse: 1.1798 - val_loss: 1.1999 - val_mse: 1.0719 - 29ms/epoch - 29ms/step\n",
      "iteration :61     Target train: tf.Tensor(1.1447518, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.1999 - mse: 1.1690 - val_loss: 1.1910 - val_mse: 1.0639 - 27ms/epoch - 27ms/step\n",
      "iteration :62     Target train: tf.Tensor(1.134876, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.1910 - mse: 1.1585 - val_loss: 1.1822 - val_mse: 1.0561 - 24ms/epoch - 24ms/step\n",
      "iteration :63     Target train: tf.Tensor(1.1252154, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.1822 - mse: 1.1483 - val_loss: 1.1736 - val_mse: 1.0485 - 24ms/epoch - 24ms/step\n",
      "iteration :64     Target train: tf.Tensor(1.115768, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.1736 - mse: 1.1382 - val_loss: 1.1652 - val_mse: 1.0410 - 26ms/epoch - 26ms/step\n",
      "iteration :65     Target train: tf.Tensor(1.106485, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.1652 - mse: 1.1283 - val_loss: 1.1570 - val_mse: 1.0337 - 27ms/epoch - 27ms/step\n",
      "iteration :66     Target train: tf.Tensor(1.0974035, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.1570 - mse: 1.1186 - val_loss: 1.1490 - val_mse: 1.0267 - 25ms/epoch - 25ms/step\n",
      "iteration :67     Target train: tf.Tensor(1.0885365, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.1490 - mse: 1.1092 - val_loss: 1.1412 - val_mse: 1.0198 - 28ms/epoch - 28ms/step\n",
      "iteration :68     Target train: tf.Tensor(1.0798938, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.1412 - mse: 1.0999 - val_loss: 1.1335 - val_mse: 1.0131 - 27ms/epoch - 27ms/step\n",
      "iteration :69     Target train: tf.Tensor(1.0714372, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.1335 - mse: 1.0909 - val_loss: 1.1261 - val_mse: 1.0065 - 24ms/epoch - 24ms/step\n",
      "iteration :70     Target train: tf.Tensor(1.063154, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.1261 - mse: 1.0820 - val_loss: 1.1188 - val_mse: 1.0001 - 27ms/epoch - 27ms/step\n",
      "iteration :71     Target train: tf.Tensor(1.0550473, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.1188 - mse: 1.0734 - val_loss: 1.1116 - val_mse: 0.9938 - 27ms/epoch - 27ms/step\n",
      "iteration :72     Target train: tf.Tensor(1.0471159, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.1116 - mse: 1.0649 - val_loss: 1.1046 - val_mse: 0.9877 - 27ms/epoch - 27ms/step\n",
      "iteration :73     Target train: tf.Tensor(1.0393398, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.1046 - mse: 1.0566 - val_loss: 1.0977 - val_mse: 0.9816 - 24ms/epoch - 24ms/step\n",
      "iteration :74     Target train: tf.Tensor(1.0317191, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.0977 - mse: 1.0484 - val_loss: 1.0910 - val_mse: 0.9757 - 24ms/epoch - 24ms/step\n",
      "iteration :75     Target train: tf.Tensor(1.0242401, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.0910 - mse: 1.0404 - val_loss: 1.0843 - val_mse: 0.9698 - 24ms/epoch - 24ms/step\n",
      "iteration :76     Target train: tf.Tensor(1.0168221, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.0843 - mse: 1.0325 - val_loss: 1.0777 - val_mse: 0.9641 - 25ms/epoch - 25ms/step\n",
      "iteration :77     Target train: tf.Tensor(1.0095366, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.0777 - mse: 1.0247 - val_loss: 1.0713 - val_mse: 0.9585 - 27ms/epoch - 27ms/step\n",
      "iteration :78     Target train: tf.Tensor(1.0023862, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.0713 - mse: 1.0170 - val_loss: 1.0650 - val_mse: 0.9530 - 23ms/epoch - 23ms/step\n",
      "iteration :79     Target train: tf.Tensor(0.9953687, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.0650 - mse: 1.0095 - val_loss: 1.0588 - val_mse: 0.9476 - 23ms/epoch - 23ms/step\n",
      "iteration :80     Target train: tf.Tensor(0.9884816, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.0588 - mse: 1.0021 - val_loss: 1.0527 - val_mse: 0.9423 - 24ms/epoch - 24ms/step\n",
      "iteration :81     Target train: tf.Tensor(0.98170245, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.0527 - mse: 0.9948 - val_loss: 1.0467 - val_mse: 0.9371 - 23ms/epoch - 23ms/step\n",
      "iteration :82     Target train: tf.Tensor(0.97504187, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.0467 - mse: 0.9877 - val_loss: 1.0408 - val_mse: 0.9320 - 26ms/epoch - 26ms/step\n",
      "iteration :83     Target train: tf.Tensor(0.96850115, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.0408 - mse: 0.9807 - val_loss: 1.0350 - val_mse: 0.9270 - 25ms/epoch - 25ms/step\n",
      "iteration :84     Target train: tf.Tensor(0.9620749, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.0350 - mse: 0.9738 - val_loss: 1.0293 - val_mse: 0.9221 - 26ms/epoch - 26ms/step\n",
      "iteration :85     Target train: tf.Tensor(0.9557637, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.0293 - mse: 0.9670 - val_loss: 1.0237 - val_mse: 0.9173 - 26ms/epoch - 26ms/step\n",
      "iteration :86     Target train: tf.Tensor(0.94957024, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.0237 - mse: 0.9603 - val_loss: 1.0183 - val_mse: 0.9126 - 29ms/epoch - 29ms/step\n",
      "iteration :87     Target train: tf.Tensor(0.9434867, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.0183 - mse: 0.9538 - val_loss: 1.0129 - val_mse: 0.9080 - 26ms/epoch - 26ms/step\n",
      "iteration :88     Target train: tf.Tensor(0.93751705, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.0129 - mse: 0.9474 - val_loss: 1.0076 - val_mse: 0.9035 - 29ms/epoch - 29ms/step\n",
      "iteration :89     Target train: tf.Tensor(0.9316647, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.0076 - mse: 0.9410 - val_loss: 1.0025 - val_mse: 0.8991 - 32ms/epoch - 32ms/step\n",
      "iteration :90     Target train: tf.Tensor(0.92592186, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 1.0025 - mse: 0.9349 - val_loss: 0.9974 - val_mse: 0.8948 - 27ms/epoch - 27ms/step\n",
      "iteration :91     Target train: tf.Tensor(0.92028475, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.9974 - mse: 0.9288 - val_loss: 0.9924 - val_mse: 0.8906 - 25ms/epoch - 25ms/step\n",
      "iteration :92     Target train: tf.Tensor(0.91475976, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.9924 - mse: 0.9228 - val_loss: 0.9875 - val_mse: 0.8865 - 26ms/epoch - 26ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "iteration :93     Target train: tf.Tensor(0.90935254, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.9875 - mse: 0.9170 - val_loss: 0.9827 - val_mse: 0.8824 - 26ms/epoch - 26ms/step\n",
      "iteration :94     Target train: tf.Tensor(0.9040424, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.9827 - mse: 0.9113 - val_loss: 0.9780 - val_mse: 0.8784 - 24ms/epoch - 24ms/step\n",
      "iteration :95     Target train: tf.Tensor(0.8988255, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.9780 - mse: 0.9056 - val_loss: 0.9734 - val_mse: 0.8744 - 31ms/epoch - 31ms/step\n",
      "iteration :96     Target train: tf.Tensor(0.893694, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.9734 - mse: 0.9001 - val_loss: 0.9688 - val_mse: 0.8706 - 29ms/epoch - 29ms/step\n",
      "iteration :97     Target train: tf.Tensor(0.888651, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.9688 - mse: 0.8947 - val_loss: 0.9644 - val_mse: 0.8667 - 24ms/epoch - 24ms/step\n",
      "iteration :98     Target train: tf.Tensor(0.8836908, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.9644 - mse: 0.8893 - val_loss: 0.9599 - val_mse: 0.8629 - 25ms/epoch - 25ms/step\n",
      "iteration :99     Target train: tf.Tensor(0.87880886, shape=(), dtype=float32)\n",
      "1/1 - 0s - loss: 0.9599 - mse: 0.8841 - val_loss: 0.9556 - val_mse: 0.8592 - 24ms/epoch - 24ms/step\n",
      "5.851686477661133\n"
     ]
    }
   ],
   "source": [
    "t0 = time.time()\n",
    "for i in range(100):\n",
    "    Num = 204 #number of training target data\n",
    "     # Access the layers\n",
    "    input_layer_weights = final_model.layers[1].trainable_weights[0]  # weight matrix only\n",
    "    output_layer_weights = final_model.layers[-1].trainable_weights[0]\n",
    "    \n",
    "    #prediction performance on the target training set\n",
    "    NN_out = final_model(RNN_input_final_Train) \n",
    "    loss11 =  tf.math.reduce_mean((NN_out[:Num,:]-RNN_output_final_Train[:Num,:])**2) # prediction on target\n",
    "    print(\"iteration :\" + str(i) + \"     Target train: \" + str(loss11))\n",
    "    \n",
    "    #history = final_model.fit(RNN_input_final_Train, RNN_output_final_Train, epochs=1, batch_size=256, validation_split=0.25, verbose=2)\n",
    "    history = final_model.fit(X_train, Y_train, epochs=1, batch_size=256, validation_split=0.25, verbose=2)\n",
    "    i += 1\n",
    "\n",
    "t1 = time.time()\n",
    "print(t1 - t0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "8f14a2c7",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Target train:  tf.Tensor(0.8740129, shape=(), dtype=float32)\n",
      "Target test:  tf.Tensor(0.9378572, 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": 17,
   "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": 18,
   "id": "b90b3b96",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Weights (kernel_P1):\n",
      " [array([[ 0.9182476 , -0.05884515,  0.        ,  0.        ],\n",
      "       [-0.06949829,  0.93406886,  0.        ,  0.        ]],\n",
      "      dtype=float32)]\n",
      "Weights (kernel_P2):\n",
      " [array([[ 0.91845953, -0.06069899,  0.        ,  0.        ],\n",
      "       [-0.06779256,  0.9336907 ,  0.        ,  0.        ],\n",
      "       [ 0.        ,  0.        ,  1.        ,  0.        ],\n",
      "       [ 0.        ,  0.        ,  0.        ,  1.        ]],\n",
      "      dtype=float32)]\n",
      "Weights (kernel_P3):\n",
      " [array([[ 0.91858125, -0.06243801],\n",
      "       [-0.06601121,  0.9329436 ],\n",
      "       [ 0.        ,  0.        ],\n",
      "       [ 0.        ,  0.        ]], dtype=float32)]\n"
     ]
    }
   ],
   "source": [
    "#calculate the output layers\n",
    "# Get first layer\n",
    "layer_P1 = final_model.layers[-3]\n",
    "# Get weights\n",
    "weights_P1 = layer_P1.get_weights()\n",
    "\n",
    "# Get first layer\n",
    "layer_P2 = final_model.layers[-2]\n",
    "# Get weights\n",
    "weights_P2 = layer_P2.get_weights()\n",
    "\n",
    "# Get first layer\n",
    "layer_P3 = final_model.layers[-1]\n",
    "# Get weights\n",
    "weights_P3 = layer_P3.get_weights()\n",
    "\n",
    "print(\"Weights (kernel_P1):\\n\", weights_P1)\n",
    "print(\"Weights (kernel_P2):\\n\", weights_P2)\n",
    "print(\"Weights (kernel_P3):\\n\", weights_P3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "e2032c68",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Weights (kernel_I1):\n",
      " [[ 0.9196388  -0.10020918 -0.04904287  0.          0.          0.\n",
      "   0.          0.        ]\n",
      " [ 0.06874309  1.082952    0.05919157  0.          0.          0.\n",
      "   0.          0.        ]\n",
      " [ 0.06881922  0.0840028   1.0577184   0.          0.          0.\n",
      "   0.          0.        ]]\n",
      "Weights (kernel_I2):\n",
      " [[ 0.9210439  -0.0921265   0.03756375  0.          0.          0.\n",
      "   0.          0.        ]\n",
      " [ 0.0743531   1.0816096  -0.01652548  0.          0.          0.\n",
      "   0.          0.        ]\n",
      " [ 0.07151941  0.0778973   0.98032933  0.          0.          0.\n",
      "   0.          0.        ]\n",
      " [ 0.          0.          0.          1.          0.          0.\n",
      "   0.          0.        ]\n",
      " [ 0.          0.          0.          0.          1.          0.\n",
      "   0.          0.        ]\n",
      " [ 0.          0.          0.          0.          0.          1.\n",
      "   0.          0.        ]\n",
      " [ 0.          0.          0.          0.          0.          0.\n",
      "   1.          0.        ]\n",
      " [ 0.          0.          0.          0.          0.          0.\n",
      "   0.          1.        ]]\n",
      "Weights (kernel_I3):\n",
      " [[ 0.9232742  -0.07993355  0.08468329]\n",
      " [ 0.07940523  1.0705732  -0.09112123]\n",
      " [ 0.07050523  0.05877202  0.91760284]\n",
      " [ 0.          0.          0.        ]\n",
      " [ 0.          0.          0.        ]\n",
      " [ 0.          0.          0.        ]\n",
      " [ 0.          0.          0.        ]\n",
      " [ 0.          0.          0.        ]]\n",
      "Weights (kernel_P1):\n",
      " [[ 0.9182476  -0.05884515  0.          0.        ]\n",
      " [-0.06949829  0.93406886  0.          0.        ]]\n",
      "Weights (kernel_P2):\n",
      " [[ 0.91845953 -0.06069899  0.          0.        ]\n",
      " [-0.06779256  0.9336907   0.          0.        ]\n",
      " [ 0.          0.          1.          0.        ]\n",
      " [ 0.          0.          0.          1.        ]]\n",
      "Weights (kernel_P3):\n",
      " [[ 0.91858125 -0.06243801]\n",
      " [-0.06601121  0.9329436 ]\n",
      " [ 0.          0.        ]\n",
      " [ 0.          0.        ]]\n",
      "Weights Final input P:\n",
      " [[ 0.75544655 -0.27835667  0.07784723]\n",
      " [ 0.23259343  1.2428268  -0.05484348]\n",
      " [ 0.22057793  0.22809018  0.94966555]]\n",
      "Weights Final output Q:\n",
      " [[ 0.78567743 -0.15616572]\n",
      " [-0.17465046  0.82552433]]\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": 20,
   "id": "409049a8",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Step 2: Freeze the original model's weights\n",
    "for layer in model.layers:\n",
    "    layer.trainable = False\n",
    "\n",
    "# Step 3: Create new layers\n",
    "input_layer = Input(shape=(3))  # Replace input_dim with your actual input feature dimension\n",
    "new_input_layer = Dense(3, activation='linear', use_bias=False)  # New front layer\n",
    "\n",
    "# Connect the frozen original model\n",
    "x = model(new_input_layer(input_layer))\n",
    "\n",
    "# Add new output layer\n",
    "new_output_layer = Dense(2, activation='linear', use_bias=False)  # Replace output_dim with your desired final output size\n",
    "\n",
    "output = new_output_layer(x)\n",
    "# Step 4: Assemble final model\n",
    "final_model_PQ = Model(inputs=input_layer, outputs=output)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "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": 22,
   "id": "be147352",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Model: \"model_1\"\n",
      "_________________________________________________________________\n",
      " Layer (type)                Output Shape              Param #   \n",
      "=================================================================\n",
      " input_2 (InputLayer)        [(None, 3)]               0         \n",
      "                                                                 \n",
      " dense_8 (Dense)             (None, 3)                 9         \n",
      "                                                                 \n",
      " sequential_1 (Sequential)   (None, 2)                 98        \n",
      "                                                                 \n",
      " dense_9 (Dense)             (None, 2)                 4         \n",
      "                                                                 \n",
      "=================================================================\n",
      "Total params: 111\n",
      "Trainable params: 111\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": 23,
   "id": "55fbdca2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/400\n",
      "1/1 - 0s - loss: 0.8790 - mse: 0.8790 - val_loss: 0.8392 - val_mse: 0.8392 - 199ms/epoch - 199ms/step\n",
      "Epoch 2/400\n",
      "1/1 - 0s - loss: 0.8586 - mse: 0.8586 - val_loss: 0.8199 - val_mse: 0.8199 - 12ms/epoch - 12ms/step\n",
      "Epoch 3/400\n",
      "1/1 - 0s - loss: 0.8387 - mse: 0.8387 - val_loss: 0.8012 - val_mse: 0.8012 - 12ms/epoch - 12ms/step\n",
      "Epoch 4/400\n",
      "1/1 - 0s - loss: 0.8194 - mse: 0.8194 - val_loss: 0.7829 - val_mse: 0.7829 - 13ms/epoch - 13ms/step\n",
      "Epoch 5/400\n",
      "1/1 - 0s - loss: 0.8006 - mse: 0.8006 - val_loss: 0.7651 - val_mse: 0.7651 - 14ms/epoch - 14ms/step\n",
      "Epoch 6/400\n",
      "1/1 - 0s - loss: 0.7823 - mse: 0.7823 - val_loss: 0.7477 - val_mse: 0.7477 - 17ms/epoch - 17ms/step\n",
      "Epoch 7/400\n",
      "1/1 - 0s - loss: 0.7646 - mse: 0.7646 - val_loss: 0.7308 - val_mse: 0.7308 - 16ms/epoch - 16ms/step\n",
      "Epoch 8/400\n",
      "1/1 - 0s - loss: 0.7474 - mse: 0.7474 - val_loss: 0.7144 - val_mse: 0.7144 - 16ms/epoch - 16ms/step\n",
      "Epoch 9/400\n",
      "1/1 - 0s - loss: 0.7306 - mse: 0.7306 - val_loss: 0.6985 - val_mse: 0.6985 - 16ms/epoch - 16ms/step\n",
      "Epoch 10/400\n",
      "1/1 - 0s - loss: 0.7144 - mse: 0.7144 - val_loss: 0.6830 - val_mse: 0.6830 - 15ms/epoch - 15ms/step\n",
      "Epoch 11/400\n",
      "1/1 - 0s - loss: 0.6987 - mse: 0.6987 - val_loss: 0.6681 - val_mse: 0.6681 - 16ms/epoch - 16ms/step\n",
      "Epoch 12/400\n",
      "1/1 - 0s - loss: 0.6835 - mse: 0.6835 - val_loss: 0.6536 - val_mse: 0.6536 - 16ms/epoch - 16ms/step\n",
      "Epoch 13/400\n",
      "1/1 - 0s - loss: 0.6688 - mse: 0.6688 - val_loss: 0.6396 - val_mse: 0.6396 - 15ms/epoch - 15ms/step\n",
      "Epoch 14/400\n",
      "1/1 - 0s - loss: 0.6546 - mse: 0.6546 - val_loss: 0.6261 - val_mse: 0.6261 - 16ms/epoch - 16ms/step\n",
      "Epoch 15/400\n",
      "1/1 - 0s - loss: 0.6407 - mse: 0.6407 - val_loss: 0.6131 - val_mse: 0.6131 - 16ms/epoch - 16ms/step\n",
      "Epoch 16/400\n",
      "1/1 - 0s - loss: 0.6274 - mse: 0.6274 - val_loss: 0.6005 - val_mse: 0.6005 - 16ms/epoch - 16ms/step\n",
      "Epoch 17/400\n",
      "1/1 - 0s - loss: 0.6145 - mse: 0.6145 - val_loss: 0.5883 - val_mse: 0.5883 - 15ms/epoch - 15ms/step\n",
      "Epoch 18/400\n",
      "1/1 - 0s - loss: 0.6020 - mse: 0.6020 - val_loss: 0.5766 - val_mse: 0.5766 - 16ms/epoch - 16ms/step\n",
      "Epoch 19/400\n",
      "1/1 - 0s - loss: 0.5899 - mse: 0.5899 - val_loss: 0.5654 - val_mse: 0.5654 - 16ms/epoch - 16ms/step\n",
      "Epoch 20/400\n",
      "1/1 - 0s - loss: 0.5782 - mse: 0.5782 - val_loss: 0.5546 - val_mse: 0.5546 - 16ms/epoch - 16ms/step\n",
      "Epoch 21/400\n",
      "1/1 - 0s - loss: 0.5668 - mse: 0.5668 - val_loss: 0.5442 - val_mse: 0.5442 - 15ms/epoch - 15ms/step\n",
      "Epoch 22/400\n",
      "1/1 - 0s - loss: 0.5559 - mse: 0.5559 - val_loss: 0.5342 - val_mse: 0.5342 - 15ms/epoch - 15ms/step\n",
      "Epoch 23/400\n",
      "1/1 - 0s - loss: 0.5453 - mse: 0.5453 - val_loss: 0.5245 - val_mse: 0.5245 - 15ms/epoch - 15ms/step\n",
      "Epoch 24/400\n",
      "1/1 - 0s - loss: 0.5351 - mse: 0.5351 - val_loss: 0.5153 - val_mse: 0.5153 - 15ms/epoch - 15ms/step\n",
      "Epoch 25/400\n",
      "1/1 - 0s - loss: 0.5252 - mse: 0.5252 - val_loss: 0.5063 - val_mse: 0.5063 - 15ms/epoch - 15ms/step\n",
      "Epoch 26/400\n",
      "1/1 - 0s - loss: 0.5156 - mse: 0.5156 - val_loss: 0.4977 - val_mse: 0.4977 - 16ms/epoch - 16ms/step\n",
      "Epoch 27/400\n",
      "1/1 - 0s - loss: 0.5064 - mse: 0.5064 - val_loss: 0.4894 - val_mse: 0.4894 - 15ms/epoch - 15ms/step\n",
      "Epoch 28/400\n",
      "1/1 - 0s - loss: 0.4974 - mse: 0.4974 - val_loss: 0.4814 - val_mse: 0.4814 - 15ms/epoch - 15ms/step\n",
      "Epoch 29/400\n",
      "1/1 - 0s - loss: 0.4887 - mse: 0.4887 - val_loss: 0.4737 - val_mse: 0.4737 - 14ms/epoch - 14ms/step\n",
      "Epoch 30/400\n",
      "1/1 - 0s - loss: 0.4804 - mse: 0.4804 - val_loss: 0.4662 - val_mse: 0.4662 - 15ms/epoch - 15ms/step\n",
      "Epoch 31/400\n",
      "1/1 - 0s - loss: 0.4722 - mse: 0.4722 - val_loss: 0.4591 - val_mse: 0.4591 - 16ms/epoch - 16ms/step\n",
      "Epoch 32/400\n",
      "1/1 - 0s - loss: 0.4644 - mse: 0.4644 - val_loss: 0.4521 - val_mse: 0.4521 - 16ms/epoch - 16ms/step\n",
      "Epoch 33/400\n",
      "1/1 - 0s - loss: 0.4568 - mse: 0.4568 - val_loss: 0.4454 - val_mse: 0.4454 - 15ms/epoch - 15ms/step\n",
      "Epoch 34/400\n",
      "1/1 - 0s - loss: 0.4494 - mse: 0.4494 - val_loss: 0.4390 - val_mse: 0.4390 - 16ms/epoch - 16ms/step\n",
      "Epoch 35/400\n",
      "1/1 - 0s - loss: 0.4422 - mse: 0.4422 - val_loss: 0.4327 - val_mse: 0.4327 - 15ms/epoch - 15ms/step\n",
      "Epoch 36/400\n",
      "1/1 - 0s - loss: 0.4352 - mse: 0.4352 - val_loss: 0.4266 - val_mse: 0.4266 - 15ms/epoch - 15ms/step\n",
      "Epoch 37/400\n",
      "1/1 - 0s - loss: 0.4285 - mse: 0.4285 - val_loss: 0.4208 - val_mse: 0.4208 - 15ms/epoch - 15ms/step\n",
      "Epoch 38/400\n",
      "1/1 - 0s - loss: 0.4219 - mse: 0.4219 - val_loss: 0.4150 - val_mse: 0.4150 - 15ms/epoch - 15ms/step\n",
      "Epoch 39/400\n",
      "1/1 - 0s - loss: 0.4155 - mse: 0.4155 - val_loss: 0.4093 - val_mse: 0.4093 - 15ms/epoch - 15ms/step\n",
      "Epoch 40/400\n",
      "1/1 - 0s - loss: 0.4093 - mse: 0.4093 - val_loss: 0.4038 - val_mse: 0.4038 - 15ms/epoch - 15ms/step\n",
      "Epoch 41/400\n",
      "1/1 - 0s - loss: 0.4033 - mse: 0.4033 - val_loss: 0.3984 - val_mse: 0.3984 - 15ms/epoch - 15ms/step\n",
      "Epoch 42/400\n",
      "1/1 - 0s - loss: 0.3974 - mse: 0.3974 - val_loss: 0.3932 - val_mse: 0.3932 - 14ms/epoch - 14ms/step\n",
      "Epoch 43/400\n",
      "1/1 - 0s - loss: 0.3917 - mse: 0.3917 - val_loss: 0.3881 - val_mse: 0.3881 - 15ms/epoch - 15ms/step\n",
      "Epoch 44/400\n",
      "1/1 - 0s - loss: 0.3861 - mse: 0.3861 - val_loss: 0.3831 - val_mse: 0.3831 - 16ms/epoch - 16ms/step\n",
      "Epoch 45/400\n",
      "1/1 - 0s - loss: 0.3807 - mse: 0.3807 - val_loss: 0.3782 - val_mse: 0.3782 - 16ms/epoch - 16ms/step\n",
      "Epoch 46/400\n",
      "1/1 - 0s - loss: 0.3754 - mse: 0.3754 - val_loss: 0.3735 - val_mse: 0.3735 - 15ms/epoch - 15ms/step\n",
      "Epoch 47/400\n",
      "1/1 - 0s - loss: 0.3702 - mse: 0.3702 - val_loss: 0.3688 - val_mse: 0.3688 - 15ms/epoch - 15ms/step\n",
      "Epoch 48/400\n",
      "1/1 - 0s - loss: 0.3652 - mse: 0.3652 - val_loss: 0.3642 - val_mse: 0.3642 - 15ms/epoch - 15ms/step\n",
      "Epoch 49/400\n",
      "1/1 - 0s - loss: 0.3602 - mse: 0.3602 - val_loss: 0.3597 - val_mse: 0.3597 - 15ms/epoch - 15ms/step\n",
      "Epoch 50/400\n",
      "1/1 - 0s - loss: 0.3554 - mse: 0.3554 - val_loss: 0.3553 - val_mse: 0.3553 - 16ms/epoch - 16ms/step\n",
      "Epoch 51/400\n",
      "1/1 - 0s - loss: 0.3507 - mse: 0.3507 - val_loss: 0.3510 - val_mse: 0.3510 - 16ms/epoch - 16ms/step\n",
      "Epoch 52/400\n",
      "1/1 - 0s - loss: 0.3460 - mse: 0.3460 - val_loss: 0.3468 - val_mse: 0.3468 - 15ms/epoch - 15ms/step\n",
      "Epoch 53/400\n",
      "1/1 - 0s - loss: 0.3415 - mse: 0.3415 - val_loss: 0.3427 - val_mse: 0.3427 - 15ms/epoch - 15ms/step\n",
      "Epoch 54/400\n",
      "1/1 - 0s - loss: 0.3371 - mse: 0.3371 - val_loss: 0.3387 - val_mse: 0.3387 - 15ms/epoch - 15ms/step\n",
      "Epoch 55/400\n",
      "1/1 - 0s - loss: 0.3327 - mse: 0.3327 - val_loss: 0.3347 - val_mse: 0.3347 - 15ms/epoch - 15ms/step\n",
      "Epoch 56/400\n",
      "1/1 - 0s - loss: 0.3285 - mse: 0.3285 - val_loss: 0.3308 - val_mse: 0.3308 - 14ms/epoch - 14ms/step\n",
      "Epoch 57/400\n",
      "1/1 - 0s - loss: 0.3243 - mse: 0.3243 - val_loss: 0.3269 - val_mse: 0.3269 - 13ms/epoch - 13ms/step\n",
      "Epoch 58/400\n",
      "1/1 - 0s - loss: 0.3202 - mse: 0.3202 - val_loss: 0.3232 - val_mse: 0.3232 - 14ms/epoch - 14ms/step\n",
      "Epoch 59/400\n",
      "1/1 - 0s - loss: 0.3161 - mse: 0.3161 - val_loss: 0.3194 - val_mse: 0.3194 - 14ms/epoch - 14ms/step\n",
      "Epoch 60/400\n",
      "1/1 - 0s - loss: 0.3121 - mse: 0.3121 - val_loss: 0.3158 - val_mse: 0.3158 - 14ms/epoch - 14ms/step\n",
      "Epoch 61/400\n",
      "1/1 - 0s - loss: 0.3082 - mse: 0.3082 - val_loss: 0.3121 - val_mse: 0.3121 - 16ms/epoch - 16ms/step\n",
      "Epoch 62/400\n",
      "1/1 - 0s - loss: 0.3043 - mse: 0.3043 - val_loss: 0.3086 - val_mse: 0.3086 - 16ms/epoch - 16ms/step\n",
      "Epoch 63/400\n",
      "1/1 - 0s - loss: 0.3005 - mse: 0.3005 - val_loss: 0.3051 - val_mse: 0.3051 - 14ms/epoch - 14ms/step\n",
      "Epoch 64/400\n",
      "1/1 - 0s - loss: 0.2968 - mse: 0.2968 - val_loss: 0.3016 - val_mse: 0.3016 - 15ms/epoch - 15ms/step\n",
      "Epoch 65/400\n",
      "1/1 - 0s - loss: 0.2932 - mse: 0.2932 - val_loss: 0.2982 - val_mse: 0.2982 - 14ms/epoch - 14ms/step\n",
      "Epoch 66/400\n",
      "1/1 - 0s - loss: 0.2896 - mse: 0.2896 - val_loss: 0.2948 - val_mse: 0.2948 - 14ms/epoch - 14ms/step\n",
      "Epoch 67/400\n",
      "1/1 - 0s - loss: 0.2860 - mse: 0.2860 - val_loss: 0.2914 - val_mse: 0.2914 - 14ms/epoch - 14ms/step\n",
      "Epoch 68/400\n",
      "1/1 - 0s - loss: 0.2825 - mse: 0.2825 - val_loss: 0.2881 - val_mse: 0.2881 - 14ms/epoch - 14ms/step\n",
      "Epoch 69/400\n",
      "1/1 - 0s - loss: 0.2791 - mse: 0.2791 - val_loss: 0.2848 - val_mse: 0.2848 - 15ms/epoch - 15ms/step\n",
      "Epoch 70/400\n",
      "1/1 - 0s - loss: 0.2757 - mse: 0.2757 - val_loss: 0.2816 - val_mse: 0.2816 - 15ms/epoch - 15ms/step\n",
      "Epoch 71/400\n",
      "1/1 - 0s - loss: 0.2723 - mse: 0.2723 - val_loss: 0.2783 - val_mse: 0.2783 - 15ms/epoch - 15ms/step\n",
      "Epoch 72/400\n",
      "1/1 - 0s - loss: 0.2690 - mse: 0.2690 - val_loss: 0.2752 - val_mse: 0.2752 - 15ms/epoch - 15ms/step\n",
      "Epoch 73/400\n",
      "1/1 - 0s - loss: 0.2658 - mse: 0.2658 - val_loss: 0.2720 - val_mse: 0.2720 - 14ms/epoch - 14ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 74/400\n",
      "1/1 - 0s - loss: 0.2626 - mse: 0.2626 - val_loss: 0.2689 - val_mse: 0.2689 - 13ms/epoch - 13ms/step\n",
      "Epoch 75/400\n",
      "1/1 - 0s - loss: 0.2594 - mse: 0.2594 - val_loss: 0.2658 - val_mse: 0.2658 - 14ms/epoch - 14ms/step\n",
      "Epoch 76/400\n",
      "1/1 - 0s - loss: 0.2563 - mse: 0.2563 - val_loss: 0.2628 - val_mse: 0.2628 - 14ms/epoch - 14ms/step\n",
      "Epoch 77/400\n",
      "1/1 - 0s - loss: 0.2532 - mse: 0.2532 - val_loss: 0.2598 - val_mse: 0.2598 - 15ms/epoch - 15ms/step\n",
      "Epoch 78/400\n",
      "1/1 - 0s - loss: 0.2502 - mse: 0.2502 - val_loss: 0.2569 - val_mse: 0.2569 - 14ms/epoch - 14ms/step\n",
      "Epoch 79/400\n",
      "1/1 - 0s - loss: 0.2472 - mse: 0.2472 - val_loss: 0.2539 - val_mse: 0.2539 - 14ms/epoch - 14ms/step\n",
      "Epoch 80/400\n",
      "1/1 - 0s - loss: 0.2443 - mse: 0.2443 - val_loss: 0.2511 - val_mse: 0.2511 - 14ms/epoch - 14ms/step\n",
      "Epoch 81/400\n",
      "1/1 - 0s - loss: 0.2414 - mse: 0.2414 - val_loss: 0.2482 - val_mse: 0.2482 - 13ms/epoch - 13ms/step\n",
      "Epoch 82/400\n",
      "1/1 - 0s - loss: 0.2386 - mse: 0.2386 - val_loss: 0.2454 - val_mse: 0.2454 - 14ms/epoch - 14ms/step\n",
      "Epoch 83/400\n",
      "1/1 - 0s - loss: 0.2358 - mse: 0.2358 - val_loss: 0.2426 - val_mse: 0.2426 - 14ms/epoch - 14ms/step\n",
      "Epoch 84/400\n",
      "1/1 - 0s - loss: 0.2330 - mse: 0.2330 - val_loss: 0.2399 - val_mse: 0.2399 - 15ms/epoch - 15ms/step\n",
      "Epoch 85/400\n",
      "1/1 - 0s - loss: 0.2302 - mse: 0.2302 - val_loss: 0.2372 - val_mse: 0.2372 - 14ms/epoch - 14ms/step\n",
      "Epoch 86/400\n",
      "1/1 - 0s - loss: 0.2275 - mse: 0.2275 - val_loss: 0.2346 - val_mse: 0.2346 - 13ms/epoch - 13ms/step\n",
      "Epoch 87/400\n",
      "1/1 - 0s - loss: 0.2249 - mse: 0.2249 - val_loss: 0.2319 - val_mse: 0.2319 - 13ms/epoch - 13ms/step\n",
      "Epoch 88/400\n",
      "1/1 - 0s - loss: 0.2222 - mse: 0.2222 - val_loss: 0.2294 - val_mse: 0.2294 - 13ms/epoch - 13ms/step\n",
      "Epoch 89/400\n",
      "1/1 - 0s - loss: 0.2196 - mse: 0.2196 - val_loss: 0.2268 - val_mse: 0.2268 - 14ms/epoch - 14ms/step\n",
      "Epoch 90/400\n",
      "1/1 - 0s - loss: 0.2171 - mse: 0.2171 - val_loss: 0.2243 - val_mse: 0.2243 - 14ms/epoch - 14ms/step\n",
      "Epoch 91/400\n",
      "1/1 - 0s - loss: 0.2145 - mse: 0.2145 - val_loss: 0.2218 - val_mse: 0.2218 - 14ms/epoch - 14ms/step\n",
      "Epoch 92/400\n",
      "1/1 - 0s - loss: 0.2120 - mse: 0.2120 - val_loss: 0.2194 - val_mse: 0.2194 - 14ms/epoch - 14ms/step\n",
      "Epoch 93/400\n",
      "1/1 - 0s - loss: 0.2096 - mse: 0.2096 - val_loss: 0.2169 - val_mse: 0.2169 - 13ms/epoch - 13ms/step\n",
      "Epoch 94/400\n",
      "1/1 - 0s - loss: 0.2071 - mse: 0.2071 - val_loss: 0.2146 - val_mse: 0.2146 - 14ms/epoch - 14ms/step\n",
      "Epoch 95/400\n",
      "1/1 - 0s - loss: 0.2047 - mse: 0.2047 - val_loss: 0.2122 - val_mse: 0.2122 - 14ms/epoch - 14ms/step\n",
      "Epoch 96/400\n",
      "1/1 - 0s - loss: 0.2024 - mse: 0.2024 - val_loss: 0.2099 - val_mse: 0.2099 - 14ms/epoch - 14ms/step\n",
      "Epoch 97/400\n",
      "1/1 - 0s - loss: 0.2000 - mse: 0.2000 - val_loss: 0.2076 - val_mse: 0.2076 - 16ms/epoch - 16ms/step\n",
      "Epoch 98/400\n",
      "1/1 - 0s - loss: 0.1977 - mse: 0.1977 - val_loss: 0.2053 - val_mse: 0.2053 - 14ms/epoch - 14ms/step\n",
      "Epoch 99/400\n",
      "1/1 - 0s - loss: 0.1954 - mse: 0.1954 - val_loss: 0.2030 - val_mse: 0.2030 - 15ms/epoch - 15ms/step\n",
      "Epoch 100/400\n",
      "1/1 - 0s - loss: 0.1932 - mse: 0.1932 - val_loss: 0.2007 - val_mse: 0.2007 - 15ms/epoch - 15ms/step\n",
      "Epoch 101/400\n",
      "1/1 - 0s - loss: 0.1910 - mse: 0.1910 - val_loss: 0.1984 - val_mse: 0.1984 - 15ms/epoch - 15ms/step\n",
      "Epoch 102/400\n",
      "1/1 - 0s - loss: 0.1888 - mse: 0.1888 - val_loss: 0.1962 - val_mse: 0.1962 - 16ms/epoch - 16ms/step\n",
      "Epoch 103/400\n",
      "1/1 - 0s - loss: 0.1866 - mse: 0.1866 - val_loss: 0.1939 - val_mse: 0.1939 - 15ms/epoch - 15ms/step\n",
      "Epoch 104/400\n",
      "1/1 - 0s - loss: 0.1845 - mse: 0.1845 - val_loss: 0.1917 - val_mse: 0.1917 - 16ms/epoch - 16ms/step\n",
      "Epoch 105/400\n",
      "1/1 - 0s - loss: 0.1824 - mse: 0.1824 - val_loss: 0.1896 - val_mse: 0.1896 - 15ms/epoch - 15ms/step\n",
      "Epoch 106/400\n",
      "1/1 - 0s - loss: 0.1803 - mse: 0.1803 - val_loss: 0.1874 - val_mse: 0.1874 - 16ms/epoch - 16ms/step\n",
      "Epoch 107/400\n",
      "1/1 - 0s - loss: 0.1783 - mse: 0.1783 - val_loss: 0.1853 - val_mse: 0.1853 - 15ms/epoch - 15ms/step\n",
      "Epoch 108/400\n",
      "1/1 - 0s - loss: 0.1763 - mse: 0.1763 - val_loss: 0.1832 - val_mse: 0.1832 - 15ms/epoch - 15ms/step\n",
      "Epoch 109/400\n",
      "1/1 - 0s - loss: 0.1743 - mse: 0.1743 - val_loss: 0.1811 - val_mse: 0.1811 - 14ms/epoch - 14ms/step\n",
      "Epoch 110/400\n",
      "1/1 - 0s - loss: 0.1723 - mse: 0.1723 - val_loss: 0.1791 - val_mse: 0.1791 - 14ms/epoch - 14ms/step\n",
      "Epoch 111/400\n",
      "1/1 - 0s - loss: 0.1704 - mse: 0.1704 - val_loss: 0.1770 - val_mse: 0.1770 - 15ms/epoch - 15ms/step\n",
      "Epoch 112/400\n",
      "1/1 - 0s - loss: 0.1685 - mse: 0.1685 - val_loss: 0.1750 - val_mse: 0.1750 - 15ms/epoch - 15ms/step\n",
      "Epoch 113/400\n",
      "1/1 - 0s - loss: 0.1666 - mse: 0.1666 - val_loss: 0.1731 - val_mse: 0.1731 - 15ms/epoch - 15ms/step\n",
      "Epoch 114/400\n",
      "1/1 - 0s - loss: 0.1647 - mse: 0.1647 - val_loss: 0.1711 - val_mse: 0.1711 - 24ms/epoch - 24ms/step\n",
      "Epoch 115/400\n",
      "1/1 - 0s - loss: 0.1629 - mse: 0.1629 - val_loss: 0.1692 - val_mse: 0.1692 - 16ms/epoch - 16ms/step\n",
      "Epoch 116/400\n",
      "1/1 - 0s - loss: 0.1611 - mse: 0.1611 - val_loss: 0.1673 - val_mse: 0.1673 - 15ms/epoch - 15ms/step\n",
      "Epoch 117/400\n",
      "1/1 - 0s - loss: 0.1593 - mse: 0.1593 - val_loss: 0.1654 - val_mse: 0.1654 - 14ms/epoch - 14ms/step\n",
      "Epoch 118/400\n",
      "1/1 - 0s - loss: 0.1575 - mse: 0.1575 - val_loss: 0.1635 - val_mse: 0.1635 - 14ms/epoch - 14ms/step\n",
      "Epoch 119/400\n",
      "1/1 - 0s - loss: 0.1557 - mse: 0.1557 - val_loss: 0.1617 - val_mse: 0.1617 - 13ms/epoch - 13ms/step\n",
      "Epoch 120/400\n",
      "1/1 - 0s - loss: 0.1540 - mse: 0.1540 - val_loss: 0.1599 - val_mse: 0.1599 - 15ms/epoch - 15ms/step\n",
      "Epoch 121/400\n",
      "1/1 - 0s - loss: 0.1523 - mse: 0.1523 - val_loss: 0.1581 - val_mse: 0.1581 - 15ms/epoch - 15ms/step\n",
      "Epoch 122/400\n",
      "1/1 - 0s - loss: 0.1506 - mse: 0.1506 - val_loss: 0.1563 - val_mse: 0.1563 - 14ms/epoch - 14ms/step\n",
      "Epoch 123/400\n",
      "1/1 - 0s - loss: 0.1490 - mse: 0.1490 - val_loss: 0.1545 - val_mse: 0.1545 - 13ms/epoch - 13ms/step\n",
      "Epoch 124/400\n",
      "1/1 - 0s - loss: 0.1473 - mse: 0.1473 - val_loss: 0.1528 - val_mse: 0.1528 - 14ms/epoch - 14ms/step\n",
      "Epoch 125/400\n",
      "1/1 - 0s - loss: 0.1457 - mse: 0.1457 - val_loss: 0.1511 - val_mse: 0.1511 - 14ms/epoch - 14ms/step\n",
      "Epoch 126/400\n",
      "1/1 - 0s - loss: 0.1441 - mse: 0.1441 - val_loss: 0.1494 - val_mse: 0.1494 - 15ms/epoch - 15ms/step\n",
      "Epoch 127/400\n",
      "1/1 - 0s - loss: 0.1425 - mse: 0.1425 - val_loss: 0.1477 - val_mse: 0.1477 - 15ms/epoch - 15ms/step\n",
      "Epoch 128/400\n",
      "1/1 - 0s - loss: 0.1410 - mse: 0.1410 - val_loss: 0.1461 - val_mse: 0.1461 - 15ms/epoch - 15ms/step\n",
      "Epoch 129/400\n",
      "1/1 - 0s - loss: 0.1394 - mse: 0.1394 - val_loss: 0.1444 - val_mse: 0.1444 - 14ms/epoch - 14ms/step\n",
      "Epoch 130/400\n",
      "1/1 - 0s - loss: 0.1379 - mse: 0.1379 - val_loss: 0.1428 - val_mse: 0.1428 - 15ms/epoch - 15ms/step\n",
      "Epoch 131/400\n",
      "1/1 - 0s - loss: 0.1364 - mse: 0.1364 - val_loss: 0.1412 - val_mse: 0.1412 - 13ms/epoch - 13ms/step\n",
      "Epoch 132/400\n",
      "1/1 - 0s - loss: 0.1349 - mse: 0.1349 - val_loss: 0.1396 - val_mse: 0.1396 - 15ms/epoch - 15ms/step\n",
      "Epoch 133/400\n",
      "1/1 - 0s - loss: 0.1334 - mse: 0.1334 - val_loss: 0.1380 - val_mse: 0.1380 - 15ms/epoch - 15ms/step\n",
      "Epoch 134/400\n",
      "1/1 - 0s - loss: 0.1320 - mse: 0.1320 - val_loss: 0.1365 - val_mse: 0.1365 - 15ms/epoch - 15ms/step\n",
      "Epoch 135/400\n",
      "1/1 - 0s - loss: 0.1306 - mse: 0.1306 - val_loss: 0.1350 - val_mse: 0.1350 - 15ms/epoch - 15ms/step\n",
      "Epoch 136/400\n",
      "1/1 - 0s - loss: 0.1292 - mse: 0.1292 - val_loss: 0.1334 - val_mse: 0.1334 - 14ms/epoch - 14ms/step\n",
      "Epoch 137/400\n",
      "1/1 - 0s - loss: 0.1278 - mse: 0.1278 - val_loss: 0.1320 - val_mse: 0.1320 - 15ms/epoch - 15ms/step\n",
      "Epoch 138/400\n",
      "1/1 - 0s - loss: 0.1264 - mse: 0.1264 - val_loss: 0.1305 - val_mse: 0.1305 - 14ms/epoch - 14ms/step\n",
      "Epoch 139/400\n",
      "1/1 - 0s - loss: 0.1250 - mse: 0.1250 - val_loss: 0.1290 - val_mse: 0.1290 - 14ms/epoch - 14ms/step\n",
      "Epoch 140/400\n",
      "1/1 - 0s - loss: 0.1237 - mse: 0.1237 - val_loss: 0.1276 - val_mse: 0.1276 - 14ms/epoch - 14ms/step\n",
      "Epoch 141/400\n",
      "1/1 - 0s - loss: 0.1224 - mse: 0.1224 - val_loss: 0.1262 - val_mse: 0.1262 - 14ms/epoch - 14ms/step\n",
      "Epoch 142/400\n",
      "1/1 - 0s - loss: 0.1211 - mse: 0.1211 - val_loss: 0.1248 - val_mse: 0.1248 - 15ms/epoch - 15ms/step\n",
      "Epoch 143/400\n",
      "1/1 - 0s - loss: 0.1198 - mse: 0.1198 - val_loss: 0.1234 - val_mse: 0.1234 - 12ms/epoch - 12ms/step\n",
      "Epoch 144/400\n",
      "1/1 - 0s - loss: 0.1185 - mse: 0.1185 - val_loss: 0.1220 - val_mse: 0.1220 - 15ms/epoch - 15ms/step\n",
      "Epoch 145/400\n",
      "1/1 - 0s - loss: 0.1172 - mse: 0.1172 - val_loss: 0.1207 - val_mse: 0.1207 - 15ms/epoch - 15ms/step\n",
      "Epoch 146/400\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1/1 - 0s - loss: 0.1160 - mse: 0.1160 - val_loss: 0.1193 - val_mse: 0.1193 - 16ms/epoch - 16ms/step\n",
      "Epoch 147/400\n",
      "1/1 - 0s - loss: 0.1148 - mse: 0.1148 - val_loss: 0.1180 - val_mse: 0.1180 - 16ms/epoch - 16ms/step\n",
      "Epoch 148/400\n",
      "1/1 - 0s - loss: 0.1135 - mse: 0.1135 - val_loss: 0.1167 - val_mse: 0.1167 - 16ms/epoch - 16ms/step\n",
      "Epoch 149/400\n",
      "1/1 - 0s - loss: 0.1123 - mse: 0.1123 - val_loss: 0.1154 - val_mse: 0.1154 - 15ms/epoch - 15ms/step\n",
      "Epoch 150/400\n",
      "1/1 - 0s - loss: 0.1112 - mse: 0.1112 - val_loss: 0.1142 - val_mse: 0.1142 - 15ms/epoch - 15ms/step\n",
      "Epoch 151/400\n",
      "1/1 - 0s - loss: 0.1100 - mse: 0.1100 - val_loss: 0.1129 - val_mse: 0.1129 - 15ms/epoch - 15ms/step\n",
      "Epoch 152/400\n",
      "1/1 - 0s - loss: 0.1088 - mse: 0.1088 - val_loss: 0.1117 - val_mse: 0.1117 - 15ms/epoch - 15ms/step\n",
      "Epoch 153/400\n",
      "1/1 - 0s - loss: 0.1077 - mse: 0.1077 - val_loss: 0.1104 - val_mse: 0.1104 - 15ms/epoch - 15ms/step\n",
      "Epoch 154/400\n",
      "1/1 - 0s - loss: 0.1066 - mse: 0.1066 - val_loss: 0.1092 - val_mse: 0.1092 - 14ms/epoch - 14ms/step\n",
      "Epoch 155/400\n",
      "1/1 - 0s - loss: 0.1055 - mse: 0.1055 - val_loss: 0.1080 - val_mse: 0.1080 - 17ms/epoch - 17ms/step\n",
      "Epoch 156/400\n",
      "1/1 - 0s - loss: 0.1044 - mse: 0.1044 - val_loss: 0.1068 - val_mse: 0.1068 - 15ms/epoch - 15ms/step\n",
      "Epoch 157/400\n",
      "1/1 - 0s - loss: 0.1033 - mse: 0.1033 - val_loss: 0.1057 - val_mse: 0.1057 - 15ms/epoch - 15ms/step\n",
      "Epoch 158/400\n",
      "1/1 - 0s - loss: 0.1022 - mse: 0.1022 - val_loss: 0.1045 - val_mse: 0.1045 - 15ms/epoch - 15ms/step\n",
      "Epoch 159/400\n",
      "1/1 - 0s - loss: 0.1012 - mse: 0.1012 - val_loss: 0.1034 - val_mse: 0.1034 - 14ms/epoch - 14ms/step\n",
      "Epoch 160/400\n",
      "1/1 - 0s - loss: 0.1001 - mse: 0.1001 - val_loss: 0.1023 - val_mse: 0.1023 - 16ms/epoch - 16ms/step\n",
      "Epoch 161/400\n",
      "1/1 - 0s - loss: 0.0991 - mse: 0.0991 - val_loss: 0.1011 - val_mse: 0.1011 - 15ms/epoch - 15ms/step\n",
      "Epoch 162/400\n",
      "1/1 - 0s - loss: 0.0981 - mse: 0.0981 - val_loss: 0.1000 - val_mse: 0.1000 - 14ms/epoch - 14ms/step\n",
      "Epoch 163/400\n",
      "1/1 - 0s - loss: 0.0971 - mse: 0.0971 - val_loss: 0.0990 - val_mse: 0.0990 - 15ms/epoch - 15ms/step\n",
      "Epoch 164/400\n",
      "1/1 - 0s - loss: 0.0961 - mse: 0.0961 - val_loss: 0.0979 - val_mse: 0.0979 - 16ms/epoch - 16ms/step\n",
      "Epoch 165/400\n",
      "1/1 - 0s - loss: 0.0951 - mse: 0.0951 - val_loss: 0.0968 - val_mse: 0.0968 - 14ms/epoch - 14ms/step\n",
      "Epoch 166/400\n",
      "1/1 - 0s - loss: 0.0942 - mse: 0.0942 - val_loss: 0.0958 - val_mse: 0.0958 - 14ms/epoch - 14ms/step\n",
      "Epoch 167/400\n",
      "1/1 - 0s - loss: 0.0932 - mse: 0.0932 - val_loss: 0.0947 - val_mse: 0.0947 - 14ms/epoch - 14ms/step\n",
      "Epoch 168/400\n",
      "1/1 - 0s - loss: 0.0923 - mse: 0.0923 - val_loss: 0.0937 - val_mse: 0.0937 - 14ms/epoch - 14ms/step\n",
      "Epoch 169/400\n",
      "1/1 - 0s - loss: 0.0914 - mse: 0.0914 - val_loss: 0.0927 - val_mse: 0.0927 - 15ms/epoch - 15ms/step\n",
      "Epoch 170/400\n",
      "1/1 - 0s - loss: 0.0905 - mse: 0.0905 - val_loss: 0.0917 - val_mse: 0.0917 - 15ms/epoch - 15ms/step\n",
      "Epoch 171/400\n",
      "1/1 - 0s - loss: 0.0896 - mse: 0.0896 - val_loss: 0.0908 - val_mse: 0.0908 - 14ms/epoch - 14ms/step\n",
      "Epoch 172/400\n",
      "1/1 - 0s - loss: 0.0887 - mse: 0.0887 - val_loss: 0.0898 - val_mse: 0.0898 - 14ms/epoch - 14ms/step\n",
      "Epoch 173/400\n",
      "1/1 - 0s - loss: 0.0878 - mse: 0.0878 - val_loss: 0.0888 - val_mse: 0.0888 - 14ms/epoch - 14ms/step\n",
      "Epoch 174/400\n",
      "1/1 - 0s - loss: 0.0870 - mse: 0.0870 - val_loss: 0.0879 - val_mse: 0.0879 - 15ms/epoch - 15ms/step\n",
      "Epoch 175/400\n",
      "1/1 - 0s - loss: 0.0861 - mse: 0.0861 - val_loss: 0.0870 - val_mse: 0.0870 - 15ms/epoch - 15ms/step\n",
      "Epoch 176/400\n",
      "1/1 - 0s - loss: 0.0853 - mse: 0.0853 - val_loss: 0.0861 - val_mse: 0.0861 - 15ms/epoch - 15ms/step\n",
      "Epoch 177/400\n",
      "1/1 - 0s - loss: 0.0845 - mse: 0.0845 - val_loss: 0.0852 - val_mse: 0.0852 - 15ms/epoch - 15ms/step\n",
      "Epoch 178/400\n",
      "1/1 - 0s - loss: 0.0836 - mse: 0.0836 - val_loss: 0.0843 - val_mse: 0.0843 - 15ms/epoch - 15ms/step\n",
      "Epoch 179/400\n",
      "1/1 - 0s - loss: 0.0828 - mse: 0.0828 - val_loss: 0.0834 - val_mse: 0.0834 - 15ms/epoch - 15ms/step\n",
      "Epoch 180/400\n",
      "1/1 - 0s - loss: 0.0820 - mse: 0.0820 - val_loss: 0.0825 - val_mse: 0.0825 - 16ms/epoch - 16ms/step\n",
      "Epoch 181/400\n",
      "1/1 - 0s - loss: 0.0813 - mse: 0.0813 - val_loss: 0.0817 - val_mse: 0.0817 - 14ms/epoch - 14ms/step\n",
      "Epoch 182/400\n",
      "1/1 - 0s - loss: 0.0805 - mse: 0.0805 - val_loss: 0.0808 - val_mse: 0.0808 - 15ms/epoch - 15ms/step\n",
      "Epoch 183/400\n",
      "1/1 - 0s - loss: 0.0797 - mse: 0.0797 - val_loss: 0.0800 - val_mse: 0.0800 - 15ms/epoch - 15ms/step\n",
      "Epoch 184/400\n",
      "1/1 - 0s - loss: 0.0790 - mse: 0.0790 - val_loss: 0.0792 - val_mse: 0.0792 - 14ms/epoch - 14ms/step\n",
      "Epoch 185/400\n",
      "1/1 - 0s - loss: 0.0782 - mse: 0.0782 - val_loss: 0.0783 - val_mse: 0.0783 - 15ms/epoch - 15ms/step\n",
      "Epoch 186/400\n",
      "1/1 - 0s - loss: 0.0775 - mse: 0.0775 - val_loss: 0.0775 - val_mse: 0.0775 - 15ms/epoch - 15ms/step\n",
      "Epoch 187/400\n",
      "1/1 - 0s - loss: 0.0767 - mse: 0.0767 - val_loss: 0.0767 - val_mse: 0.0767 - 16ms/epoch - 16ms/step\n",
      "Epoch 188/400\n",
      "1/1 - 0s - loss: 0.0760 - mse: 0.0760 - val_loss: 0.0759 - val_mse: 0.0759 - 16ms/epoch - 16ms/step\n",
      "Epoch 189/400\n",
      "1/1 - 0s - loss: 0.0753 - mse: 0.0753 - val_loss: 0.0752 - val_mse: 0.0752 - 15ms/epoch - 15ms/step\n",
      "Epoch 190/400\n",
      "1/1 - 0s - loss: 0.0746 - mse: 0.0746 - val_loss: 0.0744 - val_mse: 0.0744 - 14ms/epoch - 14ms/step\n",
      "Epoch 191/400\n",
      "1/1 - 0s - loss: 0.0739 - mse: 0.0739 - val_loss: 0.0736 - val_mse: 0.0736 - 14ms/epoch - 14ms/step\n",
      "Epoch 192/400\n",
      "1/1 - 0s - loss: 0.0732 - mse: 0.0732 - val_loss: 0.0729 - val_mse: 0.0729 - 16ms/epoch - 16ms/step\n",
      "Epoch 193/400\n",
      "1/1 - 0s - loss: 0.0725 - mse: 0.0725 - val_loss: 0.0721 - val_mse: 0.0721 - 15ms/epoch - 15ms/step\n",
      "Epoch 194/400\n",
      "1/1 - 0s - loss: 0.0719 - mse: 0.0719 - val_loss: 0.0714 - val_mse: 0.0714 - 15ms/epoch - 15ms/step\n",
      "Epoch 195/400\n",
      "1/1 - 0s - loss: 0.0712 - mse: 0.0712 - val_loss: 0.0707 - val_mse: 0.0707 - 14ms/epoch - 14ms/step\n",
      "Epoch 196/400\n",
      "1/1 - 0s - loss: 0.0705 - mse: 0.0705 - val_loss: 0.0699 - val_mse: 0.0699 - 14ms/epoch - 14ms/step\n",
      "Epoch 197/400\n",
      "1/1 - 0s - loss: 0.0699 - mse: 0.0699 - val_loss: 0.0692 - val_mse: 0.0692 - 14ms/epoch - 14ms/step\n",
      "Epoch 198/400\n",
      "1/1 - 0s - loss: 0.0692 - mse: 0.0692 - val_loss: 0.0685 - val_mse: 0.0685 - 14ms/epoch - 14ms/step\n",
      "Epoch 199/400\n",
      "1/1 - 0s - loss: 0.0686 - mse: 0.0686 - val_loss: 0.0678 - val_mse: 0.0678 - 15ms/epoch - 15ms/step\n",
      "Epoch 200/400\n",
      "1/1 - 0s - loss: 0.0680 - mse: 0.0680 - val_loss: 0.0671 - val_mse: 0.0671 - 15ms/epoch - 15ms/step\n",
      "Epoch 201/400\n",
      "1/1 - 0s - loss: 0.0673 - mse: 0.0673 - val_loss: 0.0664 - val_mse: 0.0664 - 14ms/epoch - 14ms/step\n",
      "Epoch 202/400\n",
      "1/1 - 0s - loss: 0.0667 - mse: 0.0667 - val_loss: 0.0658 - val_mse: 0.0658 - 13ms/epoch - 13ms/step\n",
      "Epoch 203/400\n",
      "1/1 - 0s - loss: 0.0661 - mse: 0.0661 - val_loss: 0.0651 - val_mse: 0.0651 - 14ms/epoch - 14ms/step\n",
      "Epoch 204/400\n",
      "1/1 - 0s - loss: 0.0655 - mse: 0.0655 - val_loss: 0.0645 - val_mse: 0.0645 - 14ms/epoch - 14ms/step\n",
      "Epoch 205/400\n",
      "1/1 - 0s - loss: 0.0649 - mse: 0.0649 - val_loss: 0.0638 - val_mse: 0.0638 - 15ms/epoch - 15ms/step\n",
      "Epoch 206/400\n",
      "1/1 - 0s - loss: 0.0643 - mse: 0.0643 - val_loss: 0.0632 - val_mse: 0.0632 - 15ms/epoch - 15ms/step\n",
      "Epoch 207/400\n",
      "1/1 - 0s - loss: 0.0637 - mse: 0.0637 - val_loss: 0.0625 - val_mse: 0.0625 - 16ms/epoch - 16ms/step\n",
      "Epoch 208/400\n",
      "1/1 - 0s - loss: 0.0631 - mse: 0.0631 - val_loss: 0.0619 - val_mse: 0.0619 - 15ms/epoch - 15ms/step\n",
      "Epoch 209/400\n",
      "1/1 - 0s - loss: 0.0625 - mse: 0.0625 - val_loss: 0.0613 - val_mse: 0.0613 - 15ms/epoch - 15ms/step\n",
      "Epoch 210/400\n",
      "1/1 - 0s - loss: 0.0620 - mse: 0.0620 - val_loss: 0.0607 - val_mse: 0.0607 - 15ms/epoch - 15ms/step\n",
      "Epoch 211/400\n",
      "1/1 - 0s - loss: 0.0614 - mse: 0.0614 - val_loss: 0.0601 - val_mse: 0.0601 - 15ms/epoch - 15ms/step\n",
      "Epoch 212/400\n",
      "1/1 - 0s - loss: 0.0608 - mse: 0.0608 - val_loss: 0.0595 - val_mse: 0.0595 - 15ms/epoch - 15ms/step\n",
      "Epoch 213/400\n",
      "1/1 - 0s - loss: 0.0603 - mse: 0.0603 - val_loss: 0.0589 - val_mse: 0.0589 - 15ms/epoch - 15ms/step\n",
      "Epoch 214/400\n",
      "1/1 - 0s - loss: 0.0597 - mse: 0.0597 - val_loss: 0.0583 - val_mse: 0.0583 - 15ms/epoch - 15ms/step\n",
      "Epoch 215/400\n",
      "1/1 - 0s - loss: 0.0592 - mse: 0.0592 - val_loss: 0.0577 - val_mse: 0.0577 - 15ms/epoch - 15ms/step\n",
      "Epoch 216/400\n",
      "1/1 - 0s - loss: 0.0586 - mse: 0.0586 - val_loss: 0.0572 - val_mse: 0.0572 - 15ms/epoch - 15ms/step\n",
      "Epoch 217/400\n",
      "1/1 - 0s - loss: 0.0581 - mse: 0.0581 - val_loss: 0.0566 - val_mse: 0.0566 - 15ms/epoch - 15ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 218/400\n",
      "1/1 - 0s - loss: 0.0575 - mse: 0.0575 - val_loss: 0.0560 - val_mse: 0.0560 - 15ms/epoch - 15ms/step\n",
      "Epoch 219/400\n",
      "1/1 - 0s - loss: 0.0570 - mse: 0.0570 - val_loss: 0.0554 - val_mse: 0.0554 - 16ms/epoch - 16ms/step\n",
      "Epoch 220/400\n",
      "1/1 - 0s - loss: 0.0564 - mse: 0.0564 - val_loss: 0.0549 - val_mse: 0.0549 - 14ms/epoch - 14ms/step\n",
      "Epoch 221/400\n",
      "1/1 - 0s - loss: 0.0559 - mse: 0.0559 - val_loss: 0.0543 - val_mse: 0.0543 - 14ms/epoch - 14ms/step\n",
      "Epoch 222/400\n",
      "1/1 - 0s - loss: 0.0554 - mse: 0.0554 - val_loss: 0.0538 - val_mse: 0.0538 - 14ms/epoch - 14ms/step\n",
      "Epoch 223/400\n",
      "1/1 - 0s - loss: 0.0549 - mse: 0.0549 - val_loss: 0.0532 - val_mse: 0.0532 - 15ms/epoch - 15ms/step\n",
      "Epoch 224/400\n",
      "1/1 - 0s - loss: 0.0544 - mse: 0.0544 - val_loss: 0.0527 - val_mse: 0.0527 - 14ms/epoch - 14ms/step\n",
      "Epoch 225/400\n",
      "1/1 - 0s - loss: 0.0538 - mse: 0.0538 - val_loss: 0.0522 - val_mse: 0.0522 - 15ms/epoch - 15ms/step\n",
      "Epoch 226/400\n",
      "1/1 - 0s - loss: 0.0533 - mse: 0.0533 - val_loss: 0.0516 - val_mse: 0.0516 - 15ms/epoch - 15ms/step\n",
      "Epoch 227/400\n",
      "1/1 - 0s - loss: 0.0528 - mse: 0.0528 - val_loss: 0.0511 - val_mse: 0.0511 - 14ms/epoch - 14ms/step\n",
      "Epoch 228/400\n",
      "1/1 - 0s - loss: 0.0523 - mse: 0.0523 - val_loss: 0.0506 - val_mse: 0.0506 - 15ms/epoch - 15ms/step\n",
      "Epoch 229/400\n",
      "1/1 - 0s - loss: 0.0518 - mse: 0.0518 - val_loss: 0.0501 - val_mse: 0.0501 - 15ms/epoch - 15ms/step\n",
      "Epoch 230/400\n",
      "1/1 - 0s - loss: 0.0513 - mse: 0.0513 - val_loss: 0.0496 - val_mse: 0.0496 - 15ms/epoch - 15ms/step\n",
      "Epoch 231/400\n",
      "1/1 - 0s - loss: 0.0508 - mse: 0.0508 - val_loss: 0.0491 - val_mse: 0.0491 - 15ms/epoch - 15ms/step\n",
      "Epoch 232/400\n",
      "1/1 - 0s - loss: 0.0503 - mse: 0.0503 - val_loss: 0.0486 - val_mse: 0.0486 - 14ms/epoch - 14ms/step\n",
      "Epoch 233/400\n",
      "1/1 - 0s - loss: 0.0498 - mse: 0.0498 - val_loss: 0.0481 - val_mse: 0.0481 - 13ms/epoch - 13ms/step\n",
      "Epoch 234/400\n",
      "1/1 - 0s - loss: 0.0493 - mse: 0.0493 - val_loss: 0.0476 - val_mse: 0.0476 - 14ms/epoch - 14ms/step\n",
      "Epoch 235/400\n",
      "1/1 - 0s - loss: 0.0489 - mse: 0.0489 - val_loss: 0.0471 - val_mse: 0.0471 - 13ms/epoch - 13ms/step\n",
      "Epoch 236/400\n",
      "1/1 - 0s - loss: 0.0484 - mse: 0.0484 - val_loss: 0.0467 - val_mse: 0.0467 - 14ms/epoch - 14ms/step\n",
      "Epoch 237/400\n",
      "1/1 - 0s - loss: 0.0479 - mse: 0.0479 - val_loss: 0.0462 - val_mse: 0.0462 - 15ms/epoch - 15ms/step\n",
      "Epoch 238/400\n",
      "1/1 - 0s - loss: 0.0475 - mse: 0.0475 - val_loss: 0.0457 - val_mse: 0.0457 - 14ms/epoch - 14ms/step\n",
      "Epoch 239/400\n",
      "1/1 - 0s - loss: 0.0470 - mse: 0.0470 - val_loss: 0.0453 - val_mse: 0.0453 - 15ms/epoch - 15ms/step\n",
      "Epoch 240/400\n",
      "1/1 - 0s - loss: 0.0466 - mse: 0.0466 - val_loss: 0.0448 - val_mse: 0.0448 - 14ms/epoch - 14ms/step\n",
      "Epoch 241/400\n",
      "1/1 - 0s - loss: 0.0461 - mse: 0.0461 - val_loss: 0.0444 - val_mse: 0.0444 - 15ms/epoch - 15ms/step\n",
      "Epoch 242/400\n",
      "1/1 - 0s - loss: 0.0456 - mse: 0.0456 - val_loss: 0.0439 - val_mse: 0.0439 - 14ms/epoch - 14ms/step\n",
      "Epoch 243/400\n",
      "1/1 - 0s - loss: 0.0452 - mse: 0.0452 - val_loss: 0.0435 - val_mse: 0.0435 - 14ms/epoch - 14ms/step\n",
      "Epoch 244/400\n",
      "1/1 - 0s - loss: 0.0447 - mse: 0.0447 - val_loss: 0.0431 - val_mse: 0.0431 - 17ms/epoch - 17ms/step\n",
      "Epoch 245/400\n",
      "1/1 - 0s - loss: 0.0443 - mse: 0.0443 - val_loss: 0.0426 - val_mse: 0.0426 - 14ms/epoch - 14ms/step\n",
      "Epoch 246/400\n",
      "1/1 - 0s - loss: 0.0439 - mse: 0.0439 - val_loss: 0.0422 - val_mse: 0.0422 - 16ms/epoch - 16ms/step\n",
      "Epoch 247/400\n",
      "1/1 - 0s - loss: 0.0434 - mse: 0.0434 - val_loss: 0.0418 - val_mse: 0.0418 - 15ms/epoch - 15ms/step\n",
      "Epoch 248/400\n",
      "1/1 - 0s - loss: 0.0430 - mse: 0.0430 - val_loss: 0.0414 - val_mse: 0.0414 - 15ms/epoch - 15ms/step\n",
      "Epoch 249/400\n",
      "1/1 - 0s - loss: 0.0426 - mse: 0.0426 - val_loss: 0.0410 - val_mse: 0.0410 - 15ms/epoch - 15ms/step\n",
      "Epoch 250/400\n",
      "1/1 - 0s - loss: 0.0422 - mse: 0.0422 - val_loss: 0.0406 - val_mse: 0.0406 - 15ms/epoch - 15ms/step\n",
      "Epoch 251/400\n",
      "1/1 - 0s - loss: 0.0418 - mse: 0.0418 - val_loss: 0.0402 - val_mse: 0.0402 - 15ms/epoch - 15ms/step\n",
      "Epoch 252/400\n",
      "1/1 - 0s - loss: 0.0414 - mse: 0.0414 - val_loss: 0.0398 - val_mse: 0.0398 - 15ms/epoch - 15ms/step\n",
      "Epoch 253/400\n",
      "1/1 - 0s - loss: 0.0410 - mse: 0.0410 - val_loss: 0.0394 - val_mse: 0.0394 - 15ms/epoch - 15ms/step\n",
      "Epoch 254/400\n",
      "1/1 - 0s - loss: 0.0406 - mse: 0.0406 - val_loss: 0.0390 - val_mse: 0.0390 - 15ms/epoch - 15ms/step\n",
      "Epoch 255/400\n",
      "1/1 - 0s - loss: 0.0402 - mse: 0.0402 - val_loss: 0.0386 - val_mse: 0.0386 - 16ms/epoch - 16ms/step\n",
      "Epoch 256/400\n",
      "1/1 - 0s - loss: 0.0398 - mse: 0.0398 - val_loss: 0.0383 - val_mse: 0.0383 - 15ms/epoch - 15ms/step\n",
      "Epoch 257/400\n",
      "1/1 - 0s - loss: 0.0394 - mse: 0.0394 - val_loss: 0.0379 - val_mse: 0.0379 - 15ms/epoch - 15ms/step\n",
      "Epoch 258/400\n",
      "1/1 - 0s - loss: 0.0390 - mse: 0.0390 - val_loss: 0.0375 - val_mse: 0.0375 - 15ms/epoch - 15ms/step\n",
      "Epoch 259/400\n",
      "1/1 - 0s - loss: 0.0386 - mse: 0.0386 - val_loss: 0.0372 - val_mse: 0.0372 - 15ms/epoch - 15ms/step\n",
      "Epoch 260/400\n",
      "1/1 - 0s - loss: 0.0382 - mse: 0.0382 - val_loss: 0.0368 - val_mse: 0.0368 - 14ms/epoch - 14ms/step\n",
      "Epoch 261/400\n",
      "1/1 - 0s - loss: 0.0379 - mse: 0.0379 - val_loss: 0.0364 - val_mse: 0.0364 - 16ms/epoch - 16ms/step\n",
      "Epoch 262/400\n",
      "1/1 - 0s - loss: 0.0375 - mse: 0.0375 - val_loss: 0.0361 - val_mse: 0.0361 - 15ms/epoch - 15ms/step\n",
      "Epoch 263/400\n",
      "1/1 - 0s - loss: 0.0371 - mse: 0.0371 - val_loss: 0.0357 - val_mse: 0.0357 - 14ms/epoch - 14ms/step\n",
      "Epoch 264/400\n",
      "1/1 - 0s - loss: 0.0368 - mse: 0.0368 - val_loss: 0.0354 - val_mse: 0.0354 - 14ms/epoch - 14ms/step\n",
      "Epoch 265/400\n",
      "1/1 - 0s - loss: 0.0364 - mse: 0.0364 - val_loss: 0.0351 - val_mse: 0.0351 - 14ms/epoch - 14ms/step\n",
      "Epoch 266/400\n",
      "1/1 - 0s - loss: 0.0361 - mse: 0.0361 - val_loss: 0.0347 - val_mse: 0.0347 - 14ms/epoch - 14ms/step\n",
      "Epoch 267/400\n",
      "1/1 - 0s - loss: 0.0357 - mse: 0.0357 - val_loss: 0.0344 - val_mse: 0.0344 - 15ms/epoch - 15ms/step\n",
      "Epoch 268/400\n",
      "1/1 - 0s - loss: 0.0354 - mse: 0.0354 - val_loss: 0.0341 - val_mse: 0.0341 - 15ms/epoch - 15ms/step\n",
      "Epoch 269/400\n",
      "1/1 - 0s - loss: 0.0350 - mse: 0.0350 - val_loss: 0.0337 - val_mse: 0.0337 - 15ms/epoch - 15ms/step\n",
      "Epoch 270/400\n",
      "1/1 - 0s - loss: 0.0347 - mse: 0.0347 - val_loss: 0.0334 - val_mse: 0.0334 - 15ms/epoch - 15ms/step\n",
      "Epoch 271/400\n",
      "1/1 - 0s - loss: 0.0344 - mse: 0.0344 - val_loss: 0.0331 - val_mse: 0.0331 - 15ms/epoch - 15ms/step\n",
      "Epoch 272/400\n",
      "1/1 - 0s - loss: 0.0341 - mse: 0.0341 - val_loss: 0.0328 - val_mse: 0.0328 - 16ms/epoch - 16ms/step\n",
      "Epoch 273/400\n",
      "1/1 - 0s - loss: 0.0337 - mse: 0.0337 - val_loss: 0.0325 - val_mse: 0.0325 - 16ms/epoch - 16ms/step\n",
      "Epoch 274/400\n",
      "1/1 - 0s - loss: 0.0334 - mse: 0.0334 - val_loss: 0.0322 - val_mse: 0.0322 - 26ms/epoch - 26ms/step\n",
      "Epoch 275/400\n",
      "1/1 - 0s - loss: 0.0331 - mse: 0.0331 - val_loss: 0.0319 - val_mse: 0.0319 - 15ms/epoch - 15ms/step\n",
      "Epoch 276/400\n",
      "1/1 - 0s - loss: 0.0328 - mse: 0.0328 - val_loss: 0.0316 - val_mse: 0.0316 - 14ms/epoch - 14ms/step\n",
      "Epoch 277/400\n",
      "1/1 - 0s - loss: 0.0325 - mse: 0.0325 - val_loss: 0.0313 - val_mse: 0.0313 - 14ms/epoch - 14ms/step\n",
      "Epoch 278/400\n",
      "1/1 - 0s - loss: 0.0322 - mse: 0.0322 - val_loss: 0.0310 - val_mse: 0.0310 - 15ms/epoch - 15ms/step\n",
      "Epoch 279/400\n",
      "1/1 - 0s - loss: 0.0319 - mse: 0.0319 - val_loss: 0.0307 - val_mse: 0.0307 - 14ms/epoch - 14ms/step\n",
      "Epoch 280/400\n",
      "1/1 - 0s - loss: 0.0316 - mse: 0.0316 - val_loss: 0.0305 - val_mse: 0.0305 - 14ms/epoch - 14ms/step\n",
      "Epoch 281/400\n",
      "1/1 - 0s - loss: 0.0314 - mse: 0.0314 - val_loss: 0.0302 - val_mse: 0.0302 - 15ms/epoch - 15ms/step\n",
      "Epoch 282/400\n",
      "1/1 - 0s - loss: 0.0311 - mse: 0.0311 - val_loss: 0.0299 - val_mse: 0.0299 - 15ms/epoch - 15ms/step\n",
      "Epoch 283/400\n",
      "1/1 - 0s - loss: 0.0308 - mse: 0.0308 - val_loss: 0.0296 - val_mse: 0.0296 - 15ms/epoch - 15ms/step\n",
      "Epoch 284/400\n",
      "1/1 - 0s - loss: 0.0305 - mse: 0.0305 - val_loss: 0.0294 - val_mse: 0.0294 - 14ms/epoch - 14ms/step\n",
      "Epoch 285/400\n",
      "1/1 - 0s - loss: 0.0303 - mse: 0.0303 - val_loss: 0.0291 - val_mse: 0.0291 - 15ms/epoch - 15ms/step\n",
      "Epoch 286/400\n",
      "1/1 - 0s - loss: 0.0300 - mse: 0.0300 - val_loss: 0.0289 - val_mse: 0.0289 - 14ms/epoch - 14ms/step\n",
      "Epoch 287/400\n",
      "1/1 - 0s - loss: 0.0297 - mse: 0.0297 - val_loss: 0.0286 - val_mse: 0.0286 - 14ms/epoch - 14ms/step\n",
      "Epoch 288/400\n",
      "1/1 - 0s - loss: 0.0295 - mse: 0.0295 - val_loss: 0.0283 - val_mse: 0.0283 - 14ms/epoch - 14ms/step\n",
      "Epoch 289/400\n",
      "1/1 - 0s - loss: 0.0292 - mse: 0.0292 - val_loss: 0.0281 - val_mse: 0.0281 - 15ms/epoch - 15ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 290/400\n",
      "1/1 - 0s - loss: 0.0290 - mse: 0.0290 - val_loss: 0.0278 - val_mse: 0.0278 - 15ms/epoch - 15ms/step\n",
      "Epoch 291/400\n",
      "1/1 - 0s - loss: 0.0287 - mse: 0.0287 - val_loss: 0.0276 - val_mse: 0.0276 - 15ms/epoch - 15ms/step\n",
      "Epoch 292/400\n",
      "1/1 - 0s - loss: 0.0285 - mse: 0.0285 - val_loss: 0.0274 - val_mse: 0.0274 - 15ms/epoch - 15ms/step\n",
      "Epoch 293/400\n",
      "1/1 - 0s - loss: 0.0282 - mse: 0.0282 - val_loss: 0.0271 - val_mse: 0.0271 - 15ms/epoch - 15ms/step\n",
      "Epoch 294/400\n",
      "1/1 - 0s - loss: 0.0280 - mse: 0.0280 - val_loss: 0.0269 - val_mse: 0.0269 - 14ms/epoch - 14ms/step\n",
      "Epoch 295/400\n",
      "1/1 - 0s - loss: 0.0277 - mse: 0.0277 - val_loss: 0.0266 - val_mse: 0.0266 - 13ms/epoch - 13ms/step\n",
      "Epoch 296/400\n",
      "1/1 - 0s - loss: 0.0275 - mse: 0.0275 - val_loss: 0.0264 - val_mse: 0.0264 - 13ms/epoch - 13ms/step\n",
      "Epoch 297/400\n",
      "1/1 - 0s - loss: 0.0273 - mse: 0.0273 - val_loss: 0.0262 - val_mse: 0.0262 - 13ms/epoch - 13ms/step\n",
      "Epoch 298/400\n",
      "1/1 - 0s - loss: 0.0270 - mse: 0.0270 - val_loss: 0.0259 - val_mse: 0.0259 - 14ms/epoch - 14ms/step\n",
      "Epoch 299/400\n",
      "1/1 - 0s - loss: 0.0268 - mse: 0.0268 - val_loss: 0.0257 - val_mse: 0.0257 - 15ms/epoch - 15ms/step\n",
      "Epoch 300/400\n",
      "1/1 - 0s - loss: 0.0265 - mse: 0.0265 - val_loss: 0.0255 - val_mse: 0.0255 - 14ms/epoch - 14ms/step\n",
      "Epoch 301/400\n",
      "1/1 - 0s - loss: 0.0263 - mse: 0.0263 - val_loss: 0.0253 - val_mse: 0.0253 - 16ms/epoch - 16ms/step\n",
      "Epoch 302/400\n",
      "1/1 - 0s - loss: 0.0261 - mse: 0.0261 - val_loss: 0.0250 - val_mse: 0.0250 - 15ms/epoch - 15ms/step\n",
      "Epoch 303/400\n",
      "1/1 - 0s - loss: 0.0259 - mse: 0.0259 - val_loss: 0.0248 - val_mse: 0.0248 - 16ms/epoch - 16ms/step\n",
      "Epoch 304/400\n",
      "1/1 - 0s - loss: 0.0256 - mse: 0.0256 - val_loss: 0.0246 - val_mse: 0.0246 - 14ms/epoch - 14ms/step\n",
      "Epoch 305/400\n",
      "1/1 - 0s - loss: 0.0254 - mse: 0.0254 - val_loss: 0.0244 - val_mse: 0.0244 - 16ms/epoch - 16ms/step\n",
      "Epoch 306/400\n",
      "1/1 - 0s - loss: 0.0252 - mse: 0.0252 - val_loss: 0.0242 - val_mse: 0.0242 - 15ms/epoch - 15ms/step\n",
      "Epoch 307/400\n",
      "1/1 - 0s - loss: 0.0250 - mse: 0.0250 - val_loss: 0.0240 - val_mse: 0.0240 - 16ms/epoch - 16ms/step\n",
      "Epoch 308/400\n",
      "1/1 - 0s - loss: 0.0248 - mse: 0.0248 - val_loss: 0.0238 - val_mse: 0.0238 - 14ms/epoch - 14ms/step\n",
      "Epoch 309/400\n",
      "1/1 - 0s - loss: 0.0246 - mse: 0.0246 - val_loss: 0.0236 - val_mse: 0.0236 - 15ms/epoch - 15ms/step\n",
      "Epoch 310/400\n",
      "1/1 - 0s - loss: 0.0244 - mse: 0.0244 - val_loss: 0.0234 - val_mse: 0.0234 - 15ms/epoch - 15ms/step\n",
      "Epoch 311/400\n",
      "1/1 - 0s - loss: 0.0241 - mse: 0.0241 - val_loss: 0.0232 - val_mse: 0.0232 - 14ms/epoch - 14ms/step\n",
      "Epoch 312/400\n",
      "1/1 - 0s - loss: 0.0239 - mse: 0.0239 - val_loss: 0.0230 - val_mse: 0.0230 - 14ms/epoch - 14ms/step\n",
      "Epoch 313/400\n",
      "1/1 - 0s - loss: 0.0237 - mse: 0.0237 - val_loss: 0.0228 - val_mse: 0.0228 - 14ms/epoch - 14ms/step\n",
      "Epoch 314/400\n",
      "1/1 - 0s - loss: 0.0235 - mse: 0.0235 - val_loss: 0.0226 - val_mse: 0.0226 - 14ms/epoch - 14ms/step\n",
      "Epoch 315/400\n",
      "1/1 - 0s - loss: 0.0234 - mse: 0.0234 - val_loss: 0.0224 - val_mse: 0.0224 - 15ms/epoch - 15ms/step\n",
      "Epoch 316/400\n",
      "1/1 - 0s - loss: 0.0232 - mse: 0.0232 - val_loss: 0.0222 - val_mse: 0.0222 - 15ms/epoch - 15ms/step\n",
      "Epoch 317/400\n",
      "1/1 - 0s - loss: 0.0230 - mse: 0.0230 - val_loss: 0.0220 - val_mse: 0.0220 - 15ms/epoch - 15ms/step\n",
      "Epoch 318/400\n",
      "1/1 - 0s - loss: 0.0228 - mse: 0.0228 - val_loss: 0.0218 - val_mse: 0.0218 - 15ms/epoch - 15ms/step\n",
      "Epoch 319/400\n",
      "1/1 - 0s - loss: 0.0226 - mse: 0.0226 - val_loss: 0.0216 - val_mse: 0.0216 - 14ms/epoch - 14ms/step\n",
      "Epoch 320/400\n",
      "1/1 - 0s - loss: 0.0224 - mse: 0.0224 - val_loss: 0.0215 - val_mse: 0.0215 - 15ms/epoch - 15ms/step\n",
      "Epoch 321/400\n",
      "1/1 - 0s - loss: 0.0222 - mse: 0.0222 - val_loss: 0.0213 - val_mse: 0.0213 - 15ms/epoch - 15ms/step\n",
      "Epoch 322/400\n",
      "1/1 - 0s - loss: 0.0220 - mse: 0.0220 - val_loss: 0.0211 - val_mse: 0.0211 - 16ms/epoch - 16ms/step\n",
      "Epoch 323/400\n",
      "1/1 - 0s - loss: 0.0219 - mse: 0.0219 - val_loss: 0.0209 - val_mse: 0.0209 - 15ms/epoch - 15ms/step\n",
      "Epoch 324/400\n",
      "1/1 - 0s - loss: 0.0217 - mse: 0.0217 - val_loss: 0.0208 - val_mse: 0.0208 - 14ms/epoch - 14ms/step\n",
      "Epoch 325/400\n",
      "1/1 - 0s - loss: 0.0215 - mse: 0.0215 - val_loss: 0.0206 - val_mse: 0.0206 - 15ms/epoch - 15ms/step\n",
      "Epoch 326/400\n",
      "1/1 - 0s - loss: 0.0213 - mse: 0.0213 - val_loss: 0.0204 - val_mse: 0.0204 - 14ms/epoch - 14ms/step\n",
      "Epoch 327/400\n",
      "1/1 - 0s - loss: 0.0212 - mse: 0.0212 - val_loss: 0.0203 - val_mse: 0.0203 - 15ms/epoch - 15ms/step\n",
      "Epoch 328/400\n",
      "1/1 - 0s - loss: 0.0210 - mse: 0.0210 - val_loss: 0.0201 - val_mse: 0.0201 - 15ms/epoch - 15ms/step\n",
      "Epoch 329/400\n",
      "1/1 - 0s - loss: 0.0208 - mse: 0.0208 - val_loss: 0.0199 - val_mse: 0.0199 - 15ms/epoch - 15ms/step\n",
      "Epoch 330/400\n",
      "1/1 - 0s - loss: 0.0206 - mse: 0.0206 - val_loss: 0.0198 - val_mse: 0.0198 - 16ms/epoch - 16ms/step\n",
      "Epoch 331/400\n",
      "1/1 - 0s - loss: 0.0205 - mse: 0.0205 - val_loss: 0.0196 - val_mse: 0.0196 - 14ms/epoch - 14ms/step\n",
      "Epoch 332/400\n",
      "1/1 - 0s - loss: 0.0203 - mse: 0.0203 - val_loss: 0.0195 - val_mse: 0.0195 - 16ms/epoch - 16ms/step\n",
      "Epoch 333/400\n",
      "1/1 - 0s - loss: 0.0202 - mse: 0.0202 - val_loss: 0.0193 - val_mse: 0.0193 - 15ms/epoch - 15ms/step\n",
      "Epoch 334/400\n",
      "1/1 - 0s - loss: 0.0200 - mse: 0.0200 - val_loss: 0.0191 - val_mse: 0.0191 - 15ms/epoch - 15ms/step\n",
      "Epoch 335/400\n",
      "1/1 - 0s - loss: 0.0198 - mse: 0.0198 - val_loss: 0.0190 - val_mse: 0.0190 - 17ms/epoch - 17ms/step\n",
      "Epoch 336/400\n",
      "1/1 - 0s - loss: 0.0197 - mse: 0.0197 - val_loss: 0.0188 - val_mse: 0.0188 - 14ms/epoch - 14ms/step\n",
      "Epoch 337/400\n",
      "1/1 - 0s - loss: 0.0195 - mse: 0.0195 - val_loss: 0.0187 - val_mse: 0.0187 - 15ms/epoch - 15ms/step\n",
      "Epoch 338/400\n",
      "1/1 - 0s - loss: 0.0194 - mse: 0.0194 - val_loss: 0.0185 - val_mse: 0.0185 - 15ms/epoch - 15ms/step\n",
      "Epoch 339/400\n",
      "1/1 - 0s - loss: 0.0192 - mse: 0.0192 - val_loss: 0.0184 - val_mse: 0.0184 - 14ms/epoch - 14ms/step\n",
      "Epoch 340/400\n",
      "1/1 - 0s - loss: 0.0191 - mse: 0.0191 - val_loss: 0.0182 - val_mse: 0.0182 - 15ms/epoch - 15ms/step\n",
      "Epoch 341/400\n",
      "1/1 - 0s - loss: 0.0189 - mse: 0.0189 - val_loss: 0.0181 - val_mse: 0.0181 - 14ms/epoch - 14ms/step\n",
      "Epoch 342/400\n",
      "1/1 - 0s - loss: 0.0188 - mse: 0.0188 - val_loss: 0.0180 - val_mse: 0.0180 - 14ms/epoch - 14ms/step\n",
      "Epoch 343/400\n",
      "1/1 - 0s - loss: 0.0186 - mse: 0.0186 - val_loss: 0.0178 - val_mse: 0.0178 - 15ms/epoch - 15ms/step\n",
      "Epoch 344/400\n",
      "1/1 - 0s - loss: 0.0185 - mse: 0.0185 - val_loss: 0.0177 - val_mse: 0.0177 - 14ms/epoch - 14ms/step\n",
      "Epoch 345/400\n",
      "1/1 - 0s - loss: 0.0184 - mse: 0.0184 - val_loss: 0.0175 - val_mse: 0.0175 - 14ms/epoch - 14ms/step\n",
      "Epoch 346/400\n",
      "1/1 - 0s - loss: 0.0182 - mse: 0.0182 - val_loss: 0.0174 - val_mse: 0.0174 - 14ms/epoch - 14ms/step\n",
      "Epoch 347/400\n",
      "1/1 - 0s - loss: 0.0181 - mse: 0.0181 - val_loss: 0.0173 - val_mse: 0.0173 - 14ms/epoch - 14ms/step\n",
      "Epoch 348/400\n",
      "1/1 - 0s - loss: 0.0179 - mse: 0.0179 - val_loss: 0.0171 - val_mse: 0.0171 - 13ms/epoch - 13ms/step\n",
      "Epoch 349/400\n",
      "1/1 - 0s - loss: 0.0178 - mse: 0.0178 - val_loss: 0.0170 - val_mse: 0.0170 - 13ms/epoch - 13ms/step\n",
      "Epoch 350/400\n",
      "1/1 - 0s - loss: 0.0177 - mse: 0.0177 - val_loss: 0.0169 - val_mse: 0.0169 - 14ms/epoch - 14ms/step\n",
      "Epoch 351/400\n",
      "1/1 - 0s - loss: 0.0175 - mse: 0.0175 - val_loss: 0.0167 - val_mse: 0.0167 - 14ms/epoch - 14ms/step\n",
      "Epoch 352/400\n",
      "1/1 - 0s - loss: 0.0174 - mse: 0.0174 - val_loss: 0.0166 - val_mse: 0.0166 - 14ms/epoch - 14ms/step\n",
      "Epoch 353/400\n",
      "1/1 - 0s - loss: 0.0173 - mse: 0.0173 - val_loss: 0.0165 - val_mse: 0.0165 - 14ms/epoch - 14ms/step\n",
      "Epoch 354/400\n",
      "1/1 - 0s - loss: 0.0171 - mse: 0.0171 - val_loss: 0.0163 - val_mse: 0.0163 - 14ms/epoch - 14ms/step\n",
      "Epoch 355/400\n",
      "1/1 - 0s - loss: 0.0170 - mse: 0.0170 - val_loss: 0.0162 - val_mse: 0.0162 - 14ms/epoch - 14ms/step\n",
      "Epoch 356/400\n",
      "1/1 - 0s - loss: 0.0169 - mse: 0.0169 - val_loss: 0.0161 - val_mse: 0.0161 - 14ms/epoch - 14ms/step\n",
      "Epoch 357/400\n",
      "1/1 - 0s - loss: 0.0168 - mse: 0.0168 - val_loss: 0.0160 - val_mse: 0.0160 - 15ms/epoch - 15ms/step\n",
      "Epoch 358/400\n",
      "1/1 - 0s - loss: 0.0166 - mse: 0.0166 - val_loss: 0.0158 - val_mse: 0.0158 - 15ms/epoch - 15ms/step\n",
      "Epoch 359/400\n",
      "1/1 - 0s - loss: 0.0165 - mse: 0.0165 - val_loss: 0.0157 - val_mse: 0.0157 - 15ms/epoch - 15ms/step\n",
      "Epoch 360/400\n",
      "1/1 - 0s - loss: 0.0164 - mse: 0.0164 - val_loss: 0.0156 - val_mse: 0.0156 - 14ms/epoch - 14ms/step\n",
      "Epoch 361/400\n",
      "1/1 - 0s - loss: 0.0163 - mse: 0.0163 - val_loss: 0.0155 - val_mse: 0.0155 - 13ms/epoch - 13ms/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 362/400\n",
      "1/1 - 0s - loss: 0.0162 - mse: 0.0162 - val_loss: 0.0153 - val_mse: 0.0153 - 13ms/epoch - 13ms/step\n",
      "Epoch 363/400\n",
      "1/1 - 0s - loss: 0.0160 - mse: 0.0160 - val_loss: 0.0152 - val_mse: 0.0152 - 14ms/epoch - 14ms/step\n",
      "Epoch 364/400\n",
      "1/1 - 0s - loss: 0.0159 - mse: 0.0159 - val_loss: 0.0151 - val_mse: 0.0151 - 15ms/epoch - 15ms/step\n",
      "Epoch 365/400\n",
      "1/1 - 0s - loss: 0.0158 - mse: 0.0158 - val_loss: 0.0150 - val_mse: 0.0150 - 15ms/epoch - 15ms/step\n",
      "Epoch 366/400\n",
      "1/1 - 0s - loss: 0.0157 - mse: 0.0157 - val_loss: 0.0149 - val_mse: 0.0149 - 16ms/epoch - 16ms/step\n",
      "Epoch 367/400\n",
      "1/1 - 0s - loss: 0.0156 - mse: 0.0156 - val_loss: 0.0148 - val_mse: 0.0148 - 15ms/epoch - 15ms/step\n",
      "Epoch 368/400\n",
      "1/1 - 0s - loss: 0.0155 - mse: 0.0155 - val_loss: 0.0147 - val_mse: 0.0147 - 15ms/epoch - 15ms/step\n",
      "Epoch 369/400\n",
      "1/1 - 0s - loss: 0.0154 - mse: 0.0154 - val_loss: 0.0145 - val_mse: 0.0145 - 15ms/epoch - 15ms/step\n",
      "Epoch 370/400\n",
      "1/1 - 0s - loss: 0.0152 - mse: 0.0152 - val_loss: 0.0144 - val_mse: 0.0144 - 14ms/epoch - 14ms/step\n",
      "Epoch 371/400\n",
      "1/1 - 0s - loss: 0.0151 - mse: 0.0151 - val_loss: 0.0143 - val_mse: 0.0143 - 15ms/epoch - 15ms/step\n",
      "Epoch 372/400\n",
      "1/1 - 0s - loss: 0.0150 - mse: 0.0150 - val_loss: 0.0142 - val_mse: 0.0142 - 15ms/epoch - 15ms/step\n",
      "Epoch 373/400\n",
      "1/1 - 0s - loss: 0.0149 - mse: 0.0149 - val_loss: 0.0141 - val_mse: 0.0141 - 15ms/epoch - 15ms/step\n",
      "Epoch 374/400\n",
      "1/1 - 0s - loss: 0.0148 - mse: 0.0148 - val_loss: 0.0140 - val_mse: 0.0140 - 15ms/epoch - 15ms/step\n",
      "Epoch 375/400\n",
      "1/1 - 0s - loss: 0.0147 - mse: 0.0147 - val_loss: 0.0139 - val_mse: 0.0139 - 15ms/epoch - 15ms/step\n",
      "Epoch 376/400\n",
      "1/1 - 0s - loss: 0.0146 - mse: 0.0146 - val_loss: 0.0138 - val_mse: 0.0138 - 14ms/epoch - 14ms/step\n",
      "Epoch 377/400\n",
      "1/1 - 0s - loss: 0.0145 - mse: 0.0145 - val_loss: 0.0137 - val_mse: 0.0137 - 17ms/epoch - 17ms/step\n",
      "Epoch 378/400\n",
      "1/1 - 0s - loss: 0.0144 - mse: 0.0144 - val_loss: 0.0136 - val_mse: 0.0136 - 16ms/epoch - 16ms/step\n",
      "Epoch 379/400\n",
      "1/1 - 0s - loss: 0.0143 - mse: 0.0143 - val_loss: 0.0135 - val_mse: 0.0135 - 16ms/epoch - 16ms/step\n",
      "Epoch 380/400\n",
      "1/1 - 0s - loss: 0.0142 - mse: 0.0142 - val_loss: 0.0134 - val_mse: 0.0134 - 15ms/epoch - 15ms/step\n",
      "Epoch 381/400\n",
      "1/1 - 0s - loss: 0.0141 - mse: 0.0141 - val_loss: 0.0133 - val_mse: 0.0133 - 15ms/epoch - 15ms/step\n",
      "Epoch 382/400\n",
      "1/1 - 0s - loss: 0.0140 - mse: 0.0140 - val_loss: 0.0132 - val_mse: 0.0132 - 14ms/epoch - 14ms/step\n",
      "Epoch 383/400\n",
      "1/1 - 0s - loss: 0.0139 - mse: 0.0139 - val_loss: 0.0131 - val_mse: 0.0131 - 14ms/epoch - 14ms/step\n",
      "Epoch 384/400\n",
      "1/1 - 0s - loss: 0.0138 - mse: 0.0138 - val_loss: 0.0130 - val_mse: 0.0130 - 15ms/epoch - 15ms/step\n",
      "Epoch 385/400\n",
      "1/1 - 0s - loss: 0.0137 - mse: 0.0137 - val_loss: 0.0129 - val_mse: 0.0129 - 15ms/epoch - 15ms/step\n",
      "Epoch 386/400\n",
      "1/1 - 0s - loss: 0.0136 - mse: 0.0136 - val_loss: 0.0128 - val_mse: 0.0128 - 14ms/epoch - 14ms/step\n",
      "Epoch 387/400\n",
      "1/1 - 0s - loss: 0.0135 - mse: 0.0135 - val_loss: 0.0127 - val_mse: 0.0127 - 14ms/epoch - 14ms/step\n",
      "Epoch 388/400\n",
      "1/1 - 0s - loss: 0.0134 - mse: 0.0134 - val_loss: 0.0126 - val_mse: 0.0126 - 14ms/epoch - 14ms/step\n",
      "Epoch 389/400\n",
      "1/1 - 0s - loss: 0.0133 - mse: 0.0133 - val_loss: 0.0125 - val_mse: 0.0125 - 14ms/epoch - 14ms/step\n",
      "Epoch 390/400\n",
      "1/1 - 0s - loss: 0.0132 - mse: 0.0132 - val_loss: 0.0125 - val_mse: 0.0125 - 14ms/epoch - 14ms/step\n",
      "Epoch 391/400\n",
      "1/1 - 0s - loss: 0.0131 - mse: 0.0131 - val_loss: 0.0124 - val_mse: 0.0124 - 15ms/epoch - 15ms/step\n",
      "Epoch 392/400\n",
      "1/1 - 0s - loss: 0.0130 - mse: 0.0130 - val_loss: 0.0123 - val_mse: 0.0123 - 15ms/epoch - 15ms/step\n",
      "Epoch 393/400\n",
      "1/1 - 0s - loss: 0.0129 - mse: 0.0129 - val_loss: 0.0122 - val_mse: 0.0122 - 15ms/epoch - 15ms/step\n",
      "Epoch 394/400\n",
      "1/1 - 0s - loss: 0.0128 - mse: 0.0128 - val_loss: 0.0121 - val_mse: 0.0121 - 15ms/epoch - 15ms/step\n",
      "Epoch 395/400\n",
      "1/1 - 0s - loss: 0.0127 - mse: 0.0127 - val_loss: 0.0120 - val_mse: 0.0120 - 13ms/epoch - 13ms/step\n",
      "Epoch 396/400\n",
      "1/1 - 0s - loss: 0.0126 - mse: 0.0126 - val_loss: 0.0119 - val_mse: 0.0119 - 13ms/epoch - 13ms/step\n",
      "Epoch 397/400\n",
      "1/1 - 0s - loss: 0.0125 - mse: 0.0125 - val_loss: 0.0118 - val_mse: 0.0118 - 13ms/epoch - 13ms/step\n",
      "Epoch 398/400\n",
      "1/1 - 0s - loss: 0.0124 - mse: 0.0124 - val_loss: 0.0118 - val_mse: 0.0118 - 14ms/epoch - 14ms/step\n",
      "Epoch 399/400\n",
      "1/1 - 0s - loss: 0.0123 - mse: 0.0123 - val_loss: 0.0117 - val_mse: 0.0117 - 14ms/epoch - 14ms/step\n",
      "Epoch 400/400\n",
      "1/1 - 0s - loss: 0.0122 - mse: 0.0122 - val_loss: 0.0116 - val_mse: 0.0116 - 15ms/epoch - 15ms/step\n",
      "6.719193696975708\n"
     ]
    }
   ],
   "source": [
    "t0 = time.time()\n",
    "history = final_model_PQ.fit(X_train, Y_train, epochs=400, batch_size=256, validation_split=0.25, verbose=2)\n",
    "t1 = time.time()\n",
    "print(t1-t0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "388b3084",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1/1 [==============================] - 0s 11ms/step - loss: 0.0120 - mse: 0.0120\n",
      "4/4 [==============================] - 0s 669us/step - loss: 0.0144 - mse: 0.0144\n"
     ]
    }
   ],
   "source": [
    "#performance of the pre-trained model on train data\n",
    "loss_and_metrics = final_model_PQ.evaluate(X_train, Y_train, batch_size=256)\n",
    "loss_and_metrics = final_model_PQ.evaluate(X_test,Y_test, batch_size=256)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f9ed7589",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
