{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "539ebd7b",
   "metadata": {},
   "outputs": [],
   "source": [
    "###This code is about develop a FNN model forwater tank in first-principles form\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from sklearn import preprocessing\n",
    "from sklearn.model_selection import train_test_split\n",
    "from sklearn.metrics import mean_absolute_percentage_error\n",
    "from keras.models import Sequential\n",
    "from keras.layers import LSTM, Dense, SimpleRNN, Input, Activation, Dropout\n",
    "from keras import backend as K\n",
    "from tensorflow.keras.optimizers import Adam,SGD\n",
    "import tensorflow as tf\n",
    "from keras.models import Model\n",
    "from keras.models import load_model\n",
    "import time "
   ]
  },
  {
   "cell_type": "markdown",
   "id": "069e2e34",
   "metadata": {},
   "source": [
    "# Generate Source dataset in real value form as target one"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "3a4a2d8e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "shape of x_deviation is (1600, 2)\n"
     ]
    }
   ],
   "source": [
    "# specifying constant parameters\n",
    "\n",
    "k1 = 1\n",
    "k2 = 1\n",
    "k3 = 1\n",
    "k4 = 1\n",
    "\n",
    "t_final = 4  #the control period\n",
    "t_step = 0.1   # the step to use first-principle to calculate the state\n",
    "\n",
    "\n",
    "# generating inputs and initial states\n",
    "u_list = np.linspace(0.5, 4., 10, endpoint=True)\n",
    "x1_initial = np.linspace(2., 10., 40, endpoint=True)\n",
    "x2_initial = np.linspace(2., 10., 40, endpoint=True)   \n",
    "\n",
    "\n",
    "\n",
    "x1_start = list()\n",
    "x2_start = list()\n",
    "\n",
    "for x1 in x1_initial:   \n",
    "    for x2 in x2_initial:\n",
    "        x1_start.append(x1)\n",
    "        x2_start.append(x2)\n",
    "\n",
    "\n",
    "# convert to np.arrays\n",
    "x_deviation = np.concatenate((np.array([x1_start]).T, np.array([x2_start]).T), axis=1)  \n",
    "print(\"shape of x_deviation is {}\".format(x_deviation.shape))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "16075e8a",
   "metadata": {},
   "outputs": [],
   "source": [
    "def tank_simulation(k1,k2,k3,k4, t_final, t_step, u, x1, x2):\n",
    "    \"\"\"\n",
    "        simulating with forward Euler method\n",
    "    \"\"\"\n",
    "    for i in range(int(t_final / t_step)):\n",
    "        dx1 = -k1 * np.sqrt(x1) + k4 * u\n",
    "        dx2 = k2 * np.sqrt(x1) - k3 * np.sqrt(x2)\n",
    "        \n",
    "        x1 += dx1 * t_step\n",
    "        x2 += dx2 * t_step\n",
    "    \n",
    "    return x1,x2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "b400bf04",
   "metadata": {},
   "outputs": [],
   "source": [
    "# get X and y data for training and testing\n",
    "\n",
    "x1_output = list()\n",
    "x2_output = list()\n",
    "\n",
    "x1_input = list()\n",
    "x2_input = list()\n",
    "u_input = list()\n",
    "\n",
    "for u in u_list: \n",
    "    for x1_initial, x2_initial in x_deviation:\n",
    "        u_input.append(u)  \n",
    "        x1_input.append(x1_initial)\n",
    "        x2_input.append(x2_initial)\n",
    "\n",
    "        x1,x2 = tank_simulation(k1,k2,k3,k4, t_final, t_step, u, x1_initial, x2_initial)\n",
    "        x1_output.append(x1) \n",
    "        x2_output.append(x2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "d18fd7d5",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "FNN_input shape is (16000, 3)\n",
      "FNN_output shape is (16000, 2)\n"
     ]
    }
   ],
   "source": [
    "# collate input for RNN\n",
    "FNN_input = np.stack((u_input, x1_input, x2_input), axis=1)   \n",
    "FNN_output = np.stack((x1_output, x2_output), axis=1)  \n",
    "\n",
    "print(\"FNN_input shape is {}\".format(FNN_input.shape))  \n",
    "print(\"FNN_output shape is {}\".format(FNN_output.shape)) "
   ]
  },
  {
   "cell_type": "markdown",
   "id": "aa5fda0a",
   "metadata": {},
   "source": [
    "# normalization using scalers for each process, due to different features"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "c4172f79",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(12000, 3) (4000, 3) (12000, 2) (4000, 2)\n"
     ]
    }
   ],
   "source": [
    "#target data\n",
    "X_train, X_test, y_train, y_test = train_test_split(FNN_input, FNN_output, test_size=0.25, random_state=123)\n",
    "\n",
    "print(X_train.shape, X_test.shape, y_train.shape, y_test.shape)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b1f81109",
   "metadata": {},
   "source": [
    "# Develop the pre-trained model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "25925acb",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/500\n",
      "36/36 - 0s - loss: 17.6741 - mse: 17.6741 - val_loss: 11.0231 - val_mse: 11.0231 - 260ms/epoch - 7ms/step\n",
      "Epoch 2/500\n",
      "36/36 - 0s - loss: 8.0348 - mse: 8.0348 - val_loss: 5.6340 - val_mse: 5.6340 - 29ms/epoch - 798us/step\n",
      "Epoch 3/500\n",
      "36/36 - 0s - loss: 4.9769 - mse: 4.9769 - val_loss: 4.4261 - val_mse: 4.4261 - 30ms/epoch - 833us/step\n",
      "Epoch 4/500\n",
      "36/36 - 0s - loss: 4.1519 - mse: 4.1519 - val_loss: 3.8012 - val_mse: 3.8012 - 28ms/epoch - 781us/step\n",
      "Epoch 5/500\n",
      "36/36 - 0s - loss: 3.5144 - mse: 3.5144 - val_loss: 3.1636 - val_mse: 3.1636 - 28ms/epoch - 773us/step\n",
      "Epoch 6/500\n",
      "36/36 - 0s - loss: 2.8357 - mse: 2.8357 - val_loss: 2.4478 - val_mse: 2.4478 - 31ms/epoch - 873us/step\n",
      "Epoch 7/500\n",
      "36/36 - 0s - loss: 2.1624 - mse: 2.1624 - val_loss: 1.8259 - val_mse: 1.8259 - 36ms/epoch - 995us/step\n",
      "Epoch 8/500\n",
      "36/36 - 0s - loss: 1.5995 - mse: 1.5995 - val_loss: 1.3312 - val_mse: 1.3312 - 28ms/epoch - 782us/step\n",
      "Epoch 9/500\n",
      "36/36 - 0s - loss: 1.1577 - mse: 1.1577 - val_loss: 0.9525 - val_mse: 0.9525 - 29ms/epoch - 816us/step\n",
      "Epoch 10/500\n",
      "36/36 - 0s - loss: 0.8283 - mse: 0.8283 - val_loss: 0.6804 - val_mse: 0.6804 - 30ms/epoch - 822us/step\n",
      "Epoch 11/500\n",
      "36/36 - 0s - loss: 0.5977 - mse: 0.5977 - val_loss: 0.4993 - val_mse: 0.4993 - 27ms/epoch - 761us/step\n",
      "Epoch 12/500\n",
      "36/36 - 0s - loss: 0.4485 - mse: 0.4485 - val_loss: 0.3855 - val_mse: 0.3855 - 27ms/epoch - 748us/step\n",
      "Epoch 13/500\n",
      "36/36 - 0s - loss: 0.3567 - mse: 0.3567 - val_loss: 0.3190 - val_mse: 0.3190 - 28ms/epoch - 776us/step\n",
      "Epoch 14/500\n",
      "36/36 - 0s - loss: 0.3019 - mse: 0.3019 - val_loss: 0.2791 - val_mse: 0.2791 - 29ms/epoch - 810us/step\n",
      "Epoch 15/500\n",
      "36/36 - 0s - loss: 0.2680 - mse: 0.2680 - val_loss: 0.2543 - val_mse: 0.2543 - 28ms/epoch - 783us/step\n",
      "Epoch 16/500\n",
      "36/36 - 0s - loss: 0.2460 - mse: 0.2460 - val_loss: 0.2371 - val_mse: 0.2371 - 28ms/epoch - 784us/step\n",
      "Epoch 17/500\n",
      "36/36 - 0s - loss: 0.2296 - mse: 0.2296 - val_loss: 0.2233 - val_mse: 0.2233 - 30ms/epoch - 838us/step\n",
      "Epoch 18/500\n",
      "36/36 - 0s - loss: 0.2163 - mse: 0.2163 - val_loss: 0.2116 - val_mse: 0.2116 - 29ms/epoch - 814us/step\n",
      "Epoch 19/500\n",
      "36/36 - 0s - loss: 0.2047 - mse: 0.2047 - val_loss: 0.2007 - val_mse: 0.2007 - 29ms/epoch - 813us/step\n",
      "Epoch 20/500\n",
      "36/36 - 0s - loss: 0.1936 - mse: 0.1936 - val_loss: 0.1904 - val_mse: 0.1904 - 28ms/epoch - 789us/step\n",
      "Epoch 21/500\n",
      "36/36 - 0s - loss: 0.1833 - mse: 0.1833 - val_loss: 0.1807 - val_mse: 0.1807 - 28ms/epoch - 782us/step\n",
      "Epoch 22/500\n",
      "36/36 - 0s - loss: 0.1738 - mse: 0.1738 - val_loss: 0.1712 - val_mse: 0.1712 - 29ms/epoch - 803us/step\n",
      "Epoch 23/500\n",
      "36/36 - 0s - loss: 0.1642 - mse: 0.1642 - val_loss: 0.1620 - val_mse: 0.1620 - 29ms/epoch - 805us/step\n",
      "Epoch 24/500\n",
      "36/36 - 0s - loss: 0.1552 - mse: 0.1552 - val_loss: 0.1533 - val_mse: 0.1533 - 29ms/epoch - 814us/step\n",
      "Epoch 25/500\n",
      "36/36 - 0s - loss: 0.1469 - mse: 0.1469 - val_loss: 0.1449 - val_mse: 0.1449 - 31ms/epoch - 875us/step\n",
      "Epoch 26/500\n",
      "36/36 - 0s - loss: 0.1384 - mse: 0.1384 - val_loss: 0.1366 - val_mse: 0.1366 - 29ms/epoch - 793us/step\n",
      "Epoch 27/500\n",
      "36/36 - 0s - loss: 0.1306 - mse: 0.1306 - val_loss: 0.1290 - val_mse: 0.1290 - 31ms/epoch - 867us/step\n",
      "Epoch 28/500\n",
      "36/36 - 0s - loss: 0.1232 - mse: 0.1232 - val_loss: 0.1215 - val_mse: 0.1215 - 28ms/epoch - 791us/step\n",
      "Epoch 29/500\n",
      "36/36 - 0s - loss: 0.1159 - mse: 0.1159 - val_loss: 0.1144 - val_mse: 0.1144 - 29ms/epoch - 808us/step\n",
      "Epoch 30/500\n",
      "36/36 - 0s - loss: 0.1092 - mse: 0.1092 - val_loss: 0.1076 - val_mse: 0.1076 - 28ms/epoch - 773us/step\n",
      "Epoch 31/500\n",
      "36/36 - 0s - loss: 0.1030 - mse: 0.1030 - val_loss: 0.1019 - val_mse: 0.1019 - 32ms/epoch - 888us/step\n",
      "Epoch 32/500\n",
      "36/36 - 0s - loss: 0.0970 - mse: 0.0970 - val_loss: 0.0954 - val_mse: 0.0954 - 28ms/epoch - 772us/step\n",
      "Epoch 33/500\n",
      "36/36 - 0s - loss: 0.0912 - mse: 0.0912 - val_loss: 0.0897 - val_mse: 0.0897 - 29ms/epoch - 794us/step\n",
      "Epoch 34/500\n",
      "36/36 - 0s - loss: 0.0858 - mse: 0.0858 - val_loss: 0.0847 - val_mse: 0.0847 - 30ms/epoch - 833us/step\n",
      "Epoch 35/500\n",
      "36/36 - 0s - loss: 0.0810 - mse: 0.0810 - val_loss: 0.0797 - val_mse: 0.0797 - 27ms/epoch - 754us/step\n",
      "Epoch 36/500\n",
      "36/36 - 0s - loss: 0.0763 - mse: 0.0763 - val_loss: 0.0750 - val_mse: 0.0750 - 27ms/epoch - 759us/step\n",
      "Epoch 37/500\n",
      "36/36 - 0s - loss: 0.0718 - mse: 0.0718 - val_loss: 0.0706 - val_mse: 0.0706 - 29ms/epoch - 809us/step\n",
      "Epoch 38/500\n",
      "36/36 - 0s - loss: 0.0677 - mse: 0.0677 - val_loss: 0.0666 - val_mse: 0.0666 - 29ms/epoch - 799us/step\n",
      "Epoch 39/500\n",
      "36/36 - 0s - loss: 0.0640 - mse: 0.0640 - val_loss: 0.0628 - val_mse: 0.0628 - 28ms/epoch - 764us/step\n",
      "Epoch 40/500\n",
      "36/36 - 0s - loss: 0.0604 - mse: 0.0604 - val_loss: 0.0594 - val_mse: 0.0594 - 29ms/epoch - 796us/step\n",
      "Epoch 41/500\n",
      "36/36 - 0s - loss: 0.0571 - mse: 0.0571 - val_loss: 0.0562 - val_mse: 0.0562 - 31ms/epoch - 854us/step\n",
      "Epoch 42/500\n",
      "36/36 - 0s - loss: 0.0541 - mse: 0.0541 - val_loss: 0.0532 - val_mse: 0.0532 - 29ms/epoch - 803us/step\n",
      "Epoch 43/500\n",
      "36/36 - 0s - loss: 0.0514 - mse: 0.0514 - val_loss: 0.0505 - val_mse: 0.0505 - 29ms/epoch - 813us/step\n",
      "Epoch 44/500\n",
      "36/36 - 0s - loss: 0.0489 - mse: 0.0489 - val_loss: 0.0481 - val_mse: 0.0481 - 28ms/epoch - 772us/step\n",
      "Epoch 45/500\n",
      "36/36 - 0s - loss: 0.0466 - mse: 0.0466 - val_loss: 0.0459 - val_mse: 0.0459 - 28ms/epoch - 778us/step\n",
      "Epoch 46/500\n",
      "36/36 - 0s - loss: 0.0445 - mse: 0.0445 - val_loss: 0.0439 - val_mse: 0.0439 - 29ms/epoch - 807us/step\n",
      "Epoch 47/500\n",
      "36/36 - 0s - loss: 0.0426 - mse: 0.0426 - val_loss: 0.0421 - val_mse: 0.0421 - 29ms/epoch - 806us/step\n",
      "Epoch 48/500\n",
      "36/36 - 0s - loss: 0.0410 - mse: 0.0410 - val_loss: 0.0404 - val_mse: 0.0404 - 27ms/epoch - 760us/step\n",
      "Epoch 49/500\n",
      "36/36 - 0s - loss: 0.0393 - mse: 0.0393 - val_loss: 0.0389 - val_mse: 0.0389 - 28ms/epoch - 773us/step\n",
      "Epoch 50/500\n",
      "36/36 - 0s - loss: 0.0379 - mse: 0.0379 - val_loss: 0.0376 - val_mse: 0.0376 - 31ms/epoch - 850us/step\n",
      "Epoch 51/500\n",
      "36/36 - 0s - loss: 0.0366 - mse: 0.0366 - val_loss: 0.0364 - val_mse: 0.0364 - 30ms/epoch - 841us/step\n",
      "Epoch 52/500\n",
      "36/36 - 0s - loss: 0.0355 - mse: 0.0355 - val_loss: 0.0352 - val_mse: 0.0352 - 30ms/epoch - 820us/step\n",
      "Epoch 53/500\n",
      "36/36 - 0s - loss: 0.0345 - mse: 0.0345 - val_loss: 0.0342 - val_mse: 0.0342 - 27ms/epoch - 763us/step\n",
      "Epoch 54/500\n",
      "36/36 - 0s - loss: 0.0336 - mse: 0.0336 - val_loss: 0.0333 - val_mse: 0.0333 - 29ms/epoch - 794us/step\n",
      "Epoch 55/500\n",
      "36/36 - 0s - loss: 0.0327 - mse: 0.0327 - val_loss: 0.0326 - val_mse: 0.0326 - 29ms/epoch - 806us/step\n",
      "Epoch 56/500\n",
      "36/36 - 0s - loss: 0.0321 - mse: 0.0321 - val_loss: 0.0319 - val_mse: 0.0319 - 29ms/epoch - 819us/step\n",
      "Epoch 57/500\n",
      "36/36 - 0s - loss: 0.0314 - mse: 0.0314 - val_loss: 0.0312 - val_mse: 0.0312 - 32ms/epoch - 893us/step\n",
      "Epoch 58/500\n",
      "36/36 - 0s - loss: 0.0308 - mse: 0.0308 - val_loss: 0.0307 - val_mse: 0.0307 - 28ms/epoch - 764us/step\n",
      "Epoch 59/500\n",
      "36/36 - 0s - loss: 0.0303 - mse: 0.0303 - val_loss: 0.0302 - val_mse: 0.0302 - 28ms/epoch - 767us/step\n",
      "Epoch 60/500\n",
      "36/36 - 0s - loss: 0.0298 - mse: 0.0298 - val_loss: 0.0297 - val_mse: 0.0297 - 30ms/epoch - 847us/step\n",
      "Epoch 61/500\n",
      "36/36 - 0s - loss: 0.0294 - mse: 0.0294 - val_loss: 0.0294 - val_mse: 0.0294 - 29ms/epoch - 794us/step\n",
      "Epoch 62/500\n",
      "36/36 - 0s - loss: 0.0291 - mse: 0.0291 - val_loss: 0.0291 - val_mse: 0.0291 - 29ms/epoch - 801us/step\n",
      "Epoch 63/500\n",
      "36/36 - 0s - loss: 0.0287 - mse: 0.0287 - val_loss: 0.0286 - val_mse: 0.0286 - 28ms/epoch - 785us/step\n",
      "Epoch 64/500\n",
      "36/36 - 0s - loss: 0.0284 - mse: 0.0284 - val_loss: 0.0283 - val_mse: 0.0283 - 28ms/epoch - 787us/step\n",
      "Epoch 65/500\n",
      "36/36 - 0s - loss: 0.0281 - mse: 0.0281 - val_loss: 0.0280 - val_mse: 0.0280 - 28ms/epoch - 791us/step\n",
      "Epoch 66/500\n",
      "36/36 - 0s - loss: 0.0278 - mse: 0.0278 - val_loss: 0.0277 - val_mse: 0.0277 - 30ms/epoch - 820us/step\n",
      "Epoch 67/500\n",
      "36/36 - 0s - loss: 0.0276 - mse: 0.0276 - val_loss: 0.0274 - val_mse: 0.0274 - 28ms/epoch - 764us/step\n",
      "Epoch 68/500\n",
      "36/36 - 0s - loss: 0.0273 - mse: 0.0273 - val_loss: 0.0272 - val_mse: 0.0272 - 28ms/epoch - 779us/step\n",
      "Epoch 69/500\n",
      "36/36 - 0s - loss: 0.0271 - mse: 0.0271 - val_loss: 0.0269 - val_mse: 0.0269 - 28ms/epoch - 784us/step\n",
      "Epoch 70/500\n",
      "36/36 - 0s - loss: 0.0269 - mse: 0.0269 - val_loss: 0.0266 - val_mse: 0.0266 - 29ms/epoch - 818us/step\n",
      "Epoch 71/500\n",
      "36/36 - 0s - loss: 0.0267 - mse: 0.0267 - val_loss: 0.0264 - val_mse: 0.0264 - 28ms/epoch - 768us/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 72/500\n",
      "36/36 - 0s - loss: 0.0265 - mse: 0.0265 - val_loss: 0.0262 - val_mse: 0.0262 - 28ms/epoch - 775us/step\n",
      "Epoch 73/500\n",
      "36/36 - 0s - loss: 0.0262 - mse: 0.0262 - val_loss: 0.0259 - val_mse: 0.0259 - 28ms/epoch - 779us/step\n",
      "Epoch 74/500\n",
      "36/36 - 0s - loss: 0.0260 - mse: 0.0260 - val_loss: 0.0257 - val_mse: 0.0257 - 30ms/epoch - 828us/step\n",
      "Epoch 75/500\n",
      "36/36 - 0s - loss: 0.0258 - mse: 0.0258 - val_loss: 0.0254 - val_mse: 0.0254 - 29ms/epoch - 794us/step\n",
      "Epoch 76/500\n",
      "36/36 - 0s - loss: 0.0256 - mse: 0.0256 - val_loss: 0.0254 - val_mse: 0.0254 - 28ms/epoch - 775us/step\n",
      "Epoch 77/500\n",
      "36/36 - 0s - loss: 0.0255 - mse: 0.0255 - val_loss: 0.0251 - val_mse: 0.0251 - 29ms/epoch - 805us/step\n",
      "Epoch 78/500\n",
      "36/36 - 0s - loss: 0.0252 - mse: 0.0252 - val_loss: 0.0249 - val_mse: 0.0249 - 29ms/epoch - 808us/step\n",
      "Epoch 79/500\n",
      "36/36 - 0s - loss: 0.0251 - mse: 0.0251 - val_loss: 0.0248 - val_mse: 0.0248 - 28ms/epoch - 772us/step\n",
      "Epoch 80/500\n",
      "36/36 - 0s - loss: 0.0250 - mse: 0.0250 - val_loss: 0.0245 - val_mse: 0.0245 - 29ms/epoch - 797us/step\n",
      "Epoch 81/500\n",
      "36/36 - 0s - loss: 0.0247 - mse: 0.0247 - val_loss: 0.0243 - val_mse: 0.0243 - 30ms/epoch - 836us/step\n",
      "Epoch 82/500\n",
      "36/36 - 0s - loss: 0.0245 - mse: 0.0245 - val_loss: 0.0241 - val_mse: 0.0241 - 30ms/epoch - 836us/step\n",
      "Epoch 83/500\n",
      "36/36 - 0s - loss: 0.0243 - mse: 0.0243 - val_loss: 0.0239 - val_mse: 0.0239 - 29ms/epoch - 801us/step\n",
      "Epoch 84/500\n",
      "36/36 - 0s - loss: 0.0241 - mse: 0.0241 - val_loss: 0.0237 - val_mse: 0.0237 - 30ms/epoch - 845us/step\n",
      "Epoch 85/500\n",
      "36/36 - 0s - loss: 0.0240 - mse: 0.0240 - val_loss: 0.0234 - val_mse: 0.0234 - 28ms/epoch - 785us/step\n",
      "Epoch 86/500\n",
      "36/36 - 0s - loss: 0.0237 - mse: 0.0237 - val_loss: 0.0233 - val_mse: 0.0233 - 28ms/epoch - 786us/step\n",
      "Epoch 87/500\n",
      "36/36 - 0s - loss: 0.0236 - mse: 0.0236 - val_loss: 0.0231 - val_mse: 0.0231 - 36ms/epoch - 989us/step\n",
      "Epoch 88/500\n",
      "36/36 - 0s - loss: 0.0234 - mse: 0.0234 - val_loss: 0.0230 - val_mse: 0.0230 - 35ms/epoch - 968us/step\n",
      "Epoch 89/500\n",
      "36/36 - 0s - loss: 0.0232 - mse: 0.0232 - val_loss: 0.0228 - val_mse: 0.0228 - 35ms/epoch - 965us/step\n",
      "Epoch 90/500\n",
      "36/36 - 0s - loss: 0.0231 - mse: 0.0231 - val_loss: 0.0230 - val_mse: 0.0230 - 33ms/epoch - 913us/step\n",
      "Epoch 91/500\n",
      "36/36 - 0s - loss: 0.0229 - mse: 0.0229 - val_loss: 0.0224 - val_mse: 0.0224 - 33ms/epoch - 907us/step\n",
      "Epoch 92/500\n",
      "36/36 - 0s - loss: 0.0227 - mse: 0.0227 - val_loss: 0.0221 - val_mse: 0.0221 - 36ms/epoch - 995us/step\n",
      "Epoch 93/500\n",
      "36/36 - 0s - loss: 0.0225 - mse: 0.0225 - val_loss: 0.0219 - val_mse: 0.0219 - 28ms/epoch - 791us/step\n",
      "Epoch 94/500\n",
      "36/36 - 0s - loss: 0.0222 - mse: 0.0222 - val_loss: 0.0218 - val_mse: 0.0218 - 31ms/epoch - 849us/step\n",
      "Epoch 95/500\n",
      "36/36 - 0s - loss: 0.0221 - mse: 0.0221 - val_loss: 0.0215 - val_mse: 0.0215 - 28ms/epoch - 771us/step\n",
      "Epoch 96/500\n",
      "36/36 - 0s - loss: 0.0218 - mse: 0.0218 - val_loss: 0.0215 - val_mse: 0.0215 - 29ms/epoch - 818us/step\n",
      "Epoch 97/500\n",
      "36/36 - 0s - loss: 0.0218 - mse: 0.0218 - val_loss: 0.0212 - val_mse: 0.0212 - 32ms/epoch - 887us/step\n",
      "Epoch 98/500\n",
      "36/36 - 0s - loss: 0.0216 - mse: 0.0216 - val_loss: 0.0209 - val_mse: 0.0209 - 30ms/epoch - 822us/step\n",
      "Epoch 99/500\n",
      "36/36 - 0s - loss: 0.0213 - mse: 0.0213 - val_loss: 0.0208 - val_mse: 0.0208 - 32ms/epoch - 882us/step\n",
      "Epoch 100/500\n",
      "36/36 - 0s - loss: 0.0210 - mse: 0.0210 - val_loss: 0.0205 - val_mse: 0.0205 - 32ms/epoch - 894us/step\n",
      "Epoch 101/500\n",
      "36/36 - 0s - loss: 0.0209 - mse: 0.0209 - val_loss: 0.0204 - val_mse: 0.0204 - 28ms/epoch - 779us/step\n",
      "Epoch 102/500\n",
      "36/36 - 0s - loss: 0.0206 - mse: 0.0206 - val_loss: 0.0201 - val_mse: 0.0201 - 29ms/epoch - 802us/step\n",
      "Epoch 103/500\n",
      "36/36 - 0s - loss: 0.0204 - mse: 0.0204 - val_loss: 0.0199 - val_mse: 0.0199 - 28ms/epoch - 774us/step\n",
      "Epoch 104/500\n",
      "36/36 - 0s - loss: 0.0202 - mse: 0.0202 - val_loss: 0.0197 - val_mse: 0.0197 - 29ms/epoch - 808us/step\n",
      "Epoch 105/500\n",
      "36/36 - 0s - loss: 0.0200 - mse: 0.0200 - val_loss: 0.0194 - val_mse: 0.0194 - 29ms/epoch - 800us/step\n",
      "Epoch 106/500\n",
      "36/36 - 0s - loss: 0.0198 - mse: 0.0198 - val_loss: 0.0192 - val_mse: 0.0192 - 28ms/epoch - 775us/step\n",
      "Epoch 107/500\n",
      "36/36 - 0s - loss: 0.0195 - mse: 0.0195 - val_loss: 0.0190 - val_mse: 0.0190 - 27ms/epoch - 757us/step\n",
      "Epoch 108/500\n",
      "36/36 - 0s - loss: 0.0193 - mse: 0.0193 - val_loss: 0.0188 - val_mse: 0.0188 - 29ms/epoch - 816us/step\n",
      "Epoch 109/500\n",
      "36/36 - 0s - loss: 0.0191 - mse: 0.0191 - val_loss: 0.0187 - val_mse: 0.0187 - 31ms/epoch - 871us/step\n",
      "Epoch 110/500\n",
      "36/36 - 0s - loss: 0.0189 - mse: 0.0189 - val_loss: 0.0184 - val_mse: 0.0184 - 34ms/epoch - 939us/step\n",
      "Epoch 111/500\n",
      "36/36 - 0s - loss: 0.0186 - mse: 0.0186 - val_loss: 0.0181 - val_mse: 0.0181 - 41ms/epoch - 1ms/step\n",
      "Epoch 112/500\n",
      "36/36 - 0s - loss: 0.0184 - mse: 0.0184 - val_loss: 0.0179 - val_mse: 0.0179 - 36ms/epoch - 1ms/step\n",
      "Epoch 113/500\n",
      "36/36 - 0s - loss: 0.0182 - mse: 0.0182 - val_loss: 0.0177 - val_mse: 0.0177 - 34ms/epoch - 940us/step\n",
      "Epoch 114/500\n",
      "36/36 - 0s - loss: 0.0179 - mse: 0.0179 - val_loss: 0.0175 - val_mse: 0.0175 - 31ms/epoch - 870us/step\n",
      "Epoch 115/500\n",
      "36/36 - 0s - loss: 0.0177 - mse: 0.0177 - val_loss: 0.0172 - val_mse: 0.0172 - 32ms/epoch - 900us/step\n",
      "Epoch 116/500\n",
      "36/36 - 0s - loss: 0.0174 - mse: 0.0174 - val_loss: 0.0172 - val_mse: 0.0172 - 33ms/epoch - 927us/step\n",
      "Epoch 117/500\n",
      "36/36 - 0s - loss: 0.0172 - mse: 0.0172 - val_loss: 0.0167 - val_mse: 0.0167 - 31ms/epoch - 870us/step\n",
      "Epoch 118/500\n",
      "36/36 - 0s - loss: 0.0170 - mse: 0.0170 - val_loss: 0.0164 - val_mse: 0.0164 - 27ms/epoch - 758us/step\n",
      "Epoch 119/500\n",
      "36/36 - 0s - loss: 0.0166 - mse: 0.0166 - val_loss: 0.0162 - val_mse: 0.0162 - 27ms/epoch - 764us/step\n",
      "Epoch 120/500\n",
      "36/36 - 0s - loss: 0.0163 - mse: 0.0163 - val_loss: 0.0160 - val_mse: 0.0160 - 31ms/epoch - 849us/step\n",
      "Epoch 121/500\n",
      "36/36 - 0s - loss: 0.0161 - mse: 0.0161 - val_loss: 0.0158 - val_mse: 0.0158 - 29ms/epoch - 806us/step\n",
      "Epoch 122/500\n",
      "36/36 - 0s - loss: 0.0159 - mse: 0.0159 - val_loss: 0.0155 - val_mse: 0.0155 - 29ms/epoch - 809us/step\n",
      "Epoch 123/500\n",
      "36/36 - 0s - loss: 0.0157 - mse: 0.0157 - val_loss: 0.0152 - val_mse: 0.0152 - 27ms/epoch - 763us/step\n",
      "Epoch 124/500\n",
      "36/36 - 0s - loss: 0.0153 - mse: 0.0153 - val_loss: 0.0149 - val_mse: 0.0149 - 30ms/epoch - 824us/step\n",
      "Epoch 125/500\n",
      "36/36 - 0s - loss: 0.0151 - mse: 0.0151 - val_loss: 0.0148 - val_mse: 0.0148 - 30ms/epoch - 828us/step\n",
      "Epoch 126/500\n",
      "36/36 - 0s - loss: 0.0148 - mse: 0.0148 - val_loss: 0.0144 - val_mse: 0.0144 - 28ms/epoch - 775us/step\n",
      "Epoch 127/500\n",
      "36/36 - 0s - loss: 0.0145 - mse: 0.0145 - val_loss: 0.0141 - val_mse: 0.0141 - 30ms/epoch - 828us/step\n",
      "Epoch 128/500\n",
      "36/36 - 0s - loss: 0.0142 - mse: 0.0142 - val_loss: 0.0138 - val_mse: 0.0138 - 28ms/epoch - 770us/step\n",
      "Epoch 129/500\n",
      "36/36 - 0s - loss: 0.0139 - mse: 0.0139 - val_loss: 0.0137 - val_mse: 0.0137 - 31ms/epoch - 848us/step\n",
      "Epoch 130/500\n",
      "36/36 - 0s - loss: 0.0136 - mse: 0.0136 - val_loss: 0.0133 - val_mse: 0.0133 - 35ms/epoch - 974us/step\n",
      "Epoch 131/500\n",
      "36/36 - 0s - loss: 0.0134 - mse: 0.0134 - val_loss: 0.0129 - val_mse: 0.0129 - 33ms/epoch - 917us/step\n",
      "Epoch 132/500\n",
      "36/36 - 0s - loss: 0.0130 - mse: 0.0130 - val_loss: 0.0126 - val_mse: 0.0126 - 34ms/epoch - 947us/step\n",
      "Epoch 133/500\n",
      "36/36 - 0s - loss: 0.0127 - mse: 0.0127 - val_loss: 0.0123 - val_mse: 0.0123 - 36ms/epoch - 989us/step\n",
      "Epoch 134/500\n",
      "36/36 - 0s - loss: 0.0124 - mse: 0.0124 - val_loss: 0.0120 - val_mse: 0.0120 - 34ms/epoch - 938us/step\n",
      "Epoch 135/500\n",
      "36/36 - 0s - loss: 0.0121 - mse: 0.0121 - val_loss: 0.0117 - val_mse: 0.0117 - 33ms/epoch - 920us/step\n",
      "Epoch 136/500\n",
      "36/36 - 0s - loss: 0.0118 - mse: 0.0118 - val_loss: 0.0114 - val_mse: 0.0114 - 32ms/epoch - 902us/step\n",
      "Epoch 137/500\n",
      "36/36 - 0s - loss: 0.0115 - mse: 0.0115 - val_loss: 0.0112 - val_mse: 0.0112 - 28ms/epoch - 781us/step\n",
      "Epoch 138/500\n",
      "36/36 - 0s - loss: 0.0113 - mse: 0.0113 - val_loss: 0.0109 - val_mse: 0.0109 - 28ms/epoch - 787us/step\n",
      "Epoch 139/500\n",
      "36/36 - 0s - loss: 0.0110 - mse: 0.0110 - val_loss: 0.0108 - val_mse: 0.0108 - 29ms/epoch - 814us/step\n",
      "Epoch 140/500\n",
      "36/36 - 0s - loss: 0.0107 - mse: 0.0107 - val_loss: 0.0103 - val_mse: 0.0103 - 32ms/epoch - 884us/step\n",
      "Epoch 141/500\n",
      "36/36 - 0s - loss: 0.0105 - mse: 0.0105 - val_loss: 0.0104 - val_mse: 0.0104 - 30ms/epoch - 829us/step\n",
      "Epoch 142/500\n",
      "36/36 - 0s - loss: 0.0103 - mse: 0.0103 - val_loss: 0.0098 - val_mse: 0.0098 - 33ms/epoch - 907us/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 143/500\n",
      "36/36 - 0s - loss: 0.0099 - mse: 0.0099 - val_loss: 0.0095 - val_mse: 0.0095 - 35ms/epoch - 970us/step\n",
      "Epoch 144/500\n",
      "36/36 - 0s - loss: 0.0097 - mse: 0.0097 - val_loss: 0.0093 - val_mse: 0.0093 - 32ms/epoch - 878us/step\n",
      "Epoch 145/500\n",
      "36/36 - 0s - loss: 0.0094 - mse: 0.0094 - val_loss: 0.0090 - val_mse: 0.0090 - 31ms/epoch - 861us/step\n",
      "Epoch 146/500\n",
      "36/36 - 0s - loss: 0.0091 - mse: 0.0091 - val_loss: 0.0089 - val_mse: 0.0089 - 31ms/epoch - 872us/step\n",
      "Epoch 147/500\n",
      "36/36 - 0s - loss: 0.0089 - mse: 0.0089 - val_loss: 0.0086 - val_mse: 0.0086 - 30ms/epoch - 838us/step\n",
      "Epoch 148/500\n",
      "36/36 - 0s - loss: 0.0087 - mse: 0.0087 - val_loss: 0.0084 - val_mse: 0.0084 - 30ms/epoch - 832us/step\n",
      "Epoch 149/500\n",
      "36/36 - 0s - loss: 0.0084 - mse: 0.0084 - val_loss: 0.0081 - val_mse: 0.0081 - 29ms/epoch - 805us/step\n",
      "Epoch 150/500\n",
      "36/36 - 0s - loss: 0.0082 - mse: 0.0082 - val_loss: 0.0079 - val_mse: 0.0079 - 28ms/epoch - 779us/step\n",
      "Epoch 151/500\n",
      "36/36 - 0s - loss: 0.0080 - mse: 0.0080 - val_loss: 0.0078 - val_mse: 0.0078 - 31ms/epoch - 857us/step\n",
      "Epoch 152/500\n",
      "36/36 - 0s - loss: 0.0078 - mse: 0.0078 - val_loss: 0.0076 - val_mse: 0.0076 - 30ms/epoch - 827us/step\n",
      "Epoch 153/500\n",
      "36/36 - 0s - loss: 0.0076 - mse: 0.0076 - val_loss: 0.0077 - val_mse: 0.0077 - 30ms/epoch - 826us/step\n",
      "Epoch 154/500\n",
      "36/36 - 0s - loss: 0.0074 - mse: 0.0074 - val_loss: 0.0071 - val_mse: 0.0071 - 30ms/epoch - 847us/step\n",
      "Epoch 155/500\n",
      "36/36 - 0s - loss: 0.0072 - mse: 0.0072 - val_loss: 0.0070 - val_mse: 0.0070 - 30ms/epoch - 829us/step\n",
      "Epoch 156/500\n",
      "36/36 - 0s - loss: 0.0070 - mse: 0.0070 - val_loss: 0.0068 - val_mse: 0.0068 - 28ms/epoch - 767us/step\n",
      "Epoch 157/500\n",
      "36/36 - 0s - loss: 0.0068 - mse: 0.0068 - val_loss: 0.0067 - val_mse: 0.0067 - 30ms/epoch - 828us/step\n",
      "Epoch 158/500\n",
      "36/36 - 0s - loss: 0.0067 - mse: 0.0067 - val_loss: 0.0066 - val_mse: 0.0066 - 30ms/epoch - 832us/step\n",
      "Epoch 159/500\n",
      "36/36 - 0s - loss: 0.0065 - mse: 0.0065 - val_loss: 0.0064 - val_mse: 0.0064 - 29ms/epoch - 812us/step\n",
      "Epoch 160/500\n",
      "36/36 - 0s - loss: 0.0064 - mse: 0.0064 - val_loss: 0.0062 - val_mse: 0.0062 - 30ms/epoch - 837us/step\n",
      "Epoch 161/500\n",
      "36/36 - 0s - loss: 0.0062 - mse: 0.0062 - val_loss: 0.0062 - val_mse: 0.0062 - 28ms/epoch - 777us/step\n",
      "Epoch 162/500\n",
      "36/36 - 0s - loss: 0.0061 - mse: 0.0061 - val_loss: 0.0059 - val_mse: 0.0059 - 29ms/epoch - 802us/step\n",
      "Epoch 163/500\n",
      "36/36 - 0s - loss: 0.0059 - mse: 0.0059 - val_loss: 0.0058 - val_mse: 0.0058 - 30ms/epoch - 839us/step\n",
      "Epoch 164/500\n",
      "36/36 - 0s - loss: 0.0058 - mse: 0.0058 - val_loss: 0.0056 - val_mse: 0.0056 - 28ms/epoch - 780us/step\n",
      "Epoch 165/500\n",
      "36/36 - 0s - loss: 0.0057 - mse: 0.0057 - val_loss: 0.0056 - val_mse: 0.0056 - 30ms/epoch - 824us/step\n",
      "Epoch 166/500\n",
      "36/36 - 0s - loss: 0.0055 - mse: 0.0055 - val_loss: 0.0054 - val_mse: 0.0054 - 28ms/epoch - 777us/step\n",
      "Epoch 167/500\n",
      "36/36 - 0s - loss: 0.0055 - mse: 0.0055 - val_loss: 0.0053 - val_mse: 0.0053 - 29ms/epoch - 799us/step\n",
      "Epoch 168/500\n",
      "36/36 - 0s - loss: 0.0054 - mse: 0.0054 - val_loss: 0.0052 - val_mse: 0.0052 - 30ms/epoch - 820us/step\n",
      "Epoch 169/500\n",
      "36/36 - 0s - loss: 0.0053 - mse: 0.0053 - val_loss: 0.0051 - val_mse: 0.0051 - 33ms/epoch - 920us/step\n",
      "Epoch 170/500\n",
      "36/36 - 0s - loss: 0.0051 - mse: 0.0051 - val_loss: 0.0050 - val_mse: 0.0050 - 32ms/epoch - 895us/step\n",
      "Epoch 171/500\n",
      "36/36 - 0s - loss: 0.0050 - mse: 0.0050 - val_loss: 0.0049 - val_mse: 0.0049 - 29ms/epoch - 810us/step\n",
      "Epoch 172/500\n",
      "36/36 - 0s - loss: 0.0049 - mse: 0.0049 - val_loss: 0.0048 - val_mse: 0.0048 - 31ms/epoch - 869us/step\n",
      "Epoch 173/500\n",
      "36/36 - 0s - loss: 0.0049 - mse: 0.0049 - val_loss: 0.0049 - val_mse: 0.0049 - 32ms/epoch - 883us/step\n",
      "Epoch 174/500\n",
      "36/36 - 0s - loss: 0.0048 - mse: 0.0048 - val_loss: 0.0047 - val_mse: 0.0047 - 29ms/epoch - 799us/step\n",
      "Epoch 175/500\n",
      "36/36 - 0s - loss: 0.0047 - mse: 0.0047 - val_loss: 0.0046 - val_mse: 0.0046 - 29ms/epoch - 797us/step\n",
      "Epoch 176/500\n",
      "36/36 - 0s - loss: 0.0046 - mse: 0.0046 - val_loss: 0.0045 - val_mse: 0.0045 - 35ms/epoch - 980us/step\n",
      "Epoch 177/500\n",
      "36/36 - 0s - loss: 0.0046 - mse: 0.0046 - val_loss: 0.0044 - val_mse: 0.0044 - 36ms/epoch - 1ms/step\n",
      "Epoch 178/500\n",
      "36/36 - 0s - loss: 0.0045 - mse: 0.0045 - val_loss: 0.0044 - val_mse: 0.0044 - 34ms/epoch - 934us/step\n",
      "Epoch 179/500\n",
      "36/36 - 0s - loss: 0.0044 - mse: 0.0044 - val_loss: 0.0044 - val_mse: 0.0044 - 33ms/epoch - 915us/step\n",
      "Epoch 180/500\n",
      "36/36 - 0s - loss: 0.0044 - mse: 0.0044 - val_loss: 0.0045 - val_mse: 0.0045 - 33ms/epoch - 907us/step\n",
      "Epoch 181/500\n",
      "36/36 - 0s - loss: 0.0044 - mse: 0.0044 - val_loss: 0.0042 - val_mse: 0.0042 - 33ms/epoch - 916us/step\n",
      "Epoch 182/500\n",
      "36/36 - 0s - loss: 0.0043 - mse: 0.0043 - val_loss: 0.0042 - val_mse: 0.0042 - 33ms/epoch - 927us/step\n",
      "Epoch 183/500\n",
      "36/36 - 0s - loss: 0.0043 - mse: 0.0043 - val_loss: 0.0042 - val_mse: 0.0042 - 32ms/epoch - 882us/step\n",
      "Epoch 184/500\n",
      "36/36 - 0s - loss: 0.0042 - mse: 0.0042 - val_loss: 0.0041 - val_mse: 0.0041 - 31ms/epoch - 848us/step\n",
      "Epoch 185/500\n",
      "36/36 - 0s - loss: 0.0042 - mse: 0.0042 - val_loss: 0.0041 - val_mse: 0.0041 - 28ms/epoch - 775us/step\n",
      "Epoch 186/500\n",
      "36/36 - 0s - loss: 0.0041 - mse: 0.0041 - val_loss: 0.0041 - val_mse: 0.0041 - 28ms/epoch - 781us/step\n",
      "Epoch 187/500\n",
      "36/36 - 0s - loss: 0.0041 - mse: 0.0041 - val_loss: 0.0040 - val_mse: 0.0040 - 32ms/epoch - 876us/step\n",
      "Epoch 188/500\n",
      "36/36 - 0s - loss: 0.0041 - mse: 0.0041 - val_loss: 0.0040 - val_mse: 0.0040 - 30ms/epoch - 820us/step\n",
      "Epoch 189/500\n",
      "36/36 - 0s - loss: 0.0040 - mse: 0.0040 - val_loss: 0.0039 - val_mse: 0.0039 - 33ms/epoch - 917us/step\n",
      "Epoch 190/500\n",
      "36/36 - 0s - loss: 0.0040 - mse: 0.0040 - val_loss: 0.0040 - val_mse: 0.0040 - 39ms/epoch - 1ms/step\n",
      "Epoch 191/500\n",
      "36/36 - 0s - loss: 0.0040 - mse: 0.0040 - val_loss: 0.0039 - val_mse: 0.0039 - 37ms/epoch - 1ms/step\n",
      "Epoch 192/500\n",
      "36/36 - 0s - loss: 0.0039 - mse: 0.0039 - val_loss: 0.0039 - val_mse: 0.0039 - 34ms/epoch - 949us/step\n",
      "Epoch 193/500\n",
      "36/36 - 0s - loss: 0.0039 - mse: 0.0039 - val_loss: 0.0038 - val_mse: 0.0038 - 33ms/epoch - 903us/step\n",
      "Epoch 194/500\n",
      "36/36 - 0s - loss: 0.0039 - mse: 0.0039 - val_loss: 0.0038 - val_mse: 0.0038 - 32ms/epoch - 896us/step\n",
      "Epoch 195/500\n",
      "36/36 - 0s - loss: 0.0039 - mse: 0.0039 - val_loss: 0.0039 - val_mse: 0.0039 - 32ms/epoch - 901us/step\n",
      "Epoch 196/500\n",
      "36/36 - 0s - loss: 0.0038 - mse: 0.0038 - val_loss: 0.0038 - val_mse: 0.0038 - 32ms/epoch - 878us/step\n",
      "Epoch 197/500\n",
      "36/36 - 0s - loss: 0.0038 - mse: 0.0038 - val_loss: 0.0038 - val_mse: 0.0038 - 33ms/epoch - 925us/step\n",
      "Epoch 198/500\n",
      "36/36 - 0s - loss: 0.0039 - mse: 0.0039 - val_loss: 0.0039 - val_mse: 0.0039 - 34ms/epoch - 943us/step\n",
      "Epoch 199/500\n",
      "36/36 - 0s - loss: 0.0038 - mse: 0.0038 - val_loss: 0.0038 - val_mse: 0.0038 - 33ms/epoch - 921us/step\n",
      "Epoch 200/500\n",
      "36/36 - 0s - loss: 0.0038 - mse: 0.0038 - val_loss: 0.0037 - val_mse: 0.0037 - 33ms/epoch - 925us/step\n",
      "Epoch 201/500\n",
      "36/36 - 0s - loss: 0.0037 - mse: 0.0037 - val_loss: 0.0039 - val_mse: 0.0039 - 36ms/epoch - 1ms/step\n",
      "Epoch 202/500\n",
      "36/36 - 0s - loss: 0.0038 - mse: 0.0038 - val_loss: 0.0038 - val_mse: 0.0038 - 31ms/epoch - 872us/step\n",
      "Epoch 203/500\n",
      "36/36 - 0s - loss: 0.0037 - mse: 0.0037 - val_loss: 0.0037 - val_mse: 0.0037 - 35ms/epoch - 981us/step\n",
      "Epoch 204/500\n",
      "36/36 - 0s - loss: 0.0037 - mse: 0.0037 - val_loss: 0.0037 - val_mse: 0.0037 - 35ms/epoch - 971us/step\n",
      "Epoch 205/500\n",
      "36/36 - 0s - loss: 0.0038 - mse: 0.0038 - val_loss: 0.0038 - val_mse: 0.0038 - 34ms/epoch - 952us/step\n",
      "Epoch 206/500\n",
      "36/36 - 0s - loss: 0.0038 - mse: 0.0038 - val_loss: 0.0037 - val_mse: 0.0037 - 33ms/epoch - 926us/step\n",
      "Epoch 207/500\n",
      "36/36 - 0s - loss: 0.0038 - mse: 0.0038 - val_loss: 0.0037 - val_mse: 0.0037 - 33ms/epoch - 927us/step\n",
      "Epoch 208/500\n",
      "36/36 - 0s - loss: 0.0037 - mse: 0.0037 - val_loss: 0.0038 - val_mse: 0.0038 - 34ms/epoch - 933us/step\n",
      "Epoch 209/500\n",
      "36/36 - 0s - loss: 0.0037 - mse: 0.0037 - val_loss: 0.0036 - val_mse: 0.0036 - 34ms/epoch - 938us/step\n",
      "Epoch 210/500\n",
      "36/36 - 0s - loss: 0.0037 - mse: 0.0037 - val_loss: 0.0036 - val_mse: 0.0036 - 35ms/epoch - 969us/step\n",
      "Epoch 211/500\n",
      "36/36 - 0s - loss: 0.0036 - mse: 0.0036 - val_loss: 0.0037 - val_mse: 0.0037 - 35ms/epoch - 976us/step\n",
      "Epoch 212/500\n",
      "36/36 - 0s - loss: 0.0036 - mse: 0.0036 - val_loss: 0.0036 - val_mse: 0.0036 - 35ms/epoch - 970us/step\n",
      "Epoch 213/500\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "36/36 - 0s - loss: 0.0036 - mse: 0.0036 - val_loss: 0.0037 - val_mse: 0.0037 - 35ms/epoch - 961us/step\n",
      "Epoch 214/500\n",
      "36/36 - 0s - loss: 0.0036 - mse: 0.0036 - val_loss: 0.0040 - val_mse: 0.0040 - 33ms/epoch - 928us/step\n",
      "Epoch 215/500\n",
      "36/36 - 0s - loss: 0.0037 - mse: 0.0037 - val_loss: 0.0035 - val_mse: 0.0035 - 32ms/epoch - 902us/step\n",
      "Epoch 216/500\n",
      "36/36 - 0s - loss: 0.0036 - mse: 0.0036 - val_loss: 0.0035 - val_mse: 0.0035 - 32ms/epoch - 889us/step\n",
      "Epoch 217/500\n",
      "36/36 - 0s - loss: 0.0036 - mse: 0.0036 - val_loss: 0.0036 - val_mse: 0.0036 - 33ms/epoch - 910us/step\n",
      "Epoch 218/500\n",
      "36/36 - 0s - loss: 0.0036 - mse: 0.0036 - val_loss: 0.0035 - val_mse: 0.0035 - 33ms/epoch - 908us/step\n",
      "Epoch 219/500\n",
      "36/36 - 0s - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0035 - val_mse: 0.0035 - 32ms/epoch - 898us/step\n",
      "Epoch 220/500\n",
      "36/36 - 0s - loss: 0.0036 - mse: 0.0036 - val_loss: 0.0035 - val_mse: 0.0035 - 32ms/epoch - 898us/step\n",
      "Epoch 221/500\n",
      "36/36 - 0s - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0036 - val_mse: 0.0036 - 32ms/epoch - 902us/step\n",
      "Epoch 222/500\n",
      "36/36 - 0s - loss: 0.0036 - mse: 0.0036 - val_loss: 0.0035 - val_mse: 0.0035 - 32ms/epoch - 878us/step\n",
      "Epoch 223/500\n",
      "36/36 - 0s - loss: 0.0036 - mse: 0.0036 - val_loss: 0.0037 - val_mse: 0.0037 - 28ms/epoch - 781us/step\n",
      "Epoch 224/500\n",
      "36/36 - 0s - loss: 0.0036 - mse: 0.0036 - val_loss: 0.0037 - val_mse: 0.0037 - 28ms/epoch - 790us/step\n",
      "Epoch 225/500\n",
      "36/36 - 0s - loss: 0.0036 - mse: 0.0036 - val_loss: 0.0035 - val_mse: 0.0035 - 32ms/epoch - 883us/step\n",
      "Epoch 226/500\n",
      "36/36 - 0s - loss: 0.0036 - mse: 0.0036 - val_loss: 0.0035 - val_mse: 0.0035 - 32ms/epoch - 903us/step\n",
      "Epoch 227/500\n",
      "36/36 - 0s - loss: 0.0036 - mse: 0.0036 - val_loss: 0.0036 - val_mse: 0.0036 - 32ms/epoch - 876us/step\n",
      "Epoch 228/500\n",
      "36/36 - 0s - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0036 - val_mse: 0.0036 - 32ms/epoch - 878us/step\n",
      "Epoch 229/500\n",
      "36/36 - 0s - loss: 0.0036 - mse: 0.0036 - val_loss: 0.0035 - val_mse: 0.0035 - 30ms/epoch - 835us/step\n",
      "Epoch 230/500\n",
      "36/36 - 0s - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0035 - val_mse: 0.0035 - 31ms/epoch - 847us/step\n",
      "Epoch 231/500\n",
      "36/36 - 0s - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0038 - val_mse: 0.0038 - 30ms/epoch - 836us/step\n",
      "Epoch 232/500\n",
      "36/36 - 0s - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0036 - val_mse: 0.0036 - 28ms/epoch - 788us/step\n",
      "Epoch 233/500\n",
      "36/36 - 0s - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0035 - val_mse: 0.0035 - 29ms/epoch - 799us/step\n",
      "Epoch 234/500\n",
      "36/36 - 0s - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0035 - val_mse: 0.0035 - 31ms/epoch - 872us/step\n",
      "Epoch 235/500\n",
      "36/36 - 0s - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0036 - val_mse: 0.0036 - 32ms/epoch - 892us/step\n",
      "Epoch 236/500\n",
      "36/36 - 0s - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0035 - val_mse: 0.0035 - 34ms/epoch - 946us/step\n",
      "Epoch 237/500\n",
      "36/36 - 0s - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0035 - val_mse: 0.0035 - 31ms/epoch - 857us/step\n",
      "Epoch 238/500\n",
      "36/36 - 0s - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0035 - val_mse: 0.0035 - 31ms/epoch - 852us/step\n",
      "Epoch 239/500\n",
      "36/36 - 0s - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0035 - val_mse: 0.0035 - 29ms/epoch - 817us/step\n",
      "Epoch 240/500\n",
      "36/36 - 0s - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0035 - val_mse: 0.0035 - 28ms/epoch - 775us/step\n",
      "Epoch 241/500\n",
      "36/36 - 0s - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0035 - val_mse: 0.0035 - 28ms/epoch - 786us/step\n",
      "Epoch 242/500\n",
      "36/36 - 0s - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0035 - val_mse: 0.0035 - 29ms/epoch - 798us/step\n",
      "Epoch 243/500\n",
      "36/36 - 0s - loss: 0.0036 - mse: 0.0036 - val_loss: 0.0036 - val_mse: 0.0036 - 29ms/epoch - 808us/step\n",
      "Epoch 244/500\n",
      "36/36 - 0s - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0035 - val_mse: 0.0035 - 28ms/epoch - 789us/step\n",
      "Epoch 245/500\n",
      "36/36 - 0s - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0035 - val_mse: 0.0035 - 28ms/epoch - 764us/step\n",
      "Epoch 246/500\n",
      "36/36 - 0s - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0039 - val_mse: 0.0039 - 28ms/epoch - 784us/step\n",
      "Epoch 247/500\n",
      "36/36 - 0s - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0035 - val_mse: 0.0035 - 28ms/epoch - 787us/step\n",
      "Epoch 248/500\n",
      "36/36 - 0s - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0035 - val_mse: 0.0035 - 28ms/epoch - 789us/step\n",
      "Epoch 249/500\n",
      "36/36 - 0s - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0037 - val_mse: 0.0037 - 29ms/epoch - 799us/step\n",
      "Epoch 250/500\n",
      "36/36 - 0s - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0037 - val_mse: 0.0037 - 28ms/epoch - 785us/step\n",
      "Epoch 251/500\n",
      "36/36 - 0s - loss: 0.0036 - mse: 0.0036 - val_loss: 0.0034 - val_mse: 0.0034 - 31ms/epoch - 859us/step\n",
      "Epoch 252/500\n",
      "36/36 - 0s - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0034 - val_mse: 0.0034 - 29ms/epoch - 792us/step\n",
      "Epoch 253/500\n",
      "36/36 - 0s - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0035 - val_mse: 0.0035 - 30ms/epoch - 821us/step\n",
      "Epoch 254/500\n",
      "36/36 - 0s - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0034 - val_mse: 0.0034 - 28ms/epoch - 782us/step\n",
      "Epoch 255/500\n",
      "36/36 - 0s - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0034 - val_mse: 0.0034 - 29ms/epoch - 795us/step\n",
      "Epoch 256/500\n",
      "36/36 - 0s - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0036 - val_mse: 0.0036 - 31ms/epoch - 856us/step\n",
      "Epoch 257/500\n",
      "36/36 - 0s - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0034 - val_mse: 0.0034 - 28ms/epoch - 774us/step\n",
      "Epoch 258/500\n",
      "36/36 - 0s - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0036 - val_mse: 0.0036 - 29ms/epoch - 797us/step\n",
      "Epoch 259/500\n",
      "36/36 - 0s - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0035 - val_mse: 0.0035 - 27ms/epoch - 741us/step\n",
      "Epoch 260/500\n",
      "36/36 - 0s - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0036 - val_mse: 0.0036 - 30ms/epoch - 838us/step\n",
      "Epoch 261/500\n",
      "36/36 - 0s - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0035 - val_mse: 0.0035 - 29ms/epoch - 815us/step\n",
      "Epoch 262/500\n",
      "36/36 - 0s - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0035 - val_mse: 0.0035 - 29ms/epoch - 802us/step\n",
      "Epoch 263/500\n",
      "36/36 - 0s - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0035 - val_mse: 0.0035 - 28ms/epoch - 766us/step\n",
      "Epoch 264/500\n",
      "36/36 - 0s - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0034 - val_mse: 0.0034 - 29ms/epoch - 799us/step\n",
      "Epoch 265/500\n",
      "36/36 - 0s - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0034 - val_mse: 0.0034 - 32ms/epoch - 901us/step\n",
      "Epoch 266/500\n",
      "36/36 - 0s - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0035 - val_mse: 0.0035 - 31ms/epoch - 851us/step\n",
      "Epoch 267/500\n",
      "36/36 - 0s - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0035 - val_mse: 0.0035 - 28ms/epoch - 788us/step\n",
      "Epoch 268/500\n",
      "36/36 - 0s - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0035 - val_mse: 0.0035 - 30ms/epoch - 838us/step\n",
      "Epoch 269/500\n",
      "36/36 - 0s - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0034 - val_mse: 0.0034 - 31ms/epoch - 871us/step\n",
      "Epoch 270/500\n",
      "36/36 - 0s - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0035 - val_mse: 0.0035 - 33ms/epoch - 913us/step\n",
      "Epoch 271/500\n",
      "36/36 - 0s - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0035 - val_mse: 0.0035 - 32ms/epoch - 901us/step\n",
      "Epoch 272/500\n",
      "36/36 - 0s - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0035 - val_mse: 0.0035 - 32ms/epoch - 896us/step\n",
      "Epoch 273/500\n",
      "36/36 - 0s - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0034 - val_mse: 0.0034 - 32ms/epoch - 902us/step\n",
      "Epoch 274/500\n",
      "36/36 - 0s - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0035 - val_mse: 0.0035 - 31ms/epoch - 851us/step\n",
      "Epoch 275/500\n",
      "36/36 - 0s - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0034 - val_mse: 0.0034 - 31ms/epoch - 854us/step\n",
      "Epoch 276/500\n",
      "36/36 - 0s - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0037 - val_mse: 0.0037 - 32ms/epoch - 889us/step\n",
      "Epoch 277/500\n",
      "36/36 - 0s - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0034 - val_mse: 0.0034 - 30ms/epoch - 846us/step\n",
      "Epoch 278/500\n",
      "36/36 - 0s - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0034 - val_mse: 0.0034 - 33ms/epoch - 917us/step\n",
      "Epoch 279/500\n",
      "36/36 - 0s - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0034 - val_mse: 0.0034 - 31ms/epoch - 868us/step\n",
      "Epoch 280/500\n",
      "36/36 - 0s - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0034 - val_mse: 0.0034 - 32ms/epoch - 882us/step\n",
      "Epoch 281/500\n",
      "36/36 - 0s - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0036 - val_mse: 0.0036 - 33ms/epoch - 913us/step\n",
      "Epoch 282/500\n",
      "36/36 - 0s - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0034 - val_mse: 0.0034 - 31ms/epoch - 857us/step\n",
      "Epoch 283/500\n",
      "36/36 - 0s - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0037 - val_mse: 0.0037 - 32ms/epoch - 882us/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 284/500\n",
      "36/36 - 0s - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0035 - val_mse: 0.0035 - 32ms/epoch - 893us/step\n",
      "Epoch 285/500\n",
      "36/36 - 0s - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0034 - val_mse: 0.0034 - 32ms/epoch - 887us/step\n",
      "Epoch 286/500\n",
      "36/36 - 0s - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0035 - val_mse: 0.0035 - 31ms/epoch - 861us/step\n",
      "Epoch 287/500\n",
      "36/36 - 0s - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0035 - val_mse: 0.0035 - 32ms/epoch - 891us/step\n",
      "Epoch 288/500\n",
      "36/36 - 0s - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0035 - val_mse: 0.0035 - 31ms/epoch - 871us/step\n",
      "Epoch 289/500\n",
      "36/36 - 0s - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0034 - val_mse: 0.0034 - 32ms/epoch - 884us/step\n",
      "Epoch 290/500\n",
      "36/36 - 0s - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0034 - val_mse: 0.0034 - 32ms/epoch - 893us/step\n",
      "Epoch 291/500\n",
      "36/36 - 0s - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0034 - val_mse: 0.0034 - 32ms/epoch - 897us/step\n",
      "Epoch 292/500\n",
      "36/36 - 0s - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0036 - val_mse: 0.0036 - 32ms/epoch - 877us/step\n",
      "Epoch 293/500\n",
      "36/36 - 0s - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0034 - val_mse: 0.0034 - 29ms/epoch - 800us/step\n",
      "Epoch 294/500\n",
      "36/36 - 0s - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0036 - val_mse: 0.0036 - 30ms/epoch - 824us/step\n",
      "Epoch 295/500\n",
      "36/36 - 0s - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0034 - val_mse: 0.0034 - 29ms/epoch - 811us/step\n",
      "Epoch 296/500\n",
      "36/36 - 0s - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0035 - val_mse: 0.0035 - 30ms/epoch - 822us/step\n",
      "Epoch 297/500\n",
      "36/36 - 0s - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0034 - val_mse: 0.0034 - 29ms/epoch - 801us/step\n",
      "Epoch 298/500\n",
      "36/36 - 0s - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0038 - val_mse: 0.0038 - 29ms/epoch - 810us/step\n",
      "Epoch 299/500\n",
      "36/36 - 0s - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0035 - val_mse: 0.0035 - 31ms/epoch - 859us/step\n",
      "Epoch 300/500\n",
      "36/36 - 0s - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0041 - val_mse: 0.0041 - 30ms/epoch - 825us/step\n",
      "Epoch 301/500\n",
      "36/36 - 0s - loss: 0.0036 - mse: 0.0036 - val_loss: 0.0033 - val_mse: 0.0033 - 31ms/epoch - 857us/step\n",
      "Epoch 302/500\n",
      "36/36 - 0s - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0034 - val_mse: 0.0034 - 30ms/epoch - 847us/step\n",
      "Epoch 303/500\n",
      "36/36 - 0s - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0034 - val_mse: 0.0034 - 30ms/epoch - 841us/step\n",
      "Epoch 304/500\n",
      "36/36 - 0s - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0034 - val_mse: 0.0034 - 28ms/epoch - 783us/step\n",
      "Epoch 305/500\n",
      "36/36 - 0s - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0037 - val_mse: 0.0037 - 30ms/epoch - 834us/step\n",
      "Epoch 306/500\n",
      "36/36 - 0s - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0035 - val_mse: 0.0035 - 31ms/epoch - 857us/step\n",
      "Epoch 307/500\n",
      "36/36 - 0s - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0041 - val_mse: 0.0041 - 28ms/epoch - 785us/step\n",
      "Epoch 308/500\n",
      "36/36 - 0s - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0034 - val_mse: 0.0034 - 29ms/epoch - 792us/step\n",
      "Epoch 309/500\n",
      "36/36 - 0s - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0034 - val_mse: 0.0034 - 28ms/epoch - 767us/step\n",
      "Epoch 310/500\n",
      "36/36 - 0s - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0034 - val_mse: 0.0034 - 29ms/epoch - 808us/step\n",
      "Epoch 311/500\n",
      "36/36 - 0s - loss: 0.0033 - mse: 0.0033 - val_loss: 0.0033 - val_mse: 0.0033 - 28ms/epoch - 779us/step\n",
      "Epoch 312/500\n",
      "36/36 - 0s - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0036 - val_mse: 0.0036 - 29ms/epoch - 799us/step\n",
      "Epoch 313/500\n",
      "36/36 - 0s - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0034 - val_mse: 0.0034 - 28ms/epoch - 790us/step\n",
      "Epoch 314/500\n",
      "36/36 - 0s - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0035 - val_mse: 0.0035 - 29ms/epoch - 796us/step\n",
      "Epoch 315/500\n",
      "36/36 - 0s - loss: 0.0033 - mse: 0.0033 - val_loss: 0.0035 - val_mse: 0.0035 - 30ms/epoch - 843us/step\n",
      "Epoch 316/500\n",
      "36/36 - 0s - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0034 - val_mse: 0.0034 - 29ms/epoch - 795us/step\n",
      "Epoch 317/500\n",
      "36/36 - 0s - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0034 - val_mse: 0.0034 - 28ms/epoch - 774us/step\n",
      "Epoch 318/500\n",
      "36/36 - 0s - loss: 0.0033 - mse: 0.0033 - val_loss: 0.0035 - val_mse: 0.0035 - 27ms/epoch - 746us/step\n",
      "Epoch 319/500\n",
      "36/36 - 0s - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0034 - val_mse: 0.0034 - 30ms/epoch - 831us/step\n",
      "Epoch 320/500\n",
      "36/36 - 0s - loss: 0.0033 - mse: 0.0033 - val_loss: 0.0033 - val_mse: 0.0033 - 28ms/epoch - 770us/step\n",
      "Epoch 321/500\n",
      "36/36 - 0s - loss: 0.0033 - mse: 0.0033 - val_loss: 0.0036 - val_mse: 0.0036 - 30ms/epoch - 823us/step\n",
      "Epoch 322/500\n",
      "36/36 - 0s - loss: 0.0033 - mse: 0.0033 - val_loss: 0.0033 - val_mse: 0.0033 - 31ms/epoch - 849us/step\n",
      "Epoch 323/500\n",
      "36/36 - 0s - loss: 0.0033 - mse: 0.0033 - val_loss: 0.0033 - val_mse: 0.0033 - 28ms/epoch - 778us/step\n",
      "Epoch 324/500\n",
      "36/36 - 0s - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0033 - val_mse: 0.0033 - 30ms/epoch - 838us/step\n",
      "Epoch 325/500\n",
      "36/36 - 0s - loss: 0.0033 - mse: 0.0033 - val_loss: 0.0036 - val_mse: 0.0036 - 32ms/epoch - 879us/step\n",
      "Epoch 326/500\n",
      "36/36 - 0s - loss: 0.0034 - mse: 0.0034 - val_loss: 0.0033 - val_mse: 0.0033 - 34ms/epoch - 946us/step\n",
      "Epoch 327/500\n",
      "36/36 - 0s - loss: 0.0033 - mse: 0.0033 - val_loss: 0.0033 - val_mse: 0.0033 - 33ms/epoch - 927us/step\n",
      "Epoch 328/500\n",
      "36/36 - 0s - loss: 0.0033 - mse: 0.0033 - val_loss: 0.0036 - val_mse: 0.0036 - 32ms/epoch - 900us/step\n",
      "Epoch 329/500\n",
      "36/36 - 0s - loss: 0.0033 - mse: 0.0033 - val_loss: 0.0033 - val_mse: 0.0033 - 31ms/epoch - 868us/step\n",
      "Epoch 330/500\n",
      "36/36 - 0s - loss: 0.0033 - mse: 0.0033 - val_loss: 0.0033 - val_mse: 0.0033 - 32ms/epoch - 876us/step\n",
      "Epoch 331/500\n",
      "36/36 - 0s - loss: 0.0033 - mse: 0.0033 - val_loss: 0.0033 - val_mse: 0.0033 - 31ms/epoch - 869us/step\n",
      "Epoch 332/500\n",
      "36/36 - 0s - loss: 0.0033 - mse: 0.0033 - val_loss: 0.0038 - val_mse: 0.0038 - 31ms/epoch - 872us/step\n",
      "Epoch 333/500\n",
      "36/36 - 0s - loss: 0.0033 - mse: 0.0033 - val_loss: 0.0033 - val_mse: 0.0033 - 33ms/epoch - 906us/step\n",
      "Epoch 334/500\n",
      "36/36 - 0s - loss: 0.0033 - mse: 0.0033 - val_loss: 0.0032 - val_mse: 0.0032 - 33ms/epoch - 906us/step\n",
      "Epoch 335/500\n",
      "36/36 - 0s - loss: 0.0033 - mse: 0.0033 - val_loss: 0.0037 - val_mse: 0.0037 - 31ms/epoch - 872us/step\n",
      "Epoch 336/500\n",
      "36/36 - 0s - loss: 0.0035 - mse: 0.0035 - val_loss: 0.0032 - val_mse: 0.0032 - 32ms/epoch - 886us/step\n",
      "Epoch 337/500\n",
      "36/36 - 0s - loss: 0.0033 - mse: 0.0033 - val_loss: 0.0032 - val_mse: 0.0032 - 32ms/epoch - 877us/step\n",
      "Epoch 338/500\n",
      "36/36 - 0s - loss: 0.0033 - mse: 0.0033 - val_loss: 0.0035 - val_mse: 0.0035 - 31ms/epoch - 875us/step\n",
      "Epoch 339/500\n",
      "36/36 - 0s - loss: 0.0033 - mse: 0.0033 - val_loss: 0.0032 - val_mse: 0.0032 - 33ms/epoch - 917us/step\n",
      "Epoch 340/500\n",
      "36/36 - 0s - loss: 0.0033 - mse: 0.0033 - val_loss: 0.0032 - val_mse: 0.0032 - 33ms/epoch - 904us/step\n",
      "Epoch 341/500\n",
      "36/36 - 0s - loss: 0.0032 - mse: 0.0032 - val_loss: 0.0032 - val_mse: 0.0032 - 31ms/epoch - 866us/step\n",
      "Epoch 342/500\n",
      "36/36 - 0s - loss: 0.0032 - mse: 0.0032 - val_loss: 0.0033 - val_mse: 0.0033 - 32ms/epoch - 894us/step\n",
      "Epoch 343/500\n",
      "36/36 - 0s - loss: 0.0032 - mse: 0.0032 - val_loss: 0.0033 - val_mse: 0.0033 - 33ms/epoch - 911us/step\n",
      "Epoch 344/500\n",
      "36/36 - 0s - loss: 0.0032 - mse: 0.0032 - val_loss: 0.0032 - val_mse: 0.0032 - 32ms/epoch - 896us/step\n",
      "Epoch 345/500\n",
      "36/36 - 0s - loss: 0.0032 - mse: 0.0032 - val_loss: 0.0032 - val_mse: 0.0032 - 31ms/epoch - 867us/step\n",
      "Epoch 346/500\n",
      "36/36 - 0s - loss: 0.0032 - mse: 0.0032 - val_loss: 0.0031 - val_mse: 0.0031 - 31ms/epoch - 869us/step\n",
      "Epoch 347/500\n",
      "36/36 - 0s - loss: 0.0031 - mse: 0.0031 - val_loss: 0.0032 - val_mse: 0.0032 - 33ms/epoch - 908us/step\n",
      "Epoch 348/500\n",
      "36/36 - 0s - loss: 0.0032 - mse: 0.0032 - val_loss: 0.0031 - val_mse: 0.0031 - 32ms/epoch - 882us/step\n",
      "Epoch 349/500\n",
      "36/36 - 0s - loss: 0.0031 - mse: 0.0031 - val_loss: 0.0032 - val_mse: 0.0032 - 31ms/epoch - 863us/step\n",
      "Epoch 350/500\n",
      "36/36 - 0s - loss: 0.0032 - mse: 0.0032 - val_loss: 0.0031 - val_mse: 0.0031 - 33ms/epoch - 913us/step\n",
      "Epoch 351/500\n",
      "36/36 - 0s - loss: 0.0032 - mse: 0.0032 - val_loss: 0.0034 - val_mse: 0.0034 - 33ms/epoch - 911us/step\n",
      "Epoch 352/500\n",
      "36/36 - 0s - loss: 0.0031 - mse: 0.0031 - val_loss: 0.0031 - val_mse: 0.0031 - 31ms/epoch - 865us/step\n",
      "Epoch 353/500\n",
      "36/36 - 0s - loss: 0.0031 - mse: 0.0031 - val_loss: 0.0031 - val_mse: 0.0031 - 29ms/epoch - 808us/step\n",
      "Epoch 354/500\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "36/36 - 0s - loss: 0.0031 - mse: 0.0031 - val_loss: 0.0030 - val_mse: 0.0030 - 31ms/epoch - 863us/step\n",
      "Epoch 355/500\n",
      "36/36 - 0s - loss: 0.0031 - mse: 0.0031 - val_loss: 0.0030 - val_mse: 0.0030 - 30ms/epoch - 835us/step\n",
      "Epoch 356/500\n",
      "36/36 - 0s - loss: 0.0031 - mse: 0.0031 - val_loss: 0.0030 - val_mse: 0.0030 - 32ms/epoch - 876us/step\n",
      "Epoch 357/500\n",
      "36/36 - 0s - loss: 0.0030 - mse: 0.0030 - val_loss: 0.0030 - val_mse: 0.0030 - 31ms/epoch - 848us/step\n",
      "Epoch 358/500\n",
      "36/36 - 0s - loss: 0.0030 - mse: 0.0030 - val_loss: 0.0030 - val_mse: 0.0030 - 28ms/epoch - 771us/step\n",
      "Epoch 359/500\n",
      "36/36 - 0s - loss: 0.0030 - mse: 0.0030 - val_loss: 0.0030 - val_mse: 0.0030 - 28ms/epoch - 775us/step\n",
      "Epoch 360/500\n",
      "36/36 - 0s - loss: 0.0030 - mse: 0.0030 - val_loss: 0.0030 - val_mse: 0.0030 - 30ms/epoch - 833us/step\n",
      "Epoch 361/500\n",
      "36/36 - 0s - loss: 0.0030 - mse: 0.0030 - val_loss: 0.0029 - val_mse: 0.0029 - 29ms/epoch - 817us/step\n",
      "Epoch 362/500\n",
      "36/36 - 0s - loss: 0.0030 - mse: 0.0030 - val_loss: 0.0031 - val_mse: 0.0031 - 29ms/epoch - 798us/step\n",
      "Epoch 363/500\n",
      "36/36 - 0s - loss: 0.0031 - mse: 0.0031 - val_loss: 0.0033 - val_mse: 0.0033 - 27ms/epoch - 755us/step\n",
      "Epoch 364/500\n",
      "36/36 - 0s - loss: 0.0031 - mse: 0.0031 - val_loss: 0.0029 - val_mse: 0.0029 - 29ms/epoch - 800us/step\n",
      "Epoch 365/500\n",
      "36/36 - 0s - loss: 0.0029 - mse: 0.0029 - val_loss: 0.0030 - val_mse: 0.0030 - 30ms/epoch - 831us/step\n",
      "Epoch 366/500\n",
      "36/36 - 0s - loss: 0.0030 - mse: 0.0030 - val_loss: 0.0030 - val_mse: 0.0030 - 29ms/epoch - 813us/step\n",
      "Epoch 367/500\n",
      "36/36 - 0s - loss: 0.0030 - mse: 0.0030 - val_loss: 0.0030 - val_mse: 0.0030 - 29ms/epoch - 817us/step\n",
      "Epoch 368/500\n",
      "36/36 - 0s - loss: 0.0029 - mse: 0.0029 - val_loss: 0.0029 - val_mse: 0.0029 - 28ms/epoch - 773us/step\n",
      "Epoch 369/500\n",
      "36/36 - 0s - loss: 0.0029 - mse: 0.0029 - val_loss: 0.0029 - val_mse: 0.0029 - 29ms/epoch - 809us/step\n",
      "Epoch 370/500\n",
      "36/36 - 0s - loss: 0.0029 - mse: 0.0029 - val_loss: 0.0029 - val_mse: 0.0029 - 30ms/epoch - 839us/step\n",
      "Epoch 371/500\n",
      "36/36 - 0s - loss: 0.0029 - mse: 0.0029 - val_loss: 0.0033 - val_mse: 0.0033 - 29ms/epoch - 808us/step\n",
      "Epoch 372/500\n",
      "36/36 - 0s - loss: 0.0029 - mse: 0.0029 - val_loss: 0.0029 - val_mse: 0.0029 - 28ms/epoch - 774us/step\n",
      "Epoch 373/500\n",
      "36/36 - 0s - loss: 0.0029 - mse: 0.0029 - val_loss: 0.0029 - val_mse: 0.0029 - 28ms/epoch - 779us/step\n",
      "Epoch 374/500\n",
      "36/36 - 0s - loss: 0.0029 - mse: 0.0029 - val_loss: 0.0028 - val_mse: 0.0028 - 32ms/epoch - 894us/step\n",
      "Epoch 375/500\n",
      "36/36 - 0s - loss: 0.0028 - mse: 0.0028 - val_loss: 0.0028 - val_mse: 0.0028 - 31ms/epoch - 851us/step\n",
      "Epoch 376/500\n",
      "36/36 - 0s - loss: 0.0029 - mse: 0.0029 - val_loss: 0.0031 - val_mse: 0.0031 - 31ms/epoch - 864us/step\n",
      "Epoch 377/500\n",
      "36/36 - 0s - loss: 0.0029 - mse: 0.0029 - val_loss: 0.0029 - val_mse: 0.0029 - 29ms/epoch - 799us/step\n",
      "Epoch 378/500\n",
      "36/36 - 0s - loss: 0.0028 - mse: 0.0028 - val_loss: 0.0030 - val_mse: 0.0030 - 29ms/epoch - 810us/step\n",
      "Epoch 379/500\n",
      "36/36 - 0s - loss: 0.0028 - mse: 0.0028 - val_loss: 0.0028 - val_mse: 0.0028 - 28ms/epoch - 772us/step\n",
      "Epoch 380/500\n",
      "36/36 - 0s - loss: 0.0028 - mse: 0.0028 - val_loss: 0.0030 - val_mse: 0.0030 - 29ms/epoch - 806us/step\n",
      "Epoch 381/500\n",
      "36/36 - 0s - loss: 0.0028 - mse: 0.0028 - val_loss: 0.0028 - val_mse: 0.0028 - 31ms/epoch - 861us/step\n",
      "Epoch 382/500\n",
      "36/36 - 0s - loss: 0.0028 - mse: 0.0028 - val_loss: 0.0029 - val_mse: 0.0029 - 29ms/epoch - 794us/step\n",
      "Epoch 383/500\n",
      "36/36 - 0s - loss: 0.0028 - mse: 0.0028 - val_loss: 0.0027 - val_mse: 0.0027 - 28ms/epoch - 787us/step\n",
      "Epoch 384/500\n",
      "36/36 - 0s - loss: 0.0027 - mse: 0.0027 - val_loss: 0.0028 - val_mse: 0.0028 - 28ms/epoch - 791us/step\n",
      "Epoch 385/500\n",
      "36/36 - 0s - loss: 0.0028 - mse: 0.0028 - val_loss: 0.0031 - val_mse: 0.0031 - 29ms/epoch - 800us/step\n",
      "Epoch 386/500\n",
      "36/36 - 0s - loss: 0.0029 - mse: 0.0029 - val_loss: 0.0029 - val_mse: 0.0029 - 30ms/epoch - 842us/step\n",
      "Epoch 387/500\n",
      "36/36 - 0s - loss: 0.0027 - mse: 0.0027 - val_loss: 0.0030 - val_mse: 0.0030 - 31ms/epoch - 858us/step\n",
      "Epoch 388/500\n",
      "36/36 - 0s - loss: 0.0028 - mse: 0.0028 - val_loss: 0.0027 - val_mse: 0.0027 - 30ms/epoch - 822us/step\n",
      "Epoch 389/500\n",
      "36/36 - 0s - loss: 0.0027 - mse: 0.0027 - val_loss: 0.0028 - val_mse: 0.0028 - 31ms/epoch - 864us/step\n",
      "Epoch 390/500\n",
      "36/36 - 0s - loss: 0.0027 - mse: 0.0027 - val_loss: 0.0027 - val_mse: 0.0027 - 37ms/epoch - 1ms/step\n",
      "Epoch 391/500\n",
      "36/36 - 0s - loss: 0.0027 - mse: 0.0027 - val_loss: 0.0027 - val_mse: 0.0027 - 32ms/epoch - 876us/step\n",
      "Epoch 392/500\n",
      "36/36 - 0s - loss: 0.0028 - mse: 0.0028 - val_loss: 0.0027 - val_mse: 0.0027 - 31ms/epoch - 857us/step\n",
      "Epoch 393/500\n",
      "36/36 - 0s - loss: 0.0027 - mse: 0.0027 - val_loss: 0.0029 - val_mse: 0.0029 - 32ms/epoch - 897us/step\n",
      "Epoch 394/500\n",
      "36/36 - 0s - loss: 0.0027 - mse: 0.0027 - val_loss: 0.0027 - val_mse: 0.0027 - 31ms/epoch - 863us/step\n",
      "Epoch 395/500\n",
      "36/36 - 0s - loss: 0.0027 - mse: 0.0027 - val_loss: 0.0027 - val_mse: 0.0027 - 32ms/epoch - 888us/step\n",
      "Epoch 396/500\n",
      "36/36 - 0s - loss: 0.0027 - mse: 0.0027 - val_loss: 0.0027 - val_mse: 0.0027 - 33ms/epoch - 909us/step\n",
      "Epoch 397/500\n",
      "36/36 - 0s - loss: 0.0027 - mse: 0.0027 - val_loss: 0.0027 - val_mse: 0.0027 - 31ms/epoch - 873us/step\n",
      "Epoch 398/500\n",
      "36/36 - 0s - loss: 0.0027 - mse: 0.0027 - val_loss: 0.0027 - val_mse: 0.0027 - 32ms/epoch - 886us/step\n",
      "Epoch 399/500\n",
      "36/36 - 0s - loss: 0.0027 - mse: 0.0027 - val_loss: 0.0026 - val_mse: 0.0026 - 32ms/epoch - 876us/step\n",
      "Epoch 400/500\n",
      "36/36 - 0s - loss: 0.0026 - mse: 0.0026 - val_loss: 0.0027 - val_mse: 0.0027 - 31ms/epoch - 862us/step\n",
      "Epoch 401/500\n",
      "36/36 - 0s - loss: 0.0027 - mse: 0.0027 - val_loss: 0.0027 - val_mse: 0.0027 - 31ms/epoch - 874us/step\n",
      "Epoch 402/500\n",
      "36/36 - 0s - loss: 0.0026 - mse: 0.0026 - val_loss: 0.0029 - val_mse: 0.0029 - 32ms/epoch - 877us/step\n",
      "Epoch 403/500\n",
      "36/36 - 0s - loss: 0.0027 - mse: 0.0027 - val_loss: 0.0026 - val_mse: 0.0026 - 32ms/epoch - 896us/step\n",
      "Epoch 404/500\n",
      "36/36 - 0s - loss: 0.0026 - mse: 0.0026 - val_loss: 0.0027 - val_mse: 0.0027 - 31ms/epoch - 856us/step\n",
      "Epoch 405/500\n",
      "36/36 - 0s - loss: 0.0026 - mse: 0.0026 - val_loss: 0.0033 - val_mse: 0.0033 - 32ms/epoch - 878us/step\n",
      "Epoch 406/500\n",
      "36/36 - 0s - loss: 0.0027 - mse: 0.0027 - val_loss: 0.0026 - val_mse: 0.0026 - 33ms/epoch - 906us/step\n",
      "Epoch 407/500\n",
      "36/36 - 0s - loss: 0.0026 - mse: 0.0026 - val_loss: 0.0026 - val_mse: 0.0026 - 33ms/epoch - 907us/step\n",
      "Epoch 408/500\n",
      "36/36 - 0s - loss: 0.0026 - mse: 0.0026 - val_loss: 0.0026 - val_mse: 0.0026 - 33ms/epoch - 904us/step\n",
      "Epoch 409/500\n",
      "36/36 - 0s - loss: 0.0026 - mse: 0.0026 - val_loss: 0.0026 - val_mse: 0.0026 - 30ms/epoch - 838us/step\n",
      "Epoch 410/500\n",
      "36/36 - 0s - loss: 0.0026 - mse: 0.0026 - val_loss: 0.0026 - val_mse: 0.0026 - 31ms/epoch - 864us/step\n",
      "Epoch 411/500\n",
      "36/36 - 0s - loss: 0.0025 - mse: 0.0025 - val_loss: 0.0026 - val_mse: 0.0026 - 33ms/epoch - 912us/step\n",
      "Epoch 412/500\n",
      "36/36 - 0s - loss: 0.0026 - mse: 0.0026 - val_loss: 0.0029 - val_mse: 0.0029 - 31ms/epoch - 853us/step\n",
      "Epoch 413/500\n",
      "36/36 - 0s - loss: 0.0026 - mse: 0.0026 - val_loss: 0.0026 - val_mse: 0.0026 - 32ms/epoch - 891us/step\n",
      "Epoch 414/500\n",
      "36/36 - 0s - loss: 0.0025 - mse: 0.0025 - val_loss: 0.0026 - val_mse: 0.0026 - 33ms/epoch - 903us/step\n",
      "Epoch 415/500\n",
      "36/36 - 0s - loss: 0.0026 - mse: 0.0026 - val_loss: 0.0026 - val_mse: 0.0026 - 31ms/epoch - 872us/step\n",
      "Epoch 416/500\n",
      "36/36 - 0s - loss: 0.0025 - mse: 0.0025 - val_loss: 0.0026 - val_mse: 0.0026 - 35ms/epoch - 963us/step\n",
      "Epoch 417/500\n",
      "36/36 - 0s - loss: 0.0026 - mse: 0.0026 - val_loss: 0.0026 - val_mse: 0.0026 - 31ms/epoch - 861us/step\n",
      "Epoch 418/500\n",
      "36/36 - 0s - loss: 0.0025 - mse: 0.0025 - val_loss: 0.0030 - val_mse: 0.0030 - 29ms/epoch - 797us/step\n",
      "Epoch 419/500\n",
      "36/36 - 0s - loss: 0.0026 - mse: 0.0026 - val_loss: 0.0026 - val_mse: 0.0026 - 31ms/epoch - 852us/step\n",
      "Epoch 420/500\n",
      "36/36 - 0s - loss: 0.0025 - mse: 0.0025 - val_loss: 0.0025 - val_mse: 0.0025 - 29ms/epoch - 807us/step\n",
      "Epoch 421/500\n",
      "36/36 - 0s - loss: 0.0025 - mse: 0.0025 - val_loss: 0.0025 - val_mse: 0.0025 - 30ms/epoch - 821us/step\n",
      "Epoch 422/500\n",
      "36/36 - 0s - loss: 0.0025 - mse: 0.0025 - val_loss: 0.0025 - val_mse: 0.0025 - 30ms/epoch - 822us/step\n",
      "Epoch 423/500\n",
      "36/36 - 0s - loss: 0.0025 - mse: 0.0025 - val_loss: 0.0027 - val_mse: 0.0027 - 29ms/epoch - 802us/step\n",
      "Epoch 424/500\n",
      "36/36 - 0s - loss: 0.0025 - mse: 0.0025 - val_loss: 0.0025 - val_mse: 0.0025 - 29ms/epoch - 810us/step\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 425/500\n",
      "36/36 - 0s - loss: 0.0026 - mse: 0.0026 - val_loss: 0.0027 - val_mse: 0.0027 - 30ms/epoch - 828us/step\n",
      "Epoch 426/500\n",
      "36/36 - 0s - loss: 0.0025 - mse: 0.0025 - val_loss: 0.0025 - val_mse: 0.0025 - 32ms/epoch - 889us/step\n",
      "Epoch 427/500\n",
      "36/36 - 0s - loss: 0.0025 - mse: 0.0025 - val_loss: 0.0025 - val_mse: 0.0025 - 35ms/epoch - 960us/step\n",
      "Epoch 428/500\n",
      "36/36 - 0s - loss: 0.0025 - mse: 0.0025 - val_loss: 0.0024 - val_mse: 0.0024 - 33ms/epoch - 912us/step\n",
      "Epoch 429/500\n",
      "36/36 - 0s - loss: 0.0024 - mse: 0.0024 - val_loss: 0.0025 - val_mse: 0.0025 - 29ms/epoch - 814us/step\n",
      "Epoch 430/500\n",
      "36/36 - 0s - loss: 0.0024 - mse: 0.0024 - val_loss: 0.0025 - val_mse: 0.0025 - 29ms/epoch - 797us/step\n",
      "Epoch 431/500\n",
      "36/36 - 0s - loss: 0.0024 - mse: 0.0024 - val_loss: 0.0025 - val_mse: 0.0025 - 28ms/epoch - 785us/step\n",
      "Epoch 432/500\n",
      "36/36 - 0s - loss: 0.0024 - mse: 0.0024 - val_loss: 0.0025 - val_mse: 0.0025 - 28ms/epoch - 779us/step\n",
      "Epoch 433/500\n",
      "36/36 - 0s - loss: 0.0024 - mse: 0.0024 - val_loss: 0.0026 - val_mse: 0.0026 - 31ms/epoch - 857us/step\n",
      "Epoch 434/500\n",
      "36/36 - 0s - loss: 0.0026 - mse: 0.0026 - val_loss: 0.0025 - val_mse: 0.0025 - 30ms/epoch - 834us/step\n",
      "Epoch 435/500\n",
      "36/36 - 0s - loss: 0.0025 - mse: 0.0025 - val_loss: 0.0024 - val_mse: 0.0024 - 31ms/epoch - 867us/step\n",
      "Epoch 436/500\n",
      "36/36 - 0s - loss: 0.0024 - mse: 0.0024 - val_loss: 0.0024 - val_mse: 0.0024 - 30ms/epoch - 822us/step\n",
      "Epoch 437/500\n",
      "36/36 - 0s - loss: 0.0024 - mse: 0.0024 - val_loss: 0.0025 - val_mse: 0.0025 - 27ms/epoch - 763us/step\n",
      "Epoch 438/500\n",
      "36/36 - 0s - loss: 0.0024 - mse: 0.0024 - val_loss: 0.0026 - val_mse: 0.0026 - 29ms/epoch - 807us/step\n",
      "Epoch 439/500\n",
      "36/36 - 0s - loss: 0.0024 - mse: 0.0024 - val_loss: 0.0024 - val_mse: 0.0024 - 31ms/epoch - 857us/step\n",
      "Epoch 440/500\n",
      "36/36 - 0s - loss: 0.0024 - mse: 0.0024 - val_loss: 0.0024 - val_mse: 0.0024 - 29ms/epoch - 815us/step\n",
      "Epoch 441/500\n",
      "36/36 - 0s - loss: 0.0024 - mse: 0.0024 - val_loss: 0.0024 - val_mse: 0.0024 - 28ms/epoch - 791us/step\n",
      "Epoch 442/500\n",
      "36/36 - 0s - loss: 0.0024 - mse: 0.0024 - val_loss: 0.0023 - val_mse: 0.0023 - 28ms/epoch - 770us/step\n",
      "Epoch 443/500\n",
      "36/36 - 0s - loss: 0.0023 - mse: 0.0023 - val_loss: 0.0023 - val_mse: 0.0023 - 29ms/epoch - 801us/step\n",
      "Epoch 444/500\n",
      "36/36 - 0s - loss: 0.0023 - mse: 0.0023 - val_loss: 0.0025 - val_mse: 0.0025 - 29ms/epoch - 816us/step\n",
      "Epoch 445/500\n",
      "36/36 - 0s - loss: 0.0024 - mse: 0.0024 - val_loss: 0.0023 - val_mse: 0.0023 - 28ms/epoch - 788us/step\n",
      "Epoch 446/500\n",
      "36/36 - 0s - loss: 0.0024 - mse: 0.0024 - val_loss: 0.0023 - val_mse: 0.0023 - 31ms/epoch - 863us/step\n",
      "Epoch 447/500\n",
      "36/36 - 0s - loss: 0.0024 - mse: 0.0024 - val_loss: 0.0022 - val_mse: 0.0022 - 30ms/epoch - 827us/step\n",
      "Epoch 448/500\n",
      "36/36 - 0s - loss: 0.0023 - mse: 0.0023 - val_loss: 0.0027 - val_mse: 0.0027 - 28ms/epoch - 789us/step\n",
      "Epoch 449/500\n",
      "36/36 - 0s - loss: 0.0024 - mse: 0.0024 - val_loss: 0.0023 - val_mse: 0.0023 - 30ms/epoch - 845us/step\n",
      "Epoch 450/500\n",
      "36/36 - 0s - loss: 0.0023 - mse: 0.0023 - val_loss: 0.0022 - val_mse: 0.0022 - 33ms/epoch - 915us/step\n",
      "Epoch 451/500\n",
      "36/36 - 0s - loss: 0.0023 - mse: 0.0023 - val_loss: 0.0024 - val_mse: 0.0024 - 34ms/epoch - 940us/step\n",
      "Epoch 452/500\n",
      "36/36 - 0s - loss: 0.0023 - mse: 0.0023 - val_loss: 0.0024 - val_mse: 0.0024 - 33ms/epoch - 924us/step\n",
      "Epoch 453/500\n",
      "36/36 - 0s - loss: 0.0023 - mse: 0.0023 - val_loss: 0.0022 - val_mse: 0.0022 - 32ms/epoch - 896us/step\n",
      "Epoch 454/500\n",
      "36/36 - 0s - loss: 0.0023 - mse: 0.0023 - val_loss: 0.0022 - val_mse: 0.0022 - 31ms/epoch - 870us/step\n",
      "Epoch 455/500\n",
      "36/36 - 0s - loss: 0.0022 - mse: 0.0022 - val_loss: 0.0024 - val_mse: 0.0024 - 32ms/epoch - 896us/step\n",
      "Epoch 456/500\n",
      "36/36 - 0s - loss: 0.0023 - mse: 0.0023 - val_loss: 0.0021 - val_mse: 0.0021 - 32ms/epoch - 892us/step\n",
      "Epoch 457/500\n",
      "36/36 - 0s - loss: 0.0022 - mse: 0.0022 - val_loss: 0.0022 - val_mse: 0.0022 - 32ms/epoch - 897us/step\n",
      "Epoch 458/500\n",
      "36/36 - 0s - loss: 0.0022 - mse: 0.0022 - val_loss: 0.0022 - val_mse: 0.0022 - 32ms/epoch - 891us/step\n",
      "Epoch 459/500\n",
      "36/36 - 0s - loss: 0.0022 - mse: 0.0022 - val_loss: 0.0022 - val_mse: 0.0022 - 32ms/epoch - 877us/step\n",
      "Epoch 460/500\n",
      "36/36 - 0s - loss: 0.0022 - mse: 0.0022 - val_loss: 0.0021 - val_mse: 0.0021 - 33ms/epoch - 908us/step\n",
      "Epoch 461/500\n",
      "36/36 - 0s - loss: 0.0022 - mse: 0.0022 - val_loss: 0.0022 - val_mse: 0.0022 - 32ms/epoch - 895us/step\n",
      "Epoch 462/500\n",
      "36/36 - 0s - loss: 0.0022 - mse: 0.0022 - val_loss: 0.0021 - val_mse: 0.0021 - 32ms/epoch - 879us/step\n",
      "Epoch 463/500\n",
      "36/36 - 0s - loss: 0.0022 - mse: 0.0022 - val_loss: 0.0022 - val_mse: 0.0022 - 33ms/epoch - 903us/step\n",
      "Epoch 464/500\n",
      "36/36 - 0s - loss: 0.0022 - mse: 0.0022 - val_loss: 0.0021 - val_mse: 0.0021 - 32ms/epoch - 892us/step\n",
      "Epoch 465/500\n",
      "36/36 - 0s - loss: 0.0022 - mse: 0.0022 - val_loss: 0.0023 - val_mse: 0.0023 - 31ms/epoch - 858us/step\n",
      "Epoch 466/500\n",
      "36/36 - 0s - loss: 0.0021 - mse: 0.0021 - val_loss: 0.0023 - val_mse: 0.0023 - 31ms/epoch - 873us/step\n",
      "Epoch 467/500\n",
      "36/36 - 0s - loss: 0.0022 - mse: 0.0022 - val_loss: 0.0021 - val_mse: 0.0021 - 33ms/epoch - 916us/step\n",
      "Epoch 468/500\n",
      "36/36 - 0s - loss: 0.0021 - mse: 0.0021 - val_loss: 0.0020 - val_mse: 0.0020 - 31ms/epoch - 863us/step\n",
      "Epoch 469/500\n",
      "36/36 - 0s - loss: 0.0021 - mse: 0.0021 - val_loss: 0.0020 - val_mse: 0.0020 - 28ms/epoch - 790us/step\n",
      "Epoch 470/500\n",
      "36/36 - 0s - loss: 0.0021 - mse: 0.0021 - val_loss: 0.0020 - val_mse: 0.0020 - 32ms/epoch - 883us/step\n",
      "Epoch 471/500\n",
      "36/36 - 0s - loss: 0.0021 - mse: 0.0021 - val_loss: 0.0020 - val_mse: 0.0020 - 31ms/epoch - 868us/step\n",
      "Epoch 472/500\n",
      "36/36 - 0s - loss: 0.0021 - mse: 0.0021 - val_loss: 0.0020 - val_mse: 0.0020 - 29ms/epoch - 817us/step\n",
      "Epoch 473/500\n",
      "36/36 - 0s - loss: 0.0020 - mse: 0.0020 - val_loss: 0.0021 - val_mse: 0.0021 - 31ms/epoch - 868us/step\n",
      "Epoch 474/500\n",
      "36/36 - 0s - loss: 0.0020 - mse: 0.0020 - val_loss: 0.0019 - val_mse: 0.0019 - 30ms/epoch - 839us/step\n",
      "Epoch 475/500\n",
      "36/36 - 0s - loss: 0.0020 - mse: 0.0020 - val_loss: 0.0020 - val_mse: 0.0020 - 29ms/epoch - 819us/step\n",
      "Epoch 476/500\n",
      "36/36 - 0s - loss: 0.0019 - mse: 0.0019 - val_loss: 0.0018 - val_mse: 0.0018 - 28ms/epoch - 780us/step\n",
      "Epoch 477/500\n",
      "36/36 - 0s - loss: 0.0019 - mse: 0.0019 - val_loss: 0.0019 - val_mse: 0.0019 - 30ms/epoch - 824us/step\n",
      "Epoch 478/500\n",
      "36/36 - 0s - loss: 0.0019 - mse: 0.0019 - val_loss: 0.0020 - val_mse: 0.0020 - 28ms/epoch - 788us/step\n",
      "Epoch 479/500\n",
      "36/36 - 0s - loss: 0.0018 - mse: 0.0018 - val_loss: 0.0017 - val_mse: 0.0017 - 29ms/epoch - 798us/step\n",
      "Epoch 480/500\n",
      "36/36 - 0s - loss: 0.0018 - mse: 0.0018 - val_loss: 0.0017 - val_mse: 0.0017 - 28ms/epoch - 785us/step\n",
      "Epoch 481/500\n",
      "36/36 - 0s - loss: 0.0018 - mse: 0.0018 - val_loss: 0.0017 - val_mse: 0.0017 - 29ms/epoch - 794us/step\n",
      "Epoch 482/500\n",
      "36/36 - 0s - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0018 - val_mse: 0.0018 - 31ms/epoch - 852us/step\n",
      "Epoch 483/500\n",
      "36/36 - 0s - loss: 0.0017 - mse: 0.0017 - val_loss: 0.0016 - val_mse: 0.0016 - 30ms/epoch - 837us/step\n",
      "Epoch 484/500\n",
      "36/36 - 0s - loss: 0.0016 - mse: 0.0016 - val_loss: 0.0016 - val_mse: 0.0016 - 29ms/epoch - 798us/step\n",
      "Epoch 485/500\n",
      "36/36 - 0s - loss: 0.0016 - mse: 0.0016 - val_loss: 0.0015 - val_mse: 0.0015 - 28ms/epoch - 774us/step\n",
      "Epoch 486/500\n",
      "36/36 - 0s - loss: 0.0016 - mse: 0.0016 - val_loss: 0.0016 - val_mse: 0.0016 - 28ms/epoch - 781us/step\n",
      "Epoch 487/500\n",
      "36/36 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0015 - val_mse: 0.0015 - 31ms/epoch - 875us/step\n",
      "Epoch 488/500\n",
      "36/36 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0015 - val_mse: 0.0015 - 31ms/epoch - 860us/step\n",
      "Epoch 489/500\n",
      "36/36 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0015 - val_mse: 0.0015 - 30ms/epoch - 830us/step\n",
      "Epoch 490/500\n",
      "36/36 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0014 - val_mse: 0.0014 - 31ms/epoch - 860us/step\n",
      "Epoch 491/500\n",
      "36/36 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0014 - val_mse: 0.0014 - 32ms/epoch - 879us/step\n",
      "Epoch 492/500\n",
      "36/36 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0016 - val_mse: 0.0016 - 32ms/epoch - 877us/step\n",
      "Epoch 493/500\n",
      "36/36 - 0s - loss: 0.0015 - mse: 0.0015 - val_loss: 0.0015 - val_mse: 0.0015 - 32ms/epoch - 878us/step\n",
      "Epoch 494/500\n",
      "36/36 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0013 - val_mse: 0.0013 - 32ms/epoch - 886us/step\n",
      "Epoch 495/500\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "36/36 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0015 - val_mse: 0.0015 - 31ms/epoch - 861us/step\n",
      "Epoch 496/500\n",
      "36/36 - 0s - loss: 0.0014 - mse: 0.0014 - val_loss: 0.0014 - val_mse: 0.0014 - 32ms/epoch - 879us/step\n",
      "Epoch 497/500\n",
      "36/36 - 0s - loss: 0.0013 - mse: 0.0013 - val_loss: 0.0013 - val_mse: 0.0013 - 32ms/epoch - 891us/step\n",
      "Epoch 498/500\n",
      "36/36 - 0s - loss: 0.0013 - mse: 0.0013 - val_loss: 0.0013 - val_mse: 0.0013 - 31ms/epoch - 869us/step\n",
      "Epoch 499/500\n",
      "36/36 - 0s - loss: 0.0013 - mse: 0.0013 - val_loss: 0.0013 - val_mse: 0.0013 - 33ms/epoch - 911us/step\n",
      "Epoch 500/500\n",
      "36/36 - 0s - loss: 0.0013 - mse: 0.0013 - val_loss: 0.0013 - val_mse: 0.0013 - 31ms/epoch - 848us/step\n",
      "16.042629957199097\n"
     ]
    }
   ],
   "source": [
    "###the standard RNN model is trained as benchmark, to show the priority of transfer learning RNN models\n",
    "model = Sequential()\n",
    "model.add(Dense(16, activation='relu'))\n",
    "model.add(Dense(2, activation='linear'))\n",
    "model.compile(optimizer='adam', loss='mse', metrics=['mse'])\n",
    "\n",
    "t0 = time.time()\n",
    "history = model.fit(X_train, y_train, epochs=500, batch_size=256, validation_split=0.25, verbose=2)\n",
    "t1 = time.time()\n",
    "print(t1-t0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "81f35c9a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "16/16 [==============================] - 0s 385us/step - loss: 0.0013 - mse: 0.0013\n",
      "[0.0013296997640281916, 0.0013296997640281916]\n",
      "16.042629957199097\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": "code",
   "execution_count": 17,
   "id": "364b1d8c",
   "metadata": {},
   "outputs": [],
   "source": [
    "model.save(\"pretrained_model.h5\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "9a846ec6",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Save to file\n",
    "np.save('source_input_data.npy', X_train)\n",
    "np.save('source_output_data.npy', y_train)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "82dfe168",
   "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
}
