{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "aa191fb7",
   "metadata": {},
   "source": [
    "# Runner"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "b179eaaa",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "\n",
    "lam_list = np.linspace(0.01, 1, 100)\n",
    "alpha = 0.05"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "656eddfc",
   "metadata": {},
   "outputs": [],
   "source": [
    "from model.v1.predictor import OffsetScalarPredictor\n",
    "from scipy.stats import norm\n",
    "import numpy as np\n",
    "from scipy.stats import multivariate_normal\n",
    "from utils.setting import config\n",
    "\n",
    "# Baslines methods (Conformal + Quantile + Gaussian)\n",
    "class MiscoverageToLam:\n",
    "    def __init__(self, x, y, model : OffsetScalarPredictor):\n",
    "        '''\n",
    "        Args:\n",
    "        - x:    [ nbatch, nX ] np\n",
    "        - y:    [ nbatch, nY ] np\n",
    "        '''\n",
    "        ypred       = model.pred(x, y.shape[1]) # [ nbatch, nY ]\n",
    "        self.diff   = y - ypred                 # [ nbatch, nY ] np      \n",
    "        score       = np.linalg.norm(self.diff, ord=np.inf, axis=1)     # [ nbatch ]\n",
    "        self.score  = score\n",
    "\n",
    "    def get_conformal_lam(self, alpha):\n",
    "        '''\n",
    "        Args:\n",
    "        - alpha:    scalar, the desired miscoverage rate\n",
    "        '''\n",
    "        n = len(self.score)\n",
    "        lam = np.quantile(self.score, np.clip(np.ceil((n + 1) * (1-alpha)) / n, a_max=1., a_min=0.))\n",
    "        return lam # scalar\n",
    "    \n",
    "    def get_quantile_lam(self, alpha):\n",
    "        lam = np.quantile(self.score, 1 - alpha)\n",
    "        return lam # scalar\n",
    "    \n",
    "    def get_gaussian_lam(self, alpha):\n",
    "        '''This is probably not equivalent to assuming Y as Gaussian?'''\n",
    "        # Estimate parameters\n",
    "        mu      = self.diff.mean(axis=0)                # mean vector, shape [nY]\n",
    "        cov     = np.cov(self.diff, rowvar=False)       # covariance matrix, shape [nY, nY]\n",
    "        dist    = multivariate_normal(mean=mu, cov=cov + 1e-5 * np.diag(np.ones_like(mu)))\n",
    "        # samples = dist.rvs(10**len(mu))                     # [ nsample, nY ]\n",
    "        samples = dist.rvs(1000)                     # [ nsample, nY ]\n",
    "        samples = samples.reshape(-1, 1) if len(samples.shape) == 1 else samples\n",
    "        score = np.linalg.norm(samples, ord=np.inf, axis=1) # [ nsample ] \n",
    "        lam = np.quantile(score, 1 - alpha)    # scalar\n",
    "        return lam"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "11e19420",
   "metadata": {},
   "outputs": [],
   "source": [
    "from model.v1.sampler import Sampler\n",
    "import numpy as np\n",
    "from model.v1.crc import ConformalRegretControl\n",
    "from utils.setting import config\n",
    "import matplotlib.pyplot as plt\n",
    "from tqdm import tqdm\n",
    "\n",
    "\n",
    "def validity(R_est, R_true, I_est, I_true):\n",
    "    '''\n",
    "    all [ nbatch ] np -> scalar\n",
    "    '''\n",
    "    mask1 = R_est >= R_true\n",
    "    mask2 = I_est >= I_true\n",
    "    mask  = np.logical_and(mask1, mask2)\n",
    "    return mask.mean() \n",
    "\n",
    "def accuracy(R_est, R_true, I_est, I_true):\n",
    "    '''\n",
    "    all [ nbatch ] np -> scalar\n",
    "    '''\n",
    "    mask1 = np.abs(R_est - R_true)\n",
    "    mask2 = np.abs(I_est - I_true)\n",
    "    mask  = mask1 + mask2\n",
    "    return - mask.mean() \n",
    "\n",
    "def exp_2_runner_1(crc : ConformalRegretControl, mean, sigma, nsample, ntrials = 10, verbose = True,\n",
    "                   B = 1,\n",
    "                   width = None, use_gaussian = False   # 9/30 update\n",
    "                   ):\n",
    "    # True Pareto frontier\n",
    "    # config()\n",
    "    true_list = []\n",
    "    x = Sampler().uniform(mean, sigma, 100) if not use_gaussian else Sampler().gaussian(mean, width, sigma, 100)\n",
    "    y = Sampler().uniform(mean, sigma, 100) if not use_gaussian else Sampler().gaussian(mean, width, sigma, 100) # [ nsample, 2 ]\n",
    "    pbar = tqdm(total = len(lam_list), desc = 'True') if verbose else None\n",
    "    for lam in lam_list:\n",
    "        pbar.update(1) if verbose else None\n",
    "        _, _, alpha_R_true, alpha_I_true = crc.estimate(x, y, lam=lam, B=B, also_mc=True)   # all scalars\n",
    "        true_list.append(np.array([alpha_R_true, alpha_I_true]))\n",
    "    true_list = np.stack(true_list, axis=0)             # [ nlams, 2 ]\n",
    "    true_list = true_list.reshape(len(lam_list), -1)    # [ nlams, 2 ]\n",
    "\n",
    "    # CREME estimate and the associated baselines\n",
    "    estimate_list = []\n",
    "    baseline_list = []\n",
    "    posthoc_list  = []\n",
    "\n",
    "    pbar = tqdm(total = ntrials * len(lam_list), desc = 'Estimate') if verbose else None\n",
    "    for i in range(ntrials):\n",
    "\n",
    "        x = Sampler().uniform(mean, sigma, nsample) if not use_gaussian else Sampler().gaussian(mean, width, sigma, nsample)\n",
    "        y = Sampler().uniform(mean, sigma, nsample) if not use_gaussian else Sampler().gaussian(mean, width, sigma, nsample) # [ nsample, 2 ]\n",
    "\n",
    "        model       = crc.optimzation.model\n",
    "        baselines   = MiscoverageToLam(x, y, model)\n",
    "\n",
    "        lam_cp  = baselines.get_conformal_lam(alpha)\n",
    "        lam_q   = baselines.get_quantile_lam(alpha)\n",
    "        lam_g   = baselines.get_gaussian_lam(alpha)\n",
    "        baseline_list.append(np.array([lam_g, lam_q, lam_cp]))\n",
    "\n",
    "        # normal estimte (not-post hoc valid)\n",
    "        for lam in lam_list:\n",
    "            pbar.update(1) if verbose else None\n",
    "            alpha_R, alpha_I, alpha_R_mc, alpha_I_mc = crc.estimate(x, y, lam=lam, B=B, also_mc=True)   # all scalars\n",
    "            estimate_list.append(np.array([alpha_R, alpha_I, alpha_R_mc, alpha_I_mc]))\n",
    "\n",
    "        # NOTE: post-hoc estimate\n",
    "        indices = np.random.choice(np.arange(x.shape[0]), size=x.shape[0]//2, replace=False)\n",
    "        x1 = x.copy()[indices, :] # post-hoc valid split\n",
    "        y1 = y.copy()[indices, :]\n",
    "        for lam in lam_list:\n",
    "            # pbar.update(1) if verbose else None\n",
    "            alpha_R, alpha_I, alpha_R_mc, alpha_I_mc = crc.estimate(x1, y1, lam=lam, B=B, also_mc=True)   # all scalars\n",
    "            posthoc_list.append(np.array([alpha_R, alpha_I, alpha_R_mc, alpha_I_mc]))\n",
    "\n",
    "    def pack_list(input_list):\n",
    "        output_list = np.stack(input_list, axis=0)                      # [ ntrials * nlams, 4 ]\n",
    "        output_list = output_list.reshape(ntrials, len(lam_list), -1)   # [ ntrials, nlams, 4 ]\n",
    "        output_list = output_list.mean(0)   # [ nlams, 4 ] NOTE: multi-shot estimator\n",
    "        output_list = output_list[:, :2]    \n",
    "        return output_list                  # [ nlams, 2 ], remove Monte Carlo columns\n",
    "\n",
    "    # Pack list into arr\n",
    "    estimate_list = pack_list(estimate_list)\n",
    "    posthoc_list  = pack_list(posthoc_list)\n",
    "    baseline_list = np.stack(baseline_list, axis=0) # [ ntrial, 3 ] np\n",
    "    baseline_list = baseline_list.mean(0)   # [ 3 ] np\n",
    "\n",
    "    # both [ nlams, 2 ] NOTE: multi-shot estimator unless ntrails=1\n",
    "    # return true_list, estimate_list, baseline_list                  \n",
    "    return np.concatenate([\n",
    "                true_list,     # [ nlams, 2 ]\n",
    "                estimate_list, # [ nlams, 2 ]\n",
    "                baseline_list[None, :] * np.ones([len(true_list), 3]),\n",
    "                posthoc_list    # [ nlams, 2 ]\n",
    "            ], axis=1) # [ nalams, 2+2+3+2 ]\n",
    "\n",
    "def exp_2_plotter(ax, arr, add_label = True, s = 100, add_dots = True, w = np.array([-1., -1.])):\n",
    "\n",
    "    config()\n",
    "\n",
    "    true_list = arr[:, [0, 1]]\n",
    "    estimate_list = arr[:, [2, 3]]\n",
    "    baseline_list = arr[0, [4, 5, 6]]\n",
    "    posthoc_list = arr[:, [7, 8]]\n",
    "\n",
    "    # coord_list = [true_list, estimate_list][::-1]\n",
    "    # color_list = ['black', 'red'][::-1]\n",
    "    # label_list = [r'True Pareto frontier $(\\alpha_I(\\lambda), \\alpha_R(\\lambda))$',\n",
    "    #               r'Estimated Pareto frontier $(\\hat \\alpha_I(\\lambda), \\hat \\alpha_R(\\lambda))$ via \\texttt{CREME}'][::-1]\n",
    "    \n",
    "    coord_list = [true_list, estimate_list, posthoc_list][::-1]\n",
    "    color_list = ['black', 'red', 'green'][::-1]\n",
    "    label_list = [r'True Pareto Frontier',\n",
    "                r'Certified Frontier',\n",
    "                r'Post-hoc Certified Frontier'][::-1]\n",
    "    \n",
    "    coord_list = np.array(coord_list)[[1, 0, 2]]\n",
    "    color_list = np.array(color_list)[[1, 0, 2]]\n",
    "    label_list = np.array(label_list)[[1, 0, 2]]\n",
    "\n",
    "    baseline_names  = ['Parametric quantile', 'Empirical quantile', 'Conformal prediction']\n",
    "    marker_list     = ['1', '2', '3']\n",
    "\n",
    "    # Plotting the true AND Pareto frontier AND post-hoc frontiers\n",
    "    for i in range(len(coord_list)):\n",
    "        ax.plot(coord_list[i][:, 1], coord_list[i][:, 0],\n",
    "                color = color_list[i],\n",
    "                label = label_list[i] if add_label else None)\n",
    "    ylow, ylim    = ax.get_ylim()\n",
    "    for i in range(len(coord_list)):\n",
    "        ax.fill_between(coord_list[i][:, 1],\n",
    "                        coord_list[i][:, 0],\n",
    "                        ylim,\n",
    "                        color = color_list[i],\n",
    "                        alpha = 0.1,\n",
    "                        lw = 0)\n",
    "    \n",
    "    # Plotting the baselines\n",
    "    mat     = np.abs(baseline_list[None, :] - lam_list[:, None])    # [ nlam, 3 ]\n",
    "    index   = mat.argmin(0) # [ 3 ]\n",
    "    baseline_color = 'tab:blue'\n",
    "    for i in range(3):\n",
    "        ax.scatter(true_list[index[i], 1], true_list[index[i], 0],\n",
    "                   s = s + 80,\n",
    "                   marker = marker_list[i],\n",
    "                   color = baseline_color,\n",
    "                   label = baseline_names[i] if add_label else None, zorder = 98)\n",
    "        \n",
    "    # plot conservativeness\n",
    "    # ax.axvline(alpha, ls = '--', color = baseline_color)\n",
    "    ax.plot(\n",
    "        [alpha, alpha],\n",
    "        [ylow, ylim],\n",
    "        ls = '--', color = baseline_color)\n",
    "    ax.fill_between(\n",
    "        [0, alpha],\n",
    "        [ylow, ylow],\n",
    "        [ylim, ylim],\n",
    "        alpha = 0.1,\n",
    "        color = baseline_color\n",
    "    )\n",
    "    \n",
    "    # Add dot for selected optimal point\n",
    "    if add_dots:\n",
    "        # NOTE: ------- post-hoc estimate --------\n",
    "        y = np.inner(w.reshape(1, 2), estimate_list)    # [ 1, num_lam ] np\n",
    "        # y = np.inner(w.reshape(1, 2), posthoc_list)    # [ 1, num_lam ] np\n",
    "        index = y.argmax(1).item()\n",
    "        ax.scatter(true_list[index, 1], true_list[index, 0], s = s / 3, color = color_list[0], zorder = 99)\n",
    "        ax.scatter(posthoc_list[index, 1], posthoc_list[index, 0], s = s / 3, edgecolor = color_list[0], zorder = 99, facecolor='none') # NOTE: NEW\n",
    "        ax.plot(\n",
    "            [true_list[index, 1], posthoc_list[index, 1]],\n",
    "            [true_list[index, 0], posthoc_list[index, 0]],\n",
    "            color = color_list[0], ls = 'dotted', lw = 2\n",
    "        )\n",
    "        # ------- estimate --------\n",
    "        y = np.inner(w.reshape(1, 2), estimate_list)    # [ 1, num_lam ] np\n",
    "        index = y.argmax(1).item()\n",
    "        ax.scatter(true_list[index, 1], true_list[index, 0], s = s / 3, color = color_list[1], zorder = 99)\n",
    "        ax.scatter(estimate_list[index, 1], estimate_list[index, 0], s = s / 3, edgecolor = color_list[1], zorder = 99, facecolor='none') # NOTE: NEW\n",
    "        # ax.scatter(estimate_list[index, 1], estimate_list[index, 0], s = s / 2, edgecolor = color_list[0], facecolor = 'none')\n",
    "        ax.plot(\n",
    "            [true_list[index, 1], estimate_list[index, 1]],\n",
    "            [true_list[index, 0], estimate_list[index, 0]],\n",
    "            color = color_list[1], ls = 'dotted', lw = 2\n",
    "        )\n",
    "        # ------- true --------\n",
    "        y = np.inner(w.reshape(1, 2), true_list)    # [ 1, num_lam ] np\n",
    "        index = y.argmax(1).item()\n",
    "        ax.scatter(true_list[index, 1], true_list[index, 0], s = s + 80, color = color_list[2], marker = '*')\n",
    "\n",
    "    return ax"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "cb9f114a",
   "metadata": {},
   "source": [
    "# Exp"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "7c339911",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "from model.v1.predictor import OffsetScalarPredictor\n",
    "from model.v1.crc import ConformalRegretControl\n",
    "from model.v1.newsvendor import Newsvendor\n",
    "from model.v1.lp import LinearProgramming, circle_as_polytope\n",
    "from model.v1.shortest_path import ShortestPath, build_incidence_many_chains\n",
    "from model.v1.portfolio import PortfolioOptimization"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "6288e681",
   "metadata": {},
   "source": [
    "## Linear Programming"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "fa93a09c",
   "metadata": {},
   "outputs": [],
   "source": [
    "mean    = [-1.1, -1.]\n",
    "sigma   = [1., 1.]\n",
    "\n",
    "model_kwds = {'offset': mean}\n",
    "model = OffsetScalarPredictor(**model_kwds)\n",
    "A, b = circle_as_polytope(R=1.0, m=32)\n",
    "A_pos = np.array([\n",
    "    [-1., 0.],\n",
    "    [0., -1.]\n",
    "])\n",
    "b_pos = np.array([0., 0.])\n",
    "A, b = np.concatenate([A, A_pos]), np.concatenate([b, b_pos])\n",
    "\n",
    "opt_kwds = {\n",
    "    'model':    model,\n",
    "    'feasible_region':  None,    # [ nres**2, 2 ]\n",
    "    'outcome_space':    None,    # [ nres**2, 2 ]\n",
    "    'A':    A,\n",
    "    'b':    b,\n",
    "}\n",
    "optimization = LinearProgramming(**opt_kwds)\n",
    "\n",
    "crc_kwds = {'optimization': optimization}\n",
    "crc = ConformalRegretControl(**crc_kwds)\n",
    "\n",
    "path = 'cache/1_28/result_list_lp.npy'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "b6f8cab1",
   "metadata": {},
   "outputs": [],
   "source": [
    "# import os\n",
    "\n",
    "# config()\n",
    "\n",
    "# exp_kwds = {\n",
    "#     'crc':      crc,\n",
    "#     'mean':     mean,\n",
    "#     'sigma':    sigma,\n",
    "#     'ntrials':  1,\n",
    "#     'nsample':  10,\n",
    "#     'verbose':  True,\n",
    "#     'B':        0.8,\n",
    "#     'width':    None,\n",
    "#     'use_gaussian': False\n",
    "# }\n",
    "# path = 'cache/1_28/result_list_lp.npy'\n",
    "\n",
    "# if os.path.exists(path) and False:\n",
    "#     pass\n",
    "# else:\n",
    "#     result_list = exp_2_runner_1(**exp_kwds)\n",
    "#     np.save(path, result_list)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "35489a2f",
   "metadata": {},
   "outputs": [],
   "source": [
    "# plt.figure(figsize=[4, 3])\n",
    "\n",
    "# arr = np.load(path)\n",
    "# ax = exp_2_plotter(plt.gca(), arr, w = np.array([-1., -0.8]))\n",
    "# plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "24d0375b",
   "metadata": {},
   "source": [
    "## Newsvendor"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "80dc00a2",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Newsvendor model\n",
    "mean    = 2\n",
    "sigma   = 1 \n",
    "\n",
    "model_kwds = {'offset': [mean]} # unbiased if set to \"mean\"\n",
    "model = OffsetScalarPredictor(**model_kwds)\n",
    "\n",
    "opt_kwds = {\n",
    "    'model':    model,\n",
    "    'p':        3,\n",
    "    'v':        0,\n",
    "    'c':        2\n",
    "}\n",
    "optimization = Newsvendor(**opt_kwds)\n",
    "crc_kwds = {'optimization': optimization}\n",
    "crc = ConformalRegretControl(**crc_kwds)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "ef7aec53",
   "metadata": {},
   "outputs": [],
   "source": [
    "# import os\n",
    "\n",
    "# config(2) # 2\n",
    "\n",
    "# exp_kwds = {\n",
    "#     'crc':      crc,\n",
    "#     'mean':     mean,\n",
    "#     'sigma':    sigma,\n",
    "#     'ntrials':  1,\n",
    "#     'nsample':  10,\n",
    "#     'verbose':  False,\n",
    "#     'B':        1.5,\n",
    "#     'width':    None,\n",
    "#     'use_gaussian': False\n",
    "# }\n",
    "# path = 'cache/1_28/result_list_nv.npy'\n",
    "\n",
    "# if os.path.exists(path) and False:\n",
    "#     pass\n",
    "# else:\n",
    "#     result_list = exp_2_runner_1(**exp_kwds)\n",
    "#     np.save(path, result_list)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "770e92e5",
   "metadata": {},
   "outputs": [],
   "source": [
    "# plt.figure(figsize=[4, 3])\n",
    "\n",
    "# arr = np.load(path)\n",
    "# ax = exp_2_plotter(plt.gca(), arr, w = np.array([-1., -0.5]))\n",
    "# plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "6cf8bb8a",
   "metadata": {},
   "source": [
    "## Portfolio"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "c897c466",
   "metadata": {},
   "outputs": [],
   "source": [
    "mean    = [2., 2.]\n",
    "sigma   = [1., 1.]\n",
    "nsample = 10\n",
    "\n",
    "model_kwds = {'offset': mean}   # unbiased if set to \"mean\"\n",
    "model = OffsetScalarPredictor(**model_kwds)\n",
    "\n",
    "opt_kwds = {\n",
    "    'model':    model,\n",
    "    'feasible_region':  None,    # [ nres**2, 2 ]\n",
    "    'outcome_space':    None,    # [ nres**2, 2 ]\n",
    "    'gamma':    1.,\n",
    "    'alpha':    0.95,\n",
    "    'nsample':  nsample,\n",
    "    'ndim':     2\n",
    "}\n",
    "opt = PortfolioOptimization(**opt_kwds)\n",
    "crc_kwds = {'optimization': opt}\n",
    "crc = ConformalRegretControl(**crc_kwds)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "f27fb318",
   "metadata": {},
   "outputs": [],
   "source": [
    "# import os\n",
    "\n",
    "# config()\n",
    "\n",
    "# exp_kwds = {\n",
    "#     'crc':      crc,\n",
    "#     'mean':     mean,\n",
    "#     'sigma':    sigma,\n",
    "#     'ntrials':  1,\n",
    "#     'nsample':  10,\n",
    "#     'verbose':  True,\n",
    "#     # 'B':        1.2,\n",
    "#     'B':        3,\n",
    "#     'width':    None,\n",
    "#     'use_gaussian': False\n",
    "# }\n",
    "# path = 'cache/1_28/result_list_pf.npy'\n",
    "\n",
    "# if os.path.exists(path) and False:\n",
    "#     pass\n",
    "# else:\n",
    "#     result_list = exp_2_runner_1(**exp_kwds)\n",
    "#     np.save(path, result_list)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "42aaec32",
   "metadata": {},
   "outputs": [],
   "source": [
    "# plt.figure(figsize=[4, 3])\n",
    "\n",
    "# arr = np.load(path)\n",
    "# ax = exp_2_plotter(plt.gca(), arr, w = np.array([-1., -0.5]))\n",
    "# plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "71bf6c31",
   "metadata": {},
   "source": [
    "## Shortest Path"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "40783618",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "\n",
    "nchains = 5\n",
    "arr     = np.array([ (11 - (2.**(-np.arange(j + 1))).sum()) / (j + 1) for j in range(nchains)])\n",
    "mean    = np.repeat(arr, np.arange(len(arr)) + 1)       # [ nedge ] np\n",
    "width   = np.ones_like(mean) \n",
    "sigma   = np.ones_like(mean) * 0.2                            # [ nedge ] np\n",
    "\n",
    "model_kwds = {\n",
    "    'offset': np.array(mean)  # unbiased if set to \"mean\"\n",
    "}\n",
    "model = OffsetScalarPredictor(**model_kwds)\n",
    "\n",
    "A, b = build_incidence_many_chains(nchains)  # [ nnode, nedge ] and [ nnode ], both np\n",
    "opt_kwds = {\n",
    "    'model':    model,\n",
    "    'feasible_region':  None,    # [ nres**2, 2 ] or None\n",
    "    'outcome_space':    None,    # [ nres**2, 2 ] or None\n",
    "    'A':    A,\n",
    "    'b':    b,\n",
    "    'width':    width\n",
    "}\n",
    "opt = ShortestPath(**opt_kwds)\n",
    "crc_kwds = {'optimization': opt}\n",
    "crc = ConformalRegretControl(**crc_kwds)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "90e11e38",
   "metadata": {},
   "outputs": [],
   "source": [
    "# import os\n",
    "\n",
    "# config(1)\n",
    "\n",
    "# exp_kwds = {\n",
    "#     'crc':      crc,\n",
    "#     'mean':     mean,\n",
    "#     'sigma':    sigma,\n",
    "#     'ntrials':  1,\n",
    "#     # 'nsample':  10,\n",
    "#     'nsample':  10,\n",
    "#     'verbose':  True,\n",
    "#     'B':        1.2,\n",
    "#     'width':    width,\n",
    "#     'use_gaussian': True\n",
    "# }\n",
    "# path = 'cache/1_28/result_list_sp.npy'\n",
    "\n",
    "# if os.path.exists(path) and False:\n",
    "#     pass\n",
    "# else:\n",
    "#     result_list = exp_2_runner_1(**exp_kwds)\n",
    "#     np.save(path, result_list)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "b9c0f4ac",
   "metadata": {},
   "outputs": [],
   "source": [
    "# plt.figure(figsize=[4, 3])\n",
    "\n",
    "# arr = np.load(path)\n",
    "# ax = exp_2_plotter(plt.gca(), arr, w = np.array([-1., -0.8]))\n",
    "# plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "2dd9ef46",
   "metadata": {},
   "source": [
    "# Fig"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "d63e17ac",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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UQNK8OcFZ+PM4f1i6mtcGuxyzqSh+GLf4axNIBOlwz0/HgfL1oPY0dCCJWudGTtQLFFPx59viIiIiIiIslBtbS3sdjsMBkPIQXcp8eZMHhr3YJWnDuyNOZOHJrhEqSP1Y2q32wP6Cc12bEuZTVVSiP++fAIA4MnVO/DNoaNpLhGF01PjBAHszoKIiIiIqIdidxZERNQTCCHw0+c+Rf23TXhs/tlZ/WMMUWfZkv9kdxZERERERERERJSxFAoFaq6eBCE6upUhotRjEpmIiIiIiIiIiDIa+xInSq+sSCJncI8bREREREQZ63eXnYFFFacjT6lId1GIiIiIKIhsyXtm9MB6BQUFAIDW1tY0l4SIiIiIKPsU5ClRXJCHgryM/thPRERElLOkvKeUB81UGX0lcl5eHlQqFRoaGgAAJSUlUCh4FQURERERERERERFlLyEEWltb0dDQAJVKhby8vHQXKSyFyPBrpoUQOHDgAFwuV7qLQkRERERERERERJQwKpUKp5xySsZfOJvxSWSJ1+uF2+1OdzGIiIiIiIiIiIiIuq2goCDjr0CWZE0SmYiIiIiIiIiIiIhSjyNsEBEREREREREREVFITCITERERERERERERUUhMIhMRERERERERERFRSEwiExEREREREREREVFITCITERERERERERERUUhMIhMRERERERERERFRSEwiExEREREREREREVFI/x8q3cCMzPyy3AAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 1440x300 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "scale = 1.2\n",
    "fig, axes = plt.subplots(1, 4, figsize = [4 * 3 * scale, 2.5 * scale])\n",
    "\n",
    "# config(fontsize=12)\n",
    "config(fontsize=12)\n",
    "\n",
    "paths = ['cache/1_28/result_list_lp.npy', 'cache/1_28/result_list_nv.npy', 'cache/1_28/result_list_pf.npy', 'cache/1_28/result_list_sp.npy']\n",
    "title_names = [ 'Linear Programming', 'Newsvendor', 'Portfolio Selection', 'Shortest Path']\n",
    "w_list = [np.array([-1., -0.8]), np.array([-1., -0.5]), np.array([-1., -0.5]), np.array([-1., -0.8])]\n",
    "\n",
    "\n",
    "for i in range(len(paths)):\n",
    "    arr = np.load(paths[i])\n",
    "    config()\n",
    "    exp_2_plotter(axes[i], arr,\n",
    "                  add_label = True if i==0 else False,\n",
    "                  add_dots = True,\n",
    "                  w = w_list[i], s = 150)\n",
    "    axes[i].set_title(title_names[i])\n",
    "    # axes[i].grid()\n",
    "    # axes[i].set_xlim(None, 1)\n",
    "    axes[i].set_ylabel('Regret')\n",
    "    axes[i].set_xlabel('Miscoverage')\n",
    "    axes[i].grid()\n",
    "plt.tight_layout()\n",
    "fig.legend(loc='lower center', ncols = 6, bbox_to_anchor = [0.5, -0.1])\n",
    "plt.savefig('fig/exp2.pdf', bbox_inches = 'tight')\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "base",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.12.3"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
