{
 "nbformat": 4,
 "nbformat_minor": 0,
 "metadata": {
  "colab": {
   "name": "Section6_3_solar_demo.ipynb",
   "provenance": [],
   "collapsed_sections": []
  },
  "kernelspec": {
   "name": "python3",
   "display_name": "Python 3"
  },
  "language_info": {
   "name": "python"
  },
  "gpuClass": "standard"
 },
 "cells": [
  {
   "cell_type": "markdown",
   "source": [
    "This file demonstrate the solar experiment shown in section 6.3, where we compare EnbPI, SPCI, AdaptiveCI, and Nex-CP WLS\n",
    "\n",
    "It is current written to be executed in google colaboratory.\n",
    "\n",
    "Please place the following files in the same directory as this `.ipynb`, which are a part of this Github repository\n",
    "\n",
    "```\n",
    "  utils_quick.py\n",
    "\n",
    "  utils_latest.py\n",
    "\n",
    "  utils_EnbPI.py\n",
    "\n",
    "  PI_class_EnbPI.py\n",
    "\n",
    "  Data/Solar_Atl_data.csv\n",
    "```"
   ],
   "metadata": {
    "id": "xysGqjV0p5aE",
    "pycharm": {
     "name": "#%% md\n"
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "DQL2E4phhx9P",
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [],
   "source": [
    "#from google.colab import drive\n",
    "#drive.mount('/content/drive')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "CXt0Szm9q_Xx",
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [],
   "source": [
    "#!pip install pickle5\n",
    "#!pip install --upgrade --no-deps statsmodels\n",
    "#!pip install scikit-garden\n",
    "#!pip install scikit-learn==0.22.2 # Needed for scikit-garden to work properly. Restart runtime is NOT needed"
   ]
  },
  {
   "cell_type": "code",
   "source": [
    "#import sys\n",
    "#path = '/content/drive/MyDrive/EnbPI' # You are free to replace this with where you place this file on drive\n",
    "#sys.path.insert(0,path)"
   ],
   "metadata": {
    "id": "y4DWIPYmcqY5",
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "execution_count": 3,
   "outputs": []
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "id": "8bloW_QoiZNE",
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "outputId": "78479661-8fea-4536-a7c9-090838c869f8",
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "outputs": [
    {
     "output_type": "stream",
     "name": "stdout",
     "text": [
      "/content/drive/MyDrive/EnbPI\n"
     ]
    }
   ],
   "source": [
    "%cd /content/drive/MyDrive/EnbPI"
   ]
  },
  {
   "cell_type": "code",
   "source": [
    "import calendar\n",
    "import seaborn as sns\n",
    "from statsmodels.tsa.stattools import pacf\n",
    "import importlib as ipb\n",
    "import pdb\n",
    "import matplotlib.pyplot as plt\n",
    "from scipy.sparse import random\n",
    "import pandas as pd\n",
    "import numpy as np\n",
    "import importlib\n",
    "import sys\n",
    "import math\n",
    "import time as time\n",
    "import utils_quick as util\n",
    "import utils_latest\n",
    "import warnings\n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import pickle\n",
    "from skgarden import RandomForestQuantileRegressor\n",
    "from numpy.lib.stride_tricks import sliding_window_view\n",
    "from sklearn.ensemble import RandomForestRegressor\n",
    "warnings.filterwarnings(\"ignore\")\n",
    "device = torch.device(\"cuda:0\" if torch.cuda.is_available() else \"cpu\")"
   ],
   "metadata": {
    "id": "eWSzk0dNQf8W",
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "execution_count": 5,
   "outputs": []
  },
  {
   "cell_type": "markdown",
   "source": [
    "# Required functions"
   ],
   "metadata": {
    "id": "fjuucWAivJOC",
    "pycharm": {
     "name": "#%% md\n"
    }
   }
  },
  {
   "cell_type": "code",
   "source": [
    "#### Main Class ####\n",
    "class prediction_interval_with_SPCI():\n",
    "    '''\n",
    "        Create prediction intervals assuming Y_t = f(X_t) + \\sigma(X_t)\\eps_t\n",
    "        Currently, assume the regression function is by default MLP implemented with PyTorch, as it needs to estimate BOTH f(X_t) and \\sigma(X_t), where the latter is impossible to estimate using scikit-learn modules\n",
    "\n",
    "        Most things carry out, except that we need to have different estimators for f and \\sigma.\n",
    "\n",
    "        fit_func = None: use MLP above\n",
    "    '''\n",
    "\n",
    "    def __init__(self, X_train, X_predict, Y_train, Y_predict, fit_func=None):\n",
    "        self.regressor = fit_func\n",
    "        self.X_train = X_train\n",
    "        self.X_predict = X_predict\n",
    "        self.Y_train = Y_train\n",
    "        self.Y_predict = Y_predict\n",
    "        # Predicted training data centers by EnbPI\n",
    "        self.Ensemble_train_interval_centers = []\n",
    "        self.Ensemble_train_interval_sigma = []\n",
    "        # Predicted test data centers by EnbPI\n",
    "        self.Ensemble_pred_interval_centers = []\n",
    "        self.Ensemble_pred_interval_sigma = []\n",
    "        self.Ensemble_online_resid = []  # LOO scores\n",
    "        self.beta_hat_bins = []\n",
    "\n",
    "    def fit_bootstrap_models_online(self, B, miss_test_idx=[], fit_sigmaX=True):\n",
    "        '''\n",
    "          Train B bootstrap estimators from subsets of (X_train, Y_train), compute aggregated predictors, and compute the residuals\n",
    "          fit_sigmaX: If False, just avoid predicting \\sigma(X_t) by defaulting it to 1\n",
    "        '''\n",
    "        n, d = self.X_train.shape\n",
    "        n1 = len(self.X_predict)\n",
    "        # hold indices of training data for each f^b\n",
    "        boot_samples_idx = util.generate_bootstrap_samples(n, n, B)\n",
    "        # hold predictions from each f^b for fX and sigma&b for sigma\n",
    "        boot_predictionsFX = torch.zeros(B, n+n1).to(device)\n",
    "        boot_predictionsSigmaX = torch.ones(B, n+n1).to(device)\n",
    "        # for i^th column, it shows which f^b uses i in training (so exclude in aggregation)\n",
    "        in_boot_sample = np.zeros((B, n), dtype=bool)\n",
    "        out_sample_predictFX = torch.zeros(n, n1).to(device)\n",
    "        out_sample_predictSigmaX = torch.ones(n, n1).to(device)\n",
    "        start = time.time()\n",
    "        Xfull = torch.vstack([self.X_train, self.X_predict])\n",
    "        for b in range(B):\n",
    "            Xboot, Yboot = self.X_train[boot_samples_idx[b],\n",
    "                                        :], self.Y_train[boot_samples_idx[b], ]\n",
    "            in_boot_sample[b, boot_samples_idx[b]] = True\n",
    "            if self.regressor.__class__.__name__ == 'NoneType':\n",
    "                start1 = time.time()\n",
    "                model_f = MLP(d).to(device)\n",
    "                optimizer_f = torch.optim.Adam(model_f.parameters(), lr=1e-3)\n",
    "                if fit_sigmaX:\n",
    "                    model_sigma = MLP(d, sigma=True).to(device)\n",
    "                    optimizer_sigma = torch.optim.Adam(\n",
    "                        model_sigma.parameters(), lr=2e-3)\n",
    "                for epoch in range(300):\n",
    "                    fXhat = model_f(Xboot)\n",
    "                    sigmaXhat = torch.ones(len(fXhat)).to(device)\n",
    "                    if fit_sigmaX:\n",
    "                        sigmaXhat = model_sigma(Xboot)\n",
    "                    loss = ((Yboot-fXhat)/sigmaXhat).pow(2).mean()/2\n",
    "                    optimizer_f.zero_grad()\n",
    "                    if fit_sigmaX:\n",
    "                        optimizer_sigma.zero_grad()\n",
    "                    loss.backward()\n",
    "                    optimizer_f.step()\n",
    "                    if fit_sigmaX:\n",
    "                        optimizer_sigma.step()\n",
    "                with torch.no_grad():\n",
    "                    boot_predictionsFX[b] = model_f(Xfull).flatten()\n",
    "                    if fit_sigmaX:\n",
    "                        boot_predictionsSigmaX[b] = model_sigma(\n",
    "                            Xfull).flatten()\n",
    "                print(\n",
    "                    f'Took {time.time()-start1} secs to finish the {b}th boostrap model')\n",
    "            else:\n",
    "                model = self.regressor\n",
    "                model.fit(Xboot, Yboot)\n",
    "                boot_predictionsFX[b] = torch.from_numpy(\n",
    "                    model.predict(Xfull).flatten()).to(device)\n",
    "                # NOTE, NO sigma estimation because these methods by deFAULT are fitting Y, but we have no observation of errors\n",
    "        print(\n",
    "            f'Finish Fitting {B} Bootstrap models, took {time.time()-start} secs.')\n",
    "        start = time.time()\n",
    "        keep = []\n",
    "        for i in range(n):\n",
    "            b_keep = np.argwhere(~(in_boot_sample[:, i])).reshape(-1)\n",
    "            pred_iFX = boot_predictionsFX[b_keep, i].mean()\n",
    "            pred_iSigmaX = boot_predictionsSigmaX[b_keep, i].mean()\n",
    "            pred_testFX = boot_predictionsFX[b_keep, n:].mean(0)\n",
    "            pred_testSigmaX = boot_predictionsSigmaX[b_keep, n:].mean(0)\n",
    "            if(len(b_keep) > 0):\n",
    "                self.Ensemble_train_interval_centers.append(pred_iFX)\n",
    "                self.Ensemble_train_interval_sigma.append(pred_iSigmaX)\n",
    "                resid_LOO = (self.Y_train[i] - pred_iFX)/pred_iSigmaX\n",
    "                out_sample_predictFX[i] = pred_testFX\n",
    "                out_sample_predictSigmaX[i] = pred_testSigmaX\n",
    "                keep = keep+[b_keep]\n",
    "            self.Ensemble_online_resid.append(resid_LOO.item())\n",
    "        sorted_out_sample_predictFX = out_sample_predictFX.mean(0)  # length n1\n",
    "        sorted_out_sample_predictSigmaX = out_sample_predictSigmaX.mean(\n",
    "            0)  # length n1\n",
    "        resid_out_sample = (\n",
    "            self.Y_predict-sorted_out_sample_predictFX)/sorted_out_sample_predictSigmaX\n",
    "        if len(miss_test_idx) > 0:\n",
    "            # Replace missing residuals with that from the immediate predecessor that is not missing, as\n",
    "            # o/w we are not assuming prediction data are missing\n",
    "            for idx in range(len(miss_test_idx)):\n",
    "                i = miss_test_idx[idx]\n",
    "                if i > 0:\n",
    "                    j = i-1\n",
    "                    while j in miss_test_idx[:idx]:\n",
    "                        j -= 1\n",
    "                    resid_out_sample[i] = resid_out_sample[j]\n",
    "\n",
    "                else:\n",
    "                    # The first Y during testing is missing, let it be the last of the training residuals\n",
    "                    # note, training data already takes out missing values, so doing is is fine\n",
    "                    resid_out_sample[0] = self.Ensemble_online_resid[-1]\n",
    "        self.Ensemble_online_resid = np.append(\n",
    "            self.Ensemble_online_resid, resid_out_sample.cpu().detach().numpy())\n",
    "        # print(f'Finish Computing LOO residuals, took {time.time()-start} secs.')\n",
    "        # print(f'Max LOO test residual is {np.max(self.Ensemble_online_resid[n:])}')\n",
    "        # print(f'Min LOO test residual is {np.min(self.Ensemble_online_resid[n:])}')\n",
    "        self.Ensemble_pred_interval_centers = sorted_out_sample_predictFX\n",
    "        self.Ensemble_pred_interval_sigma = sorted_out_sample_predictSigmaX\n",
    "\n",
    "    def compute_PIs_Ensemble_online(self, alpha, stride=1, smallT=True, past_window=100, use_quantile_regr=False, quantile_regr='RF'):\n",
    "        '''\n",
    "            smallT: if True, we would only start with the last n number of LOO residuals, rather than use the full length T ones. Used in change detection\n",
    "                NOTE: smallT can be important if time-series is very dynamic, in which case training MORE data may actaully be worse (because quantile longer)\n",
    "                HOWEVER, if fit quantile regression, set it to be FALSE because we want to have many training pts for the quantile regressor\n",
    "            use_quantile_regr: if True, we fit conditional quantile to compute the widths, rather than simply using empirical quantile\n",
    "        '''\n",
    "        n1 = len(self.X_train)\n",
    "        if smallT:\n",
    "            n1 = min(past_window, len(self.X_train))\n",
    "        # Now f^b and LOO residuals have been constructed from earlier\n",
    "        out_sample_predict = self.Ensemble_pred_interval_centers.cpu().detach().numpy()\n",
    "        out_sample_predictSigmaX = self.Ensemble_pred_interval_sigma\n",
    "        start = time.time()\n",
    "        # Matrix, where each row is a UNIQUE slice of residuals with length stride.\n",
    "        resid_strided = util.strided_app(\n",
    "            self.Ensemble_online_resid[len(self.X_train)-n1:-1], n1, stride)\n",
    "        print(f'Shape of slided residual lists is {resid_strided.shape}')\n",
    "        num_unique_resid = resid_strided.shape[0]\n",
    "        width_left = np.zeros(num_unique_resid)\n",
    "        width_right = np.zeros(num_unique_resid)\n",
    "        # # NEW, alpha becomes alpha_t. Uncomment things below if we decide to use this upgraded EnbPI\n",
    "        # alpha_t = alpha\n",
    "        # errs = []\n",
    "        # gamma = 0.005\n",
    "        # method = 'simple'  # 'simple' or 'complex'\n",
    "        # self.alphas = []\n",
    "        # NOTE: 'max_features='log2', max_depth=2' make the model \"simpler\", which improves performance in practice\n",
    "        for i in range(num_unique_resid):\n",
    "            # for p in range(stride):  # NEW for adaptive alpha\n",
    "            past_resid = resid_strided[i, :]\n",
    "            curr_SigmaX = out_sample_predictSigmaX[i].item()\n",
    "            if use_quantile_regr:\n",
    "                # New predicted conditional quntile\n",
    "                # 1. Get \"past_resid\" into an auto-regressive fashion\n",
    "                # This should be more carefully examined, b/c it depends on how long \\hat{\\eps}_t depends on the past\n",
    "                # From practice, making it small make intervals wider\n",
    "                n2 = past_window\n",
    "                residX = sliding_window_view(past_resid, window_shape=n2)\n",
    "                residY = past_resid[n2:]\n",
    "                # 2. Fit the model. Default quantile regressor is the quantile RF from\n",
    "                # scikit-garden: https://scikit-garden.github.io/\n",
    "                # NOTE, should NOT warm start, as it makes result poor, although training is longer\n",
    "                if quantile_regr == 'RF':\n",
    "                    rfqr = RandomForestQuantileRegressor(\n",
    "                        max_depth=2, random_state=0)\n",
    "                    rfqr.fit(residX[:-1], residY)\n",
    "                    # 3. Find best \\hat{\\beta} via evaluating many quantiles\n",
    "                    beta_hat_bin = util.binning_use_RF_quantile_regr(\n",
    "                        rfqr, residX[-1], alpha)\n",
    "                    width_left[i] = curr_SigmaX*rfqr.predict(\n",
    "                        residX[-1].reshape(1, -1), math.ceil(100 * beta_hat_bin))\n",
    "                    width_right[i] = curr_SigmaX*rfqr.predict(\n",
    "                        residX[-1].reshape(1, -1), math.ceil(100 * (1-alpha+beta_hat_bin)))\n",
    "                # if quantile_regr == 'LR':\n",
    "                #     start1 = time.time()\n",
    "                #     wleft, wright = util.binning_use_linear_quantile_regr(\n",
    "                #         residX, residY, alpha)\n",
    "                #     if i == 0:\n",
    "                #         print(\n",
    "                #             f'100 Linear QRegr approx. takes {100*(time.time()-start1)} secs.')\n",
    "                #     width_left[i] = curr_SigmaX*wleft\n",
    "                #     width_right[i] = curr_SigmaX*wright\n",
    "                if i % int(num_unique_resid/20) == 0:\n",
    "                    print(\n",
    "                        f'Width at test {i} is {width_right[i]-width_left[i]}')\n",
    "            else:\n",
    "                # Naive empirical quantile\n",
    "                # The number of bins will be determined INSIDE binning\n",
    "                beta_hat_bin = util.binning(past_resid, alpha)\n",
    "                # beta_hat_bin = util.binning(past_resid, alpha_t)\n",
    "                self.beta_hat_bins.append(beta_hat_bin)\n",
    "                width_left[i] = curr_SigmaX*np.percentile(\n",
    "                    past_resid, math.ceil(100*beta_hat_bin))\n",
    "                width_right[i] = curr_SigmaX*np.percentile(\n",
    "                    past_resid, math.ceil(100*(1-alpha+beta_hat_bin)))\n",
    "        print(\n",
    "            f'Finish Computing {num_unique_resid} UNIQUE Prediction Intervals, took {time.time()-start} secs.')\n",
    "        # This is because |width|=T1/stride.\n",
    "        width_left = np.repeat(width_left, stride)\n",
    "        # This is because |width|=T1/stride.\n",
    "        width_right = np.repeat(width_right, stride)\n",
    "        PIs_Ensemble = pd.DataFrame(np.c_[out_sample_predict+width_left,\n",
    "                                          out_sample_predict+width_right], columns=['lower', 'upper'])\n",
    "        self.PIs_Ensemble = PIs_Ensemble\n",
    "\n",
    "    '''\n",
    "        All together\n",
    "    '''\n",
    "\n",
    "    def get_results(self, alpha, data_name, itrial, true_Y_predict=[], method='Ensemble'):\n",
    "        '''\n",
    "            NOTE: I added a \"true_Y_predict\" option, which will be used for calibrating coverage under missing data\n",
    "            In particular, this is needed when the Y_predict we use for training is NOT the same as true Y_predict\n",
    "        '''\n",
    "        results = pd.DataFrame(columns=['itrial', 'dataname', 'muh_fun',\n",
    "                                        'method', 'train_size', 'coverage', 'width'])\n",
    "        train_size = len(self.X_train)\n",
    "        if method == 'Ensemble':\n",
    "            PI = self.PIs_Ensemble\n",
    "        Ytest = self.Y_predict.cpu().detach().numpy()\n",
    "        coverage = ((np.array(PI['lower']) <= Ytest) & (\n",
    "            np.array(PI['upper']) >= Ytest)).mean()\n",
    "        if len(true_Y_predict) > 0:\n",
    "            coverage = ((np.array(PI['lower']) <= true_Y_predict) & (\n",
    "                np.array(PI['upper']) >= true_Y_predict)).mean()\n",
    "        print(f'Average Coverage is {coverage}')\n",
    "        width = (PI['upper'] - PI['lower']).mean()\n",
    "        print(f'Average Width is {width}')\n",
    "        results.loc[len(results)] = [itrial, data_name,\n",
    "                                     'torch_MLP', method, train_size, coverage, width]\n",
    "        return results\n",
    "\n",
    "\n",
    "def CP_LS(X, Y, x, alpha, weights=[], tags=[]):\n",
    "    # Barber et al. 2022: Nex-CP\n",
    "    # weights are used for computing quantiles for the prediction interval\n",
    "    # tags are used as weights in weighted least squares regression\n",
    "    n = len(Y)\n",
    "\n",
    "    if(len(tags) == 0):\n",
    "        tags = np.ones(n+1)\n",
    "\n",
    "    if(len(weights) == 0):\n",
    "        weights = np.ones(n+1)\n",
    "    if(len(weights) == n):\n",
    "        weights = np.r_[weights, 1]\n",
    "    weights = weights / np.sum(weights)\n",
    "\n",
    "    # randomly permute one weight for the regression\n",
    "    random_ind = int(np.where(np.random.multinomial(1, weights, 1))[1])\n",
    "    tags[np.c_[random_ind, n]] = tags[np.c_[n, random_ind]]\n",
    "\n",
    "    XtX = (X.T*tags[:-1]).dot(X) + np.outer(x, x)*tags[-1]\n",
    "    a = Y - X.dot(np.linalg.solve(XtX, (X.T*tags[:-1]).dot(Y)))\n",
    "    b = -X.dot(np.linalg.solve(XtX, x))*tags[-1]\n",
    "    a1 = -x.T.dot(np.linalg.solve(XtX, (X.T*tags[:-1]).dot(Y)))\n",
    "    b1 = 1 - x.T.dot(np.linalg.solve(XtX, x))*tags[-1]\n",
    "    # if we run weighted least squares on (X[1,],Y[1]),...(X[n,],Y[n]),(x,y)\n",
    "    # then a + b*y = residuals of data points 1,..,n\n",
    "    # and a1 + b1*y = residual of data point n+1\n",
    "\n",
    "    y_knots = np.sort(\n",
    "        np.unique(np.r_[((a-a1)/(b1-b))[b1-b != 0], ((-a-a1)/(b1+b))[b1+b != 0]]))\n",
    "    y_inds_keep = np.where(((np.abs(np.outer(a1+b1*y_knots, np.ones(n)))\n",
    "                             > np.abs(np.outer(np.ones(len(y_knots)), a)+np.outer(y_knots, b))) *\n",
    "                            weights[:-1]).sum(1) <= 1-alpha)[0]\n",
    "    y_PI = np.array([y_knots[y_inds_keep.min()], y_knots[y_inds_keep.max()]])\n",
    "    if(weights[:-1].sum() <= 1-alpha):\n",
    "        y_PI = np.array([-np.inf, np.inf])\n",
    "    return y_PI\n",
    "\n",
    "#### Model and data helper ####\n",
    "\n",
    "\n",
    "class MLP(nn.Module):\n",
    "    def __init__(self, d, sigma=False):\n",
    "        super(MLP, self).__init__()\n",
    "        H = 64\n",
    "        layers = [nn.Linear(d, H), nn.ReLU(), nn.Linear(\n",
    "            H, H), nn.ReLU(), nn.Linear(H, 1)]\n",
    "        self.sigma = sigma\n",
    "        if self.sigma:\n",
    "            layers.append(nn.ReLU())\n",
    "        self.layers = nn.Sequential(*layers)\n",
    "\n",
    "    def forward(self, x):\n",
    "        perturb = 1e-3 if self.sigma else 0\n",
    "        return self.layers(x)+perturb\n",
    "\n",
    "\n",
    "def get_new_data():\n",
    "    ''' Note, the difference from earlier case 3 in paper is that\n",
    "        1) I reduce d from 100 to 20,\n",
    "        2) I let X to be different, so sigmaX differs\n",
    "            The sigmaX is a linear model so this effect in X is immediate\n",
    "        I keep the same AR(1) eps & everything else.'''\n",
    "    def True_mod_nonlinear_pre(feature):\n",
    "        '''\n",
    "        Input:\n",
    "        Output:\n",
    "        Description:\n",
    "            f(feature): R^d -> R\n",
    "        '''\n",
    "        # Attempt 3 Nonlinear model:\n",
    "        # f(X)=sqrt(1+(beta^TX)+(beta^TX)^2+(beta^TX)^3), where 1 is added in case beta^TX is zero\n",
    "        d = len(feature)\n",
    "        np.random.seed(0)\n",
    "        # e.g. 20% of the entries are NON-missing\n",
    "        beta1 = random(1, d, density=0.2).A\n",
    "        betaX = np.abs(beta1.dot(feature))\n",
    "        return (betaX + betaX**2 + betaX**3)**(1/4)\n",
    "    Tot, d = 2000, 20\n",
    "    Fmap = True_mod_nonlinear_pre\n",
    "    # Multiply each random feature by exponential component, which is repeated every Tot/rep elements\n",
    "    rep = 10\n",
    "    mult = np.exp(np.repeat(np.linspace(0, 2, rep), Tot/rep)).reshape(Tot, 1)\n",
    "    X = np.random.rand(Tot, d)*mult\n",
    "    fX = np.array([Fmap(x) for x in X]).flatten()\n",
    "    beta_Sigma = 0.1*np.ones(d)\n",
    "    sigmaX = np.maximum(X.dot(beta_Sigma).T, 0)\n",
    "    with open(f'Data_nochangepts_nonlinear.p', 'rb') as fp:\n",
    "        Data_dc = pickle.load(fp)\n",
    "    eps = Data_dc['Eps']\n",
    "    Y = fX + sigmaX*eps\n",
    "    np.random.seed(1103)\n",
    "    idx = np.random.choice(Tot, Tot, replace=False)\n",
    "    Y, X, fX, sigmaX, eps = Y[idx], X[idx], fX[idx], sigmaX[idx], eps[idx]\n",
    "    return {'Y': torch.from_numpy(Y).float(), 'X': torch.from_numpy(X).float(), 'f(X)': fX, 'sigma(X)': sigmaX, 'Eps': eps}\n",
    "\n",
    "\n",
    "def get_new_data_simple(num_pts, alpha, beta):\n",
    "    '''\n",
    "        Y_t = alpha*Y_{t-1}+\\eps_t\n",
    "        \\eps_t = beta*\\eps_{t-1}+v_t\n",
    "        v_t ~ N(0,1)\n",
    "        So X_t = Y_{t-1}, f(X_t) = alpha*X_t\n",
    "        If t = 0:\n",
    "            X_t = 0, Y_t=\\eps_t = v_t\n",
    "    '''\n",
    "    v0 = torch.randn(1)\n",
    "    Y, X, fX, eps = [v0], [torch.zeros(1)], [torch.zeros(1)], [v0]\n",
    "    scale = torch.sqrt(torch.ones(1)*0.1)\n",
    "    for _ in range(num_pts-1):\n",
    "        vt = torch.randn(1)*scale\n",
    "        X.append(Y[-1])\n",
    "        fX.append(alpha*Y[-1])\n",
    "        eps.append(beta*eps[-1]+vt)\n",
    "        Y.append(fX[-1]+eps[-1])\n",
    "    Y, X, fX, eps = torch.hstack(Y), torch.vstack(\n",
    "        X), torch.vstack(fX), torch.hstack(eps)\n",
    "    return {'Y': Y.float(), 'X': X.float(), 'f(X)': fX, 'Eps': eps}\n",
    "\n",
    "\n",
    "def electric_dataset():\n",
    "    # ELEC2 data set\n",
    "    # downloaded from https://www.kaggle.com/yashsharan/the-elec2-dataset\n",
    "    data = pd.read_csv('electricity-normalized.csv')\n",
    "    col_names = data.columns\n",
    "    data = data.to_numpy()\n",
    "\n",
    "    # remove the first stretch of time where 'transfer' does not vary\n",
    "    data = data[17760:]\n",
    "\n",
    "    # set up variables for the task (predicting 'transfer')\n",
    "    covariate_col = ['nswprice', 'nswdemand', 'vicprice', 'vicdemand']\n",
    "    response_col = 'transfer'\n",
    "    # keep data points for 9:00am - 12:00pm\n",
    "    keep_rows = np.where((data[:, 2] > data[17, 2])\n",
    "                         & (data[:, 2] < data[24, 2]))[0]\n",
    "\n",
    "    X = data[keep_rows][:, np.where(\n",
    "        [t in covariate_col for t in col_names])[0]]\n",
    "    Y = data[keep_rows][:, np.where(col_names == response_col)[0]].flatten()\n",
    "    X = X.astype('float64')\n",
    "    Y = Y.astype('float64')\n",
    "\n",
    "    return X, Y\n",
    "\n",
    "#### Other helpers ####\n",
    "\n",
    "def rolling_avg(x, window=100):\n",
    "    return np.convolve(x, np.ones(window)/window)[(window-1):-window]\n",
    "\n",
    "\n",
    "def dict_to_latex(dict):\n",
    "    DF = pd.DataFrame.from_dict(np.vstack(dict.values()))\n",
    "    keys = list(dict.keys())\n",
    "    index = np.array([[f'{key} coverage', f'{key} width']\n",
    "                     for key in keys]).flatten()\n",
    "    DF.index = index\n",
    "    DF.columns = train_ls\n",
    "    print(DF)\n",
    "    print(DF.round(2).to_latex())"
   ],
   "metadata": {
    "id": "2blvGaelQXAO",
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "execution_count": 22,
   "outputs": []
  },
  {
   "cell_type": "markdown",
   "source": [
    "# Running tests"
   ],
   "metadata": {
    "id": "bXrLT5QDvMVH",
    "pycharm": {
     "name": "#%% md\n"
    }
   }
  },
  {
   "cell_type": "code",
   "source": [
    "alpha = 0.1\n",
    "# Whether we save dictionary for plotting rolling cov or width\n",
    "save_dict_rolling = True\n",
    "non_stat_solar = True  # Whether X_t in solar contains time covariate\n",
    "if non_stat_solar == False:\n",
    "    # We only visualize rolling results under non-stationary feature X_t\n",
    "    save_dict_rolling = False\n",
    "train_ls = [0.5, 0.6, 0.7, 0.8]\n",
    "train_ls = [0.8]"
   ],
   "metadata": {
    "id": "vhYz613WvY4u",
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "execution_count": 7,
   "outputs": []
  },
  {
   "cell_type": "markdown",
   "source": [
    "## EnbPI & SPCI"
   ],
   "metadata": {
    "id": "h82M4AKEvcOb",
    "pycharm": {
     "name": "#%% md\n"
    }
   }
  },
  {
   "cell_type": "code",
   "source": [
    "'''\n",
    "    Arguments:\n",
    "        simulation: bool. True use simulated data. False use solar\n",
    "            simul_type: int. 1 = simple state-space. 2 = non-statioanry. 3 = heteroskedastic\n",
    "            The latter 2 follows from case 3 in paper\n",
    "        conditions: Contain these three below:\n",
    "            use_quantile_regr: bool. True use `quantile_regr`. False use empirical quatile\n",
    "            quantile_regr: str. Which quantile regression to fit residuals (e.g., \"RF\", \"LR\")\n",
    "            fit_func: None or sklearn module with methods `.fit` & `.predict`. If None, use MLP above\n",
    "\n",
    "        fit_sigmaX: bool. True if to fit heteroskedastic errors. ONLY activated if fit_func is NONE (i.e. MLP), because errors are unobserved so `.fit()` does not work\n",
    "\n",
    "        smallT: bool. True if empirical quantile uses not ALL T residual in the past to get quantile (should be tuned as sometimes longer memory causes poor coverage)\n",
    "            past_window: int. If smallT True, EnbPI uses `past_window` most residuals to get width. FOR quantile_regr of residuals, it determines the dimension of the \"feature\" that predict new quantile of residuals autoregressively\n",
    "\n",
    "    Results:\n",
    "        dict: contains dictionary of coverage and width under different training fraction (fix alpha) under various argument combinations\n",
    "\n",
    "'''\n",
    "importlib.reload(sys.modules['utils_quick'])\n",
    "importlib.reload(sys.modules['utils_latest'])\n",
    "dict_full = {}\n",
    "dict_rolling = {}\n",
    "''' Test '''\n",
    "# Conditions: [if simulation, if use quantile regr, which quantile regr]\n",
    "conditions_simulation = [[True, False, ''], [True, True, 'RF']]\n",
    "conditions_real = [[False, False, ''], [False, True, 'RF']]\n",
    "# For burn-in period plot\n",
    "PIs_EnbPI = 0\n",
    "PIs_SPCI = 0\n",
    "for condition in conditions_real:\n",
    "    simulation, use_quantile_regr, quantile_regr = condition\n",
    "    name = 'SPCI' if use_quantile_regr else 'EnbPI'\n",
    "    result_cov, result_width = [], []\n",
    "    for train_frac in train_ls:\n",
    "        print('########################################')\n",
    "        print(f'Train frac at {train_frac}')\n",
    "        if simulation:\n",
    "            simul_type = 2  # 1, 2, 3\n",
    "            fit_sigmaX = True if simul_type == 3 else False  # If we fit variance given X_t\n",
    "            if simul_type == 1:\n",
    "                Data_dict = get_new_data_simple(\n",
    "                    num_pts=2000, alpha=0.9, beta=0.9)\n",
    "                data_name = 'simulation_state_space'\n",
    "            if simul_type == 2:\n",
    "                data_container = utils_latest.data_loader()\n",
    "                _, Data_dict = data_container.get_non_stationary_simulate()\n",
    "                Data_dict['X'] = torch.from_numpy(Data_dict['X']).float()\n",
    "                Data_dict['Y'] = torch.from_numpy(Data_dict['Y']).float()\n",
    "                data_name = 'simulate_nonstationary'\n",
    "            if simul_type == 3:\n",
    "                # NOTE: somehow for this case, currently RF quantile regression does not yield shorter interval. We may tune past window to get different results (like decrease it to 250) if need\n",
    "                Data_dict = get_new_data()\n",
    "                data_name = 'simulate_heteroskedastic'\n",
    "            X_full, Y_full = Data_dict['X'].to(\n",
    "                device), Data_dict['Y'].to(device)\n",
    "            B = 20\n",
    "            past_window = 500\n",
    "            fit_func = None  # It is MLP above\n",
    "        else:\n",
    "            data_name = 'solar'  # 'electric' or 'solar'\n",
    "            if data_name == 'solar':\n",
    "                # Get solar data WITH time t as covariate\n",
    "                dloader = utils_latest.data_loader()\n",
    "                Y_full, X_full_old, X_full_nonstat = dloader.get_non_stationary_real(\n",
    "                    univariate=False)\n",
    "                if non_stat_solar:\n",
    "                    X_full = X_full_nonstat\n",
    "                else:\n",
    "                    X_full = X_full_old\n",
    "                fit_func = RandomForestRegressor(n_estimators=10, criterion='mse',\n",
    "                                                  bootstrap=False, n_jobs=-1)\n",
    "                past_window = 500\n",
    "            if data_name == 'electric':\n",
    "                X_full, Y_full = electric_dataset()\n",
    "                fit_func = RandomForestRegressor(n_estimators=10, max_depth=1, criterion='mse',\n",
    "                                                  bootstrap=False, n_jobs=-1)\n",
    "                past_window = 300\n",
    "            Y_full, X_full = torch.from_numpy(Y_full).float().to(\n",
    "                device), torch.from_numpy(X_full).float().to(device)\n",
    "            fit_sigmaX = False\n",
    "            B = 25\n",
    "        alpha, itrial = 0.1, 0\n",
    "        N = int(X_full.shape[0]*train_frac)\n",
    "        X_train, X_predict, Y_train, Y_predict = X_full[:\n",
    "                                                        N], X_full[N:], Y_full[:N], Y_full[N:]\n",
    "\n",
    "        # Train\n",
    "        EnbPI = prediction_interval_with_SPCI(\n",
    "            X_train, X_predict, Y_train, Y_predict, fit_func=fit_func)\n",
    "        EnbPI.fit_bootstrap_models_online(B, fit_sigmaX=fit_sigmaX)\n",
    "        # Under cond quantile, we are ALREADY using the last window for prediction so smallT is True\n",
    "        smallT = not use_quantile_regr\n",
    "        EnbPI.compute_PIs_Ensemble_online(\n",
    "            alpha, smallT=smallT, past_window=past_window, use_quantile_regr=use_quantile_regr,\n",
    "            quantile_regr=quantile_regr)\n",
    "        results = EnbPI.get_results(alpha, data_name, itrial)\n",
    "        result_cov.append(results['coverage'].item())\n",
    "        result_width.append(results['width'].item())\n",
    "        # Lastly, compute rolling width to plot\n",
    "        PI = EnbPI.PIs_Ensemble\n",
    "        if use_quantile_regr:\n",
    "            PIs_SPCI = PI\n",
    "        else:\n",
    "            PIs_EnbPI = PI\n",
    "        Ytest = EnbPI.Y_predict.cpu().detach().numpy()\n",
    "        coverage = ((np.array(PI['lower']) <= Ytest)\n",
    "                    & (np.array(PI['upper']) >= Ytest))\n",
    "        width = ((np.array(PI['upper'])-np.array(PI['lower'])))\n",
    "        # cov_moving = rolling_avg(coverage)\n",
    "        # width_moving = rolling_avg(width)\n",
    "        dict_rolling[f'{name}{np.round(train_frac,2)}'] = np.vstack([\n",
    "            coverage, width])\n",
    "        if save_dict_rolling:\n",
    "            with open(f'EnbPI_rolling_{data_name}.p', 'wb') as fp:\n",
    "                pickle.dump(dict_rolling, fp,\n",
    "                            protocol=pickle.HIGHEST_PROTOCOL)\n",
    "        if simulation:\n",
    "            # # Examine recovery of F and Sigma\n",
    "            fig, ax = plt.subplots(2, 2, figsize=(12, 8))\n",
    "            ax[0, 0].plot(Data_dict['f(X)'])\n",
    "            ax[0, 1].plot(\n",
    "                EnbPI.Ensemble_pred_interval_centers.cpu().detach().numpy())\n",
    "            ax[1, 0].plot(Data_dict['Eps'])\n",
    "            ax[1, 1].plot(EnbPI.Ensemble_online_resid)\n",
    "            titles = [r'True $f(X)$', r'Est $f(X)$',\n",
    "                      r'True $\\epsilon$', r'Est $\\epsilon$']\n",
    "            fig.tight_layout()\n",
    "            for i, ax_i in enumerate(ax.flatten()):\n",
    "                ax_i.set_title(titles[i])\n",
    "            fig.tight_layout()\n",
    "            plt.show()\n",
    "            plt.close()\n",
    "    dict_full[name] = np.vstack([result_cov, result_width])"
   ],
   "metadata": {
    "id": "jNWExRaNvjAF",
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "execution_count": null,
   "outputs": []
  },
  {
   "cell_type": "markdown",
   "source": [
    "Due to variability, what you see for EnbPI may be different. However, in general EnbPI intervals are wider\n",
    "\n",
    "0.8 indicates that training fraction as a percentage of total data is 80\\% or 1600 observations"
   ],
   "metadata": {
    "id": "ZPWsYs6Dz8UT",
    "pycharm": {
     "name": "#%% md\n"
    }
   }
  },
  {
   "cell_type": "code",
   "source": [
    "dict_to_latex(dict_full)"
   ],
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "v6yJdKh8wWxY",
    "outputId": "163ad1de-9c1a-49a2-f965-0c910b84bfa5",
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "execution_count": 9,
   "outputs": [
    {
     "output_type": "stream",
     "name": "stdout",
     "text": [
      "                      0.8\n",
      "EnbPI coverage   0.877500\n",
      "EnbPI width     49.640250\n",
      "SPCI coverage    0.917500\n",
      "SPCI width      47.726013\n",
      "\\begin{tabular}{lr}\n",
      "\\toprule\n",
      "{} &    0.8 \\\\\n",
      "\\midrule\n",
      "EnbPI coverage &   0.88 \\\\\n",
      "EnbPI width    &  49.64 \\\\\n",
      "SPCI coverage  &   0.92 \\\\\n",
      "SPCI width     &  47.73 \\\\\n",
      "\\bottomrule\n",
      "\\end{tabular}\n",
      "\n"
     ]
    }
   ]
  },
  {
   "cell_type": "markdown",
   "source": [
    "## AdaptiveCI"
   ],
   "metadata": {
    "id": "gSawvfzevdfg",
    "pycharm": {
     "name": "#%% md\n"
    }
   }
  },
  {
   "cell_type": "code",
   "source": [
    "import PI_class_EnbPI\n",
    "!pip install skranger\n",
    "# Need for skranger to work properly. Sorry for the possibly avoidable complexity. We assumed one can \n",
    "# get away with this if skranger or scikit-garden is consistently used\n",
    "# May need to restart runtime\n",
    "!pip install scikit-learn==0.24\n",
    "from skranger.ensemble import RangerForestRegressor"
   ],
   "metadata": {
    "id": "jd5tmtpR2Nwm",
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "execution_count": null,
   "outputs": []
  },
  {
   "cell_type": "code",
   "source": [
    "# NOTE: the variance of this method seems high, and I often need to tune a LOT to avoid yielding very very high coverage.\n",
    "data_name = 'solar'\n",
    "dict_AdaptiveCI = {}\n",
    "dict_rolling_AdaptiveCI = {}\n",
    "cov_ls, width_ls = [], []\n",
    "for train_frac in train_ls:\n",
    "    # As it is split conformal, the result can be random, so we repeat over seed\n",
    "    seeds = [524, 1103, 1111, 1214, 1228]\n",
    "    cov_tmp_ls, width_tmp_ls = [], []\n",
    "    print('########################################')\n",
    "    print(f'Train frac at {train_frac} over {len(seeds)} seeds')\n",
    "    for seed in seeds:\n",
    "        dloader = utils_latest.data_loader()\n",
    "        Y_full, X_full_old, X_full_nonstat = dloader.get_non_stationary_real(\n",
    "            univariate=False)\n",
    "        if non_stat_solar:\n",
    "            X_full = X_full_nonstat\n",
    "        else:\n",
    "            X_full = X_full_old\n",
    "        N = int(X_full.shape[0]*train_frac)\n",
    "        X_train, X_predict, Y_train, Y_predict = X_full[:\n",
    "                                                        N], X_full[N:], Y_full[:N], Y_full[N:]\n",
    "        if non_stat_solar:\n",
    "            # More complex yields wider intervals and more conservative coverage\n",
    "            fit_func = RangerForestRegressor(\n",
    "                n_estimators=5, quantiles=True, seed=seed)\n",
    "        else:\n",
    "            fit_func = RangerForestRegressor(\n",
    "                n_estimators=10, quantiles=True, seed=seed)\n",
    "        PI_test_adaptive = PI_class_EnbPI.QOOB_or_adaptive_CI(\n",
    "            fit_func, X_train, X_predict, Y_train, Y_predict)\n",
    "        AdaptiveCI_result = PI_test_adaptive.compute_AdaptiveCI_intervals(\n",
    "            data_name, 0, l=int(0.75 * X_train.shape[0]),\n",
    "            alpha=alpha)\n",
    "        PIs_AdaptiveCI = PI_test_adaptive.PIs\n",
    "        Ytest = PI_test_adaptive.Y_predict\n",
    "        coverage = ((np.array(PIs_AdaptiveCI['lower']) <= Ytest)\n",
    "                    & (np.array(PIs_AdaptiveCI['upper']) >= Ytest))\n",
    "        width = (\n",
    "            (np.array(PIs_AdaptiveCI['upper'])-np.array(PIs_AdaptiveCI['lower'])))\n",
    "        cov_tmp_ls.append(coverage)\n",
    "        width_tmp_ls.append(width)\n",
    "    coverage = np.vstack(cov_tmp_ls).mean(axis=0)\n",
    "    width = np.vstack(width_tmp_ls).mean(axis=0)\n",
    "    PIs_AdaptiveCI = width  # for plot later\n",
    "    # cov_moving = rolling_avg(coverage)\n",
    "    # width_moving = rolling_avg(width)\n",
    "    dict_rolling_AdaptiveCI[f'placeholder{np.round(train_frac,2)}'] = np.vstack([\n",
    "        coverage, width])\n",
    "    if save_dict_rolling:\n",
    "        with open(f'AdaptiveCI_rolling_{data_name}.p', 'wb') as fp:\n",
    "            pickle.dump(dict_rolling_AdaptiveCI, fp,\n",
    "                        protocol=pickle.HIGHEST_PROTOCOL)\n",
    "    cov_ls.append(np.mean(coverage))\n",
    "    width_ls.append(np.mean(width))\n",
    "dict_AdaptiveCI['AdaptiveCI'] = np.vstack([cov_ls, width_ls])"
   ],
   "metadata": {
    "id": "8iQCRvFDvrYY",
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "execution_count": null,
   "outputs": []
  },
  {
   "cell_type": "code",
   "source": [
    "dict_to_latex(dict_AdaptiveCI)"
   ],
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "-PDVv1Gr2x48",
    "outputId": "bcbed9d1-e724-4722-982e-532435304867",
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "execution_count": 12,
   "outputs": [
    {
     "output_type": "stream",
     "name": "stdout",
     "text": [
      "                           0.8\n",
      "AdaptiveCI coverage   0.903500\n",
      "AdaptiveCI width     60.542017\n",
      "\\begin{tabular}{lr}\n",
      "\\toprule\n",
      "{} &    0.8 \\\\\n",
      "\\midrule\n",
      "AdaptiveCI coverage &   0.90 \\\\\n",
      "AdaptiveCI width    &  60.54 \\\\\n",
      "\\bottomrule\n",
      "\\end{tabular}\n",
      "\n"
     ]
    }
   ]
  },
  {
   "cell_type": "markdown",
   "source": [
    "## Nex-CP WLS"
   ],
   "metadata": {
    "id": "I5WGZbUkvdmG",
    "pycharm": {
     "name": "#%% md\n"
    }
   }
  },
  {
   "cell_type": "code",
   "source": [
    "cov, width = [], []\n",
    "dict_full = {}\n",
    "dict_rolling = {}\n",
    "data_name = 'solar'  # Eletric or solar\n",
    "if data_name == 'solar':\n",
    "    # Get solar data WITH time t as covariate\n",
    "    dloader = utils_latest.data_loader()\n",
    "    Y_full, X_full_old, X_full_nonstat = dloader.get_non_stationary_real(\n",
    "        univariate=False)\n",
    "    if non_stat_solar:\n",
    "        X_full = X_full_nonstat\n",
    "    else:\n",
    "        X_full = X_full_old\n",
    "if data_name == 'electric':\n",
    "    X_full, Y_full = electric_dataset()\n",
    "N = len(X_full)\n",
    "for train_frac in train_ls:\n",
    "    train_size = int(train_frac*N)\n",
    "    PI_nexCP_WLS = np.zeros((N, 2))\n",
    "    for n in np.arange(train_size, N):\n",
    "        # weights and tags (parameters for new methods)\n",
    "        rho = 0.99\n",
    "        rho_LS = 0.99\n",
    "        weights = rho**(np.arange(n, 0, -1))\n",
    "        tags = rho_LS**(np.arange(n, -1, -1))\n",
    "        PI_nexCP_WLS[n, :] = CP_LS(X_full[:n, :], Y_full[:n], X_full[n, :], alpha,\n",
    "                                    weights=weights, tags=tags)\n",
    "        inc = int((N-train_size)/20)\n",
    "        if (n-train_size) % inc == 0:\n",
    "            print(\n",
    "                f'NEX-CP WLS width at {n-train_size} is: {PI_nexCP_WLS[n,1] - PI_nexCP_WLS[n,0]}')\n",
    "    cov_nexCP_WLS = (PI_nexCP_WLS[train_size:, 0] <= Y_full[train_size:N]) *\\\n",
    "        (PI_nexCP_WLS[train_size:, 1] >= Y_full[train_size:N])\n",
    "    PI_width_nexCP_WLS = PI_nexCP_WLS[train_size:,\n",
    "                                      1]-PI_nexCP_WLS[train_size:, 0]\n",
    "    cov.append(np.mean(cov_nexCP_WLS))\n",
    "    width.append(np.mean(PI_width_nexCP_WLS))\n",
    "    print(\n",
    "        f'At {train_frac} tot data \\n cov: {cov[-1]} & width: {width[-1]}')\n",
    "    # Rolling coverage and width\n",
    "    # cov_moving = rolling_avg(cov_nexCP_WLS)\n",
    "    # width_moving = rolling_avg(PI_width_nexCP_WLS)\n",
    "    dict_rolling[f'placeholder{train_frac}'] = np.vstack(\n",
    "        [cov_nexCP_WLS, PI_width_nexCP_WLS])\n",
    "    if save_dict_rolling:\n",
    "        with open(f'NEXCP_rolling_{data_name}.p', 'wb') as fp:\n",
    "            pickle.dump(dict_rolling, fp, protocol=pickle.HIGHEST_PROTOCOL)\n",
    "dict_full = {'Nex-CP WLS': np.vstack([cov, width])}"
   ],
   "metadata": {
    "id": "5q7TzGQlvyo8",
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "execution_count": null,
   "outputs": []
  },
  {
   "cell_type": "code",
   "source": [
    "dict_to_latex(dict_full)"
   ],
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/"
    },
    "id": "KdJogtc3271d",
    "outputId": "e084f75e-386c-4c55-eed6-ac3e4c2592e4",
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "execution_count": 15,
   "outputs": [
    {
     "output_type": "stream",
     "name": "stdout",
     "text": [
      "                            0.8\n",
      "Nex-CP WLS coverage    0.897500\n",
      "Nex-CP WLS width     103.824461\n",
      "\\begin{tabular}{lr}\n",
      "\\toprule\n",
      "{} &     0.8 \\\\\n",
      "\\midrule\n",
      "Nex-CP WLS coverage &    0.90 \\\\\n",
      "Nex-CP WLS width    &  103.82 \\\\\n",
      "\\bottomrule\n",
      "\\end{tabular}\n",
      "\n"
     ]
    }
   ]
  },
  {
   "cell_type": "markdown",
   "source": [
    "# Visualization"
   ],
   "metadata": {
    "id": "3U6PIRbGvhZI",
    "pycharm": {
     "name": "#%% md\n"
    }
   }
  },
  {
   "cell_type": "markdown",
   "source": [
    "## Burn-in plot"
   ],
   "metadata": {
    "id": "9sdrgB6Dv6bP",
    "pycharm": {
     "name": "#%% md\n"
    }
   }
  },
  {
   "cell_type": "code",
   "source": [
    "import pickle5 as pickle"
   ],
   "metadata": {
    "id": "_73dOA8w8tyn",
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "execution_count": 43,
   "outputs": []
  },
  {
   "cell_type": "code",
   "source": [
    "with open(f'EnbPI_rolling_{data_name}.p', 'rb') as fp:\n",
    "    dict_rolling = pickle.load(fp)\n",
    "with open(f'NEXCP_rolling_{data_name}.p', 'rb') as fp:\n",
    "    NEXCP_dict_rolling = pickle.load(fp)\n",
    "with open(f'AdaptiveCI_rolling_{data_name}.p', 'rb') as fp:\n",
    "    AdaptiveCI_dict_rolling = pickle.load(fp)\n",
    "vanilla_cov_rolling, vanilla_width_rolling = dict_rolling['EnbPI0.8']\n",
    "predictive_cov_rolling, predictive_width_rolling = dict_rolling['SPCI0.8']\n",
    "NEXCP_cov_rolling, NEXCP_width_rolling = NEXCP_dict_rolling['placeholder0.8']\n",
    "AdaptiveCI_cov_rolling, AdaptiveCI_width_rolling = AdaptiveCI_dict_rolling[\n",
    "    'placeholder0.8']"
   ],
   "metadata": {
    "id": "9o9tVyPb6Uuw",
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "execution_count": 51,
   "outputs": []
  },
  {
   "cell_type": "code",
   "source": [
    "window_size = 100\n",
    "fig, ax = plt.subplots(figsize=(8, 5))\n",
    "first = vanilla_width_rolling[:window_size]\n",
    "ax.plot(first, label=f'EnbPI: {np.round(first.mean(),2)}', color='black')\n",
    "second = predictive_width_rolling[:window_size]\n",
    "ax.plot(second, label=f'SPCI: {np.round(second.mean(),2)}', color='orange')\n",
    "third = AdaptiveCI_width_rolling[:window_size]\n",
    "ax.plot(\n",
    "    third, label=f'AdaptiveCI: {np.round(third.mean(),2)}', color='gray', linewidth=0.75)\n",
    "fourth = NEXCP_width_rolling[:window_size]\n",
    "ax.plot(\n",
    "    fourth, label=f'Nex-CP WLS: {np.round(fourth.mean(),2)}', color='magenta')\n",
    "ax.set_xlabel('Burn-in Period')\n",
    "ax.set_ylabel('Width')\n",
    "ax.legend(title='Method: Ave Width in burn-in', title_fontsize=17,\n",
    "          loc='lower center', ncol=2, bbox_to_anchor=(0.5, -0.525))\n",
    "suffix = 'non_stat_' if non_stat_solar else ''\n",
    "plt.savefig(f'Brun_in_plot_{suffix}{data_name}.pdf', dpi=300,\n",
    "            bbox_inches='tight',\n",
    "            pad_inches=0)"
   ],
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 436
    },
    "id": "HTB7X3QdyZGi",
    "outputId": "615d67b4-f7d1-44af-9b74-b89d0814af25",
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "execution_count": 52,
   "outputs": [
    {
     "output_type": "display_data",
     "data": {
      "text/plain": [
       "<Figure size 576x360 with 1 Axes>"
      ],
      "image/png": "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w/2LFi0K1pXn6F7z5HI5+/zzz5sZhhF+9tlnAfn5+VWub2sI5OrVqwOkUilbtGhR6iOPPJJtug0bNix3586d/iUlJQQAo0ePLgwLCyvbtGmT/8aNG/19fX3Lp06dWuF3IZPJcNddd2X//vvvvgcPHqySGTE7O1tirl9N0YczLl26NESj0VTYpgHA29tb265du+L//e9/zQoKCqQDBgywaGoAgKioKHX79u2LtmzZEmAYVnjy5Em3w4cPVzE1eHh4aM0Nps7Mt99+G1RQUFDRr1u2bPG+evWq26hRoyp8LmJiYkoLCgqkf/75p7t+X25uruSHH36ol8RZU6ZMyTfcOnToYFYzJ2i8CE2CwKV48MEHcx588EGzjlh6/Pz8tP/3f/93c+7cuS3bt2/fcdq0aZlhYWHqpKQkhd5Z7ujRo5cBoG/fvoVEhI8++ig0IyNDplQqtRMmTMgPDw+3yRwB8NDCzz//PG/58uUhSUlJ8j59+hQePXrUc+vWrQHDhw/Pve+++/IAIDQ0tHzevHmp//nPf0IHDx7cZuLEidkJCQluP/74Y4DhbFHPrFmzWhw/flxVnfNiaWkp7dixw693794FetuvKZMmTcrZvn27/6ZNm3z0TmxTpkzJWrlyZbBcLmfTpk3LNE2Ks2zZsqQjR454jRkzpt29996b0aVLl+KCggJJXFyc+y+//OJ38uTJC23btq12wOjVq1ext7e35tSpU56hoaFlMTExRtEbvXv3Lli9enUzABg6dKhVjcW7776bNH369Nb9+vVr/+CDD6YXFxdLVq1a1SwmJqY4Pj7e3bBu586dC7dt2xbwyiuvhLRq1ao0JCSkfPLkybXWijQECoWC9evXr92MGTMy79y5I//666+bBQUFqRcuXFjhEPvYY49lLV68OOK+++6LmTt3bpparaZ169YFBgQElKempopcBAK7IzQJgkbJo48+mv3LL79catGiRclXX30V/O9//7v5xo0bAwICAsr/9a9/VTx0O3ToULZ48eJbaWlp8hdffDH6ySefbHnq1Cn36s5tikQiwc8//5wwb9681NjYWK833ngj8ujRo15PP/106s6dO68a1l26dGnyggULkq5du+a2aNGiyL///ttz8+bNV2ob/rh582bvnJwc2V133WVRcLrnnnty5XI5W7t2bcVs86GHHsrSaDRUUlIimTNnTpUw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\n"
     },
     "metadata": {
      "needs_background": "light"
     }
    }
   ]
  },
  {
   "cell_type": "markdown",
   "source": [
    "## Rolling cov and width after burn-in"
   ],
   "metadata": {
    "id": "swTYh0rwv-Me",
    "pycharm": {
     "name": "#%% md\n"
    }
   }
  },
  {
   "cell_type": "code",
   "source": [
    "dsets = ['solar']\n",
    "methods = ['NEXCP+AdaptiveCI']\n",
    "for data_name in dsets:\n",
    "    for compete in methods:\n",
    "        if data_name == 'electric' and compete == 'AdaptiveCI':\n",
    "            continue\n",
    "        print(f'EnbPI vs. {compete} on {data_name}')\n",
    "        if data_name == 'solar':\n",
    "            # Get solar data WITH time t as covariate\n",
    "            dloader = utils_latest.data_loader()\n",
    "            Y_full, X_full_old, X_full_nonstat = dloader.get_non_stationary_real(\n",
    "                univariate=False)\n",
    "            if non_stat_solar:\n",
    "                X_full = X_full_nonstat\n",
    "            else:\n",
    "                X_full = X_full_old\n",
    "        vanilla_cov_rolling, vanilla_width_rolling = rolling_avg(\n",
    "            vanilla_cov_rolling, window_size), rolling_avg(vanilla_width_rolling, window_size)\n",
    "        predictive_cov_rolling, predictive_width_rolling = rolling_avg(\n",
    "            predictive_cov_rolling, window_size), rolling_avg(predictive_width_rolling, window_size)\n",
    "        NEXCP_cov_rolling, NEXCP_width_rolling = rolling_avg(\n",
    "            NEXCP_cov_rolling, window_size), rolling_avg(NEXCP_width_rolling, window_size)\n",
    "        AdaptiveCI_cov_rolling, AdaptiveCI_width_rolling = rolling_avg(\n",
    "            AdaptiveCI_cov_rolling, window_size), rolling_avg(AdaptiveCI_width_rolling, window_size)\n",
    "        N = len(Y_full)\n",
    "        N0 = int(0.8*len(X_full))\n",
    "        fig, ax = plt.subplots(1, 2, figsize=(15, 4), sharex=True)\n",
    "        ax[0].axhline(y=1-alpha, linestyle='--', color='gray')\n",
    "        xaxis = np.arange(N0+window_size, N)\n",
    "        ax[0].plot(xaxis, vanilla_cov_rolling,\n",
    "                    color='black', label='EnbPI')\n",
    "        color_tmp = 'orange'\n",
    "        ax[0].plot(xaxis, predictive_cov_rolling,\n",
    "                    color=color_tmp, label='SPCI')\n",
    "        ax[0].plot(xaxis, AdaptiveCI_cov_rolling,\n",
    "                    color='gray', label='AdaptiveCI')\n",
    "        ax[0].plot(xaxis, NEXCP_cov_rolling,\n",
    "                    color='magenta', label='Nex-CP WLS')\n",
    "        ax[0].set_xlabel('Data index')\n",
    "        ax[1].plot(xaxis, AdaptiveCI_width_rolling, color='gray')\n",
    "        ax[1].plot(xaxis, NEXCP_width_rolling, color='magenta')\n",
    "        ax[0].set_ylim([1-4*alpha, 1])\n",
    "        ax[0].set_ylabel('Rolling coverage')\n",
    "        ax[0].legend(ncol=2, loc='lower center')\n",
    "        ax[1].plot(xaxis, vanilla_width_rolling, color='black')\n",
    "        ax[1].plot(xaxis, predictive_width_rolling, color=color_tmp)\n",
    "        ax[1].set_ylabel('Rolling width')\n",
    "        ax[1].set_xlabel('Data index')\n",
    "        fig.tight_layout()\n",
    "        plt.savefig(f'Rolling_comparison_{compete}_{data_name}.pdf', dpi=300,\n",
    "                    bbox_inches='tight',\n",
    "                    pad_inches=0)\n",
    "        plt.show()\n",
    "        plt.close()"
   ],
   "metadata": {
    "colab": {
     "base_uri": "https://localhost:8080/",
     "height": 332
    },
    "id": "86Gvw_IFyh_W",
    "outputId": "2f676f49-8998-46e5-b3e3-673ae396e36c",
    "pycharm": {
     "name": "#%%\n"
    }
   },
   "execution_count": 53,
   "outputs": [
    {
     "output_type": "stream",
     "name": "stdout",
     "text": [
      "EnbPI vs. NEXCP+AdaptiveCI on solar\n",
      "(8760, 8)\n"
     ]
    },
    {
     "output_type": "display_data",
     "data": {
      "text/plain": [
       "<Figure size 1080x288 with 2 Axes>"
      ],
      "image/png": "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\n"
     },
     "metadata": {
      "needs_background": "light"
     }
    }
   ]
  }
 ]
}