{"nbformat":4,"nbformat_minor":0,"metadata":{"colab":{"provenance":[],"authorship_tag":"ABX9TyMMEBOeGcnj3TXnrYis57w4"},"kernelspec":{"name":"python3","display_name":"Python 3"},"language_info":{"name":"python"}},"cells":[{"cell_type":"code","source":["from google.colab import drive\n","#drive.flush_and_unmount()"],"metadata":{"id":"Q_ih5rs1xyO1","executionInfo":{"status":"ok","timestamp":1722913431374,"user_tz":240,"elapsed":207,"user":{"displayName":"Pooja Algikar","userId":"10909962456072049438"}}},"execution_count":3,"outputs":[]},{"cell_type":"code","source":["drive.mount('/content/gdrive')"],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"HLLk6ecnx2Q8","executionInfo":{"status":"ok","timestamp":1722913456345,"user_tz":240,"elapsed":24724,"user":{"displayName":"Pooja Algikar","userId":"10909962456072049438"}},"outputId":"8272d94c-bec7-4a92-e2d0-a22cb3cf0bb8"},"execution_count":4,"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":"V-pmLKd0x254","executionInfo":{"status":"ok","timestamp":1722913456603,"user_tz":240,"elapsed":260,"user":{"displayName":"Pooja Algikar","userId":"10909962456072049438"}},"outputId":"9e922db7-a601-4461-d582-5ad0339a3268"},"execution_count":5,"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":"EDQb7KYZx-y9","executionInfo":{"status":"ok","timestamp":1722913457055,"user_tz":240,"elapsed":453,"user":{"displayName":"Pooja Algikar","userId":"10909962456072049438"}},"outputId":"f8527541-ce59-437c-f8bc-9720db16360e"},"execution_count":6,"outputs":[{"output_type":"stream","name":"stdout","text":["total 177\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","-rw------- 1 root root 55269 Aug  5 04:29  Energy_data_focused.xlsx\n","-rw------- 1 root root 49827 Aug  5 14:50  Energy_data_assymetric.xlsx\n","-rw------- 1 root root 19615 Aug  5 15:28  Yacht_data_assymetric.xlsx\n","-rw------- 1 root root 21324 Aug  5 15:32 'Yacht_data_focused (1).xlsx'\n","-rw------- 1 root root 20772 Aug  5 22:04  Yacht_data_focused.xlsx\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":"99HOzeLcyAaX","executionInfo":{"status":"ok","timestamp":1722913457055,"user_tz":240,"elapsed":4,"user":{"displayName":"Pooja Algikar","userId":"10909962456072049438"}}},"execution_count":7,"outputs":[]},{"cell_type":"code","source":["import tensorflow as tf\n","import numpy as np\n","# import gpflow\n"],"metadata":{"id":"Z64ZGBfXyCiE","executionInfo":{"status":"ok","timestamp":1722913480061,"user_tz":240,"elapsed":23009,"user":{"displayName":"Pooja Algikar","userId":"10909962456072049438"}}},"execution_count":8,"outputs":[]},{"cell_type":"code","source":["!pip install check_shapes"],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"mAJxHSvuyEn5","executionInfo":{"status":"ok","timestamp":1722913493587,"user_tz":240,"elapsed":13549,"user":{"displayName":"Pooja Algikar","userId":"10909962456072049438"}},"outputId":"71d163a0-a6a6-472e-b2c4-d4ae193f1de8"},"execution_count":9,"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[31m993.4 kB/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[31m2.6 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":"tqiCUIx8yHCm","executionInfo":{"status":"ok","timestamp":1722913517019,"user_tz":240,"elapsed":23435,"user":{"displayName":"Pooja Algikar","userId":"10909962456072049438"}}},"execution_count":10,"outputs":[]},{"cell_type":"code","source":["!pip install gpflow"],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"I2yveVnTyJxp","executionInfo":{"status":"ok","timestamp":1722913535353,"user_tz":240,"elapsed":18349,"user":{"displayName":"Pooja Algikar","userId":"10909962456072049438"}},"outputId":"56b5c688-1f14-44a0-c004-e17611764e5d"},"execution_count":11,"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[31m5.5 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":["from rcgp.rcgp import RCGPR\n","# from rcgp.rcgp import RCSGPR\n","\n","from rcgp.w import IMQ\n","import matplotlib.pyplot as plt"],"metadata":{"id":"STUXygIeyOED","executionInfo":{"status":"ok","timestamp":1722913548033,"user_tz":240,"elapsed":12719,"user":{"displayName":"Pooja Algikar","userId":"10909962456072049438"}}},"execution_count":12,"outputs":[]},{"cell_type":"code","source":["from experiments.uci import datasets as ds\n","from pathlib import Path"],"metadata":{"id":"mph-e8b9znGI","executionInfo":{"status":"ok","timestamp":1722913550697,"user_tz":240,"elapsed":2697,"user":{"displayName":"Pooja Algikar","userId":"10909962456072049438"}}},"execution_count":13,"outputs":[]},{"cell_type":"code","source":["!pip install tueplots\n","from tueplots import bundles\n"],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"pAXg8XYa3F3k","executionInfo":{"status":"ok","timestamp":1722913561069,"user_tz":240,"elapsed":10544,"user":{"displayName":"Pooja Algikar","userId":"10909962456072049438"}},"outputId":"c1b3855d-bbee-4e4a-d082-c06ebdad3d5c"},"execution_count":14,"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 time import perf_counter"],"metadata":{"id":"d53x-UozzpQw","executionInfo":{"status":"ok","timestamp":1722913561070,"user_tz":240,"elapsed":32,"user":{"displayName":"Pooja Algikar","userId":"10909962456072049438"}}},"execution_count":15,"outputs":[]},{"cell_type":"code","source":["seed = 10\n","sigma_n = 0.1"],"metadata":{"id":"qMyOIKs0yOno","executionInfo":{"status":"ok","timestamp":1722913561070,"user_tz":240,"elapsed":31,"user":{"displayName":"Pooja Algikar","userId":"10909962456072049438"}}},"execution_count":16,"outputs":[]},{"cell_type":"code","source":["!pwd"],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"Ds1lwITayQYs","executionInfo":{"status":"ok","timestamp":1722913561070,"user_tz":240,"elapsed":31,"user":{"displayName":"Pooja Algikar","userId":"10909962456072049438"}},"outputId":"5e445a3b-fd15-40bd-d60e-3dc95f1684d3"},"execution_count":17,"outputs":[{"output_type":"stream","name":"stdout","text":["/content/gdrive/MyDrive/RCGP/RCGP/RCGP-main\n"]}]},{"cell_type":"code","source":["import pandas"],"metadata":{"id":"oQRZgSrtySbW","executionInfo":{"status":"ok","timestamp":1722913561271,"user_tz":240,"elapsed":228,"user":{"displayName":"Pooja Algikar","userId":"10909962456072049438"}}},"execution_count":18,"outputs":[]},{"cell_type":"code","source":["import tensorflow as tf\n","import numpy as np\n","import pandas as pd\n","import gpflow\n"],"metadata":{"id":"RMYxf-LmyUvz","executionInfo":{"status":"ok","timestamp":1722913561271,"user_tz":240,"elapsed":5,"user":{"displayName":"Pooja Algikar","userId":"10909962456072049438"}}},"execution_count":19,"outputs":[]},{"cell_type":"code","source":["# asymmetric = [ds.boston_asymmetric.create_dataset(Path('/tmp/benchmark_data')),\n","#                ds.energy_asymmetric.create_dataset(Path('/tmp/benchmark_data')),\n","#                 ds.synthetic_asymmetric.create_dataset(Path('/tmp/benchmark_data')),\n","#                   ds.yacht_asymmetric.create_dataset(Path('/tmp/benchmark_data'))]\n","# time_asymmetric ={}\n","# mae_asymmetric = {}\n","# RMSE0 = [[0] * 3 for _ in range(9)]"],"metadata":{"id":"1X-um1LIz_0w","executionInfo":{"status":"ok","timestamp":1722913565163,"user_tz":240,"elapsed":3896,"user":{"displayName":"Pooja Algikar","userId":"10909962456072049438"}}},"execution_count":20,"outputs":[]},{"cell_type":"code","source":["focused = [ds.boston_focused.create_dataset(Path('/tmp/benchmark_data')),\n","               ds.energy_focused.create_dataset(Path('/tmp/benchmark_data')),\n","                ds.synthetic_focused.create_dataset(Path('/tmp/benchmark_data')),\n","                  ds.yacht_focused.create_dataset(Path('/tmp/benchmark_data'))]\n","RMSE0 = [[0] * 3 for _ in range(9)]"],"metadata":{"id":"8HE0EBJpwRhX","executionInfo":{"status":"ok","timestamp":1722913827604,"user_tz":240,"elapsed":961,"user":{"displayName":"Pooja Algikar","userId":"10909962456072049438"}}},"execution_count":34,"outputs":[]},{"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":"ms3fcUG-ypuJ","executionInfo":{"status":"ok","timestamp":1722913565163,"user_tz":240,"elapsed":73,"user":{"displayName":"Pooja Algikar","userId":"10909962456072049438"}}},"execution_count":22,"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":"gFI1KFErys3L","executionInfo":{"status":"ok","timestamp":1722913565164,"user_tz":240,"elapsed":37,"user":{"displayName":"Pooja Algikar","userId":"10909962456072049438"}}},"execution_count":23,"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":"GTTcGMW5yvWo","executionInfo":{"status":"ok","timestamp":1722913565164,"user_tz":240,"elapsed":20,"user":{"displayName":"Pooja Algikar","userId":"10909962456072049438"}}},"execution_count":24,"outputs":[]},{"cell_type":"code","source":["lengthscale = 1\n","variance = 1\n","\n","kernel=gpflow.kernels.SquaredExponential(lengthscales=lengthscale, variance=variance)"],"metadata":{"id":"DCH25w_G6Xh_","executionInfo":{"status":"ok","timestamp":1722913594519,"user_tz":240,"elapsed":255,"user":{"displayName":"Pooja Algikar","userId":"10909962456072049438"}}},"execution_count":26,"outputs":[]},{"cell_type":"code","source":["from scipy.stats.qmc import Halton\n","def create_inducing(data):\n","    n = min(data.N // 2, 200)\n","    Z = Halton(data.D, scramble=False).random(n)\n","    lower = np.min(data.X, axis=0)\n","    upper = np.max(data.X, axis=0)\n","    Z = Z * (upper - lower) + lower\n","    return (Z)"],"metadata":{"id":"ayXvEKPE5qAm","executionInfo":{"status":"ok","timestamp":1722913597564,"user_tz":240,"elapsed":2032,"user":{"displayName":"Pooja Algikar","userId":"10909962456072049438"}}},"execution_count":27,"outputs":[]},{"cell_type":"code","source":["def create_rbf(data, rng):\n","    return gpflow.kernels.SquaredExponential(\n","        variance=rng.gamma(5.0, 0.2, []),\n","        lengthscales=rng.gamma(5.0, 0.2, [data.D]),\n","    )"],"metadata":{"id":"JpkGm1MbBJLz","executionInfo":{"status":"ok","timestamp":1722913598891,"user_tz":240,"elapsed":2,"user":{"displayName":"Pooja Algikar","userId":"10909962456072049438"}}},"execution_count":28,"outputs":[]},{"cell_type":"code","source":["from rcgp.rcsvgp import RCSGPR\n","from rcgp.w import IMQ"],"metadata":{"id":"nzPB4fsr6G86","executionInfo":{"status":"ok","timestamp":1722913600800,"user_tz":240,"elapsed":453,"user":{"displayName":"Pooja Algikar","userId":"10909962456072049438"}}},"execution_count":29,"outputs":[]},{"cell_type":"code","source":["for dataset in focused:\n","    print(dataset.name)\n","    if dataset.name == 'energy_focused':\n","      for i in range(1):\n","          print('Iteration',i)\n","          x = dataset.train.X\n","          y = dataset.train.Y\n","          xt = dataset.test.X\n","          yt = dataset.test.Y\n","\n","          rng = np.random.default_rng(1235+i)\n","\n","          inducing_variable = create_inducing(dataset.train)\n","          variance=rng.gamma(5.0, 0.2, []),\n","          lengthscales=rng.gamma(5.0, 0.2, [dataset.train.D]),\n","          noise_variance = 0.01\n","\n","          # standard_gp = gpflow.models.GPR(\n","          # (x, y),\n","          # kernel=gpflow.kernels.SquaredExponential(lengthscales=lengthscales_0,variance = variance_0),\n","          # noise_variance = 0.01)\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","\n","\n","          model = RCSGPR(\n","          (x, y),\n","          kernel=create_rbf(dataset.train, rng),\n","          weighting_function=IMQ(C=np.quantile(np.abs(y), 0.95)),\n","          noise_variance=sigma_n**2 ,\n","          inducing_variable = inducing_variable\n","      )\n","\n","          gpflow.set_trainable(model.likelihood.variance, False)\n","\n","          opt = gpflow.optimizers.Scipy()\n","          log = opt.minimize(model.training_loss_closure(), model.trainable_variables,options={\"maxiter\": 1_000})\n","          t_after = perf_counter()\n","\n","          if isinstance(xt, pd.DataFrame):  # convert xt into tensorflow data types\n","              xt = xt.values\n","\n","          Eft, Varft  = model.predict_f(xt)\n","\n","\n","\n","          # model = RCGPR(\n","          #     (x, y),\n","          #     kernel=gpflow.kernels.SquaredExponential(),\n","          #     # weighting_function=IMQ(1.5),\n","          #     weighting_function=IMQ(C=np.quantile(np.abs(y), 0.85)),\n","          #     # weighting_function=IRQ(C=np.quantile(np.abs(Y_train), 0.9)),\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","\n","\n","\n","          Eft, Varft = model.predict_f(xt, full_cov=False)\n","          std_ft = np.sqrt(Varft)\n","\n","          RMSE0[i][0]=RMSE(Eft,Varft)\n","          RMSE0[i][1]=MAE(Eft,Varft)\n","          RMSE0[i][2]=NLP(Eft,Varft,yt)\n","\n"],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"K1kqOSgVzMGv","executionInfo":{"status":"ok","timestamp":1722913855386,"user_tz":240,"elapsed":8672,"user":{"displayName":"Pooja Algikar","userId":"10909962456072049438"}},"outputId":"e23b5f30-8578-4e76-c1f8-4a97f5c23096"},"execution_count":35,"outputs":[{"output_type":"stream","name":"stdout","text":["boston_focused\n","energy_focused\n","Iteration 0\n","synthetic_focused\n","yacht_focused\n"]}]},{"cell_type":"code","source":["print (RMSE0)\n","\n"],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"Mru48hnryjyg","executionInfo":{"status":"ok","timestamp":1722913859481,"user_tz":240,"elapsed":279,"user":{"displayName":"Pooja Algikar","userId":"10909962456072049438"}},"outputId":"02e3bf9e-e571-4e17-a9cd-7c7f8401f630"},"execution_count":36,"outputs":[{"output_type":"stream","name":"stdout","text":["[[0.0038745329641284906, 0.0038745329640772924, 128.3532142155058], [0, 0, 0], [0, 0, 0], [0, 0, 0], [0, 0, 0], [0, 0, 0], [0, 0, 0], [0, 0, 0], [0, 0, 0]]\n"]}]},{"cell_type":"code","source":["from IPython.display import Javascript\n","display(Javascript('IPython.notebook.execute_cells_above()'))"],"metadata":{"colab":{"base_uri":"https://localhost:8080/","height":17},"id":"59Szt47Fo1SC","executionInfo":{"status":"ok","timestamp":1722913370200,"user_tz":240,"elapsed":222,"user":{"displayName":"Pooja Algikar","userId":"10909962456072049438"}},"outputId":"30fbecf7-d477-4309-f109-abf2a2349b71"},"execution_count":2,"outputs":[{"output_type":"display_data","data":{"text/plain":["<IPython.core.display.Javascript object>"],"application/javascript":["IPython.notebook.execute_cells_above()"]},"metadata":{}}]},{"cell_type":"code","source":["df_train = pd.DataFrame({\n","    'x_0': x[:, 0], 'x_1': x[:, 1], 'x_2': x[:, 2], 'x_3': x[:, 3],\n","    'x_4': x[:, 4], 'x_5': x[:, 5],\n","    'y': y.flatten()  # Flatten y to make it 1D\n","})\n","\n","df_test = pd.DataFrame({\n","    'xt_0': xt[:, 0], 'xt_1': xt[:, 1], 'xt_2': xt[:, 2], 'xt_3': xt[:, 3],\n","    'xt_4': xt[:, 4], 'xt_5': xt[:, 5],\n","    'yt': yt.flatten()  # Flatten yt to make it 1D\n","})\n","\n","# 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)\n","\n","# df_results = pd.DataFrame({\n","#     'rmse': Results[:, 0], 'mae': Results[:, 1], 'nlp': Results[:, 2]\n","# })\n","\n","# Create an ExcelWriter object\n","with pd.ExcelWriter('Yacht_data_focused.xlsx') as writer:\n","    df_train.to_excel(writer, sheet_name='Train', index=False)\n","    df_test.to_excel(writer, sheet_name='Test', index=False)\n","    # df_results.to_excel(writer, sheet_name='Results', index=False)"],"metadata":{"id":"boOr31foTF_F","executionInfo":{"status":"ok","timestamp":1722895493828,"user_tz":240,"elapsed":317,"user":{"displayName":"Pooja Algikar","userId":"10909962456072049438"}}},"execution_count":24,"outputs":[]},{"cell_type":"code","source":["print(RMSE0)\n","print(i)\n","\n"],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"Gus7_84A0uFA","executionInfo":{"status":"ok","timestamp":1722871923004,"user_tz":240,"elapsed":8,"user":{"displayName":"Pooja Algikar","userId":"10909962456072049438"}},"outputId":"5f9d72c8-7938-4035-d6e7-3eecffbabe99"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["[[1.0929273949686509, 0.9487919481334208, 1.1939364336252156], [0, 0, 0], [0, 0, 0], [0, 0, 0], [0, 0, 0], [0, 0, 0], [0, 0, 0], [0, 0, 0], [0, 0, 0]]\n","0\n"]}]},{"cell_type":"markdown","source":[],"metadata":{"id":"VFuX5AzBxLBm"}},{"cell_type":"code","source":[],"metadata":{"id":"S71JdJsgyx_R"},"execution_count":null,"outputs":[]}]}