{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "2ed62c06",
   "metadata": {},
   "source": [
    "# Synthetic experiment: validity \\& accuracy tradeoff"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0bbb119c",
   "metadata": {},
   "source": [
    "# Runner"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "a1fbee9f",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "\n",
    "ntrial = 20\n",
    "lam_list = np.linspace(0.01, 1, 10)\n",
    "nsample_list = np.arange(50)[::5] + 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "1d618de2",
   "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",
    "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",
    "\n",
    "def runner(crc, mean, sigma,\n",
    "           ntrial = 10,\n",
    "           lam_list = np.linspace(0.01, 1, 10),\n",
    "           nsample_list = [10, 20, 30, 40, 50],\n",
    "           verbose=True, B=1,\n",
    "           width=None, use_gaussian=False):\n",
    "    \n",
    "    # ground-truth\n",
    "    x = Sampler().uniform(mean, sigma, 100) if not use_gaussian else Sampler().gaussian(mean, width, sigma, 100) # [ nsample, data_dim ]\n",
    "    y = Sampler().uniform(mean, sigma, 100) if not use_gaussian else Sampler().gaussian(mean, width, sigma, 100) # [ nsample, data_dim ]\n",
    "    true_list = []\n",
    "    for lam in lam_list:\n",
    "        alpha_R, alpha_I, _, _ = crc.estimate(x, y, lam=lam, B=B, also_mc=True)   # two scalars\n",
    "        true_list.append(np.array([alpha_R, alpha_I]))\n",
    "    true_arr =  np.array(true_list) # [ len(lam_list), 2 ]\n",
    "\n",
    "    # estimate\n",
    "    result_list = []\n",
    "    pbar = tqdm(total=ntrial * len(nsample_list) * len(lam_list))\n",
    "    for _ in range(ntrial):\n",
    "        for nsample in nsample_list:\n",
    "            \n",
    "            # generate calibration data\n",
    "            x = Sampler().uniform(mean, sigma, nsample) if not use_gaussian else Sampler().gaussian(mean, width, sigma, nsample) # [ nsample, data_dim ]\n",
    "            y = Sampler().uniform(mean, sigma, nsample) if not use_gaussian else Sampler().gaussian(mean, width, sigma, nsample) # [ nsample, data_dim ]\n",
    "            \n",
    "            indices = np.random.choice(np.arange(x.shape[0]), size=max(x.shape[0]//2, 1), replace=False)\n",
    "            x1 = x.copy()[indices, :] # post-hoc valid split\n",
    "            y1 = y.copy()[indices, :]\n",
    "\n",
    "            # collect estimation\n",
    "            for lam in lam_list:\n",
    "                \n",
    "                # NOTE: standard\n",
    "                alpha_R, alpha_I, alpha_R_mc, alpha_I_mc = crc.estimate(x, y, lam=lam, B=B, also_mc=True)   # two scalars\n",
    "\n",
    "                # NOTE: post-hoc\n",
    "                alpha_R_ph, alpha_I_ph, _, _ = crc.estimate(x1, y1, lam=lam, B=B, also_mc=True)   # two scalars\n",
    "\n",
    "                result_list.append(np.array([alpha_R, alpha_I, alpha_R_mc, alpha_I_mc, alpha_R_ph, alpha_I_ph]))\n",
    "                pbar.update(1)\n",
    "    pbar.close()\n",
    "    arr = np.array(result_list) # [ ntrial * len(nsample_list) * len(lam_list), 6 ]\n",
    "    arr = arr.reshape(ntrial, len(nsample_list), len(lam_list), -1) # [ ntrial, len(nsample_list), len(lam_list), 6 ]\n",
    "\n",
    "    arr = np.concatenate([\n",
    "        arr, # [ ntrial, len(nsample_list), len(lam_list), 6 ]\n",
    "        true_arr[None, None, :, :] * np.ones_like(arr[..., :2]) # [ ntrial, len(nsample_list), len(lam_list), 6 ]\n",
    "    ], axis=-1)\n",
    "\n",
    "    return arr # [ ntrial, len(nsample_list), len(lam_list), 6 + 2 ]\n",
    "\n",
    "\n",
    "def exp_1_plotter(ax, arr, add_label = True, s = None):\n",
    "\n",
    "    ntrial, len_nsample_list, len_lam_list, _ = arr.shape\n",
    "    result_list = []\n",
    "    for i in range(ntrial):\n",
    "        for j in range(len_nsample_list):\n",
    "            arr_ = arr[i, j, :, :]\n",
    "            val_crc = validity(arr_[:, 0], arr_[:, 0+6], arr_[:, 1], arr_[:, 1+6])\n",
    "            acc_crc = accuracy(arr_[:, 0], arr_[:, 0+6], arr_[:, 1], arr_[:, 1+6])\n",
    "            \n",
    "            val_mc  = validity(arr_[:, 2], arr_[:, 0+6], arr_[:, 3], arr_[:, 1+6])\n",
    "            acc_mc  = accuracy(arr_[:, 2], arr_[:, 0+6], arr_[:, 3], arr_[:, 1+6])\n",
    "\n",
    "            val_ph  = validity(arr_[:, 4], arr_[:, 0+6], arr_[:, 5], arr_[:, 1+6])\n",
    "            acc_ph  = accuracy(arr_[:, 4], arr_[:, 0+6], arr_[:, 5], arr_[:, 1+6])\n",
    "\n",
    "            result_list.append(np.array([val_crc, acc_crc, val_mc, acc_mc, val_ph, acc_ph]))\n",
    "    result_arr = np.array(result_list).reshape(ntrial, len_nsample_list, 6) # [ ntrial, len_nsample_list, 6 ]\n",
    "    result_arr = result_arr.mean(0) # [ len_nsample_list, 6 ]\n",
    "\n",
    "    # x, y for CRC\n",
    "    x_crc = result_arr[:, 0]\n",
    "    y_crc = result_arr[:, 1]\n",
    "\n",
    "    # x, y for MC\n",
    "    x_mc = result_arr[:, 2]\n",
    "    y_mc = result_arr[:, 3]\n",
    "\n",
    "    # x, y for CRC posthoc \n",
    "    x_ph = result_arr[:, 4]\n",
    "    y_ph = result_arr[:, 5]\n",
    "\n",
    "    start_alpha = 0.2\n",
    "    alpha_list = nsample_list / nsample_list.max() * (1 - start_alpha) + start_alpha\n",
    "\n",
    "    x_list      = [x_crc, x_ph, x_mc]\n",
    "    y_list      = [y_crc, y_ph, y_mc]\n",
    "    label_list  = [\n",
    "            r'Certified Estimate',\n",
    "            r'Post-hoc Certified Estimate',\n",
    "            'Monte Carlo'\n",
    "    ]\n",
    "    colors      = ['red', 'green', 'gray']\n",
    "    \n",
    "    for i in range(3):\n",
    "        for j in range(len(result_arr)):\n",
    "            ax.scatter(x_list[i][j], y_list[i][j], facecolor=colors[i], edgecolor = 'none', ls='--',\n",
    "                       alpha = alpha_list[j],\n",
    "                       s = s,\n",
    "                       label = label_list[i] if add_label and j == len(result_arr) - 1 else None)\n",
    "            if j > 0:\n",
    "                ax.plot(\n",
    "                    [x_list[i][j-1], x_list[i][j]],\n",
    "                    [y_list[i][j-1], y_list[i][j]],\n",
    "                    color = colors[i], ls = '--', alpha = alpha_list[j])\n",
    "\n",
    "    return ax"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "44d22fc5",
   "metadata": {},
   "source": [
    "# Exp"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "05394b9a",
   "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": "43c14b6a",
   "metadata": {},
   "source": [
    "## Linear programming"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "12c13236",
   "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)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "a0911d61",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 2000/2000 [07:38<00:00,  4.36it/s]\n"
     ]
    }
   ],
   "source": [
    "import os \n",
    "\n",
    "config()\n",
    "\n",
    "exp_kwds = {\n",
    "    'crc':      crc,\n",
    "    'mean':     mean,\n",
    "    'sigma':    sigma,\n",
    "    'ntrial':  ntrial,\n",
    "    'lam_list': lam_list,\n",
    "    'nsample_list': nsample_list,\n",
    "    'verbose':  True,\n",
    "    'B': 3,\n",
    "}\n",
    "\n",
    "path = 'cache/1_28_exp1/result_list_lp.npy'\n",
    "\n",
    "if os.path.exists(path) and False:\n",
    "    pass\n",
    "else:\n",
    "    result_list_lp = runner(**exp_kwds)\n",
    "    np.save(path, result_list_lp)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "4b0316b1",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAXUAAAEWCAYAAACZnQc8AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8fJSN1AAAACXBIWXMAAA9hAAAPYQGoP6dpAAAw8klEQVR4nO3deXBb12Eu8O9iJ0EQAPdVC0iKFCnJEmV5jXcqjpPUS0I5caZJk7Yj9mV5zbgNNcq8aZpJWg3VyUvetE0ipk3SxE1iiY4du84mxo7jJY4l0bYkaiXBXeIKXoAkiIXAfX8cAyQk7iKI7fvNYERcnIt7dE1/9+jcc8+RFEVRQERESUEV6woQEdHaYagTESURhjoRURJhqBMRJRGGOhFREmGoExElEYY6EVESYagTESURhjoRURJhqBMRJRHNehzk8OHDsFgsAABZltHY2BiVfYiIUp0U7blfDh8+DADhUG5tbcWxY8dw5MiRNd0nJBgM4sqVKzCZTJAk6UarT0QUc4qiYGJiAkVFRVCpFu9giXqoW61WdHV1hVvdACBJEhY77Gr2Cenv70dpaemNVJmIKC719fWhpKRk0TJR7X6x2+2QZTkinENaW1tRV1d3w/t4vV54vd7w+1Dw9/X1ITMz88b+AkREccDlcqG0tBQmk2nJslEP9flYLBbIsrwm+xw6dAhf/epXr9uemZnJUCeipLKcLuWYjH7JysqCw+FYk30OHjwIp9MZfvX19a1VNYmIEs66jH651koDfbF99Ho99Hr9jVaJiCgpRLWlbrPZ5t0uy/KCn61mnzUxNQXY7eJPIqIEFfVQt1gs8/aTz3eTdLX73BCnE2hoAPLygLIy8ef+/WI7EVGCiXqf+sGDB9Ha2hp+39LSgv3794ff2+328Lj05e6zZmZmgAcfBJqbAbdbbHO7ge99T2yfmVn7Y9LSvF7gjTeAN98E/P5Y14YooUR9nDogHiYKdZ2cOHECTU1N4c+am5vR1NSEzs7OZe+zGJfLBbPZDKfTufTol2eeAerrF/68pQX46EeXdVxahclJ4KmngBdfFD/fdBNgMADPPguERjrl5gKNjcCnPhXTqhLF0kpybV1CfT2tKNQ/8xnghz9c+HONBsjIALTayJdGA3z4w8C//IsoFwwCdXVi+3xld+8G/vZvZ7/3//wfQFEiy4R+3rgRePjh2bLPPy++f76yZjOwdets2f5+QJKuL6fVAmr1is9lVE1OAn/xF8ClS7PbHA5geFicc50usvy///viF2CiJLaSXIvJ6Je4sdT1bGZmtsV4rdra2Z/9fuDllxf+HpcrMtSbmhbu2nnggchQ/9SnFu7fv+024I9/nH1/663AlSvzl73pJuCdd2bf33470NMz/4Vo0ybg5z+fLfuFL4iy812wcnKAr3xFhLAkAf/5n6IO15bTagGjEfjEJ8R3/uhHoj6BgNgPAEZHxfuJCRHsc0c1fetbDHWiZUjtUH/oIeC//mvhz7/1LeADHxChPfc1MyPCLEStBn72s/nL+f3iBuxcX/wi4PNdX87vB7Ztiyx7223ionBtOb8fKC6OLBsK0PkuGNe21AcHgatX5/97h+4vhLz8MtDePn/Z9HTgrbfEn+9/vzifJ0/OX9ZqFaHu9wNHj4rw93iuLxcIiAtZXt7stsuXgTNngM2bReAT0bxSu/vF7xeh2dZ2/We7dgF/+pMIykSjKCIY514AACA7e7bMpUsivK+9UPj9ol/73ntnyz77LDA2FlnmlVdE0KvVwIYNs2VdLmD7dlEHn0+812hEfYxG4K67xI3pS5dEoM/99bv2VzE3V7TivV7xXQ89JOq2axfwyU8C+flrfuqI4hG7X5ZLqwWOHxct56NHRXjo9cDjj4tWeiIGOiCCUKMRr7S0+cts2bL873vsscj3V64Av/61aDUDIoz9fmB6WlwoQkHe0SGC++jR2b7/n/5UXEhMJnF+9XrRdaPRAEND4r8BIFr1kiS+0+cTAa/Xi2O1tYlnCv75n4F55ggiSmWp3VKfS5ZFWBUVpWxQTPmm8NTpp/Ba32vI0Gbg49s+jns23XN9waNHRWs7pLMT6Oub7RvX62cDX6cDduwAqqrE9kBAbJ+cBL7/fRHm6emz2/r6xDajUQS42w2oVOIeQE5OZDfSww8DH//42p8IojjDlvpqWCwpG+YAcGnsEup+VIc+1+zcOd899V08se0JPPWRp6CS5jzScO3Ycc17v0aSJAI4Lw/4xjeAigrx8yOPiLC+lsUiRryEQt1oBLKyxM9Opxj1Ewr99nbRet+1a3b/tjaGOtE1GOoEAHjimSciAj3kp2d/ijtK78Dnb/n87MZdu4Af/GD2fWGh6K+XJBHEjz0mbpoC4gLw+c+LbpVQ37jPN/vz5s0i3Ccngepq4JvfFNunp8WFoLtbfKeiiAtGMCj+BJYevUSUghjqhBMDJ9B2dZ6bxe/57snv4m9u/hu0D7fDmmaFpawEGbt2QvX2O6KATjc7rtxkAv7qr2Z31mqBRx9d+OBer2iFZ2SIfUOrWzkcwLe/LW7SVlZGBnvI3Fb7CgSVIFxeF4xaI7TqBL1vQrQAhjrBPj7/HPZzPx+aHMLOIzvD21QmFcx36WHxAJYZDT42kocD6e8HnnwSHqsJ//LK12AxWOZ9ZaVlwagzitFFzz4bOaxxyxYxquV//kcEvkYjWu3X3vDNzBTDTVcgqATxnRPfwX+8/R+4MnEFaZo0fGTrR/Dlu76MNE0anF4nctJzoFPrlv4yojjFUCdstm5e8nO33408Yx5kjwxfwIegEsQ4pjFuEGXu2bMPePzbAIAx1wD+4ff/sOD3fXrnp/GD6i8DP/sZ3IoPd5taYFH0sHglWE5OwRLQwGLKg2VjCbZ/4Yu4p1cFtLZCmZrEFa0HlqpdSP/UX0EK9b8v05d++yU8deap8PvpmWn8+PSPcbT9KLLTshFEEJn6TNRvrcfnb/k8W/GUkBjqhFuKb8Gugl14e/DteT9v2N2AiuwKDP39EADAM+OB7JEjXiWZs+smatVa7K/dD9krY3x6PKLcuGccFr1FPNCkKBiXvDilGX5vRwDh54qGAJzBp4fzcc/HfgA89hjcV3pQ8l9bAN9z0Hz/+n8JvN/2fnzpzi8BEMsafufkd2DWm2ExWDDhm8AP3/0hJEgRN31dXhcCwQCCShDZ6dlweV34/jvfR6+zF9/8wDfX9kQTrQOGOgEAfvLRn6DuR3UYmBiI2P54zeP43J7PRWwzaAwoyChAQUbBvN+VZ8zDkT87Mu9niqIgoASAf/hHAIBV0eNF54cgn3oDsuSBbNJhPM8E+Y7dkDO1uLX4VtEVk54Ol94PjaTBjDKDmeAMRt2jGHWPhr977oVlemYan/vl5649fJhWpUVQCSKoBAEATo8T1jRrOPBbu1rRPtyOmryaBb+DKB4x1AkAUJVThfOfO48fn/4xXut9DUatEU9sfwL3b75/TY8jSRI00nsPRU1OIh1afDBYDnhHxZh0pxrw5wO3fE08mer3A0+J1nchAB8+CzdmIEteyGmAXLEB8p27IXtkbLRsFHPhZGTAnyahvuIRyDOTGPfI6Ja74Zh2QIEYMaPgvYvLe9wzbgxPDUdcqF7ufnnxUA8EgIsXxZw1JpMYvcNVuCjGGOoUZtKb8Nk9n8Vn93w2+gfbvVs8lRpy223iz2BQBH7oCdRAALj/fjFu3emE5HTC6HTC6NOi2A3AUAFs+ZAo6/cD/1dcAMwAjmGTGGZpMqFfmsDfD/wAL1XqoEBBUAnCNOLCuDaACa0CRQX4A5Hj7xd9Lm9wUDyENTk5u621VczeOXfmTKJ1xlCn2Lj3XuDsWTFd8FwajXigKPRAk8EQOWslIIY2er0i6Oc+YerzATt2YHp0EJ3dbfA6RpCuScNG30aUaNNwp6kaL6EDvoAPaYoGjW+o4A8GMGZU4XSpDrucaug0Y5hMU6EnT4+7H7t79rvHxsSIG61WTHPw9NPXL33o9wO/+IV44GruPDtE64ihTrFhMIgpfV99Vczq6PGIKX/vvVf8uRhJEvsbDJHbjUa8sbcK//TqM/AWeCEFNUjzemDyXsBf2D4CvS4fhvbvYNwzDpWixahFC5NHA9uMDhU9oYuDDwBgy9+Kmwpuem+TD/ja18TP6ekizLu7xfH1evEUbGhGyWBQPOm6d++NnyOiVWCoU+zo9WJxkTVae1b2yPinV/8J3hkxKZiikuDUKbjoG8SLZ7+CgowCmA1mbLZsxgObH8Anv/BJGDQGNP3+62i7+HukT88gx6fBg7m345P3/+/ZL56cFA9X+Xyi37+/X/Sjezyie6iqKnKa4OHhNfn7EK0GQ52Sxm86fhMOdADoHO/E4ORg+P1McAaNdzbiz3f8OXRqHYJKEP6AH9/88L9hvG4cjmkHCjMKxYNRc2VliYVNvF4x8dvx48BPfiJC/b0++wjGa/YnWkcMdUoa1w7H9M344Av4oJE00Kl1CAQDyNRnhp8YvTh6EV/41RegVqmRrk1HujYdaZq08M8PlT8UnqVS9jrxm47fIP3qKNL73kaa0QFjqQ5puYVIL8mEVfHBKL33JOqOHev6916Jk1dO4redv8WViSuwGqy4Z9M9uH/z/ZETtlFCY6hT0sgz5kW8zzfmiyGUKg0URUGJuQS56bnhz91+scJTIBjAhHcCE96JiP13F+4O/3z16iV871dfF1MWAEBNQNyw1YwAOI0/V3bi01ItsGsXBnL0+PtnnkC6Jn32YqFNg1FrRJo2DXuK9uDWklsBAN4ZL05eORkuN7d8miYNUmg64zVwrP0Ynr3wbPi9Y9qBzvFOnBk6gy/e9sU1PRbFDkOdksaDZQ/ix6d/jEBQjD/PSs9CVvrsVAJHPnwEZVmzSwvWFtbi+Seeh9vvxrR/GlP+KUz7p+H2u+H2u1GRXSEKer3IeOYF7PUUY1o1g6mSPEznWjHlGsX08BW4vZMwZm8A7t4HVFRgYvQCRqZGFqynUWsMh/rw1DC+8vuvzFtOkiTsq96H/bv3AxAPSH39D1+/LvxDF4vyrHJsyxPLIQaVIPpd/eF/ebi8Ljx38bl5j3PiygmcvHISe4r3LO9EU1xjqFPSyDXm4snbnsQ3/viN8JOiIQ27GyICHRChGQrHRen1KN1ThwN9lWJJvSWGK26ybMK3P/Tt8MXh2ovGzoKdEXXYmrNVlJuZLa8oChRFgVY1O//MhG9iwakcAODRqkfDoe70OPGXv/jL8GfDU8MYmx6DWlJDURQUZBTMXrQAvN73OkM9STDUKak8WP4gqnOr8cvLv8TAxADyjHl4qPyh6wJ9UX6/GGpZUzO7Dupdd4mbosvoojBoDNiSvbzlAksyS/CvH/zXiG2KosAX8GHKPxUR6laDFV++68sRF4u5F42KrNmQ9ga8MOlNcPvd4bltAsEAPEGP2KYEYLPaoFaJoZyhrihKfFzOjlKTLAPvvAP09oq+8dJSYOdO8UDTr34lPi8oAD7zmWUFebxSFAX+oB8v21/GP77yj+h19kKBAqvBim1528Kh/kjlI/jYto/FuLa0EC5nR7SY0VHgxRcjl+U7f148DWo0zi7YEWqdJzBJkqBT65CuT4dj2gGtWouCjAJssmwKj3jRa/R4wPZAjGtKa4WhTqnnrbciA31gADh3TjxclJEBfOpTwD33zK7mlATuKLkD+2r24cLIBWjV2vBIF6vBis/d8jnkpOfEuIa0VhjqlFo8HuDKldn3g4PA738vAjw/X4wxv+OOpAj00JJ9apUaapUaX7vva5AkCRdGL2DANYCstCzsyN8R7oKh5MBQp9Tij5yJEWazmKDLYBBBnpFxfZkE1O/qx+HXD2NnwU58ZudnIElSuHVelVOFqpyqGNeQooWhTqklI0O8QlPmajSiq2VwUPSnm0xiNkZA3Cy1WGJV02XxBXw4eeUkep29SNOkYXfRbjg9TnzzzW/C7Xfj7PBZuP3u66c+oKTFUKfUIkmii+WNN8R7rVbMCrlhg2ih79gBqFRi4q6f/1y05LduBSoqRNk4Mjg5iG+f+DZcXld421Onn8KIewRFpiJUZlfi7+74OwZ6imGoU+qprhaTc50+PdvVotOJhTu2bxfvx8ZEuI+PiwvAiRMi2Kur46L1rigKfvD2D8KBrigKOsY70OHoACDWnf3yXV/m4tkpiKFOqWnXLmDbttmbpoWFkTdHS0uBT3wCuHxZjIxxOsWf586Jsu97n2jFx0iHowNDU0Ph9+dGzqHX1QsAsFltKDYVM9BTFEOdUpdWC2zcuPDnOp14qrSmRoT/uXNAT4+YL33uAh2Ksu7j2UfckXPL5Bpz0e/qR1VuFTaaN2Jsemxd60Pxg6FOtBxFReI1NQWMjEQuMP3ii2Jd1epq0YpfB1lpWRHvzXozco258Mx45v2cUgdDnWgljMbIRTBkWYycAYCuLtHfXl0d9RurldmVyErLgmPaAQDwzHgw4ZvAhG8CecY8PFHyRNSOTfGNM+MT3QiLBfjIR8SSdhqNCPk33hArI73+uuiLjwJJkvDpnZ8OzzBpNphRlFEEAJjyTWGzZTN65B44PdE5PsUvTuhFtFZ8PnFj9fx5Ee4A8MADwObNUTvkpG8Sb/a/iV5nL9SSGm/0vYFeZy9y0nOwNXcrAKDMWoYPbfkQMnQZUasHRRcn9CKKhWtvrHZ0RN6IPXdOrJxUVbVm65hm6DJQZxMLd/sDfnQ4OnB2+CxcPheKTEUwG8zoHO/Ef5/+b/x17V9zSoAUwO4XomgoKgLuvluMdQeAYBB4913g7beBn/0M+N3vgKtX1/SQ7SPtSNOmodBUCCjA6aHT4cVCxqbHcH70/Joej+ITQ51ovdxyi5ijXVHETdUXXwRaWkQLfg3mm+mRewAANbk1gCRunoZGwwBAt9x9w8eg+MfuF6L1oFIBZWXi5XCIfvfLl2dvrDoc4oGmGznEnPnRs9Oy4fa7Me4ZD99MVUvsekkFbKkTrbesLODOO8UTq3fcIUbQVM2ZNVGWAbtddNmswNyZFxUoUEkqGLXGeT+n5MWWOlGs6HRiTHt1deT2s2eBCxfEA01VVcu+sVqeVY5Nlk3ocHTAHxDdOaERL2XWMmy2Rm8UDsUPhjpRvDGZRKBPT4sbq++8I2aSXOKJVUmS8HjN43it9zVk6DLgmHbArDdjV+Eu3Fl657pVn2KL49SJ4lEwCHR3i5uooSdWAaC4GHjooWV9hS/gg06d+Cs4EcepEyU+lQqw2cRr7o3V/PzZMooi+t+t1nm/goGemhjqRPEudGP1lltEkIf09gLHj4thktXVootGpcIz556BTq3D3RvvhtkQu+mBKTYY6kSJ4toJwsbHxZS/g4PilZYG/5ZyXJo4C0WrxX2b74tNPSmmGOpEiWrnTjEb5IUL4jU9jZG2V6G434UxuxAZtxuW/ApKPgx1okRmNIpl+HbtArq7MXjyecCtID9gELNGhgSDs1MWhPh8Ytk+SQJyciLLU8Lif0WiZPDejdWhQCVgGUN+zs7Zz3w+4Ngx0ee+davooz9/HujsnH3ASaMBtmwBystjUXtaQwx1oiQyOCn61gtK5zzQ1N0txryfPy9egYBoneflzbbeZ2bE8MmllvijuMdQJ0oSQSUYXrs0P2PO0MctW8QDTefOiekHzp8XIa7TASUlwIYNs4tuXztdMCUchjpRkpjyTcGsN2PSNwmr4Zqx64WF4lVdDUxMAP39olums1O01jdsEF0wU1OAxxO5sDYlFIY6UZIw6U1ouLkBgWAAkiTNXygzU/Sb22zA8DDQ3i4W0lapRJ+7JAFqzuaYyDhLI1GSWXR1I6NRzAqpUomHlvbsEduHhwG3G8jNjeqC2RR9DHWiVFNTM3uDNDNTjIZRFNElc+2MkZRwot79cvjwYVgsFgCALMtobGxctHxrayuOHDmCvXv3wmaz4fjx49izZw/q6+ujXVWihPZvb/0bMvWZeKzqMZj0poULZmcDd90l5pIZHhYLd2i1YoFsHeeLSXRRDfXDhw8DAPbv3w9ABHZDQwOOHDmy4D6yLKO1tRUtLS2w2Ww4cOAAA51oCU6PEy6vC5O+yfBKR4sym4Gbb55973DMdstQQotqqB86dAhdXV3h93V1ddi7d++ioQ4AXV1d4dY9ES1taGoIAJCTnrN4n/pCsrLWuEYUK1G7LNvtdsiyPG84t7a2RuuwRCnHMe3Anwb+BMe0A7npuTf2ZaFFsScn16ZytO6i1lK32+3zbrdYLJBledF9jx49iqysLDgcDnR2dqKpqWnBsl6vF16vN/ze5XKtqr5EicY748VLXS9hYGIAJ6+cxNDUEDJ0GajJq0F51iof9z97VoR6Xh5w221rW2FaF+vegRYK64XU1tairq4O9fX12L9/P8rKyrBv374Fyx86dAhmszn8Ki0tjUa1ieJOKNABwOl1AgDStel4pfsVMV3Aathsol99eDhyxSVKGMtuqbe0tODpp59estzBgwdRW1u74OeLBToA2Gy2iPePP/44GhoaFuzKOXjwIJ588snwe5fLxWCnpOeYdoQD3TvjhWfGAyiASWeCAgVnhs6gIKNg5V9sNIrRMJcvi1b73PlhKCEsO9Tr6+tXNArl2nAOkWV5wc8AcfGYe5xQkNvt9nkvFnq9Hnq9ftn1IkoGw1PD4Z8DSgBWgxU9zh5Mz0xDq9aG54BZlYoKoK9PPIzU0SHmjqGEEbVLsM1mg8Vimbdvva6ubt59ZFnGvn37IvYJ9b8vdiEgSjV69WxDJl2bDmuaFSWmEpweOo2rE1dvbH1SjUY8oASIFvv09A3WltZTVP9ddfDgwYiRLi0tLeEx64BofYfGsgOiVd7Y2BgR4M3Nzaivr+cQR6I5Ss2lEcFdkVWBnPQcKIqCDkcHJrwTCAQDqz9AcbF4SCkQEPPDUMKQFGXuSrZr7/Dhw+GQPnHiRMRIlubmZjQ1NaGzszO8TZZlNDc3h9+PjY0tOvrlWi6XC2azGU6nE5mZmWvwNyCKTx2ODrzS/QoUzP4v3Ofsw9j0GHbk7cAjVY9ETsG7Ui6X6Ffftk1MJ0Axs5Jci3qorzeGOqWSwclBnB0+i5GpEejUOpRnlcOsN8M940Z1LudxSRYryTVOvUuUwAoyCpYc5eL0ONHv6kdNXs2NHWxmhuuYJgD+FyJKYjPBGbTaWzHuGcfw1DDu2ngXNKoV/m8fDIrVkvr6gPvuAzjaLK5xACpREtOoNKjKqYIECZ3jnXj+4vOY8E6s7EskCRgbEyslnTsXnYrSmmGoEyW5mrwafLDig0jTpMEx7cBzF55Dv6t/+V8gScD27eLnvj4xoyPFLYY6UQooNBXi0apHkZueC2/Ai193/BrvDr67/C+wWsU6pgBw5oyY+IviEkOdKEUYdUZ8eMuHUZldCQDodfYiqASX/wVbt4rFNJxOoKcnSrWkG8UbpUQpRK1S466NdyE/Ix8lmSVQSSto1+n1QGWlGLt+4QJQVMSVkuIQW+pEKWhL9paIFZLarrahR15G63vzZsBkEiNiOM11XGJLnSjFDbgG0Ha1DQCwq2AXagtrIUnS/IUlCdi9W7TQDYZ1rCUtF1vqRCmu0FSImlzxYNLbg2/jt52/hXfGu/AOmZkM9DjGUCdKcSpJhdtLb8e9m+6FWlKjz9WHX1z8BRzTyxi6yMU04g5DnYgAAOVZ5Xi48mGYdCa4vC48f/F5dI13LbzDlSvAm28Cp0+LKQQoLjDUiSgsOz0bj1Y9imJTMWaCMxEzQF6noECslOTxAJcurV8laVEMdSKKoNfo8YHyD+DBsgdhsy6yOI1KJablBQC7HZicXJ8K0qIY6kR0HUmSUGqeXevX7Xfj+YvPY9Q9GlkwP1+8gkHxpCnFHEOdiJb01sBbGJ4axgsXX8ClsWu6WrZtE632kRHeNI0DDHUiWtIdpXdgg3kDAkoAf+j5A97oe2N2igGjESgvFz+fOSNa7RQzDHUiWpJOrcNe217UFtYCAM6NnMOLl16E2+8WBSoqxJqmoVY7xQzPPhEtiyRJqC2sxfvL3g+dWoehqSE8d+E5jE+PA2o1cOedQGFhrKuZ8hjqRLQiG8wb8EjlI7AarNCr9cjQZVxfiOPWY4ZzvxDRipkNZjxc+TC8AS+0am14eyAYgLp/QKyQtHs3kJsbw1qmJrbUiWhVtGptRCv99NBpvHDpBUw6BsXSd7xpGhMMdSK6Yf6AH2eGzmDUPYrnlHO4iknxMFLXItMMUFQw1InohmnVWjxc+TCy07LhUWbwy/R+nJnuBi5eFNMI0LphqBPRmjDpTfizyj9DeVY5FKsVf8IAXh5vw8zZ07GuWkphqBPRmtGoNLh30724vfQOqEpK0ekdxP+cew7BsdGld6Y1wVAnojVXk1eDD95Uj7TcImzRF0E1Lse6SimDQxqJKCoKMgpQ/8AXoPcFAIsFADDtn4ZBY1h4uTy6YWypE1HU6NNN4UD3znjxwqUX0GpvhT/gj23Fkhhb6kS0LkZGujF5pRuubBeeu/Ac7t10L8Y947g6cRVBJYic9BzYrDYYdcZYVzWhSYqiLLK0SeJxuVwwm81wOp3IzMyMdXWICACmp4Hf/Q4j3nG0lvggq3zolrtRkV2BPGNeuJhGpcHtJbfDmmaNYWXjz0pyjd0vRBR9aWlAYSFytWY86tmEgBLAlH8K7wy+g8uOywi1LWeCM3h36N0YVzaxMdSJaH3U1ABqNdKcU6jyZGCjeSMAoGu8C5fHLofnZ3d5XXB5XbGsaUJjqBPR+jAYgMpKBJUgjJe6UWUpx/a87VCgwOl1YmRqJFzUF/DFsKKJjTdKiWj92GxQ9fTAOKyBp2sAhRUbAACyRw7fIFVJKph0pljWMqEx1Ilo/ahUwPbtKBjqwnRfN9xFuSjIKEChaXZxjWJTMfQafQwrmdgY6kS0vvLykFe5C66ZYgyn+SIeRCrIKMCO/B0xrFziY6gT0frbvRvlAEpmPBicHEQgGIDZYMbQ5BDaR9oZ7DeAoU5EMWPQGLApU/Srj3ud6BzvhAQJmyybkKnncyarwdEvRBQ7DgfwyivA5cuwpllRmFEIBQrOjZyLdc0SFkOdiGLH4wEmJoDLlwG3G9W51ZAgYXhqGKNuTte7Ggx1IoqdoiIgJ0esZXr2LIw6IzZZNgEA2ofbkWSzmKwLhjoRxdb27YAkAYODwPAwKnMqoVFp4PQ6MTAxEOvaJRyGOhHFlskE2Gzi57NnoZM0qMiqAABcHrscw4olJo5+IaLY27IF6O8HJicBux02mw2+gA9lWWWxrlnCYUudiGJPqwWqq8XPY2NQq9SoyauBQWOIbb0SEFvqRBQfSkoAvR7Iy7vuI7ffjXRtegwqlXjYUiei+CBJ1wV6IBjAWwNv4aWul+D2u2NUscTCUCei+OP3A5cvQy2pEAgGEFSCOD9yPta1SggMdSKKL4oCvPoqcP480N2NmrwaAMDAxADGp8djXLn4x1AnovgiSbNDHC9cQKZkQGlmKQBw+oBlYKgTUfzZuBHIzBTdMOfPoyqnCipJhbHpMQxODsa6dnGNoU5E8UeSxJOmANDTg7QpL8qsYsz6uZFznD5gEQx1IopP2dlimCMAnDmDcmsZdGodAsEAR8IsguPUiSh+VVeLOWHGx6G9OoTbS26HSW+CSmJ7dCEMdSKKXwYDUFkppufNy4NZz7VLl8JQJ6L4Vnb9/C+KoqDX2Yv8jHxOJXCNqIe6LMs4evQojh07huPHjy9rn8OHD8NisYT3b2xsjGINiSihBAJ4Z/g0+lx92OjZiJsKbop1jeJKVDum2tracPToUciyDIfDsax9Dh8+DADYv38/9u/fj9raWjQ0NESzmkSUCKangbfeAv70J2y0bAQA9Dp7MeGdiHHF4oukrMPYoJaWFhw6dAinTp1asqzVakVXV1e4pQ4AkiQtewiTy+WC2WyG0+lEZiYXriVKGm438NJLYpWkm2/GCWUAVyevIt+Yj1tLbo117aJqJbkWV7eQ7XY7ZFmOCPSQ1tbW9a8QEcWP9HSgQiyegfZ2bM3aAgkShqaGuJ7pHHEX6vOxWCyQZXnez7xeL1wuV8SLiJJUeTmQlgZMTyOj52p4PVM+kDQrrkJ9IVlZWQv2yR86dAhmszn8Ki0tXefaEdG6UauBbdvEzx0d2GIohkalgeyRuZ7pe5Y9+qWlpQVPP/30kuUOHjyI2traG6rUtRa7yXrw4EE8+eST4fcul4vBTpTMCguB3FxgZAT6ix0oLyvHyNQIMnQZsa5ZXFh2qNfX16O+vj6adYEtNDPbNWRZXvAzvV4PPR9IIEot27cDL78MuFyoyLgJW7K3xLpGcSOuul9sNhssFsu8fet1dXUxqBERxaWMDOC224D77oPERl2EdQn1hbpP7HZ7eFx6yMGDByNGurS0tGD//v1RrR8RJaDcXNHH/h5/wI/24faUXyEpqqEeCu0jR46gra0NBw4cQEtLS/jz1tZWHDlyJGKfxsZGyLKMlpYWtLS04MSJE9eVISIKUxSguxvj41fQOd6JzvHOlJ7FcV0ePlpPfPiIKMW8+y7Q0wMUF+OPeT6MuEdQbCrG7qLdsa7ZmknYh4+IiFZs0ybx58AAqtUF4seJAcgeOWZViiWGOhElNrM5HOzmSz0oNYmFNdqH22NYqdhhqBNR4quqAnQ6wOVC1VRaeD3TocmhWNds3THUiSjx6XQi2AGkdXTDZhSt9YtjF2NZq5jgIhlElBw2bhQ3TJ1OVAz5ESjejIrsiljXat0x1IkoOUiSeNL03Dloy7Zgu9kc6xrFBEOdiJJHVhbwvvddt9kz40mZZe/Yp05ESWvG78VbA2/hd/bfwTvjjXV11gVDnYiSTyAAtLdD8/Ir8HqmEFACuDB6Ida1WhcMdSJKPpIEDA0BHg9qnDoAqbOeKUOdiJKPSiVumgLIGnCgQDJBgYLzo8k/2RdDnYiSU26uWFBDUVA9GIAECYOTgxhzj8W6ZlHFUCei5FVTA6hUyJDd2OhLAwC0j7Qn9XqmDHUiSl7p6UCFeACp8ooXGkjwznjhmfHEuGLRw3HqRJTcysuBvj7ofT7cnlENc9FmqKTkbc8y1IkouanVwO7dQFoarIbkfwApeS9XREQhViswJ9AVRUGvsxf+gD+GlYoOttSJKLWMjuLU8Du4onZjwjqBmryaWNdoTbGlTkSpo78feOMNlPbIQDCILrkr6dYzZagTUeooKAAMBuT7dcgZ9yKoBJNu+gCGOhGlDo0GqK4GANSMSIDXi35Xf1KtZ8pQJ6LUUlICZGXBLBlQMiJmbjw3ci7GlVo7DHUiSj07dgCShK0TeqgmJjHqHk2a9UwZ6kSUejIzgY0bkabSwzboRZbBmjSLaHBIIxGlpqoqYHwcVeW1UBWXxLo2a4ahTkSpSacD7rkn6borGOpERAD8fi8uy53QqXUozyqPdXVWjaFORNTbi5F3X0NHEaA2mVGaWQq9Rh/rWq1Ksv3Lg4ho5cbGUKRkwDIwhkBwBhfHLsa6RqvGUCciqq4GNBrUzFiB0VH0yD2Y9E3GularwlAnItLrgcpKZGsyUTA4CWXGn7APJDHUiYgAYPNmwGRCtboA0sBAwq5nylAnIgIAlQrYvh0Z6jRsHFcAtzshJ/vi6BciopCcHKCoCJX9fiBgwJai3bGu0Yox1ImI5qqpgb6sDDus1ljXZFXY/UJENFdamlj+bg7vjDdGlVk5hjoR0QJ8rnG89fYLeLn75YRZz5ShTkQ0n8lJaF95DVMXzsA36cRlx+VY12hZGOpERPPJyICUm4tqXQnQ2wv7uB3T/ulY12pJDHUiooVs24Z8fRZyJoMIOsZwfvR8rGu0JIY6EdFCMjIAmw3VhlKgpwf9ci+cHmesa7UohjoR0WK2bIElIwcligm4ehXtI+2xrtGiGOpERIvRaICaGlQZSqC6OoipSUdcD3Hkw0dEREspLkZ6XyluM5bCWrEbao021jVaEEOdiGg5brsNObGuwzKw+4WIaIWUYBB9ci8CwUCsq3IdttSJiFbC4cCJ157GYKYK09vvw5bsLbGuUQS21ImIVmJiAsU+AzAwgI6h83F305ShTkS0Ehs2oCjXBouUhpmerrhbz5ShTkS0EpIEaccO8UDS6Ah6+tvjaj1ThjoR0UpZrcixbUO+xgKlpxvnhuPngSSGOhHRamzdimqTDdLUFAa7zsAx7Yh1jQAw1ImIVkevh6l6FzZoc5HlVqCW1LGuEQAOaSQiWr3Nm7FN/1Goi0tiXZMwttSJiFZLkuIq0AGGOhHRmvB7p3Gu7TfolrtjWg92vxAR3ahgEFeO/xwd4+eg8w2jeE8xtOrYTPrFljoR0Y1SqbCh4mZkqNLg67ajY+RC7KoS7QPIsozm5mbs3bt3WeVbW1uxb98+NDc3o7W1FQcOHEBLS0uUa0lEdGOkigpUZ1UCfh86z74as/VMoxrqbW1tOHr0KGRZhsOxvDGcsiyjtbUVDQ0NaGhoQFlZGerr66NZTSKiG6dSoaD2bmSrMxEcvIoLvW0xqUZU+9Rra2tRW1u74pZ2V1cXLBZLdCpFRBQt+fmo2bAbf+h6GX1nX4eteBvMBvO6VoF96kREa8iy63YU63IBlxMXLr6+7sePy9EvR48eRVZWFhwOBzo7O9HU1LRgWa/XC693dupLl8u1HlUkIpqf0YitNfdAPXIBlbbb1/3wcRfqtbW1AACbzQYAaG5uxr59+3Ds2LF5yx86dAhf/epX161+RERLSd+2CzuxKybHlhRFUZZTsKWlBU8//fSS5Q4ePBgO5rn7Hjp0CKdOnVpxBWVZhtVqxfj4+Lz97PO11EtLS+F0OpGZmbni4xERrTWf3wOd1rDq/V0uF8xm87Jybdkt9fr6+nUZhdLS0hJxnFCQ2+326y4WAKDX66HX66NeLyKilfJOyDj9x+cgz0zi/g/8L6hV0Z/0K65ulMqyjH379sFut0dsA2a7Y4iIEoVWkSCP9GJ67CrsnSfX5ZjrEuoLjVG32+04fPhw+L3FYkFjY2NEgDc3N6O+vp5DHIko4agyzdhacQcA4PK7L8E9JcM75YISDEbtmMvuU18Nu90e7otva2tDY2Mj9uzZE+5eaW5uRlNTEzo7O8P7hJ5ADRkbG1t09Mu1VtL3REQUbYrPh98dbULfwDmYrAUo3bgNGo0e+SWVKK7YDUm1dNt6JbkW1VCPBYY6EcUTv8eNN5/5fzh7+XVAJWHrjgeQlmYCAOQWlMF2071LfsdKci2u+tSJiJLNUE87dNm5sKZbgaCCq91nw5+NDHbCMymv6fEY6kREUSSP9gOShMJNOwAA7ikZM35f+PPxoe41PV7cPXxERJRMFEXcFDWYs1BetgfGrAKoNdGLXrbUiYiiyJI9u9xdZl7JdYFuyd2wpsdjqBMRRVHB5u3QLvA0aU7+ZqRlZq3p8RjqRERRpDWko/qWD8GSVRTeplZrUVhaDduOe9f8eOxTJyKKMkOGBZV7HoLf48aMzwO9MRMqdXTil6FORLROtIZ0aA3pUT0Gu1+IiJIIQ52IKIkw1ImIkghDnYgoiSTdjdLQ/GRcq5SIkkUoz5Yz/2LShfrExAQAoLS0NMY1ISJaWxMTEzCbzYuWSbqpd4PBIK5cuQKTyQRJkmJdnYQRWtu1r6+PUxavM5772EmUc68oCiYmJlBUVATVEvOvJ11LXaVSoaSkZOmCNK/MzMy4/uVOZjz3sZMI536pFnoIb5QSESURhjoRURJhqBMAQK/X4ytf+Qr0en2sq5JyeO5jJxnPfdLdKCUiSmVsqRMRJRGGOhFREmGoExElkaQbp04LO3z4MCwWCwBAlmU0NjauaP+9e/fi+PHjUahZ8lvtuT9w4ADKysoAAFlZWaivr49WFZPWas59c3MzZFmGxWJBZ2cnDh48GP6OuKdQSmhqalKamprC748fP67s379/2fsfO3ZM4a/L6qzm3I+Pjyu1tbXK+Pi4oiiKcurUKZ7/VVjNuW9qagqfd0UR/y3q6+ujVcU1x9EvKcJqtaKrqyuitSFJ0rImCJJlGUePHkVDQ8OyylOk1Zz7hoYGlJWVRbQqW1tbUVdXF82qJp3VnPv5/kWaSP9KZZ96CrDb7eF/Sl6rtbV1yf2PHj2Kxx9/PAo1S36rPffNzc2or6+H3W4Pl2Ogr8xqz73FYsHevXshy3L4e2w2W5RqufYY6inAbrfPu91isYR/cRfC1uGNWc25D+3T1tYGWZZhs9nQ0NCwrAswzVrt7/33vvc92O12WK1WHDhwAK2trThy5EiUarn2GOopLCsrCw6HY9EyoVChtbXYuQ+FkcViQW1tLWw2G5qamrBv3771rGLSWur33mKx4MCBA6ivr8fhw4dx7NixJRs/8YShnsKWCvRQFwCtvaXOPQDcfPPN4Z9DrUu21m/cUuf+wIEDsNlsOHbsGDo7O+FwOLB79+51qt2NY6ingIVa2ou1wtva2iJChVZnNed+oe0Wi2XBLgW63mrOfagfPtTlaLPZcOrUKVgsFrS0tEStrmuJ49RTgM1mCwfCtb/MC/WXOxwOtLW1hVuGnZ2dAMSYX5vNxhb8Mq3m3NtsNthsNtjtdtTW1oa3y7LMC+0KrObc2+32eW+sNjQ0RKOK0RHL8ZS0fpqampQjR46E3x87dixivG5nZ2fEeN5rcZz06q3m3B87dkxpbGyMeF9XVxf9yiaZ1Zz7urq6iHHqiqKs6JmOWOM49RQSamUDwIkTJ9DU1BT+rLm5GU1NTeEW+VwtLS14+umn0dLSgsbGRuzdu5cjYlZoNec+9FQjAIyNjUXsQ8u30nMvyzIOHTqE7Ozs8L2M/fv3J8wTpQx1IqIkwhulRERJhKFORJREGOpEREmEoU5ElEQY6kRESYShTkSURBjqRERJhKFORJREGOpEREmEoU5ElEQY6kRESYShTkSURP4/4T5EodHJLmIAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 400x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=[4, 3])\n",
    "\n",
    "result_list_lp = np.load(path)\n",
    "exp_1_plotter(plt.gca(), result_list_lp)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a879a236",
   "metadata": {},
   "source": [
    "## Newsvendor model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "5651838a",
   "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": null,
   "id": "f7a4593b",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 2000/2000 [00:00<00:00, 7295.72it/s]\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "\n",
    "config()\n",
    "\n",
    "exp_kwds = {\n",
    "    'crc':      crc,\n",
    "    'mean':     mean,\n",
    "    'sigma':    sigma,\n",
    "    'ntrial':  ntrial,\n",
    "    'lam_list': lam_list,\n",
    "    'nsample_list': nsample_list,\n",
    "    'verbose':  True,\n",
    "    'B': 3,\n",
    "}\n",
    "\n",
    "path = 'cache/1_28_exp1/result_list_nv.npy'\n",
    "\n",
    "\n",
    "if os.path.exists(path) and False:\n",
    "    pass\n",
    "else:\n",
    "    result_list_nv = runner(**exp_kwds)\n",
    "    np.save(path, result_list_nv)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "289ae40f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=[4, 3])\n",
    "\n",
    "result_list_nv = np.load(path)\n",
    "exp_1_plotter(plt.gca(), result_list_nv)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "9a08fc33",
   "metadata": {},
   "source": [
    "## Portfolio optimization"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "0429926f",
   "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": null,
   "id": "6446cf1f",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 2000/2000 [09:19<00:00,  3.57it/s]\n"
     ]
    }
   ],
   "source": [
    "import os \n",
    "\n",
    "config()\n",
    "\n",
    "exp_kwds = {\n",
    "    'crc':      crc,\n",
    "    'mean':     mean,\n",
    "    'sigma':    sigma,\n",
    "    'ntrial':  ntrial,\n",
    "    'lam_list': lam_list,\n",
    "    'nsample_list': nsample_list,\n",
    "    'verbose':  True,\n",
    "    'B': 3,\n",
    "}\n",
    "\n",
    "path = 'cache/1_28_exp1/result_list_pf.npy'\n",
    "\n",
    "if os.path.exists(path) and False:\n",
    "    pass\n",
    "else:\n",
    "    result_list_pf = runner(**exp_kwds)\n",
    "    np.save(path, result_list_pf)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "64df289d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=[4, 3])\n",
    "\n",
    "result_list = np.load(path)\n",
    "exp_1_plotter(plt.gca(), result_list)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "2da2fd0f",
   "metadata": {},
   "source": [
    "## Shortest Path"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "a76a33bf",
   "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": null,
   "id": "20430f52",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 2000/2000 [07:08<00:00,  4.67it/s]\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "\n",
    "config()\n",
    "\n",
    "exp_kwds = {\n",
    "    'crc':      crc,\n",
    "    'mean':     mean,\n",
    "    'sigma':    sigma,\n",
    "    'ntrial':  ntrial,\n",
    "    'lam_list': lam_list,\n",
    "    'nsample_list': nsample_list,\n",
    "    'verbose':  True,\n",
    "    'B': 3,\n",
    "}\n",
    "\n",
    "path = 'cache/1_28_exp1/result_list_sp.npy'\n",
    "\n",
    "if os.path.exists(path) and False:\n",
    "    pass\n",
    "else:\n",
    "    result_list = runner(**exp_kwds)\n",
    "    np.save(path, result_list)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "84aa08a7",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=[4, 3])\n",
    "\n",
    "result_list = np.load(path)\n",
    "exp_1_plotter(plt.gca(), result_list)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "72b95fb6",
   "metadata": {},
   "source": [
    "# Fig"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "ccc591cd",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "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_exp1/result_list_lp.npy', 'cache/1_28_exp1/result_list_nv.npy', 'cache/1_28_exp1/result_list_pf.npy', 'cache/1_28_exp1/result_list_sp.npy']\n",
    "title_names = [ 'Linear Programming', 'Newsvendor', 'Portfolio Selection', 'Shortest Path']\n",
    "for i in range(len(paths)):\n",
    "    result_list = np.load(paths[i])\n",
    "    exp_1_plotter(axes[i], result_list,\n",
    "                  add_label = True if i==0 else False,\n",
    "                  s = 80)\n",
    "    axes[i].set_title(title_names[i])\n",
    "    axes[i].grid()\n",
    "    axes[i].set_xlim(-0.05, 1)\n",
    "    axes[i].set_xlabel('Validity')\n",
    "    axes[i].set_ylabel('Accuracy (negative error)')\n",
    "plt.tight_layout()\n",
    "fig.legend(loc='lower center', ncols = 3, bbox_to_anchor = [0.5, -0.1])\n",
    "plt.savefig('fig/exp1.pdf', bbox_inches = 'tight')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0a48f184",
   "metadata": {},
   "source": [
    "Possible extension: examine biased models?"
   ]
  }
 ],
 "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
}
