{
  "nbformat": 4,
  "nbformat_minor": 0,
  "metadata": {
    "colab": {
      "provenance": []
    },
    "kernelspec": {
      "name": "python3",
      "display_name": "Python 3"
    },
    "language_info": {
      "name": "python"
    }
  },
  "cells": [
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "dP0_Qk0xi2j3"
      },
      "outputs": [],
      "source": [
        "from google.colab import drive\n",
        "#drive.flush_and_unmount()\n"
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "drive.mount('/content/gdrive')"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "hOoLB-WNjmIk",
        "outputId": "c8726951-4c2e-4e96-fa3c-914cf301f1fe"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Mounted at /content/gdrive\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "%cd /content/gdrive/MyDrive/RCGP/RCGP/RCGP-main/"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "Ou0T4U9_jyOQ",
        "outputId": "04d2b06f-d0fa-4b03-c70a-980ac304c9d8"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "/content/gdrive/MyDrive/RCGP/RCGP/RCGP-main\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "ls-lrt"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "k10FQBU5k6Sc",
        "outputId": "5e0703c5-8742-4637-eaac-66b4bb1da480"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "total 13\n",
            "-rw------- 1 root root  482 Aug  2 19:19 README.md\n",
            "-rw------- 1 root root    0 Aug  2 19:19 __init__.py\n",
            "drwx------ 2 root root 4096 Aug  2 19:20 \u001b[0m\u001b[01;34mrcgp\u001b[0m/\n",
            "drwx------ 2 root root 4096 Aug  2 19:20 \u001b[01;34mexperiments\u001b[0m/\n",
            "drwx------ 2 root root 4096 Aug  2 19:48 \u001b[01;34mmy_dataset\u001b[0m/\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "import sys\n",
        "import os\n",
        "\n",
        "SCRIPT_DIR = os.path.dirname(os.path.abspath(os.getcwd()))\n",
        "sys.path.append(SCRIPT_DIR)\n"
      ],
      "metadata": {
        "id": "L4ulpAL4QlgT"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "import tensorflow as tf\n",
        "import numpy as np\n",
        "# import gpflow\n"
      ],
      "metadata": {
        "id": "-EMYIum6QzAf"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "!pip install check_shapes"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "wuOjbhpxWlSE",
        "outputId": "5dcb02fa-a995-4d01-fdca-39ea57828944"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Collecting check_shapes\n",
            "  Downloading check_shapes-1.1.1-py3-none-any.whl.metadata (2.4 kB)\n",
            "Collecting dropstackframe>=0.1.0 (from check_shapes)\n",
            "  Downloading dropstackframe-0.1.0-py3-none-any.whl.metadata (4.4 kB)\n",
            "Collecting lark<2.0.0,>=1.1.0 (from check_shapes)\n",
            "  Downloading lark-1.1.9-py3-none-any.whl.metadata (1.9 kB)\n",
            "Downloading check_shapes-1.1.1-py3-none-any.whl (45 kB)\n",
            "\u001b[2K   \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m45.8/45.8 kB\u001b[0m \u001b[31m3.7 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
            "\u001b[?25hDownloading dropstackframe-0.1.0-py3-none-any.whl (4.5 kB)\n",
            "Downloading lark-1.1.9-py3-none-any.whl (111 kB)\n",
            "\u001b[2K   \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m111.7/111.7 kB\u001b[0m \u001b[31m9.9 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
            "\u001b[?25hInstalling collected packages: lark, dropstackframe, check_shapes\n",
            "Successfully installed check_shapes-1.1.1 dropstackframe-0.1.0 lark-1.1.9\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "import check_shapes"
      ],
      "metadata": {
        "id": "O4iTKqtlW3a_"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "!pip install gpflow"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "GTNnIhtCXfVn",
        "outputId": "163e3f06-6e98-46aa-dc11-b85ff53ed43c"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Collecting gpflow\n",
            "  Downloading gpflow-2.9.2-py3-none-any.whl.metadata (13 kB)\n",
            "Requirement already satisfied: check-shapes>=1.0.0 in /usr/local/lib/python3.10/dist-packages (from gpflow) (1.1.1)\n",
            "Collecting deprecated (from gpflow)\n",
            "  Downloading Deprecated-1.2.14-py2.py3-none-any.whl.metadata (5.4 kB)\n",
            "Requirement already satisfied: multipledispatch>=0.6 in /usr/local/lib/python3.10/dist-packages (from gpflow) (1.0.0)\n",
            "Requirement already satisfied: numpy in /usr/local/lib/python3.10/dist-packages (from gpflow) (1.26.4)\n",
            "Requirement already satisfied: packaging in /usr/local/lib/python3.10/dist-packages (from gpflow) (24.1)\n",
            "Requirement already satisfied: scipy in /usr/local/lib/python3.10/dist-packages (from gpflow) (1.13.1)\n",
            "Requirement already satisfied: setuptools>=41.0.0 in /usr/local/lib/python3.10/dist-packages (from gpflow) (71.0.4)\n",
            "Requirement already satisfied: tabulate in /usr/local/lib/python3.10/dist-packages (from gpflow) (0.9.0)\n",
            "Requirement already satisfied: tensorflow-probability>=0.12.0 in /usr/local/lib/python3.10/dist-packages (from tensorflow-probability[tf]>=0.12.0->gpflow) (0.24.0)\n",
            "Requirement already satisfied: typing-extensions in /usr/local/lib/python3.10/dist-packages (from gpflow) (4.12.2)\n",
            "Requirement already satisfied: tensorflow>=2.4.0 in /usr/local/lib/python3.10/dist-packages (from gpflow) (2.17.0)\n",
            "Requirement already satisfied: dropstackframe>=0.1.0 in /usr/local/lib/python3.10/dist-packages (from check-shapes>=1.0.0->gpflow) (0.1.0)\n",
            "Requirement already satisfied: lark<2.0.0,>=1.1.0 in /usr/local/lib/python3.10/dist-packages (from check-shapes>=1.0.0->gpflow) (1.1.9)\n",
            "Requirement already satisfied: absl-py>=1.0.0 in /usr/local/lib/python3.10/dist-packages (from tensorflow>=2.4.0->gpflow) (1.4.0)\n",
            "Requirement already satisfied: astunparse>=1.6.0 in /usr/local/lib/python3.10/dist-packages (from tensorflow>=2.4.0->gpflow) (1.6.3)\n",
            "Requirement already satisfied: flatbuffers>=24.3.25 in /usr/local/lib/python3.10/dist-packages (from tensorflow>=2.4.0->gpflow) (24.3.25)\n",
            "Requirement already satisfied: gast!=0.5.0,!=0.5.1,!=0.5.2,>=0.2.1 in /usr/local/lib/python3.10/dist-packages (from tensorflow>=2.4.0->gpflow) (0.6.0)\n",
            "Requirement already satisfied: google-pasta>=0.1.1 in /usr/local/lib/python3.10/dist-packages (from tensorflow>=2.4.0->gpflow) (0.2.0)\n",
            "Requirement already satisfied: h5py>=3.10.0 in /usr/local/lib/python3.10/dist-packages (from tensorflow>=2.4.0->gpflow) (3.11.0)\n",
            "Requirement already satisfied: libclang>=13.0.0 in /usr/local/lib/python3.10/dist-packages (from tensorflow>=2.4.0->gpflow) (18.1.1)\n",
            "Requirement already satisfied: ml-dtypes<0.5.0,>=0.3.1 in /usr/local/lib/python3.10/dist-packages (from tensorflow>=2.4.0->gpflow) (0.4.0)\n",
            "Requirement already satisfied: opt-einsum>=2.3.2 in /usr/local/lib/python3.10/dist-packages (from tensorflow>=2.4.0->gpflow) (3.3.0)\n",
            "Requirement already satisfied: protobuf!=4.21.0,!=4.21.1,!=4.21.2,!=4.21.3,!=4.21.4,!=4.21.5,<5.0.0dev,>=3.20.3 in /usr/local/lib/python3.10/dist-packages (from tensorflow>=2.4.0->gpflow) (3.20.3)\n",
            "Requirement already satisfied: requests<3,>=2.21.0 in /usr/local/lib/python3.10/dist-packages (from tensorflow>=2.4.0->gpflow) (2.31.0)\n",
            "Requirement already satisfied: six>=1.12.0 in /usr/local/lib/python3.10/dist-packages (from tensorflow>=2.4.0->gpflow) (1.16.0)\n",
            "Requirement already satisfied: termcolor>=1.1.0 in /usr/local/lib/python3.10/dist-packages (from tensorflow>=2.4.0->gpflow) (2.4.0)\n",
            "Requirement already satisfied: wrapt>=1.11.0 in /usr/local/lib/python3.10/dist-packages (from tensorflow>=2.4.0->gpflow) (1.16.0)\n",
            "Requirement already satisfied: grpcio<2.0,>=1.24.3 in /usr/local/lib/python3.10/dist-packages (from tensorflow>=2.4.0->gpflow) (1.64.1)\n",
            "Requirement already satisfied: tensorboard<2.18,>=2.17 in /usr/local/lib/python3.10/dist-packages (from tensorflow>=2.4.0->gpflow) (2.17.0)\n",
            "Requirement already satisfied: keras>=3.2.0 in /usr/local/lib/python3.10/dist-packages (from tensorflow>=2.4.0->gpflow) (3.4.1)\n",
            "Requirement already satisfied: tensorflow-io-gcs-filesystem>=0.23.1 in /usr/local/lib/python3.10/dist-packages (from tensorflow>=2.4.0->gpflow) (0.37.1)\n",
            "Requirement already satisfied: decorator in /usr/local/lib/python3.10/dist-packages (from tensorflow-probability>=0.12.0->tensorflow-probability[tf]>=0.12.0->gpflow) (4.4.2)\n",
            "Requirement already satisfied: cloudpickle>=1.3 in /usr/local/lib/python3.10/dist-packages (from tensorflow-probability>=0.12.0->tensorflow-probability[tf]>=0.12.0->gpflow) (2.2.1)\n",
            "Requirement already satisfied: dm-tree in /usr/local/lib/python3.10/dist-packages (from tensorflow-probability>=0.12.0->tensorflow-probability[tf]>=0.12.0->gpflow) (0.1.8)\n",
            "Requirement already satisfied: tf-keras>=2.16 in /usr/local/lib/python3.10/dist-packages (from tensorflow-probability[tf]>=0.12.0->gpflow) (2.17.0)\n",
            "Requirement already satisfied: wheel<1.0,>=0.23.0 in /usr/local/lib/python3.10/dist-packages (from astunparse>=1.6.0->tensorflow>=2.4.0->gpflow) (0.43.0)\n",
            "Requirement already satisfied: rich in /usr/local/lib/python3.10/dist-packages (from keras>=3.2.0->tensorflow>=2.4.0->gpflow) (13.7.1)\n",
            "Requirement already satisfied: namex in /usr/local/lib/python3.10/dist-packages (from keras>=3.2.0->tensorflow>=2.4.0->gpflow) (0.0.8)\n",
            "Requirement already satisfied: optree in /usr/local/lib/python3.10/dist-packages (from keras>=3.2.0->tensorflow>=2.4.0->gpflow) (0.12.1)\n",
            "Requirement already satisfied: charset-normalizer<4,>=2 in /usr/local/lib/python3.10/dist-packages (from requests<3,>=2.21.0->tensorflow>=2.4.0->gpflow) (3.3.2)\n",
            "Requirement already satisfied: idna<4,>=2.5 in /usr/local/lib/python3.10/dist-packages (from requests<3,>=2.21.0->tensorflow>=2.4.0->gpflow) (3.7)\n",
            "Requirement already satisfied: urllib3<3,>=1.21.1 in /usr/local/lib/python3.10/dist-packages (from requests<3,>=2.21.0->tensorflow>=2.4.0->gpflow) (2.0.7)\n",
            "Requirement already satisfied: certifi>=2017.4.17 in /usr/local/lib/python3.10/dist-packages (from requests<3,>=2.21.0->tensorflow>=2.4.0->gpflow) (2024.7.4)\n",
            "Requirement already satisfied: markdown>=2.6.8 in /usr/local/lib/python3.10/dist-packages (from tensorboard<2.18,>=2.17->tensorflow>=2.4.0->gpflow) (3.6)\n",
            "Requirement already satisfied: tensorboard-data-server<0.8.0,>=0.7.0 in /usr/local/lib/python3.10/dist-packages (from tensorboard<2.18,>=2.17->tensorflow>=2.4.0->gpflow) (0.7.2)\n",
            "Requirement already satisfied: werkzeug>=1.0.1 in /usr/local/lib/python3.10/dist-packages (from tensorboard<2.18,>=2.17->tensorflow>=2.4.0->gpflow) (3.0.3)\n",
            "Requirement already satisfied: MarkupSafe>=2.1.1 in /usr/local/lib/python3.10/dist-packages (from werkzeug>=1.0.1->tensorboard<2.18,>=2.17->tensorflow>=2.4.0->gpflow) (2.1.5)\n",
            "Requirement already satisfied: markdown-it-py>=2.2.0 in /usr/local/lib/python3.10/dist-packages (from rich->keras>=3.2.0->tensorflow>=2.4.0->gpflow) (3.0.0)\n",
            "Requirement already satisfied: pygments<3.0.0,>=2.13.0 in /usr/local/lib/python3.10/dist-packages (from rich->keras>=3.2.0->tensorflow>=2.4.0->gpflow) (2.16.1)\n",
            "Requirement already satisfied: mdurl~=0.1 in /usr/local/lib/python3.10/dist-packages (from markdown-it-py>=2.2.0->rich->keras>=3.2.0->tensorflow>=2.4.0->gpflow) (0.1.2)\n",
            "Downloading gpflow-2.9.2-py3-none-any.whl (392 kB)\n",
            "\u001b[2K   \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m392.9/392.9 kB\u001b[0m \u001b[31m18.2 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
            "\u001b[?25hDownloading Deprecated-1.2.14-py2.py3-none-any.whl (9.6 kB)\n",
            "Installing collected packages: deprecated, gpflow\n",
            "Successfully installed deprecated-1.2.14 gpflow-2.9.2\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [],
      "metadata": {
        "id": "sOlcp8H2XmaX"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "from rcgp.rcgp import RCGPR\n",
        "from rcgp.w import IMQ\n",
        "\n",
        "import matplotlib.pyplot as plt"
      ],
      "metadata": {
        "id": "EM5PIT2TQ1JV"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "seed = 10\n",
        "sigma_n = 0.1"
      ],
      "metadata": {
        "id": "vFDvWoixQ6OR"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "!pwd"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "lpnEZiEsYDid",
        "outputId": "142a5b7f-7661-4714-9653-ab8c39592069"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "/content/gdrive/MyDrive/RCGP/RCGP/RCGP-main\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "import pandas\n",
        "\n",
        "\n",
        "\n",
        "#get a data frame with selected columns\n",
        "# FORMAT = ['Col_1', 'Col_2', 'Col_3']\n",
        "# df_selected = df[FORMAT]"
      ],
      "metadata": {
        "id": "977kk7rvT7-6"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "x = pandas.read_excel('/content/gdrive/MyDrive/RCGP/RCGP/RCGP-main/my_dataset/Neal_data.xls',sheet_name='Sheet1', header=None, usecols=[0]) #, names=['A'])\n",
        "y = pandas.read_excel('/content/gdrive/MyDrive/RCGP/RCGP/RCGP-main/my_dataset/Neal_data.xls',sheet_name='Sheet1', header=None, usecols=[1]) #, names=['B'])\n",
        "xt = pandas.read_excel('/content/gdrive/MyDrive/RCGP/RCGP/RCGP-main/my_dataset/Neal_data.xls',sheet_name='Sheet2', header=None, usecols=[0]) #, names=['A'])\n",
        "yt = pandas.read_excel('/content/gdrive/MyDrive/RCGP/RCGP/RCGP-main/my_dataset/Neal_data.xls',sheet_name='Sheet2', header=None, usecols=[1]) #, names=['B'])\n",
        "\n",
        "#print the column names\n",
        "print (x)\n",
        "print (xt)\n",
        "print (y)\n",
        "print (yt)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "zmQJAB8hYjLg",
        "outputId": "cd9fd53c-4580-4bbd-c7c4-73c975ef1f21"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "          0\n",
            "0  -0.17308\n",
            "1  -0.47952\n",
            "2  -0.78357\n",
            "3  -0.63218\n",
            "4  -0.91060\n",
            "..      ...\n",
            "95 -0.12340\n",
            "96 -1.13396\n",
            "97  0.51589\n",
            "98  0.48192\n",
            "99  0.32773\n",
            "\n",
            "[100 rows x 1 columns]\n",
            "        0\n",
            "0   -2.70\n",
            "1   -2.69\n",
            "2   -2.68\n",
            "3   -2.67\n",
            "4   -2.66\n",
            "..    ...\n",
            "866  5.96\n",
            "867  5.97\n",
            "868  5.98\n",
            "869  5.99\n",
            "870  6.00\n",
            "\n",
            "[871 rows x 1 columns]\n",
            "          1\n",
            "0   1.10456\n",
            "1   0.63622\n",
            "2   0.16344\n",
            "3  -0.86175\n",
            "4   0.06405\n",
            "..      ...\n",
            "95  1.15153\n",
            "96  0.25201\n",
            "97  1.79423\n",
            "98  1.87952\n",
            "99  1.88636\n",
            "\n",
            "[100 rows x 1 columns]\n",
            "            1\n",
            "0   -1.069877\n",
            "1   -1.057639\n",
            "2   -1.045090\n",
            "3   -1.032236\n",
            "4   -1.019082\n",
            "..        ...\n",
            "866  2.526786\n",
            "867  2.518241\n",
            "868  2.509842\n",
            "869  2.501599\n",
            "870  2.493519\n",
            "\n",
            "[871 rows x 1 columns]\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "print(y.iloc[6, 0])\n",
        "print(np.arange(4.3, 4.6, 0.1))\n",
        "print(x.iloc[21,0])"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "goN14Csym6qb",
        "outputId": "dc526ed2-1079-4877-c8b2-8c1631dfdc8e"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "0.74596\n",
            "[4.3 4.4 4.5]\n",
            "0.84909\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "#Adding v outliers and b outliers\n",
        "out_idx_v = [6, 7, 8, 9, 10, 14, 60, 69]\n",
        "out_idx_b = [20, 21, 22]\n",
        "out_idx_g = [49, 50, 51, 52, 53, 54]\n",
        "\n",
        "# Adding bad leverage points\n",
        "# x.iloc[out_idx_b] = [[4.3], [4.6], [0.1]]\n",
        "# y.iloc[out_idx_b] = [[8.4763], [9.1938], [0.2833]]\n",
        "\n",
        "# Adding vertical outliers\n",
        "# y.iloc[out_idx_v] = [[90.5], [8.6], [98.1], [5.3], [5.2], [6.1], [1], [8]]\n",
        "y.iloc[out_idx_v]=  [[5], [5], [5], [5], [5], [5], [5], [5]]   #5 * np.ones(len(out_idx_v))\n",
        "\n",
        "# Adding good leverage points (commented out)\n",
        "# x.iloc[out_idx_g]=[[2.8],[3.82],[3.84],[3.16],[2.88],[2.9]]\n",
        "# y.iloc[out_idx_g]= [[2.0230],[1.5103], [1.5011], [2.0535],  [2.0688],  [2.0768]]\n",
        "\n",
        "\n",
        "# Exporting data (commented out)\n",
        "# np.savetxt('Neal_data.csv', np.column_stack((x, y)), delimiter=',')\n",
        "\n",
        "# Adding noise\n",
        "n = len(x)\n",
        "# noise = np.random.normal(0.01, 0.08, n)  # Uncomment for normal noise\n",
        "# noise = 0.01 * np.random.standard_t(10, n)  # Uncomment for Student's-t noise with nu=10\n",
        "# noise = 0.1 * np.random.laplace(0, 1, n)  # Uncomment for Laplacian noise\n",
        "noise = 0.01 * np.random.standard_t(1, n)  # Uncomment for Student's-t noise with nu=1 (Cauchy)\n"
      ],
      "metadata": {
        "id": "YzUL3Xov3Fyh"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "y.iloc[:, 0] = y.iloc[:, 0] + noise  # Access the first (and only) column of y\n",
        "print (y)\n",
        "print (x)\n"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "hFAwbPg3Acp_",
        "outputId": "761346a0-b29a-45eb-88d3-93153f19e993"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "           1\n",
            "0   1.102697\n",
            "1   0.558448\n",
            "2   0.274540\n",
            "3  -0.798616\n",
            "4   0.116976\n",
            "..       ...\n",
            "95  1.151094\n",
            "96  0.258683\n",
            "97  1.790455\n",
            "98  1.895370\n",
            "99  1.871432\n",
            "\n",
            "[100 rows x 1 columns]\n",
            "          0\n",
            "0  -0.17308\n",
            "1  -0.47952\n",
            "2  -0.78357\n",
            "3  -0.63218\n",
            "4  -0.91060\n",
            "..      ...\n",
            "95 -0.12340\n",
            "96 -1.13396\n",
            "97  0.51589\n",
            "98  0.48192\n",
            "99  0.32773\n",
            "\n",
            "[100 rows x 1 columns]\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "import tensorflow as tf\n",
        "import numpy as np\n",
        "import pandas as pd\n",
        "import gpflow\n",
        "\n",
        "# from tueplots import bundles"
      ],
      "metadata": {
        "id": "6rvsy54jeNHe"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "# Trining standadrf GP\n",
        "standard_gp = gpflow.models.GPR(\n",
        "    (x, y),\n",
        "    kernel=gpflow.kernels.SquaredExponential(lengthscales=0.01,variance = 0.01),\n",
        "    noise_variance = 0.01\n",
        ")\n",
        "\n",
        "opt = gpflow.optimizers.Scipy()\n",
        "opt_options = dict()\n",
        "res = opt.minimize(standard_gp.training_loss_closure(), standard_gp.trainable_variables, options=opt_options)\n",
        "print(res)\n",
        "# gpflow.utilities.print_summary(standard_gp, \"notebook\")"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "igx8DCy-c43m",
        "outputId": "a5ec1a84-26f5-425d-c964-1423f7a8282c"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "  message: CONVERGENCE: REL_REDUCTION_OF_F_<=_FACTR*EPSMCH\n",
            "  success: True\n",
            "   status: 0\n",
            "      fun: 163.46306787645662\n",
            "        x: [ 3.526e-01  1.851e+00  9.987e-01]\n",
            "      nit: 19\n",
            "      jac: [ 5.635e-05  5.024e-05 -2.106e-04]\n",
            "     nfev: 22\n",
            "     njev: 22\n",
            " hess_inv: <3x3 LbfgsInvHessProduct with dtype=float64>\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "model = RCGPR(\n",
        "    (x, y),\n",
        "    kernel=gpflow.kernels.SquaredExponential(),\n",
        "    weighting_function=IMQ(1.5),\n",
        "    noise_variance=standard_gp.likelihood.variance)\n",
        "\n",
        "gpflow.set_trainable(model.likelihood.variance, False)\n",
        "opt = gpflow.optimizers.Scipy()\n",
        "opt_options = dict()\n",
        "res = opt.minimize(model.training_loss_closure(), model.trainable_variables, options=opt_options)\n",
        "print(res)\n",
        "gpflow.utilities.print_summary(model, \"notebook\")\n",
        "\n"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 299
        },
        "id": "K5iEVOmzc-Nh",
        "outputId": "251ea483-2f1c-40a0-9939-3443eb2b9255"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "  message: CONVERGENCE: REL_REDUCTION_OF_F_<=_FACTR*EPSMCH\n",
            "  success: True\n",
            "   status: 0\n",
            "      fun: 156.75788652254153\n",
            "        x: [ 5.931e-01  1.133e+01  3.053e+00]\n",
            "      nit: 18\n",
            "      jac: [-2.638e-05 -1.945e-06  1.053e-05]\n",
            "     nfev: 20\n",
            "     njev: 20\n",
            " hess_inv: <3x3 LbfgsInvHessProduct with dtype=float64>\n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<IPython.core.display.HTML object>"
            ],
            "text/html": [
              "<table>\n",
              "<thead>\n",
              "<tr><th>name                      </th><th>class    </th><th>transform       </th><th>prior  </th><th>trainable  </th><th>shape  </th><th>dtype  </th><th style=\"text-align: right;\">   value</th></tr>\n",
              "</thead>\n",
              "<tbody>\n",
              "<tr><td>RCGPR.kernel.variance     </td><td>Parameter</td><td>Softplus        </td><td>       </td><td>True       </td><td>()     </td><td>float64</td><td style=\"text-align: right;\">11.3321 </td></tr>\n",
              "<tr><td>RCGPR.kernel.lengthscales </td><td>Parameter</td><td>Softplus        </td><td>       </td><td>True       </td><td>()     </td><td>float64</td><td style=\"text-align: right;\"> 1.03303</td></tr>\n",
              "<tr><td>RCGPR.likelihood.variance </td><td>Parameter</td><td>Softplus + Shift</td><td>       </td><td>False      </td><td>()     </td><td>float64</td><td style=\"text-align: right;\"> 1.31233</td></tr>\n",
              "<tr><td>RCGPR.weighting_function.C</td><td>Parameter</td><td>Softplus        </td><td>       </td><td>True       </td><td>()     </td><td>float64</td><td style=\"text-align: right;\"> 3.09947</td></tr>\n",
              "</tbody>\n",
              "</table>"
            ]
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "import sklearn\n",
        "from sklearn.preprocessing import StandardScaler, RobustScaler\n"
      ],
      "metadata": {
        "id": "eO6ydvCjftHm"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "!pip install tueplots\n"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "Hb3eQYiXf2h8",
        "outputId": "93d0700c-e431-449f-ff47-658cf81b2b81"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Collecting tueplots\n",
            "  Downloading tueplots-0.0.15-py3-none-any.whl.metadata (5.2 kB)\n",
            "Requirement already satisfied: matplotlib in /usr/local/lib/python3.10/dist-packages (from tueplots) (3.7.1)\n",
            "Requirement already satisfied: numpy in /usr/local/lib/python3.10/dist-packages (from tueplots) (1.26.4)\n",
            "Requirement already satisfied: contourpy>=1.0.1 in /usr/local/lib/python3.10/dist-packages (from matplotlib->tueplots) (1.2.1)\n",
            "Requirement already satisfied: cycler>=0.10 in /usr/local/lib/python3.10/dist-packages (from matplotlib->tueplots) (0.12.1)\n",
            "Requirement already satisfied: fonttools>=4.22.0 in /usr/local/lib/python3.10/dist-packages (from matplotlib->tueplots) (4.53.1)\n",
            "Requirement already satisfied: kiwisolver>=1.0.1 in /usr/local/lib/python3.10/dist-packages (from matplotlib->tueplots) (1.4.5)\n",
            "Requirement already satisfied: packaging>=20.0 in /usr/local/lib/python3.10/dist-packages (from matplotlib->tueplots) (24.1)\n",
            "Requirement already satisfied: pillow>=6.2.0 in /usr/local/lib/python3.10/dist-packages (from matplotlib->tueplots) (9.4.0)\n",
            "Requirement already satisfied: pyparsing>=2.3.1 in /usr/local/lib/python3.10/dist-packages (from matplotlib->tueplots) (3.1.2)\n",
            "Requirement already satisfied: python-dateutil>=2.7 in /usr/local/lib/python3.10/dist-packages (from matplotlib->tueplots) (2.8.2)\n",
            "Requirement already satisfied: six>=1.5 in /usr/local/lib/python3.10/dist-packages (from python-dateutil>=2.7->matplotlib->tueplots) (1.16.0)\n",
            "Downloading tueplots-0.0.15-py3-none-any.whl (13 kB)\n",
            "Installing collected packages: tueplots\n",
            "Successfully installed tueplots-0.0.15\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "from tueplots import bundles\n"
      ],
      "metadata": {
        "id": "-bisN_6Jf_3Z"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "# predictions\n",
        "if isinstance(xt, pd.DataFrame):  # convert xt into tensorflow data types\n",
        "    xt = xt.values\n"
      ],
      "metadata": {
        "id": "8gy2HjhDbWBd"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "Eft, Varft = model.predict_f(xt, full_cov=False)\n",
        "std_ft = np.sqrt(Varft)"
      ],
      "metadata": {
        "id": "FyKKfnmjihgj"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "print (Varft)\n",
        "print (Eft)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "xfLHESAqi85O",
        "outputId": "6082645c-37d1-4e03-fe2c-38a23f3f456a"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "tf.Tensor(\n",
            "[[ 1.25840796]\n",
            " [ 1.23163522]\n",
            " [ 1.20557824]\n",
            " [ 1.18022487]\n",
            " [ 1.15556265]\n",
            " [ 1.13157884]\n",
            " [ 1.10826044]\n",
            " [ 1.0855942 ]\n",
            " [ 1.06356666]\n",
            " [ 1.04216416]\n",
            " [ 1.02137285]\n",
            " [ 1.00117874]\n",
            " [ 0.98156769]\n",
            " [ 0.96252547]\n",
            " [ 0.94403773]\n",
            " [ 0.92609007]\n",
            " [ 0.90866802]\n",
            " [ 0.89175708]\n",
            " [ 0.87534276]\n",
            " [ 0.85941056]\n",
            " [ 0.843946  ]\n",
            " [ 0.82893467]\n",
            " [ 0.81436221]\n",
            " [ 0.80021434]\n",
            " [ 0.7864769 ]\n",
            " [ 0.77313583]\n",
            " [ 0.7601772 ]\n",
            " [ 0.74758726]\n",
            " [ 0.73535241]\n",
            " [ 0.72345921]\n",
            " [ 0.71189446]\n",
            " [ 0.70064513]\n",
            " [ 0.68969843]\n",
            " [ 0.67904181]\n",
            " [ 0.66866297]\n",
            " [ 0.65854984]\n",
            " [ 0.64869065]\n",
            " [ 0.6390739 ]\n",
            " [ 0.62968836]\n",
            " [ 0.62052312]\n",
            " [ 0.61156756]\n",
            " [ 0.60281138]\n",
            " [ 0.59424457]\n",
            " [ 0.58585747]\n",
            " [ 0.57764073]\n",
            " [ 0.56958535]\n",
            " [ 0.56168262]\n",
            " [ 0.55392422]\n",
            " [ 0.54630213]\n",
            " [ 0.53880867]\n",
            " [ 0.53143653]\n",
            " [ 0.52417869]\n",
            " [ 0.51702852]\n",
            " [ 0.50997968]\n",
            " [ 0.5030262 ]\n",
            " [ 0.49616242]\n",
            " [ 0.48938301]\n",
            " [ 0.48268297]\n",
            " [ 0.47605763]\n",
            " [ 0.46950261]\n",
            " [ 0.46301387]\n",
            " [ 0.45658763]\n",
            " [ 0.45022046]\n",
            " [ 0.44390918]\n",
            " [ 0.4376509 ]\n",
            " [ 0.43144304]\n",
            " [ 0.42528323]\n",
            " [ 0.41916941]\n",
            " [ 0.41309974]\n",
            " [ 0.40707264]\n",
            " [ 0.40108676]\n",
            " [ 0.39514096]\n",
            " [ 0.38923433]\n",
            " [ 0.38336616]\n",
            " [ 0.37753593]\n",
            " [ 0.37174332]\n",
            " [ 0.36598816]\n",
            " [ 0.36027046]\n",
            " [ 0.3545904 ]\n",
            " [ 0.34894827]\n",
            " [ 0.34334453]\n",
            " [ 0.33777975]\n",
            " [ 0.3322546 ]\n",
            " [ 0.32676988]\n",
            " [ 0.32132647]\n",
            " [ 0.31592535]\n",
            " [ 0.31056755]\n",
            " [ 0.3052542 ]\n",
            " [ 0.29998646]\n",
            " [ 0.29476557]\n",
            " [ 0.28959276]\n",
            " [ 0.28446935]\n",
            " [ 0.27939664]\n",
            " [ 0.27437598]\n",
            " [ 0.26940868]\n",
            " [ 0.26449611]\n",
            " [ 0.25963958]\n",
            " [ 0.25484043]\n",
            " [ 0.25009995]\n",
            " [ 0.24541941]\n",
            " [ 0.24080006]\n",
            " [ 0.2362431 ]\n",
            " [ 0.23174969]\n",
            " [ 0.22732096]\n",
            " [ 0.22295796]\n",
            " [ 0.21866169]\n",
            " [ 0.21443312]\n",
            " [ 0.21027312]\n",
            " [ 0.20618251]\n",
            " [ 0.20216204]\n",
            " [ 0.19821239]\n",
            " [ 0.19433417]\n",
            " [ 0.19052789]\n",
            " [ 0.18679402]\n",
            " [ 0.18313292]\n",
            " [ 0.1795449 ]\n",
            " [ 0.17603017]\n",
            " [ 0.17258886]\n",
            " [ 0.16922103]\n",
            " [ 0.16592666]\n",
            " [ 0.16270564]\n",
            " [ 0.15955781]\n",
            " [ 0.15648289]\n",
            " [ 0.15348057]\n",
            " [ 0.15055042]\n",
            " [ 0.14769198]\n",
            " [ 0.14490469]\n",
            " [ 0.14218793]\n",
            " [ 0.13954102]\n",
            " [ 0.13696321]\n",
            " [ 0.13445369]\n",
            " [ 0.13201159]\n",
            " [ 0.12963597]\n",
            " [ 0.12732586]\n",
            " [ 0.12508023]\n",
            " [ 0.122898  ]\n",
            " [ 0.12077805]\n",
            " [ 0.11871921]\n",
            " [ 0.11672027]\n",
            " [ 0.11478001]\n",
            " [ 0.11289714]\n",
            " [ 0.11107038]\n",
            " [ 0.10929839]\n",
            " [ 0.10757982]\n",
            " [ 0.10591332]\n",
            " [ 0.1042975 ]\n",
            " [ 0.10273097]\n",
            " [ 0.10121231]\n",
            " [ 0.09974013]\n",
            " [ 0.09831299]\n",
            " [ 0.09692949]\n",
            " [ 0.09558821]\n",
            " [ 0.09428775]\n",
            " [ 0.09302669]\n",
            " [ 0.09180365]\n",
            " [ 0.09061724]\n",
            " [ 0.0894661 ]\n",
            " [ 0.08834887]\n",
            " [ 0.08726423]\n",
            " [ 0.08621087]\n",
            " [ 0.0851875 ]\n",
            " [ 0.08419286]\n",
            " [ 0.0832257 ]\n",
            " [ 0.08228484]\n",
            " [ 0.08136908]\n",
            " [ 0.08047727]\n",
            " [ 0.07960831]\n",
            " [ 0.07876111]\n",
            " [ 0.07793462]\n",
            " [ 0.07712784]\n",
            " [ 0.07633977]\n",
            " [ 0.07556949]\n",
            " [ 0.07481609]\n",
            " [ 0.0740787 ]\n",
            " [ 0.0733565 ]\n",
            " [ 0.07264869]\n",
            " [ 0.07195454]\n",
            " [ 0.07127332]\n",
            " [ 0.07060436]\n",
            " [ 0.06994703]\n",
            " [ 0.06930073]\n",
            " [ 0.0686649 ]\n",
            " [ 0.06803903]\n",
            " [ 0.06742263]\n",
            " [ 0.06681525]\n",
            " [ 0.06621649]\n",
            " [ 0.06562597]\n",
            " [ 0.06504336]\n",
            " [ 0.06446834]\n",
            " [ 0.06390066]\n",
            " [ 0.06334008]\n",
            " [ 0.06278638]\n",
            " [ 0.06223941]\n",
            " [ 0.06169902]\n",
            " [ 0.06116509]\n",
            " [ 0.06063755]\n",
            " [ 0.06011633]\n",
            " [ 0.05960141]\n",
            " [ 0.0590928 ]\n",
            " [ 0.0585905 ]\n",
            " [ 0.05809457]\n",
            " [ 0.05760507]\n",
            " [ 0.0571221 ]\n",
            " [ 0.05664577]\n",
            " [ 0.0561762 ]\n",
            " [ 0.05571355]\n",
            " [ 0.05525799]\n",
            " [ 0.05480969]\n",
            " [ 0.05436885]\n",
            " [ 0.05393569]\n",
            " [ 0.05351044]\n",
            " [ 0.05309332]\n",
            " [ 0.05268459]\n",
            " [ 0.05228451]\n",
            " [ 0.05189334]\n",
            " [ 0.05151136]\n",
            " [ 0.05113885]\n",
            " [ 0.0507761 ]\n",
            " [ 0.0504234 ]\n",
            " [ 0.05008104]\n",
            " [ 0.04974933]\n",
            " [ 0.04942856]\n",
            " [ 0.04911903]\n",
            " [ 0.04882105]\n",
            " [ 0.04853492]\n",
            " [ 0.04826092]\n",
            " [ 0.04799936]\n",
            " [ 0.04775053]\n",
            " [ 0.0475147 ]\n",
            " [ 0.04729216]\n",
            " [ 0.04708318]\n",
            " [ 0.04688802]\n",
            " [ 0.04670694]\n",
            " [ 0.04654018]\n",
            " [ 0.04638798]\n",
            " [ 0.04625057]\n",
            " [ 0.04612815]\n",
            " [ 0.04602092]\n",
            " [ 0.04592907]\n",
            " [ 0.04585277]\n",
            " [ 0.04579218]\n",
            " [ 0.04574743]\n",
            " [ 0.04571865]\n",
            " [ 0.04570594]\n",
            " [ 0.04570939]\n",
            " [ 0.04572907]\n",
            " [ 0.04576504]\n",
            " [ 0.0458173 ]\n",
            " [ 0.04588589]\n",
            " [ 0.04597078]\n",
            " [ 0.04607194]\n",
            " [ 0.04618931]\n",
            " [ 0.04632282]\n",
            " [ 0.04647236]\n",
            " [ 0.04663781]\n",
            " [ 0.04681902]\n",
            " [ 0.04701582]\n",
            " [ 0.047228  ]\n",
            " [ 0.04745535]\n",
            " [ 0.04769763]\n",
            " [ 0.04795455]\n",
            " [ 0.04822584]\n",
            " [ 0.04851115]\n",
            " [ 0.04881016]\n",
            " [ 0.04912248]\n",
            " [ 0.04944773]\n",
            " [ 0.04978549]\n",
            " [ 0.05013532]\n",
            " [ 0.05049674]\n",
            " [ 0.05086927]\n",
            " [ 0.05125239]\n",
            " [ 0.05164558]\n",
            " [ 0.05204827]\n",
            " [ 0.05245989]\n",
            " [ 0.05287983]\n",
            " [ 0.05330749]\n",
            " [ 0.05374223]\n",
            " [ 0.05418338]\n",
            " [ 0.05463029]\n",
            " [ 0.05508226]\n",
            " [ 0.05553858]\n",
            " [ 0.05599855]\n",
            " [ 0.05646144]\n",
            " [ 0.05692651]\n",
            " [ 0.057393  ]\n",
            " [ 0.05786016]\n",
            " [ 0.05832722]\n",
            " [ 0.05879341]\n",
            " [ 0.05925797]\n",
            " [ 0.0597201 ]\n",
            " [ 0.06017903]\n",
            " [ 0.06063399]\n",
            " [ 0.06108419]\n",
            " [ 0.06152887]\n",
            " [ 0.06196725]\n",
            " [ 0.06239859]\n",
            " [ 0.06282213]\n",
            " [ 0.06323713]\n",
            " [ 0.06364287]\n",
            " [ 0.06403863]\n",
            " [ 0.06442373]\n",
            " [ 0.06479749]\n",
            " [ 0.06515925]\n",
            " [ 0.06550837]\n",
            " [ 0.06584426]\n",
            " [ 0.06616632]\n",
            " [ 0.06647399]\n",
            " [ 0.06676676]\n",
            " [ 0.06704412]\n",
            " [ 0.06730561]\n",
            " [ 0.06755079]\n",
            " [ 0.06777927]\n",
            " [ 0.0679907 ]\n",
            " [ 0.06818475]\n",
            " [ 0.06836114]\n",
            " [ 0.06851964]\n",
            " [ 0.06866004]\n",
            " [ 0.0687822 ]\n",
            " [ 0.068886  ]\n",
            " [ 0.06897138]\n",
            " [ 0.06903832]\n",
            " [ 0.06908686]\n",
            " [ 0.06911706]\n",
            " [ 0.06912907]\n",
            " [ 0.06912305]\n",
            " [ 0.06909923]\n",
            " [ 0.06905788]\n",
            " [ 0.06899933]\n",
            " [ 0.06892395]\n",
            " [ 0.06883217]\n",
            " [ 0.06872445]\n",
            " [ 0.06860133]\n",
            " [ 0.06846337]\n",
            " [ 0.0683112 ]\n",
            " [ 0.06814548]\n",
            " [ 0.06796693]\n",
            " [ 0.06777631]\n",
            " [ 0.06757443]\n",
            " [ 0.06736213]\n",
            " [ 0.06714031]\n",
            " [ 0.06690991]\n",
            " [ 0.06667189]\n",
            " [ 0.06642728]\n",
            " [ 0.06617712]\n",
            " [ 0.06592249]\n",
            " [ 0.06566452]\n",
            " [ 0.06540434]\n",
            " [ 0.06514315]\n",
            " [ 0.06488214]\n",
            " [ 0.06462253]\n",
            " [ 0.06436559]\n",
            " [ 0.06411258]\n",
            " [ 0.06386479]\n",
            " [ 0.06362352]\n",
            " [ 0.06339009]\n",
            " [ 0.06316581]\n",
            " [ 0.06295203]\n",
            " [ 0.06275007]\n",
            " [ 0.06256127]\n",
            " [ 0.06238697]\n",
            " [ 0.06222849]\n",
            " [ 0.06208716]\n",
            " [ 0.06196429]\n",
            " [ 0.06186118]\n",
            " [ 0.06177911]\n",
            " [ 0.06171936]\n",
            " [ 0.06168315]\n",
            " [ 0.06167173]\n",
            " [ 0.06168627]\n",
            " [ 0.06172794]\n",
            " [ 0.06179787]\n",
            " [ 0.06189716]\n",
            " [ 0.06202687]\n",
            " [ 0.06218801]\n",
            " [ 0.06238157]\n",
            " [ 0.06260848]\n",
            " [ 0.06286962]\n",
            " [ 0.06316583]\n",
            " [ 0.0634979 ]\n",
            " [ 0.06386655]\n",
            " [ 0.06427248]\n",
            " [ 0.06471629]\n",
            " [ 0.06519856]\n",
            " [ 0.0657198 ]\n",
            " [ 0.06628044]\n",
            " [ 0.06688087]\n",
            " [ 0.06752141]\n",
            " [ 0.06820231]\n",
            " [ 0.06892378]\n",
            " [ 0.06968593]\n",
            " [ 0.07048883]\n",
            " [ 0.07133247]\n",
            " [ 0.07221679]\n",
            " [ 0.07314164]\n",
            " [ 0.07410683]\n",
            " [ 0.07511208]\n",
            " [ 0.07615707]\n",
            " [ 0.07724139]\n",
            " [ 0.07836459]\n",
            " [ 0.07952614]\n",
            " [ 0.08072546]\n",
            " [ 0.08196191]\n",
            " [ 0.08323477]\n",
            " [ 0.08454329]\n",
            " [ 0.08588665]\n",
            " [ 0.08726398]\n",
            " [ 0.08867436]\n",
            " [ 0.09011682]\n",
            " [ 0.09159033]\n",
            " [ 0.09309384]\n",
            " [ 0.09462625]\n",
            " [ 0.0961864 ]\n",
            " [ 0.09777312]\n",
            " [ 0.09938519]\n",
            " [ 0.10102136]\n",
            " [ 0.10268038]\n",
            " [ 0.10436094]\n",
            " [ 0.10606173]\n",
            " [ 0.10778142]\n",
            " [ 0.10951866]\n",
            " [ 0.11127211]\n",
            " [ 0.11304039]\n",
            " [ 0.11482216]\n",
            " [ 0.11661606]\n",
            " [ 0.11842073]\n",
            " [ 0.12023485]\n",
            " [ 0.12205708]\n",
            " [ 0.12388612]\n",
            " [ 0.1257207 ]\n",
            " [ 0.12755956]\n",
            " [ 0.12940149]\n",
            " [ 0.1312453 ]\n",
            " [ 0.13308987]\n",
            " [ 0.13493409]\n",
            " [ 0.13677693]\n",
            " [ 0.13861741]\n",
            " [ 0.14045461]\n",
            " [ 0.14228766]\n",
            " [ 0.14411579]\n",
            " [ 0.14593827]\n",
            " [ 0.14775448]\n",
            " [ 0.14956387]\n",
            " [ 0.15136599]\n",
            " [ 0.15316045]\n",
            " [ 0.15494701]\n",
            " [ 0.15672549]\n",
            " [ 0.15849583]\n",
            " [ 0.1602581 ]\n",
            " [ 0.16201246]\n",
            " [ 0.16375921]\n",
            " [ 0.16549875]\n",
            " [ 0.16723165]\n",
            " [ 0.16895859]\n",
            " [ 0.17068037]\n",
            " [ 0.17239798]\n",
            " [ 0.1741125 ]\n",
            " [ 0.17582521]\n",
            " [ 0.17753752]\n",
            " [ 0.179251  ]\n",
            " [ 0.18096738]\n",
            " [ 0.18268857]\n",
            " [ 0.18441664]\n",
            " [ 0.18615382]\n",
            " [ 0.18790255]\n",
            " [ 0.18966542]\n",
            " [ 0.1914452 ]\n",
            " [ 0.19324488]\n",
            " [ 0.1950676 ]\n",
            " [ 0.19691671]\n",
            " [ 0.19879575]\n",
            " [ 0.20070847]\n",
            " [ 0.2026588 ]\n",
            " [ 0.20465087]\n",
            " [ 0.20668903]\n",
            " [ 0.20877783]\n",
            " [ 0.210922  ]\n",
            " [ 0.21312653]\n",
            " [ 0.21539657]\n",
            " [ 0.2177375 ]\n",
            " [ 0.22015491]\n",
            " [ 0.22265461]\n",
            " [ 0.22524261]\n",
            " [ 0.22792514]\n",
            " [ 0.23070864]\n",
            " [ 0.23359976]\n",
            " [ 0.23660536]\n",
            " [ 0.23973253]\n",
            " [ 0.24298854]\n",
            " [ 0.2463809 ]\n",
            " [ 0.24991731]\n",
            " [ 0.25360569]\n",
            " [ 0.25745414]\n",
            " [ 0.26147099]\n",
            " [ 0.26566476]\n",
            " [ 0.27004415]\n",
            " [ 0.27461809]\n",
            " [ 0.27939567]\n",
            " [ 0.28438619]\n",
            " [ 0.2895991 ]\n",
            " [ 0.29504407]\n",
            " [ 0.30073093]\n",
            " [ 0.30666966]\n",
            " [ 0.31287042]\n",
            " [ 0.31934355]\n",
            " [ 0.32609952]\n",
            " [ 0.33314894]\n",
            " [ 0.34050258]\n",
            " [ 0.34817134]\n",
            " [ 0.35616625]\n",
            " [ 0.36449845]\n",
            " [ 0.37317921]\n",
            " [ 0.38221989]\n",
            " [ 0.39163194]\n",
            " [ 0.40142694]\n",
            " [ 0.41161649]\n",
            " [ 0.4222123 ]\n",
            " [ 0.43322614]\n",
            " [ 0.44466982]\n",
            " [ 0.45655519]\n",
            " [ 0.46889413]\n",
            " [ 0.48169856]\n",
            " [ 0.49498038]\n",
            " [ 0.50875152]\n",
            " [ 0.52302387]\n",
            " [ 0.53780932]\n",
            " [ 0.5531197 ]\n",
            " [ 0.56896681]\n",
            " [ 0.58536239]\n",
            " [ 0.60231811]\n",
            " [ 0.61984553]\n",
            " [ 0.63795615]\n",
            " [ 0.65666133]\n",
            " [ 0.67597234]\n",
            " [ 0.69590027]\n",
            " [ 0.71645611]\n",
            " [ 0.73765065]\n",
            " [ 0.75949453]\n",
            " [ 0.78199818]\n",
            " [ 0.80517184]\n",
            " [ 0.82902555]\n",
            " [ 0.8535691 ]\n",
            " [ 0.87881204]\n",
            " [ 0.90476367]\n",
            " [ 0.93143303]\n",
            " [ 0.95882887]\n",
            " [ 0.98695965]\n",
            " [ 1.01583351]\n",
            " [ 1.0454583 ]\n",
            " [ 1.07584151]\n",
            " [ 1.10699029]\n",
            " [ 1.13891146]\n",
            " [ 1.17161143]\n",
            " [ 1.20509626]\n",
            " [ 1.23937161]\n",
            " [ 1.27444274]\n",
            " [ 1.31031449]\n",
            " [ 1.34699128]\n",
            " [ 1.3844771 ]\n",
            " [ 1.4227755 ]\n",
            " [ 1.46188956]\n",
            " [ 1.50182192]\n",
            " [ 1.54257473]\n",
            " [ 1.58414967]\n",
            " [ 1.62654794]\n",
            " [ 1.66977024]\n",
            " [ 1.71381677]\n",
            " [ 1.75868722]\n",
            " [ 1.80438078]\n",
            " [ 1.85089611]\n",
            " [ 1.89823137]\n",
            " [ 1.94638416]\n",
            " [ 1.99535158]\n",
            " [ 2.04513018]\n",
            " [ 2.095716  ]\n",
            " [ 2.1471045 ]\n",
            " [ 2.19929066]\n",
            " [ 2.25226887]\n",
            " [ 2.30603301]\n",
            " [ 2.36057643]\n",
            " [ 2.41589191]\n",
            " [ 2.47197172]\n",
            " [ 2.52880761]\n",
            " [ 2.58639077]\n",
            " [ 2.64471189]\n",
            " [ 2.70376113]\n",
            " [ 2.76352813]\n",
            " [ 2.82400203]\n",
            " [ 2.88517147]\n",
            " [ 2.94702457]\n",
            " [ 3.00954899]\n",
            " [ 3.07273188]\n",
            " [ 3.13655994]\n",
            " [ 3.20101939]\n",
            " [ 3.26609601]\n",
            " [ 3.33177511]\n",
            " [ 3.3980416 ]\n",
            " [ 3.46487995]\n",
            " [ 3.53227422]\n",
            " [ 3.60020806]\n",
            " [ 3.66866476]\n",
            " [ 3.73762722]\n",
            " [ 3.80707798]\n",
            " [ 3.87699924]\n",
            " [ 3.94737287]\n",
            " [ 4.01818042]\n",
            " [ 4.08940315]\n",
            " [ 4.161022  ]\n",
            " [ 4.23301769]\n",
            " [ 4.30537065]\n",
            " [ 4.37806108]\n",
            " [ 4.45106897]\n",
            " [ 4.52437409]\n",
            " [ 4.59795604]\n",
            " [ 4.67179424]\n",
            " [ 4.74586794]\n",
            " [ 4.8201563 ]\n",
            " [ 4.8946383 ]\n",
            " [ 4.96929289]\n",
            " [ 5.04409887]\n",
            " [ 5.11903502]\n",
            " [ 5.19408007]\n",
            " [ 5.26921269]\n",
            " [ 5.34441156]\n",
            " [ 5.41965537]\n",
            " [ 5.49492283]\n",
            " [ 5.57019269]\n",
            " [ 5.64544374]\n",
            " [ 5.72065487]\n",
            " [ 5.79580505]\n",
            " [ 5.87087337]\n",
            " [ 5.94583904]\n",
            " [ 6.02068139]\n",
            " [ 6.09537994]\n",
            " [ 6.16991437]\n",
            " [ 6.24426455]\n",
            " [ 6.31841056]\n",
            " [ 6.39233268]\n",
            " [ 6.46601145]\n",
            " [ 6.53942763]\n",
            " [ 6.61256227]\n",
            " [ 6.68539668]\n",
            " [ 6.75791245]\n",
            " [ 6.83009149]\n",
            " [ 6.901916  ]\n",
            " [ 6.97336853]\n",
            " [ 7.04443194]\n",
            " [ 7.11508946]\n",
            " [ 7.18532466]\n",
            " [ 7.25512147]\n",
            " [ 7.32446421]\n",
            " [ 7.39333759]\n",
            " [ 7.46172669]\n",
            " [ 7.52961701]\n",
            " [ 7.59699445]\n",
            " [ 7.66384532]\n",
            " [ 7.73015636]\n",
            " [ 7.79591474]\n",
            " [ 7.86110803]\n",
            " [ 7.92572428]\n",
            " [ 7.98975195]\n",
            " [ 8.05317996]\n",
            " [ 8.11599767]\n",
            " [ 8.1781949 ]\n",
            " [ 8.23976189]\n",
            " [ 8.30068938]\n",
            " [ 8.36096854]\n",
            " [ 8.42059099]\n",
            " [ 8.47954881]\n",
            " [ 8.53783456]\n",
            " [ 8.59544121]\n",
            " [ 8.65236223]\n",
            " [ 8.7085915 ]\n",
            " [ 8.76412338]\n",
            " [ 8.81895267]\n",
            " [ 8.8730746 ]\n",
            " [ 8.92648487]\n",
            " [ 8.97917958]\n",
            " [ 9.03115529]\n",
            " [ 9.08240899]\n",
            " [ 9.13293808]\n",
            " [ 9.18274038]\n",
            " [ 9.23181413]\n",
            " [ 9.28015797]\n",
            " [ 9.32777095]\n",
            " [ 9.37465251]\n",
            " [ 9.42080248]\n",
            " [ 9.46622106]\n",
            " [ 9.51090884]\n",
            " [ 9.55486676]\n",
            " [ 9.59809614]\n",
            " [ 9.64059863]\n",
            " [ 9.68237623]\n",
            " [ 9.72343128]\n",
            " [ 9.76376643]\n",
            " [ 9.80338466]\n",
            " [ 9.84228925]\n",
            " [ 9.8804838 ]\n",
            " [ 9.91797218]\n",
            " [ 9.95475853]\n",
            " [ 9.9908473 ]\n",
            " [10.02624318]\n",
            " [10.0609511 ]\n",
            " [10.09497627]\n",
            " [10.1283241 ]\n",
            " [10.16100025]\n",
            " [10.19301059]\n",
            " [10.22436118]\n",
            " [10.25505831]\n",
            " [10.28510844]\n",
            " [10.3145182 ]\n",
            " [10.3432944 ]\n",
            " [10.37144401]\n",
            " [10.39897417]\n",
            " [10.42589212]\n",
            " [10.45220527]\n",
            " [10.47792115]\n",
            " [10.50304739]\n",
            " [10.52759173]\n",
            " [10.55156203]\n",
            " [10.57496622]\n",
            " [10.59781231]\n",
            " [10.6201084 ]\n",
            " [10.64186265]\n",
            " [10.66308327]\n",
            " [10.68377854]\n",
            " [10.70395676]\n",
            " [10.72362627]\n",
            " [10.74279546]\n",
            " [10.76147272]\n",
            " [10.77966647]\n",
            " [10.79738511]\n",
            " [10.81463708]\n",
            " [10.8314308 ]\n",
            " [10.84777467]\n",
            " [10.86367708]\n",
            " [10.8791464 ]\n",
            " [10.89419097]\n",
            " [10.90881911]\n",
            " [10.92303908]\n",
            " [10.93685912]\n",
            " [10.95028739]\n",
            " [10.96333204]\n",
            " [10.97600114]\n",
            " [10.98830269]\n",
            " [11.00024465]\n",
            " [11.01183489]\n",
            " [11.02308122]\n",
            " [11.03399138]\n",
            " [11.04457302]\n",
            " [11.0548337 ]\n",
            " [11.06478093]\n",
            " [11.0744221 ]\n",
            " [11.08376452]\n",
            " [11.09281541]\n",
            " [11.10158189]\n",
            " [11.11007101]\n",
            " [11.11828968]\n",
            " [11.12624475]\n",
            " [11.13394294]\n",
            " [11.14139088]\n",
            " [11.1485951 ]\n",
            " [11.15556202]\n",
            " [11.16229795]\n",
            " [11.1688091 ]\n",
            " [11.17510157]\n",
            " [11.18118136]\n",
            " [11.18705434]\n",
            " [11.1927263 ]\n",
            " [11.19820289]\n",
            " [11.20348969]\n",
            " [11.20859213]\n",
            " [11.21351556]\n",
            " [11.21826521]\n",
            " [11.22284621]\n",
            " [11.22726356]\n",
            " [11.23152217]\n",
            " [11.23562686]\n",
            " [11.2395823 ]\n",
            " [11.2433931 ]\n",
            " [11.24706373]\n",
            " [11.25059858]\n",
            " [11.25400192]\n",
            " [11.25727793]\n",
            " [11.26043069]\n",
            " [11.26346416]\n",
            " [11.26638223]\n",
            " [11.26918867]\n",
            " [11.27188716]\n",
            " [11.2744813 ]\n",
            " [11.27697458]\n",
            " [11.27937039]\n",
            " [11.28167205]\n",
            " [11.28388278]\n",
            " [11.2860057 ]\n",
            " [11.28804388]\n",
            " [11.29000026]\n",
            " [11.29187772]\n",
            " [11.29367906]\n",
            " [11.29540699]\n",
            " [11.29706414]\n",
            " [11.29865308]\n",
            " [11.30017627]\n",
            " [11.30163613]\n",
            " [11.30303499]\n",
            " [11.30437512]\n",
            " [11.30565869]\n",
            " [11.30688784]\n",
            " [11.30806461]\n",
            " [11.30919101]\n",
            " [11.31026895]\n",
            " [11.3113003 ]\n",
            " [11.31228686]\n",
            " [11.31323038]\n",
            " [11.31413254]\n",
            " [11.31499497]\n",
            " [11.31581924]\n",
            " [11.31660688]\n",
            " [11.31735934]\n",
            " [11.31807806]\n",
            " [11.3187644 ]\n",
            " [11.31941968]\n",
            " [11.32004516]\n",
            " [11.32064209]\n",
            " [11.32121163]\n",
            " [11.32175494]\n",
            " [11.32227311]\n",
            " [11.3227672 ]\n",
            " [11.32323823]\n",
            " [11.32368718]\n",
            " [11.32411499]\n",
            " [11.32452258]\n",
            " [11.32491082]\n",
            " [11.32528055]\n",
            " [11.32563258]\n",
            " [11.32596768]\n",
            " [11.3262866 ]\n",
            " [11.32659006]\n",
            " [11.32687875]\n",
            " [11.32715333]\n",
            " [11.32741444]\n",
            " [11.32766267]\n",
            " [11.32789863]\n",
            " [11.32812286]\n",
            " [11.32833591]\n",
            " [11.3285383 ]\n",
            " [11.32873051]\n",
            " [11.32891301]\n",
            " [11.32908627]\n",
            " [11.32925072]\n",
            " [11.32940677]\n",
            " [11.32955482]\n",
            " [11.32969526]\n",
            " [11.32982843]\n",
            " [11.32995471]\n",
            " [11.33007441]\n",
            " [11.33018785]\n",
            " [11.33029535]\n",
            " [11.33039718]\n",
            " [11.33049364]\n",
            " [11.33058498]\n",
            " [11.33067146]\n",
            " [11.33075332]\n",
            " [11.33083079]\n",
            " [11.33090408]\n",
            " [11.33097342]\n",
            " [11.33103901]\n",
            " [11.33110102]\n",
            " [11.33115965]\n",
            " [11.33121506]\n",
            " [11.33126743]\n",
            " [11.33131691]], shape=(871, 1), dtype=float64)\n",
            "tf.Tensor(\n",
            "[[-0.5431419 ]\n",
            " [-0.52037888]\n",
            " [-0.49754156]\n",
            " [-0.47463872]\n",
            " [-0.45167918]\n",
            " [-0.42867187]\n",
            " [-0.40562575]\n",
            " [-0.38254984]\n",
            " [-0.35945321]\n",
            " [-0.33634497]\n",
            " [-0.31323428]\n",
            " [-0.29013033]\n",
            " [-0.26704232]\n",
            " [-0.24397949]\n",
            " [-0.2209511 ]\n",
            " [-0.19796641]\n",
            " [-0.17503468]\n",
            " [-0.15216519]\n",
            " [-0.12936719]\n",
            " [-0.10664993]\n",
            " [-0.08402265]\n",
            " [-0.06149456]\n",
            " [-0.03907482]\n",
            " [-0.0167726 ]\n",
            " [ 0.00540303]\n",
            " [ 0.02744299]\n",
            " [ 0.0493383 ]\n",
            " [ 0.07108001]\n",
            " [ 0.09265924]\n",
            " [ 0.1140672 ]\n",
            " [ 0.13529515]\n",
            " [ 0.15633446]\n",
            " [ 0.17717657]\n",
            " [ 0.19781302]\n",
            " [ 0.21823545]\n",
            " [ 0.23843562]\n",
            " [ 0.25840539]\n",
            " [ 0.27813673]\n",
            " [ 0.29762176]\n",
            " [ 0.3168527 ]\n",
            " [ 0.33582193]\n",
            " [ 0.35452196]\n",
            " [ 0.37294545]\n",
            " [ 0.39108521]\n",
            " [ 0.40893419]\n",
            " [ 0.42648555]\n",
            " [ 0.44373256]\n",
            " [ 0.46066871]\n",
            " [ 0.47728763]\n",
            " [ 0.49358317]\n",
            " [ 0.50954934]\n",
            " [ 0.52518034]\n",
            " [ 0.5404706 ]\n",
            " [ 0.55541472]\n",
            " [ 0.57000751]\n",
            " [ 0.584244  ]\n",
            " [ 0.59811943]\n",
            " [ 0.61162925]\n",
            " [ 0.62476915]\n",
            " [ 0.63753504]\n",
            " [ 0.64992304]\n",
            " [ 0.66192952]\n",
            " [ 0.67355109]\n",
            " [ 0.68478459]\n",
            " [ 0.6956271 ]\n",
            " [ 0.70607596]\n",
            " [ 0.71612874]\n",
            " [ 0.72578326]\n",
            " [ 0.73503762]\n",
            " [ 0.74389014]\n",
            " [ 0.75233941]\n",
            " [ 0.76038429]\n",
            " [ 0.76802388]\n",
            " [ 0.77525755]\n",
            " [ 0.78208494]\n",
            " [ 0.78850595]\n",
            " [ 0.79452074]\n",
            " [ 0.80012973]\n",
            " [ 0.80533363]\n",
            " [ 0.81013338]\n",
            " [ 0.81453023]\n",
            " [ 0.81852565]\n",
            " [ 0.82212142]\n",
            " [ 0.82531956]\n",
            " [ 0.82812235]\n",
            " [ 0.83053236]\n",
            " [ 0.83255241]\n",
            " [ 0.83418556]\n",
            " [ 0.83543518]\n",
            " [ 0.83630485]\n",
            " [ 0.83679843]\n",
            " [ 0.83692005]\n",
            " [ 0.83667406]\n",
            " [ 0.83606509]\n",
            " [ 0.835098  ]\n",
            " [ 0.83377791]\n",
            " [ 0.83211016]\n",
            " [ 0.83010036]\n",
            " [ 0.82775434]\n",
            " [ 0.82507815]\n",
            " [ 0.82207809]\n",
            " [ 0.81876069]\n",
            " [ 0.81513267]\n",
            " [ 0.81120099]\n",
            " [ 0.80697283]\n",
            " [ 0.80245557]\n",
            " [ 0.79765677]\n",
            " [ 0.79258422]\n",
            " [ 0.78724589]\n",
            " [ 0.78164995]\n",
            " [ 0.77580473]\n",
            " [ 0.76971875]\n",
            " [ 0.76340072]\n",
            " [ 0.75685948]\n",
            " [ 0.75010406]\n",
            " [ 0.74314363]\n",
            " [ 0.73598751]\n",
            " [ 0.72864516]\n",
            " [ 0.72112617]\n",
            " [ 0.71344028]\n",
            " [ 0.70559733]\n",
            " [ 0.69760728]\n",
            " [ 0.6894802 ]\n",
            " [ 0.68122627]\n",
            " [ 0.67285575]\n",
            " [ 0.66437899]\n",
            " [ 0.65580642]\n",
            " [ 0.64714855]\n",
            " [ 0.63841595]\n",
            " [ 0.62961924]\n",
            " [ 0.62076911]\n",
            " [ 0.61187627]\n",
            " [ 0.60295148]\n",
            " [ 0.59400551]\n",
            " [ 0.58504918]\n",
            " [ 0.5760933 ]\n",
            " [ 0.56714867]\n",
            " [ 0.55822612]\n",
            " [ 0.54933645]\n",
            " [ 0.54049044]\n",
            " [ 0.53169885]\n",
            " [ 0.5229724 ]\n",
            " [ 0.51432177]\n",
            " [ 0.50575758]\n",
            " [ 0.49729042]\n",
            " [ 0.48893077]\n",
            " [ 0.48068909]\n",
            " [ 0.47257571]\n",
            " [ 0.46460089]\n",
            " [ 0.45677482]\n",
            " [ 0.44910754]\n",
            " [ 0.44160901]\n",
            " [ 0.43428907]\n",
            " [ 0.42715742]\n",
            " [ 0.42022364]\n",
            " [ 0.41349716]\n",
            " [ 0.40698728]\n",
            " [ 0.40070313]\n",
            " [ 0.39465369]\n",
            " [ 0.38884776]\n",
            " [ 0.38329399]\n",
            " [ 0.37800082]\n",
            " [ 0.37297653]\n",
            " [ 0.36822919]\n",
            " [ 0.36376669]\n",
            " [ 0.35959669]\n",
            " [ 0.35572667]\n",
            " [ 0.35216387]\n",
            " [ 0.34891531]\n",
            " [ 0.34598781]\n",
            " [ 0.34338792]\n",
            " [ 0.34112199]\n",
            " [ 0.33919611]\n",
            " [ 0.33761612]\n",
            " [ 0.33638762]\n",
            " [ 0.33551596]\n",
            " [ 0.33500621]\n",
            " [ 0.33486319]\n",
            " [ 0.33509147]\n",
            " [ 0.33569533]\n",
            " [ 0.33667878]\n",
            " [ 0.33804556]\n",
            " [ 0.33979912]\n",
            " [ 0.34194265]\n",
            " [ 0.34447903]\n",
            " [ 0.34741088]\n",
            " [ 0.35074051]\n",
            " [ 0.35446995]\n",
            " [ 0.35860094]\n",
            " [ 0.36313492]\n",
            " [ 0.36807304]\n",
            " [ 0.37341615]\n",
            " [ 0.37916482]\n",
            " [ 0.3853193 ]\n",
            " [ 0.39187956]\n",
            " [ 0.39884526]\n",
            " [ 0.40621579]\n",
            " [ 0.4139902 ]\n",
            " [ 0.42216729]\n",
            " [ 0.43074553]\n",
            " [ 0.43972312]\n",
            " [ 0.44909794]\n",
            " [ 0.45886761]\n",
            " [ 0.46902944]\n",
            " [ 0.47958045]\n",
            " [ 0.49051739]\n",
            " [ 0.50183671]\n",
            " [ 0.51353458]\n",
            " [ 0.52560692]\n",
            " [ 0.53804932]\n",
            " [ 0.55085716]\n",
            " [ 0.5640255 ]\n",
            " [ 0.57754915]\n",
            " [ 0.59142268]\n",
            " [ 0.60564037]\n",
            " [ 0.62019626]\n",
            " [ 0.63508415]\n",
            " [ 0.65029757]\n",
            " [ 0.66582982]\n",
            " [ 0.68167398]\n",
            " [ 0.69782288]\n",
            " [ 0.71426913]\n",
            " [ 0.73100512]\n",
            " [ 0.74802301]\n",
            " [ 0.76531478]\n",
            " [ 0.78287219]\n",
            " [ 0.80068678]\n",
            " [ 0.81874994]\n",
            " [ 0.83705285]\n",
            " [ 0.8555865 ]\n",
            " [ 0.87434172]\n",
            " [ 0.89330919]\n",
            " [ 0.9124794 ]\n",
            " [ 0.93184271]\n",
            " [ 0.9513893 ]\n",
            " [ 0.97110926]\n",
            " [ 0.9909925 ]\n",
            " [ 1.01102883]\n",
            " [ 1.03120795]\n",
            " [ 1.05151941]\n",
            " [ 1.07195271]\n",
            " [ 1.0924972 ]\n",
            " [ 1.11314219]\n",
            " [ 1.13387687]\n",
            " [ 1.15469039]\n",
            " [ 1.1755718 ]\n",
            " [ 1.19651011]\n",
            " [ 1.21749429]\n",
            " [ 1.23851325]\n",
            " [ 1.25955587]\n",
            " [ 1.28061101]\n",
            " [ 1.3016675 ]\n",
            " [ 1.32271416]\n",
            " [ 1.34373981]\n",
            " [ 1.36473328]\n",
            " [ 1.38568339]\n",
            " [ 1.40657902]\n",
            " [ 1.42740903]\n",
            " [ 1.44816234]\n",
            " [ 1.46882792]\n",
            " [ 1.48939477]\n",
            " [ 1.50985196]\n",
            " [ 1.53018862]\n",
            " [ 1.55039396]\n",
            " [ 1.57045727]\n",
            " [ 1.59036791]\n",
            " [ 1.61011536]\n",
            " [ 1.62968918]\n",
            " [ 1.64907906]\n",
            " [ 1.66827478]\n",
            " [ 1.68726626]\n",
            " [ 1.70604356]\n",
            " [ 1.72459685]\n",
            " [ 1.74291646]\n",
            " [ 1.76099287]\n",
            " [ 1.7788167 ]\n",
            " [ 1.79637875]\n",
            " [ 1.81366999]\n",
            " [ 1.83068154]\n",
            " [ 1.84740472]\n",
            " [ 1.86383104]\n",
            " [ 1.87995218]\n",
            " [ 1.89576004]\n",
            " [ 1.9112467 ]\n",
            " [ 1.92640446]\n",
            " [ 1.94122583]\n",
            " [ 1.95570354]\n",
            " [ 1.96983054]\n",
            " [ 1.9836    ]\n",
            " [ 1.99700533]\n",
            " [ 2.01004016]\n",
            " [ 2.02269837]\n",
            " [ 2.03497409]\n",
            " [ 2.04686167]\n",
            " [ 2.05835574]\n",
            " [ 2.06945115]\n",
            " [ 2.08014304]\n",
            " [ 2.09042679]\n",
            " [ 2.10029804]\n",
            " [ 2.10975269]\n",
            " [ 2.11878693]\n",
            " [ 2.12739719]\n",
            " [ 2.1355802 ]\n",
            " [ 2.14333292]\n",
            " [ 2.15065264]\n",
            " [ 2.15753687]\n",
            " [ 2.16398343]\n",
            " [ 2.16999041]\n",
            " [ 2.17555618]\n",
            " [ 2.18067939]\n",
            " [ 2.18535896]\n",
            " [ 2.18959409]\n",
            " [ 2.19338429]\n",
            " [ 2.1967293 ]\n",
            " [ 2.19962918]\n",
            " [ 2.20208426]\n",
            " [ 2.20409513]\n",
            " [ 2.20566268]\n",
            " [ 2.20678806]\n",
            " [ 2.20747272]\n",
            " [ 2.20771836]\n",
            " [ 2.20752695]\n",
            " [ 2.20690075]\n",
            " [ 2.20584228]\n",
            " [ 2.20435432]\n",
            " [ 2.20243993]\n",
            " [ 2.20010241]\n",
            " [ 2.19734535]\n",
            " [ 2.19417256]\n",
            " [ 2.19058813]\n",
            " [ 2.18659639]\n",
            " [ 2.18220192]\n",
            " [ 2.17740955]\n",
            " [ 2.17222434]\n",
            " [ 2.16665159]\n",
            " [ 2.16069683]\n",
            " [ 2.15436583]\n",
            " [ 2.14766458]\n",
            " [ 2.14059927]\n",
            " [ 2.13317634]\n",
            " [ 2.12540243]\n",
            " [ 2.11728436]\n",
            " [ 2.10882919]\n",
            " [ 2.10004415]\n",
            " [ 2.09093669]\n",
            " [ 2.08151442]\n",
            " [ 2.07178514]\n",
            " [ 2.06175683]\n",
            " [ 2.05143765]\n",
            " [ 2.0408359 ]\n",
            " [ 2.02996007]\n",
            " [ 2.01881878]\n",
            " [ 2.0074208 ]\n",
            " [ 1.99577508]\n",
            " [ 1.98389065]\n",
            " [ 1.9717767 ]\n",
            " [ 1.95944256]\n",
            " [ 1.94689766]\n",
            " [ 1.93415153]\n",
            " [ 1.92121382]\n",
            " [ 1.9080943 ]\n",
            " [ 1.8948028 ]\n",
            " [ 1.88134924]\n",
            " [ 1.86774366]\n",
            " [ 1.85399612]\n",
            " [ 1.84011678]\n",
            " [ 1.82611587]\n",
            " [ 1.81200364]\n",
            " [ 1.79779042]\n",
            " [ 1.78348657]\n",
            " [ 1.76910248]\n",
            " [ 1.75464858]\n",
            " [ 1.74013532]\n",
            " [ 1.72557315]\n",
            " [ 1.71097255]\n",
            " [ 1.696344  ]\n",
            " [ 1.68169796]\n",
            " [ 1.6670449 ]\n",
            " [ 1.65239526]\n",
            " [ 1.63775946]\n",
            " [ 1.6231479 ]\n",
            " [ 1.60857092]\n",
            " [ 1.59403885]\n",
            " [ 1.57956194]\n",
            " [ 1.56515042]\n",
            " [ 1.55081442]\n",
            " [ 1.53656405]\n",
            " [ 1.5224093 ]\n",
            " [ 1.50836012]\n",
            " [ 1.49442634]\n",
            " [ 1.48061774]\n",
            " [ 1.46694396]\n",
            " [ 1.45341459]\n",
            " [ 1.44003906]\n",
            " [ 1.42682673]\n",
            " [ 1.41378681]\n",
            " [ 1.4009284 ]\n",
            " [ 1.38826049]\n",
            " [ 1.3757919 ]\n",
            " [ 1.36353134]\n",
            " [ 1.35148736]\n",
            " [ 1.33966838]\n",
            " [ 1.32808264]\n",
            " [ 1.31673825]\n",
            " [ 1.30564314]\n",
            " [ 1.29480509]\n",
            " [ 1.28423169]\n",
            " [ 1.27393036]\n",
            " [ 1.26390835]\n",
            " [ 1.25417273]\n",
            " [ 1.24473037]\n",
            " [ 1.23558795]\n",
            " [ 1.22675198]\n",
            " [ 1.21822874]\n",
            " [ 1.21002434]\n",
            " [ 1.20214467]\n",
            " [ 1.19459541]\n",
            " [ 1.18738205]\n",
            " [ 1.18050985]\n",
            " [ 1.17398386]\n",
            " [ 1.16780892]\n",
            " [ 1.16198964]\n",
            " [ 1.15653043]\n",
            " [ 1.15143546]\n",
            " [ 1.14670867]\n",
            " [ 1.14235379]\n",
            " [ 1.13837431]\n",
            " [ 1.13477349]\n",
            " [ 1.13155437]\n",
            " [ 1.12871976]\n",
            " [ 1.12627221]\n",
            " [ 1.12421407]\n",
            " [ 1.12254743]\n",
            " [ 1.12127417]\n",
            " [ 1.12039591]\n",
            " [ 1.11991404]\n",
            " [ 1.11982973]\n",
            " [ 1.12014389]\n",
            " [ 1.12085722]\n",
            " [ 1.12197017]\n",
            " [ 1.12348294]\n",
            " [ 1.12539554]\n",
            " [ 1.1277077 ]\n",
            " [ 1.13041894]\n",
            " [ 1.13352854]\n",
            " [ 1.13703556]\n",
            " [ 1.14093883]\n",
            " [ 1.14523693]\n",
            " [ 1.14992824]\n",
            " [ 1.1550109 ]\n",
            " [ 1.16048283]\n",
            " [ 1.16634174]\n",
            " [ 1.17258509]\n",
            " [ 1.17921017]\n",
            " [ 1.186214  ]\n",
            " [ 1.19359344]\n",
            " [ 1.2013451 ]\n",
            " [ 1.20946541]\n",
            " [ 1.21795057]\n",
            " [ 1.2267966 ]\n",
            " [ 1.23599932]\n",
            " [ 1.24555433]\n",
            " [ 1.25545706]\n",
            " [ 1.26570276]\n",
            " [ 1.27628646]\n",
            " [ 1.28720303]\n",
            " [ 1.29844716]\n",
            " [ 1.31001335]\n",
            " [ 1.32189595]\n",
            " [ 1.33408913]\n",
            " [ 1.3465869 ]\n",
            " [ 1.35938309]\n",
            " [ 1.3724714 ]\n",
            " [ 1.38584537]\n",
            " [ 1.39949839]\n",
            " [ 1.4134237 ]\n",
            " [ 1.42761441]\n",
            " [ 1.44206348]\n",
            " [ 1.45676377]\n",
            " [ 1.47170798]\n",
            " [ 1.48688871]\n",
            " [ 1.50229844]\n",
            " [ 1.51792952]\n",
            " [ 1.53377421]\n",
            " [ 1.54982467]\n",
            " [ 1.56607295]\n",
            " [ 1.58251101]\n",
            " [ 1.59913072]\n",
            " [ 1.61592387]\n",
            " [ 1.63288217]\n",
            " [ 1.64999726]\n",
            " [ 1.6672607 ]\n",
            " [ 1.68466399]\n",
            " [ 1.70219859]\n",
            " [ 1.71985586]\n",
            " [ 1.73762717]\n",
            " [ 1.75550379]\n",
            " [ 1.773477  ]\n",
            " [ 1.791538  ]\n",
            " [ 1.80967799]\n",
            " [ 1.82788814]\n",
            " [ 1.84615959]\n",
            " [ 1.86448348]\n",
            " [ 1.88285094]\n",
            " [ 1.90125307]\n",
            " [ 1.91968101]\n",
            " [ 1.93812587]\n",
            " [ 1.95657878]\n",
            " [ 1.9750309 ]\n",
            " [ 1.99347339]\n",
            " [ 2.01189744]\n",
            " [ 2.03029427]\n",
            " [ 2.04865514]\n",
            " [ 2.06697133]\n",
            " [ 2.08523418]\n",
            " [ 2.10343506]\n",
            " [ 2.1215654 ]\n",
            " [ 2.1396167 ]\n",
            " [ 2.15758049]\n",
            " [ 2.17544839]\n",
            " [ 2.19321208]\n",
            " [ 2.21086329]\n",
            " [ 2.22839387]\n",
            " [ 2.24579572]\n",
            " [ 2.26306083]\n",
            " [ 2.28018127]\n",
            " [ 2.29714923]\n",
            " [ 2.31395697]\n",
            " [ 2.33059684]\n",
            " [ 2.34706134]\n",
            " [ 2.36334302]\n",
            " [ 2.37943457]\n",
            " [ 2.3953288 ]\n",
            " [ 2.41101861]\n",
            " [ 2.42649705]\n",
            " [ 2.44175725]\n",
            " [ 2.45679251]\n",
            " [ 2.47159623]\n",
            " [ 2.48616195]\n",
            " [ 2.50048335]\n",
            " [ 2.51455423]\n",
            " [ 2.52836853]\n",
            " [ 2.54192036]\n",
            " [ 2.55520392]\n",
            " [ 2.56821361]\n",
            " [ 2.58094394]\n",
            " [ 2.59338959]\n",
            " [ 2.60554537]\n",
            " [ 2.61740627]\n",
            " [ 2.62896741]\n",
            " [ 2.64022408]\n",
            " [ 2.65117172]\n",
            " [ 2.66180594]\n",
            " [ 2.67212249]\n",
            " [ 2.68211731]\n",
            " [ 2.69178647]\n",
            " [ 2.70112622]\n",
            " [ 2.71013299]\n",
            " [ 2.71880334]\n",
            " [ 2.72713402]\n",
            " [ 2.73512194]\n",
            " [ 2.74276418]\n",
            " [ 2.75005798]\n",
            " [ 2.75700075]\n",
            " [ 2.76359007]\n",
            " [ 2.76982368]\n",
            " [ 2.7756995 ]\n",
            " [ 2.7812156 ]\n",
            " [ 2.78637023]\n",
            " [ 2.79116181]\n",
            " [ 2.7955889 ]\n",
            " [ 2.79965027]\n",
            " [ 2.80334482]\n",
            " [ 2.80667162]\n",
            " [ 2.80962991]\n",
            " [ 2.81221909]\n",
            " [ 2.81443872]\n",
            " [ 2.81628854]\n",
            " [ 2.81776841]\n",
            " [ 2.81887839]\n",
            " [ 2.81961867]\n",
            " [ 2.81998961]\n",
            " [ 2.81999171]\n",
            " [ 2.81962564]\n",
            " [ 2.81889221]\n",
            " [ 2.81779239]\n",
            " [ 2.81632728]\n",
            " [ 2.81449814]\n",
            " [ 2.81230637]\n",
            " [ 2.80975352]\n",
            " [ 2.80684128]\n",
            " [ 2.80357146]\n",
            " [ 2.79994602]\n",
            " [ 2.79596705]\n",
            " [ 2.79163678]\n",
            " [ 2.78695757]\n",
            " [ 2.7819319 ]\n",
            " [ 2.77656236]\n",
            " [ 2.77085169]\n",
            " [ 2.76480275]\n",
            " [ 2.75841848]\n",
            " [ 2.75170198]\n",
            " [ 2.74465644]\n",
            " [ 2.73728516]\n",
            " [ 2.72959155]\n",
            " [ 2.72157912]\n",
            " [ 2.7132515 ]\n",
            " [ 2.70461239]\n",
            " [ 2.6956656 ]\n",
            " [ 2.68641504]\n",
            " [ 2.67686471]\n",
            " [ 2.66701868]\n",
            " [ 2.65688112]\n",
            " [ 2.64645628]\n",
            " [ 2.63574848]\n",
            " [ 2.62476213]\n",
            " [ 2.6135017 ]\n",
            " [ 2.60197175]\n",
            " [ 2.59017687]\n",
            " [ 2.57812176]\n",
            " [ 2.56581114]\n",
            " [ 2.55324982]\n",
            " [ 2.54044264]\n",
            " [ 2.52739451]\n",
            " [ 2.51411039]\n",
            " [ 2.50059527]\n",
            " [ 2.4868542 ]\n",
            " [ 2.47289226]\n",
            " [ 2.45871457]\n",
            " [ 2.4443263 ]\n",
            " [ 2.42973262]\n",
            " [ 2.41493877]\n",
            " [ 2.39994997]\n",
            " [ 2.38477151]\n",
            " [ 2.36940866]\n",
            " [ 2.35386674]\n",
            " [ 2.33815106]\n",
            " [ 2.32226697]\n",
            " [ 2.30621979]\n",
            " [ 2.29001489]\n",
            " [ 2.27365762]\n",
            " [ 2.25715333]\n",
            " [ 2.24050739]\n",
            " [ 2.22372513]\n",
            " [ 2.20681191]\n",
            " [ 2.18977307]\n",
            " [ 2.17261393]\n",
            " [ 2.15533981]\n",
            " [ 2.13795601]\n",
            " [ 2.1204678 ]\n",
            " [ 2.10288045]\n",
            " [ 2.0851992 ]\n",
            " [ 2.06742925]\n",
            " [ 2.04957581]\n",
            " [ 2.03164401]\n",
            " [ 2.013639  ]\n",
            " [ 1.99556586]\n",
            " [ 1.97742966]\n",
            " [ 1.95923541]\n",
            " [ 1.94098811]\n",
            " [ 1.9226927 ]\n",
            " [ 1.90435407]\n",
            " [ 1.88597708]\n",
            " [ 1.86756655]\n",
            " [ 1.84912725]\n",
            " [ 1.83066387]\n",
            " [ 1.8121811 ]\n",
            " [ 1.79368355]\n",
            " [ 1.77517577]\n",
            " [ 1.75666228]\n",
            " [ 1.73814751]\n",
            " [ 1.71963587]\n",
            " [ 1.70113169]\n",
            " [ 1.68263924]\n",
            " [ 1.66416273]\n",
            " [ 1.64570633]\n",
            " [ 1.62727411]\n",
            " [ 1.6088701 ]\n",
            " [ 1.59049827]\n",
            " [ 1.5721625 ]\n",
            " [ 1.55386663]\n",
            " [ 1.53561442]\n",
            " [ 1.51740956]\n",
            " [ 1.49925567]\n",
            " [ 1.48115632]\n",
            " [ 1.46311499]\n",
            " [ 1.4451351 ]\n",
            " [ 1.42721998]\n",
            " [ 1.40937292]\n",
            " [ 1.39159711]\n",
            " [ 1.3738957 ]\n",
            " [ 1.35627172]\n",
            " [ 1.33872818]\n",
            " [ 1.32126799]\n",
            " [ 1.30389398]\n",
            " [ 1.28660893]\n",
            " [ 1.26941553]\n",
            " [ 1.2523164 ]\n",
            " [ 1.23531408]\n",
            " [ 1.21841107]\n",
            " [ 1.20160975]\n",
            " [ 1.18491246]\n",
            " [ 1.16832145]\n",
            " [ 1.15183892]\n",
            " [ 1.13546697]\n",
            " [ 1.11920765]\n",
            " [ 1.10306293]\n",
            " [ 1.0870347 ]\n",
            " [ 1.07112479]\n",
            " [ 1.05533496]\n",
            " [ 1.0396669 ]\n",
            " [ 1.02412222]\n",
            " [ 1.00870248]\n",
            " [ 0.99340915]\n",
            " [ 0.97824364]\n",
            " [ 0.9632073 ]\n",
            " [ 0.94830141]\n",
            " [ 0.93352718]\n",
            " [ 0.91888575]\n",
            " [ 0.90437821]\n",
            " [ 0.89000557]\n",
            " [ 0.8757688 ]\n",
            " [ 0.86166877]\n",
            " [ 0.84770632]\n",
            " [ 0.83388221]\n",
            " [ 0.82019716]\n",
            " [ 0.80665181]\n",
            " [ 0.79324675]\n",
            " [ 0.77998252]\n",
            " [ 0.76685958]\n",
            " [ 0.75387836]\n",
            " [ 0.74103922]\n",
            " [ 0.72834248]\n",
            " [ 0.71578837]\n",
            " [ 0.70337712]\n",
            " [ 0.69110887]\n",
            " [ 0.67898372]\n",
            " [ 0.66700172]\n",
            " [ 0.65516288]\n",
            " [ 0.64346715]\n",
            " [ 0.63191445]\n",
            " [ 0.62050463]\n",
            " [ 0.60923751]\n",
            " [ 0.59811286]\n",
            " [ 0.58713043]\n",
            " [ 0.57628989]\n",
            " [ 0.56559089]\n",
            " [ 0.55503306]\n",
            " [ 0.54461594]\n",
            " [ 0.53433909]\n",
            " [ 0.52420199]\n",
            " [ 0.5142041 ]\n",
            " [ 0.50434486]\n",
            " [ 0.49462364]\n",
            " [ 0.48503981]\n",
            " [ 0.47559269]\n",
            " [ 0.46628158]\n",
            " [ 0.45710574]\n",
            " [ 0.44806442]\n",
            " [ 0.43915681]\n",
            " [ 0.43038211]\n",
            " [ 0.42173946]\n",
            " [ 0.41322799]\n",
            " [ 0.40484681]\n",
            " [ 0.39659501]\n",
            " [ 0.38847164]\n",
            " [ 0.38047574]\n",
            " [ 0.37260633]\n",
            " [ 0.3648624 ]\n",
            " [ 0.35724294]\n",
            " [ 0.34974691]\n",
            " [ 0.34237324]\n",
            " [ 0.33512087]\n",
            " [ 0.32798872]\n",
            " [ 0.32097567]\n",
            " [ 0.31408061]\n",
            " [ 0.30730241]\n",
            " [ 0.30063994]\n",
            " [ 0.29409203]\n",
            " [ 0.28765752]\n",
            " [ 0.28133524]\n",
            " [ 0.27512401]\n",
            " [ 0.26902264]\n",
            " [ 0.26302992]\n",
            " [ 0.25714466]\n",
            " [ 0.25136562]\n",
            " [ 0.24569161]\n",
            " [ 0.2401214 ]\n",
            " [ 0.23465375]\n",
            " [ 0.22928744]\n",
            " [ 0.22402123]\n",
            " [ 0.21885389]\n",
            " [ 0.21378417]\n",
            " [ 0.20881084]\n",
            " [ 0.20393265]\n",
            " [ 0.19914837]\n",
            " [ 0.19445674]\n",
            " [ 0.18985654]\n",
            " [ 0.18534652]\n",
            " [ 0.18092543]\n",
            " [ 0.17659206]\n",
            " [ 0.17234517]\n",
            " [ 0.16818352]\n",
            " [ 0.16410589]\n",
            " [ 0.16011106]\n",
            " [ 0.15619782]\n",
            " [ 0.15236494]\n",
            " [ 0.14861123]\n",
            " [ 0.14493548]\n",
            " [ 0.14133649]\n",
            " [ 0.13781309]\n",
            " [ 0.13436408]\n",
            " [ 0.13098829]\n",
            " [ 0.12768455]\n",
            " [ 0.12445171]\n",
            " [ 0.1212886 ]\n",
            " [ 0.1181941 ]\n",
            " [ 0.11516705]\n",
            " [ 0.11220633]\n",
            " [ 0.10931083]\n",
            " [ 0.10647944]\n",
            " [ 0.10371105]\n",
            " [ 0.10100458]\n",
            " [ 0.09835894]\n",
            " [ 0.09577308]\n",
            " [ 0.09324592]\n",
            " [ 0.09077641]\n",
            " [ 0.08836353]\n",
            " [ 0.08600623]\n",
            " [ 0.0837035 ]\n",
            " [ 0.08145434]\n",
            " [ 0.07925775]\n",
            " [ 0.07711274]\n",
            " [ 0.07501834]\n",
            " [ 0.07297359]\n",
            " [ 0.07097754]\n",
            " [ 0.06902925]\n",
            " [ 0.06712778]\n",
            " [ 0.06527223]\n",
            " [ 0.06346169]\n",
            " [ 0.06169527]\n",
            " [ 0.05997208]\n",
            " [ 0.05829125]\n",
            " [ 0.05665193]\n",
            " [ 0.05505327]\n",
            " [ 0.05349445]\n",
            " [ 0.05197462]\n",
            " [ 0.05049299]\n",
            " [ 0.04904875]\n",
            " [ 0.04764113]\n",
            " [ 0.04626933]\n",
            " [ 0.04493261]\n",
            " [ 0.0436302 ]\n",
            " [ 0.04236136]\n",
            " [ 0.04112538]\n",
            " [ 0.03992153]\n",
            " [ 0.0387491 ]\n",
            " [ 0.0376074 ]\n",
            " [ 0.03649575]\n",
            " [ 0.03541347]\n",
            " [ 0.03435991]\n",
            " [ 0.03333441]\n",
            " [ 0.03233635]\n",
            " [ 0.03136508]\n",
            " [ 0.03042   ]\n",
            " [ 0.0295005 ]\n",
            " [ 0.02860598]\n",
            " [ 0.02773587]\n",
            " [ 0.02688958]\n",
            " [ 0.02606656]\n",
            " [ 0.02526625]], shape=(871, 1), dtype=float64)\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "def RMSE(Eft, yt):\n",
        "  \"\"\"\n",
        "  Calculates the Root Mean Squared Error (RMSE) between two arrays.\n",
        "\n",
        "  Args:\n",
        "    Eft: A numpy array of predicted values.\n",
        "    yt: A numpy array of true values.\n",
        "\n",
        "  Returns:\n",
        "    The calculated RMSE.\n",
        "  \"\"\"\n",
        "\n",
        "  rmse = np.sqrt(np.mean((Eft - yt) ** 2))\n",
        "  return rmse"
      ],
      "metadata": {
        "id": "tid63OBpR63f"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "def MAE(Eft, yt):\n",
        "  \"\"\"\n",
        "  Calculates the Mean Absolute Error (MAE) between two arrays.\n",
        "\n",
        "  Args:\n",
        "    Eft: A numpy array of predicted values.\n",
        "    yt: A numpy array of true values.\n",
        "\n",
        "  Returns:\n",
        "    The calculated MAE.\n",
        "  \"\"\"\n",
        "\n",
        "  mae = np.mean(np.abs(Eft - yt))\n",
        "  return mae"
      ],
      "metadata": {
        "id": "ILMWD7CgS2Bd"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "def NLP(means, variances, yTrue):\n",
        "  \"\"\"\n",
        "  Calculates NLP\n",
        "\n",
        "  Args:\n",
        "    means: A numpy array of means.\n",
        "    variances: A numpy array of variances.\n",
        "    yTrue: A numpy array of true values.\n",
        "\n",
        "  Returns:\n",
        "    The calculated value.\n",
        "  \"\"\"\n",
        "\n",
        "  value = 0.5 * np.mean(np.log(2 * np.pi * variances) + ((means - yTrue) ** 2) / variances)\n",
        "  return value"
      ],
      "metadata": {
        "id": "_5HGzRG9mmfA"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "Results = np.zeros((1, 3))\n",
        "Results[0,0]=RMSE(Eft, yt)\n",
        "Results[0,1]=MAE(Eft, yt)\n",
        "Results[0,2]=NLP(Eft,Varft, yt)\n",
        "print(Results)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "2TEMUPjaTIFT",
        "outputId": "6f48b359-098a-4bc8-c5f8-1d6280a5cb4b"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "[[1.09783913 0.76432326 1.02358648]]\n"
          ]
        }
      ]
    }
  ]
}