{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "8465a86f",
   "metadata": {},
   "source": [
    "# Runner"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "6ecc518d",
   "metadata": {},
   "outputs": [],
   "source": [
    "from utils.setting import config\n",
    "import numpy as np\n",
    "from model.sampler import GaussianMixtureSampler\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from model.conformal_dra import ConformalizedDecisionRiskAssessment\n",
    "from model.naive_dra import NaiveDecisionRiskAssessment "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "8b7fe16a",
   "metadata": {},
   "outputs": [],
   "source": [
    "config()\n",
    "\n",
    "def synthetic_experiment(mu1, scale1, weights1,\n",
    "                         mu2, scale2, weights2,\n",
    "                         ncal, k, A, b):\n",
    "    # true model\n",
    "    sampler_kwds = {\n",
    "        'mu':       mu1,     # [ ncomp, data_dim ] np, the mean of GMs\n",
    "        'scale':    scale1,  # [ ncomp ] np, the variance of GMs \n",
    "        'weights':  weights1 # [ ncomp ]\n",
    "    }\n",
    "    sampler     = GaussianMixtureSampler(**sampler_kwds)\n",
    "    # misspecified model\n",
    "    model_kwds = {\n",
    "        'mu':       mu2,     # [ ncomp, data_dim ] np, the mean of GMs\n",
    "        'scale':    scale2,  # [ ncomp ] np, the variance of GMs \n",
    "        'weights':  weights2 # [ ncomp ]\n",
    "    }\n",
    "\n",
    "    Ycal        = sampler.sample(ncal)      # [ ncal, data_dim ]\n",
    "\n",
    "    # Point prediction model / Predict-Then-Optimize Model\n",
    "    point_model_kwds = {\n",
    "        'mu':       mu2.mean(0)[None, :], # [ 1, data_dim ] np, the mean of GMs\n",
    "        'scale':    np.array([1e-5]),\n",
    "    }\n",
    "\n",
    "    # Initialize DRA Models\n",
    "    true_kwds = {\n",
    "        'A':    A,\n",
    "        'b':    b,\n",
    "        'kwds': sampler_kwds,\n",
    "        'boundary_scale':   10\n",
    "    }\n",
    "\n",
    "    kwds = {\n",
    "        'A':    A,\n",
    "        'b':    b,\n",
    "        'kwds': model_kwds,\n",
    "        'boundary_scale':   10\n",
    "    }\n",
    "\n",
    "    naive_kwds = kwds\n",
    "\n",
    "    point_kwds = {\n",
    "        'A':    A,\n",
    "        'b':    b,\n",
    "        'kwds': point_model_kwds,\n",
    "        'boundary_scale':   10\n",
    "    }\n",
    "\n",
    "    # All baseline models\n",
    "    true_dra    = NaiveDecisionRiskAssessment(**true_kwds) \n",
    "    naive_dra   = NaiveDecisionRiskAssessment(**naive_kwds)\n",
    "    dra         = ConformalizedDecisionRiskAssessment(**kwds)\n",
    "    point_dra   = ConformalizedDecisionRiskAssessment(**point_kwds)\n",
    "\n",
    "    # Two models that needs to calibrate first\n",
    "    dra.calibrate(Ycal)\n",
    "    point_dra.calibrate(Ycal)\n",
    "\n",
    "    a = dra.get_prob(K = k)\n",
    "    b = naive_dra.get_prob(K = k)\n",
    "    c = point_dra.get_prob(K = k)\n",
    "    d = true_dra.get_prob(K = 10000)\n",
    "\n",
    "    return a, b, c, d\n",
    "\n",
    "def conservativeness_rate(r, r4):\n",
    "    '''\n",
    "    Conservativeness rate\n",
    "\n",
    "    Args:\n",
    "    - r:    [ num_seq, num_decision ], estimated matrix\n",
    "    - r4:   [ num_seq, num_decision ], true_prob matrix\n",
    "    '''\n",
    "    mask = r <= r4      # [ num_seq, 3 ]\n",
    "    out = mask.mean(1)  # [ num_seq ]\n",
    "    return out \n",
    "\n",
    "def relative_accuracy(r, r4):\n",
    "    '''\n",
    "    Relative accuracy\n",
    "\n",
    "    Args:\n",
    "    - r:    [ num_seq, ntrial, num_decision ], estimated matrix\n",
    "    - r4:   [ num_seq, ntrial, num_decision ], true_prob matrix\n",
    "    '''\n",
    "    mask    = - np.abs(r - r4)  # [ num_seq, ntrials ,3 ]\n",
    "    out     =   mask.mean(-1)   # [ num_seq, ntrial ]\n",
    "    return out\n",
    "\n",
    "def true_positive_rate(r, r4):\n",
    "    '''\n",
    "    True postiive rate\n",
    "\n",
    "    Args:\n",
    "    - r:    [ num_seq, ntrial, num_decision ], estimated matrix\n",
    "    - r4:   [ num_seq, ntrial, num_decision ], true_prob matrix\n",
    "    '''\n",
    "    mask_est =  r > 0\n",
    "    mask_true = r4 > 0\n",
    "    TP_est = np.logical_and(mask_est, mask_true).mean(-1)\n",
    "    return TP_est # [ num_seq, ntrial ]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b6f10de3",
   "metadata": {},
   "source": [
    "# Visualization"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "5eee0ac8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1120x280 with 5 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "offset = 0.2\n",
    "\n",
    "# Probabilistic setup\n",
    "sampler_kwds = {\n",
    "    'mu':       np.array([[-3, 0], [3, 0]]),    # [ ncomp, data_dim ] np, the mean of GMs\n",
    "    'scale':    np.array([2, 2]),           # [ ncomp ] np, the variance of GMs \n",
    "    'weights':  np.array([0.5-offset, 0.5+offset])              # [ ncomp ] np, the weights of GMs \n",
    "}\n",
    "\n",
    "model_kwds = {\n",
    "    'mu':       sampler_kwds['mu'],    # [ ncomp, data_dim ] np, the mean of GMs\n",
    "    'scale':    sampler_kwds['scale'],           # [ ncomp ] np, the variance of GMs \n",
    "    'weights':  np.array([0.5+offset, 0.5-offset])              # [ ncomp ] np, the weights of GMs \n",
    "}\n",
    "\n",
    "point_model_kwds = {\n",
    "    'mu':      (model_kwds['mu'] * model_kwds['weights'][:, None]).sum(0)[None, :],            # [ ncomp, data_dim ] np, the mean of GMs\n",
    "    'scale':   np.array([1e-5])             # [ ncomp ] np, the variance of GMs \n",
    "}\n",
    "\n",
    "sampler     = GaussianMixtureSampler(**sampler_kwds)\n",
    "model       = GaussianMixtureSampler(**model_kwds)\n",
    "point_model = GaussianMixtureSampler(**point_model_kwds) \n",
    "\n",
    "# Model setup\n",
    "A = np.array([\n",
    "    [np.sqrt(3),    -1],\n",
    "    [-np.sqrt(3),   -1],\n",
    "    [0,             1]\n",
    "])\n",
    "b = np.array([2, 2, 1])\n",
    "\n",
    "init_kwds = {\n",
    "    'A':    A,\n",
    "    'b':    b,\n",
    "    'kwds': model_kwds,\n",
    "    'boundary_scale':   10\n",
    "}\n",
    "\n",
    "init_point_kwds = {\n",
    "    'A':    A,\n",
    "    'b':    b,\n",
    "    'kwds': point_model_kwds,\n",
    "    'boundary_scale':   10\n",
    "}\n",
    "\n",
    "init_true_kwds = {\n",
    "    'A':    A,\n",
    "    'b':    b,\n",
    "    'kwds': sampler_kwds,\n",
    "    'boundary_scale':   10\n",
    "}\n",
    "\n",
    "dra         = ConformalizedDecisionRiskAssessment(**init_kwds)\n",
    "naive_dra   = NaiveDecisionRiskAssessment(**init_kwds) \n",
    "point_dra   = ConformalizedDecisionRiskAssessment(**init_point_kwds)\n",
    "true_dra    = NaiveDecisionRiskAssessment(**init_true_kwds)\n",
    "\n",
    "# get probability visualizations\n",
    "xx, yy = np.meshgrid(np.linspace(-5, 5, 100), np.linspace(-5, 5, 100))\n",
    "xx_, yy_ = xx.flatten(), yy.flatten()\n",
    "xy = np.stack([xx_, yy_], 1)          # [ ngrids, 2 ]\n",
    "zz_sampler  = sampler.pdf(xy).reshape(xx.shape)\n",
    "zz_model    = model.pdf(xy).reshape(xx.shape) \n",
    "\n",
    "plt_scale = 0.7\n",
    "fig, axes = plt.subplots(1, 3, figsize = [16 * plt_scale, 4 * plt_scale])\n",
    "\n",
    "# plt.figure(figsize=[4, 3])\n",
    "ax = axes[0]\n",
    "ax.set_title(r'Decision space')\n",
    "ax = dra.plot_feasible_region(ax, vertice=True)\n",
    "ax.set_ylim(-2.2, 1.5)\n",
    "ax.set_xlim(-2.5, 2.5)\n",
    "# ax.legend(bbox_to_anchor = [0.9, -0.2], ncol = 2)\n",
    "ax.legend(loc=  'center')\n",
    "ax.set_ylabel(r'Second dimenison $z_2$')\n",
    "ax.set_xlabel(r'First dimenison $z_1$')\n",
    "\n",
    "ax = axes[1]\n",
    "ax = dra.plot_inverse_feasible_region(ax)\n",
    "ax.text(-3, -4, 'Decision A', va = 'center', ha = 'center', color = 'red')\n",
    "ax.text(3, -4, 'Decision B', va = 'center', ha = 'center', color = 'red')\n",
    "ax.text(0, 4, 'Decision C', va = 'center', ha = 'center', color = 'red')\n",
    "ax.set_xlim(-5, 5)\n",
    "ax.set_ylim(-5, 5)\n",
    "ax.set_ylabel(r'Second dimenison $y_2$')\n",
    "ax.set_xlabel(r'First dimenison $y_1$')\n",
    "ax.set_title('Real data distribution')\n",
    "contours = ax.contourf(xx, yy, zz_sampler, 10, cmap = 'Blues', zorder = -1)\n",
    "fig.colorbar(contours, ax=ax, label = 'Density')\n",
    "\n",
    "ax = axes[2]\n",
    "ax = dra.plot_inverse_feasible_region(ax)\n",
    "ax.text(-3, -4, 'Decision A', va = 'center', ha = 'center', color = 'red')\n",
    "ax.text(3, -4, 'Decision B', va = 'center', ha = 'center', color = 'red')\n",
    "ax.text(0, 4, 'Decision C', va = 'center', ha = 'center', color = 'red')\n",
    "ax.set_xlim(-5, 5)\n",
    "ax.set_ylim(-5, 5)\n",
    "ax.set_ylabel(r'Second dimenison $y_2$')\n",
    "ax.set_xlabel(r'First dimenison $y_1$')\n",
    "ax.set_title('Model distribution')\n",
    "ax.scatter(*point_model_kwds['mu'].T, color = 'black', marker = 'x', lw = 3, zorder = 99)\n",
    "ax.text(point_model_kwds['mu'][0, 0], point_model_kwds['mu'][0, 1] - 0.5, 'Mean', ha = 'center', va = 'top', color = 'black', zorder = 99)\n",
    "\n",
    "contours = ax.contourf(xx, yy, zz_model, 10, cmap = 'Blues', zorder = -1)\n",
    "fig.colorbar(contours, ax=ax, label = 'Density')\n",
    "\n",
    "plt.tight_layout()\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "00fdb4dd",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAmsAAAENCAYAAABQCSI+AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8fJSN1AAAACXBIWXMAAA9hAAAPYQGoP6dpAABHX0lEQVR4nO3df3Ab9Z0//qfkH4p/xJblhBZwmmb9AUqaBCI7c8z0Ci2WQ68dSA/k+Ds3R6/020gFQgkcSDVTplBojQRMGAoUKcy1JXO9iyVgmh49QEpLwt0MM46XNPz69lJtyCdp0iNElpSQxCG2vn8su5ZsyZZtSbsrPR8zntir1e57N7tvvfR+v97vNaXT6TSIiIiISJfMWheAiIiIiPJjsEZERESkYwzWiIiIiHSMwRoRERGRjjFYIyIiItIxBmtEREREOsZgjYiIiEjHGKwRERER6Vit1gWg0pEkCYFAAH6/H4IgwO12AwBOnDgBAOjs7ITL5dKyiDSLYDCIQCAAURRhtVohCAK6u7sBAF1dXfz/o6qRSCQwODiIdevWAQDi8TgA8B4wAFEU4fV6sXfvXmzcuBGBQCDrdUmS0Nvbi0AgAIfDoVEpdS5NFc/hcKRdLte05S6XK+10OouyD4/HU/C25rJutRodHU3b7fb0yMhIOp1Op2OxWDoUCqV9Pl/abrfz/FFVGRkZSTscjvTo6GjW8lAolHY4HPPebiAQWGDJqBBKPRaJRNIA0h6PZ9o6Lpcrbbfby100w2A3aBULBAJIJBIIBoML3lZvby/6+/uLvm618nq9cLvdsNvtAABBEOB0OmG322Gz2RAKhTQuIVH59PT0wOv1wmq1Zi13Op1ZvQZzFYlEilA6mo1SjzkcDgQCgZyfOYFAAIIglLtohmFKp/ls0ErX29sLQRCmNT0Dcjeb1+vF6OioBiWjuZAkCW63mx8wVFW8Xi+i0ShGRkZyvi5JEjo7OxGLxeb0Ya+kGOTbLpWOyWRCKBSC0+nMWu71euHz+TQqlb4xZ63Kbdy4EW63G6Ioqt9+lBw3SZLUFh3F1G9ELpdLzUeQJAmxWCxrXUEQkEgkIEkSrFYruru7c66buV9AroA9Hg8AIBqNwuv1AgC2bdsGSZIgSRJOnDhR0I2dqxyCIMDr9cJms6Gvrw+AnBMzdZtKy6MgCIhEIlmtXTOdk6nHlOtczkUikUBfXx927do1r/cTGVU4HJ52z2VS6oxwOAyPx5OzPvJ6vQgGg/D5fHC5XIhGo4hEIpAkCX6/HwDU+gYo7J4GZq+n4vE4RkZG1NYkm82GHTt2YGBgYNoxzaWuMHqdZrfbMTw8nPXecDjMHpeZaN0PS6WXL2dNAUDN3XA6nelQKJT1XiXfwOfzZeUahEIhdd2RkZG0IAhZr2Xmg8RiMfXvqesq+41EIlnrZ+aiRCKRtCAIWesIgqCWLZ+ZyhEKhdIA0rFYTH3d4/FknSuPx5P1uiAIWXkzM52Tmc5loZQ8DqvVmhYEgblqVHUApH0+34zrTL03lPoik8PhyKoLIpFIzhyp2e7p+dRTU7c3db9zqSuMXqel07nzpWf6jCLmrFEGSZIQDoezvu309fWpuW1erxcDAwPqazt27IAkSXm3FwqFkEgkACBrFONUoigiGo1mjQISBAHxeBzRaBQAYLPZIEnStHVm2v9s5bBarbDb7VldJwMDAwgGg+p2JUlSy6C8X/l7pnMy07mcC5/PB5vNhoMHDyIWi2Hbtm1zej9RJVBGsBfKZrNNWzY13y2Xme7phdRTmex2e1a9NZ+6wsh1GiDPRJB5DoLBoNoaSLmxG7TKZd7w0WgUVqs160aOxWKQJAl79+6F1WrNqvBmSnJ3Op0IBAJoa2uD3W5Hf39/VjdDpr179+bMNVGa6ZWKb+o6VqtVHb5fjHIo27RarRBFEYIgqMeodDfE43F1nzOdk2AwmPdcFkrp+gyFQuo+CvnAIaokhXwpU/I5F2q2e3q+9VRnZ2fefc5U7+Zi5Dotk/LZI0kSRkZGOAXLLBisVbm9e/cCALq7u9WbOfNbofJ7OBye87YjkYj6bVT59pWrUlFu2lIptBy5iKKIwcFB9Pb2YuPGjVkV8UzlTiQSec9lIXIFagrlW/5889+IjMThcGQFCFOJoqiuN5PZ6hlJkma9p0thPnWFEeu0TJl1mtfr5ej2ArAbtMoFAgH4fD61+TzXt6REIgG73Z7zRs53cysJqna7HR6PByMjI9ixY0fOdR0OR879SpKkToA5X3MpByAfT+bx9vT0YGBgAC6XC1arNevb4EznZKZzOZuZAjVAngyXLWxULXw+H+LxeN4vjF6vFy6Xa8ZBCABmbYVXBlnlu6dLVU/Nta4wYp2Wi9VqRV9fX1aXK+XHYK2K+f1+JBIJ9RuZw+FAd3f3tEpxaGhIHfWjjJwC5Jt0aGgo57Zzzd+Wb1i93W6f9u1Z+bY8U+tRoYHPTOUQRTFrO4ODg3C5XGrXi1JJKZQKX2mFzHdOZjqXM5EkCV1dXRAEAcFgEOFwGNFoVK0kg8EgNm7cyFm+qWpYrVaEQiEMDg5OCxaUe3vqqPCpXadKl1/mvZ65jhKozHRPl6qemmtdYbQ6Ld8xiKKI/v7+WYNsknGetQo20+OmEokEOjs7czade71edHZ2qkm6mRWR1+tFe3u7mlirTN0xODiIcDgMn88Hj8ejVibKNiRJgsvlgiRJ09adul9AzoVQKuBc2/f7/RgcHIQgCBgYGMhbWeYrh5J7oSTTKjkdAKaVCZDnqgOgDo/v7+9X95nrnBRyLqdKJBLYtGkTbDYb4vF4Vk6JUsG63W7mdlBVSnz6uKmp+V/57gcl4FACmR07dkAURfh8vqx7F5j+6L1C7mmg8HpKmbLIZrOp63g8HrXuydzubHWFkeo0AGpwq3zBzGzdYypH4RisUdVSKjZOiklElUCPdZoyv53P51MbEPgM0LnjAAMiIiIqCZfLhUgkgk2bNsHhcGBkZIQ5t/PAYI2IiIhKhqM9F44DDKgqRaNR+Hw+iKKYlUxLRGRErNMqG3PWiIiIiHSMLWtEREREOsZgjYiIiEjHKnaAwcTEBI4ePYrFixfDZDJpXRwiKpJ0Oo2TJ0/ioosugtlcHd83WZ8RVaZC67OKDdaOHj2KZcuWaV0MIiqRw4cPo6OjQ+tilAXrs8q3BMDxKcuWAvhIg7JQ+c1Wn1VssLZ48WIA8gloaWnRuDREVCypVArLli1T7/FqwPqs8pk++giY8nQGKRZDeskSjUpE5VBofVaxwZrSVdDS0sLKjagCVVN3IOuzKjA2Nm3R4sWLAf5/V4XZ6rPqSPggIiIiMigGa0REREQ6xmCNiIiISMcYrBERERHpGIM1IiIiIh2r+mBNFEW43W6YTCZ4vV4Eg0H4/X643W6Ew+EFb7+rq2vW7RSyznzkO7a+vr6S7A+iCLjdgMkEeL1AMAj4/fKyYuyvq2v27RSyznzkOzavF2hrA6LRIu2mcq/HqURRhNfrLfl+iIgML12hkslkGkA6mUzOuu7o6GgaQHp0dDRrudPpTPt8vgWVIxKJTNvufNaZr1zHpiyLRCKl2GE6Dcj/ZnI60+kFnst0JDJ9u/NZZ75isdzHNjKSTgcCRdtNJV+PmVwuV9pqtc75fXO5tytFNR5z1fnwQ7l+yfz58EOtS0UlVui9XfUtazPZtm0bvF4vEonEvLfhcDhgtVoXvM5CZW7farXCbrcjFAqVdJ9Ztm2TW6EWcC7hcACznadC1pkvmy33cru9NPubopKuR0C+DhOJBKJFapUkIqpUDNZmoAQ1wWBQ66IUVSKRgCRJ6OvrK99OrVY5qKmkcymKgCTJv2/cWPLdVdL1GI1G0d/fD4fDUd4vDUREBlSxTzAoFkEQMDw8rP4djUYhiqK63OfzAQAkSUIgEMC6desQj8exceNGSJKETZs2we12w+VyIZFIYGhoCIIgIJFIYHh4GP39/VnrAHIuTzQahSAIkCQJTqcTgiAgGo3C6/XC7Xarr0UikYI+7MLhMKxWq/qeXbt2wV6mFiGVIAAZ5xLRqBzwKMs/PZeQJCAQANatA+JxORCSJGDTJjlvzOWSW+iGhuT3JhLy+/v7s9cB5O1Ho/J6kgQ4nfLv0ajc0ud2T74WiQCFBA5KsLRjx+T6ZWiJAirnehRFER6PB263G5s2bUIgECjNCSMiqgRl6pYtu2LkrKXTcp6Qw+FIp9PpdCwWS9vtdvW1QCCQ9vl86dHR0bQgCOr7PR6Pmlvk8/nSgU/zmXw+X1aeWOZy5fdYLKbuT2G327O27XQ61dccDkd6ZGRk1mPLFIlE0g6HIx2LxfK+b97y5ayl03LemnJssVg6nXEu04GAnNM2OppOC8Lk+z2eyVw3n28yN8znk/PTMt8/dZ1YbHJ/Crs9e9sZ5zLtcMj5Z4Uem88n76PIKvl6VGTm3mGO+ZPVmL9VjGMeGRlJu1yuNIC0x+NRrxeXy5UOhUILLqPdbp91O4WsUwwjIyNpj8dT8v0UlQFz1ir5msp3bE6ns6j7K/TeZsvaLCRJgsPhAAAEAgHYbLasHJvh4WFYrVYIgqDm+QwMDOTcltPpRFdXFwRBQH9/v9pykSkQCExr8RIEAUNDQ3C5XGhvb0d7e7v6mtVqRTwen9MxORwOBAIBuN1uRCKROb13QSRJzikD5JYzmy17FOXwsNxCJQiTLVV5ziWcTnnkpyDILWo5ziUCgen5ZIIgt8i5XEB7u/yjsFrllrxCOZ2Tv0ejk8dWQpVwPUajUcRiMbU7VxAEhEIh9bioNOx2O3w+H4LBIAYGBrLyEvv6+iBJEjwez7y37/P50N3dveB1iiEQCGBoaEhtaabSqORrKt+xJRIJtLW1IRKJlLXOYs7aLCRJgtvtVv+22+1wOBxwOBxwuVwIhUJIJBLTEvhzJWjbbDaMjo5i27ZtOHHiRHlzxqZYt24d9u7dW96dSpLc7aiw2+UAx+GQg6dQSO7SzDx3VmvuLkabDRgdlQcunDgBaHEuBUH+ASZz10qsEq5HURQRCATgcrngcrng8/kwNDRUln3rxUIHihQbB69QsVXSNaX5AD0wWJuRkrcjfPqB3N/fP+3mj0ajcDqdEEVx2nKFcrEODg5CkiQ1Ys+8AJR1cu1DFEVsLHICeyQSKfo2Z6TkkSnBTX//9LnJolG5tWrKucxaT7nxBwflAMlul3PdMm9WZZ1c+xDF+Q8GyNdilEgAIyPz2+YcVOr16HQ6q+qDVRRF+P1+rYuRhYNXqNgq6ZrKpMkAPXCAgfotH5A/vDo7O5FIJBCLxdDb2wtnRleX8qHm9Xqxbt06AJNRfSAQmLZcFEXs2LEDNpsNTqcT7e3tiEajsNlsiMfj6O/vn7aOsg+/368mjYdCIVitVnVdZfuSJKnlFwRB/RDPdWxer1c9tuHhYQiCUPykblGUux7lkwl0dsqBTCwG9PZmdxsqQZbXKw8kkA9KDroCgenLRVFO6LfZ5O20t8uBmM0mB1H9/dPXUfbh908OYgiF5H0o6yrbl6TJ8me2mM10bIB8bMFg/u7aOZ/Cyr0eo9EofD4f4vE4HA6H2r0aDAZhtVrVwQq5umMriSRJ086NHnDwChVbpVxTuhigV7QsOZ2pxiRkompg5HtbSUzOHACSy9mzZ9PJZFL9OXz4cFGOmYNXdMyAAwzS6cq+psoxQI8DDIiIdGRqLuFMBgcH8eCDD5a2QFNw8AoVWyVcU1NpNUCPOWtERGUwNDRUcNAwMDCAZDKp/hw+fLjEpePgFSq+SrimctFigB6DNSKiEotGo3MalGGxWNDS0pL1U0ocvELFVqnXFKDBAD1wgAERUVlktvBIkoTBwUH09/eXLVGZg1cqf/BKuVXyNVX2AXqzMKXT6XRZ91gmqVQKra2tSCaTJf9WSkTlUwn3tslkQiwWK3hUaCUcM83i+HHggguyl334IbB0qTblobIo9N5mNygRUZkkEgl1jjWfzzet+4eIKBd2g5LxjY8Db7wBHDsGXHgh8OUvAzU1WpeKaBqr1QqPx7OgR/AQUfXRfcuaKIro6urSuhhFd+rUKTz00ENYtmwZampqsGzZMjz00EM4deqU1kUzlhdfBD7/eeCrXwX+4R/kfz//eXk5FYzXIxGRfuk6Zy0cDkMQBHR1dWGuxdRzjsepU6dwzTXXYN++fZiYmFCXm81mXHnlldi9ezeam5s1LKFBvPii/KSCqdeGyST/Gw4DN95Y/nIZjNGuRz3f26VSjcdcdZizVpUqImdNGd1RabZu3TrtgxEAJiYmsG/fPmzdulWjkhnI+Dhw553TAzVgctmWLfJ6NCNej0RE+qbrljWFyWSatWVtbGwMY2Nj6t+pVArLli3T5TfRZcuW4ciRI3lfv/jii3Ho0KEylsiAXn8dNQVMMDoejQJf+Urpy2Ngy5cvx1/+8pe8r3d0dJRlUtZCVWMrUzUec9Vhy1pVKvTerpgBBlo8nmW+jh49OuPrx44dw0cffVSm0hjTogMH0FrAeqcOHMDZVatKXh4jO3bs2Iyvz3a9EhFRaem6G3QutHg8y3xddNFFM77+mc98pkwlMa7xqd9AF7heNZvtepvteiUiotKqmGCt3I9nWQiXywWzOfepN5vNuPnmm8tcIuP55KqrMH7hhUgrgwmmSJtMGL/oInxy1VVlLpnx3HzzzTNej5z1nYhIWxUTrBnJXXfdhSuvvHLaB6TZbMaqVauyHnxLedTU4OTDDwPAtIBN+fvkQw9xvrUCuN1urFq1Kuf1eOWVV+Kuu+7SqGRERAQYKFhTHtRaCZqbm7F792488MAD6OjogNlsxsUXXwyPx4OXXnoJTU1NWhfREMa+8Q0kn3sOE5/9bNbyiQsvRPK55zD2jW9oVDJjaWpqwssvv5x1PXZ0dOCBBx7Q3bQdRETVSNejQaPRKCKRCPx+PzweD9atW5f1YNiZGHH01JkzZ5BKpbQuhvGMj6PuzTdR8+GHGL/gArnrky1qBTOZTLDZbKitNcZ4IyPe2wtVjcdcdTgatCpVxGhQh8MBh8MBn8+ndVHKYtGiRTh9+jTOnz+vdVGMpaYGn3zpS/hE63IY1KJFiwwTqBERVSPDdINWA5PJxC4nKiuTycRudyIinWOwpjMWiwX19fVaF4OqRGNjI2rYZUxEpGsM1nSIrWtUDmazGY2NjVoXg4iIZsFgTYfq6uqwaNEirYtBFa6pqSnv/GpERKQfrKl1qqmpCaY8E74SLVRtbS0aGhq0LgYRERWAwZpO8cOUSolfBoiIjIPBmo6xm4pKgd3sRETGwkhAx5gATqXAASxERMbCYE3nOLUCFdOiRYs4NQzRbEQRcLsBkwnweoFgEPD75WXh8MK339VV2HZ++9uF72uqfMfm9QJtbUA0Wvx90oLp+nFTC1FJj2fhY6ioGIz2WKl8KuneLlQ1HrPmEgk5eBkdBazWyeV9fcC6dYDHM/9tR6NAd3f2dnM9burAAeD//J/57ycfSQI6O6cfmygCe/cCLlfx90k5FXpvs2XNAPg4ICqGhoYGXkdEC7Vtm9wKlUjMfxsOR3aQlE9r6/z3MRObLfdyu700+6MFY7BmAHwMFS2U2WzmY6WIisFqlYOaYFDrkhSPKMqtbQCwcaO2ZaGc+DXbIJTHUJ07d07ropABNTY2cmQxUbEIAjA8PPl3NCoHPMpyn09eLklAICB3m8bjciAkScCmTXLemMslt9ANDeVu7Xr+eeCf/1n+XRTl/QiCvA2nU/49GpVb+tzuydciESAUmv04lIBzx47J9Qtp8aOyY7BmIM3NzRgdHUWFphlSidTU1HBUMVGxKd2gkiQHSyMj8t/xuJyw73IBvb3ycqt1Mpnf4wH6+ye3EwzKLXVXXJF/X8o+IpHJZV1dwK5dcpeqw5EdoIVCcnA3W7emy8XgzCAYrBmIMj/WmTNntC4KGQgnwCUqMkmSAyRAbjmz2bJHUQ4Py0GQIEwGQwMDubfldMqB1+c+l39/gcD0wEsQ5BY5lwtob5d/FFarHDQWyumc/D0anTw20g0GawbT1NSEs2fPsnWNClJbW8sJcImKTZLkbkeF3Z4d4LhccutaZqtVvhYsm00elam0kmlBECZ/V3LXSFeYxGIw7NKiuWhubmarmk6Iogi/3w+/34++vj4kFjKakLSj5JopAU5///S5yaJRubVKFKcvVyj//4ODcoC0Zs30fSWT+fchivMfDJCv1S2RmOzOJV1hy5oBNTY24syZM5iYmNC6KKRj9fX1sFgsWheDPhWNRuH5dG4uv9+Pnp4ejPCDUZ9EUe56BORgqrNTDmRiMTkPLbPb0G6XBxR4vfJAAmByao5AYPpyUZQT+m02eTvt7XIglmtand275UBO2YffPzmIIRSS96FsT9m+JE2WXxCyW83yHRsgH1swmL+7ljTFSXEN6vTp0zh58qTWxSCdMplMaGtrQ11dndZFKToj3tuiKKKnpwejo6MAAEmS0NnZiVgsBmHqh2kORjxmmqNck+J++CGwdKk25aGyKPTeZsuaQTU0NOD06dMYHx/XuiikQxaLpSIDNaOy2+3Ytm2b+rfSBWrLMznp2NgYxsbG1L/5BBOi6sacNYPiRLmUD68NfXJmdJ3t2LEDDocD1jxJ54ODg2htbVV/li1bVqZSEpEeMVgzMLaeUC4NDQ2oqanRuhiURyKRQDgcRmiGSUsHBgaQTCbVn8OHD5exhESkN+wGNTClBUXJgyHiY6X0z+v1IhKJ5G1VA+QvYhwcQkQKtqwZHEf8UaampiY+VkrH/H4/vF4vBEFAIpHg9B1EVBDW6hWAc2kRIM/B19DQoHUxKI9wOAy73a4GakNDQzO2rhERKdgNWgGUWer5GKrqxqBdvyRJQl9fX9Yyq9UKl8ulUYmIyEgYrFUIPoaqutXV1bE7XMcEQeC9SUTzxmCtQiiPofr444+Lsr3jx4/jvffew/vvv48rr7wSLS0tGBsbQyqVwvvvv49bbrmlaMFBOBzG2rVr0dnZiSNHjmDPnj34m7/5G3QqM2tnOHLkCN58802sXLkSK1euLMr+5yqzvHrBVjUiosrFYK2CFPMxVEuXLsXatWvx/vvvY+3atVmB2dKlS5FKpbC0SDNrX3XVVeq2Ojo6cPHFF+ddt6OjQ/MgKbO8emCxWFBfX691MYiIqEQ4wKCCFHvahnwtZ52dnVmzqy9UR0dH1r703p03tbxa4gS4RESVj8FahWloaEBtrgcCF8Hx48cxNjYGi8XC5xPqxKJFi0r2/01ERPrAWr7CKC0tpZi/KRaLYe3atQCAlpYWHDlyBMePH0dLSwuOHz+Oq666Sl3PYrEglUohlUqpy8fGxhCLxdT8t+PHj6OzsxO7d++eloN25MgRWCwWdb2pXbGZ8pVj6jp79uzBlVdeCQB477334HQ6ZzyGVCoFi8WilvP48ePo6OiYVt7jx4/jyJEjaGlpQSqVQmdnp3p+lPw65bUjR45g/fr1Rfn/MJlMnACXiKgKsGWtAhU7h+m9997DW2+9hSNHjqjLUqkU3nzzTTXRvqWlBW+99RYAIBKJoKWlBStXrlQDNGU7LS0tat5ZS0sLli5dmjMHLXO9jo4OvPbaaznLNlM5Mim5cMePH8fKlSuxdu3avO8dGxvD7t27sXbtWqxcuRJ/+ctf0NLSgrVr104r79RtrF27Fq+99hrGxsbQ0dGBjo4OHDlyBB0dHer5OH78+IL+PxSNjY18rBQRURVgy1qFam5uRjweL8q2Vq5cCYvFkpVU/95778FisWQFcEoQoowUTaVS6ghSQM51C4fDaGlpQWdn54yjOTNb0To6OvAf//EfahdsppnKkWubyvs7Ozvx5ptvFvzefN57771pgw1aWloQi8VynjeltXChzGYzGhsbF7wdIiLSPwZrFaqurg6LFi3C2bNni7bNjo6OrL+XLl2atUwJvt566y1YLBa1tUphsVjwne98B8ePH0csFsNrr72G66+/fsHlyleOXKbm2uV778qVK9XjuPzyy3WXo8fHShERVQ/W9hWsqalpQXNvzdQCpMyJlunIkSNqDtjatWvV3DTltbfeekud8uOqq67KaiWbuq/Mv48fP46LL7445/r5ylHIMc30XovFonaDKnl6ubaTaxsfffRRSacXqa2t5WOliIiqCFvWKpjyoX769Ok5v1eZFBcA3nzzzWnzmykB15tvvpk1RxqArK7Fzs5ONVdNWa50BSpJ+8qAhMyWOCUhX8nxUpLylfWV/c1UjkxKIKmMZJ3tvalUCr/+9a9RX1+vlm3lypXTyqts46233lIHKfT29qoDEzLLmkql8NFHH6nnY76tdQsNwomIyFhM6Qp9BkoqlUJrayuSyaTuurDKaWJiAidOnCjKRLnVIrN1EJgcRLBy5cqcgWA51dXVwWazaVoGrVXjvV2Nx1x1jh8HLrgge9mHHwI6moCbiq/Qe5vdoBWOiehzp4zeVCgDIpSBElriBLhERNVH992gkiQhHA5DEARIkgSXywWr1ap1sQxFeQzV+Pi41kUxBKVbU5k7DZBz1LR6FqmCj5UiIqpOug/W+vr6MDIyAkAO3DZt2oRQKKRxqYxFmTxVDy1DRpFrUIGW+FgpIqLqpetuUEmSsv4WBAHRaFSj0hgbH0tkbKV8jBgREembroO1aDQ6LZnaZrNBFMVp6yqTr2b+0CS2zBgXHytFRFTddB2s5Xu+Za6Z+QcHB9Ha2qr+LFu2rMSlMx7mPBkTJ8AlIqpuhvwEyBXEDQwMIJlMqj+HDx8uf8EMoLm5mXN0GUhNTQ1H8xIRVTldJ8FYrdZprWjxeDznaNDM5z5SfnV1dbBYLEV9DBWVDifAJSIiXbesORyOnMu7u7vLXJLKwtY1Y6itrcWiRYu0LgYREWlM18GaIAhZf0uShO7ubs6ztkA1NTV8tqQBMKgmIiJA592gABAKheD1erFu3ToMDw9zjrUiaWpqwtmzZ/kYKp1SnklKRESk+2BNEAT4fD4AgNPp1Lg0lcNsNqOpqQknT57Uuig0BadZISKiTLruBqXSamhoQE1NjdbFoCksFgvq6uq0LgYREekEg7UqxhYc/eH/CRERTcVgrcqxFUdf2NpJRERTMVircmzJ0Q8lj5C0sWvXLnR3d+PWW2/FBx98AAB44YUXcOutt2pbMKoa4zDjdVyDf8P/g9dxDcbHtS4R6cWCgjVWbpWBIw/1obGxkY+V0lAkEkEoFILT6YTH48G+fftw0003IRqNFmX7kiTB7/cjHA7D7/fnfZweVacX/6Men8cH+Cpexz/g3/BVvI7Pd9nw4otal4z0YEGjQZXKTZIkeDwe3Hfffbjpppvwgx/8oFjlozJpbm7GuXPnkE6ntS5KVeJjpbS3bt06rFixAitWrEBPTw8effRRpNPpos3r2NfXh5GREQBy4LZp0yZORUQAgBdfBJz/bwvSWJy1/C/HzHA6gXAYuPFGjQpHurCgr/FK5dbT04OhoSFEIhG89dZbnLTWgDhbvrb4WCl9eOyxx9Tf7733XsTjccRisQVvV5KkrL8FQShaix0Z2/g4cOedgPw9OfsjOZ2W64QtW8Au0Sq34D6XUlVuVH4MGLRRV1fHQFkHbrrpJqxduzZrWU9Pj9oathDRaBQ2my1rmc1mgyiKOdcfGxtDKpXK+qHK9MYbwJEjAJC77k2ngcOH5fWoes0rWNu3bx+A0lZuVH7sitMGHyulrR/84AcYGBjA73//e/T09Ex7fcWKFQveR778tHg8nnP54OAgWltb1Z9ly5YtuAykT8eOFXc9qkzzCtZWrFiB3//+9wDkb4cDAwPTXidjYpJ7eVksFtTX12tdjKo2MDAAQRDw7LPPor29Hddddx0ee+wxddBUKeUL4gYGBpBMJtWfw4cPl7wsVH47d+6E1/utgtb1++/C+++/X+ISkV7N61P54MGDeOSRR7Bv3z6sXbsWGzduxHXXXVfsspEGOH1E+XDaFH1obW3Fpk2bMDQ0hBMnTmBwcBCvvfYaXC5X0Ua2W63Waa1o8Xg8b36vxWJBS0tL1g9VhomJCTzyyCO44IILsGHDBhw58m+wWI7DZMo3uCuNurpj2LfvSaxcuRKXX345du7cWdYyk/bmFaz19PTA7/djxYoV+OCDD7B3716cOHGi2GUjjTQ0NKC2VvePjTW8RYsW8TzrQCqVUnsKAMBut8PtdqsBW2Ze7nw5HI6cy7u7uxe8bTKGZDKJ73znO2hqasLAwABOnToFt9uNVGoUv/71UgAmTM2GMJnkL3X//u8X4n/+5//D+vXr8T//8z/YsGEDli5dikceeQQTExOaHA+V17yCtcHBQezduxetra0YHR2FKIrYtWtXsctGGjGZTGxdKzGeY/3weDx49tlncckll+DWW2/Fc889p47UXLt2bVHSOgRByPpbkiR0d3dz5HwVeP/993HttdfCZrPhF7/4BVpbW/H444/j1KlTePbZZ9Hc3Iwbb5Sn57j44uz3dnRMTttxySWX4NVXX0UymYTb7cbHH3+MgYEBNDY24pZbbuG8fRVuXsGay+VCX18fALkyEwQBo6OjRS0YaWvRokXMpSqhxsZGPlZKJ7q6ujA0NIQDBw7A4XBgdHQUHo8HyWQS3d3dRRv8EQqF4PV6EQ6HEQgEOMdahdu5cycuv/xyrFy5En/4wx9w+eWX43e/+x3++te/4u67756WG3zjjcAHHwB/+APw61/L/x48OH1+tebmZjz77LM4deoUtm7dCqvVil/+8pew2Wy49tprmddWoUzpIs2C+tZbb00bGaqlVCqF1tZWJJNJ5nvM07lz5xiEl4DZbEZ7ezsHcsxTKe7tF198ETfmmHVUL/Ua6zNjmJiYgN/vx+OPP46PPvoIZrMZDocDTz31FC655JKS7ffVV1/FPffcg3feeQcAcNlll8Hv9+OGG24o2T6pOAq9t4v2aaGHCo2Kq76+nvN/lUBTUxMDNZ3JFagBrNeoMIlEAt/5znfQ2NiIgYEBfPzxx3C73Ugmk3j11VdLGqgBwHXXXYe3334bf/7zn7F+/XocOHCAeW0Vhp8YNCNOlFtctbW1aGho0LoYRFQEU/PRrFYrtm7dmpWPVk6dnZ1qXtv3vvc95rVVEAZrNCMGF8XF4JfI+Hbu3IkvfOELaj7aF7/4Rbzyyiv461//ii1btmject7c3Iyf//znal5bW1ubmtf21a9+Fe+++66m5aO5Y7BGs2K3XXHwsVJExqXMj7Z06VJs2LABBw4cUKfSePvtt3U516jZbMaWLVtw7NgxvPLKK/jiF7+I119/HatWrcIXvvAF/OY3v9G6iFQgfgLTrMxmMx9DVQScAJfIeBKJBG655RbN8tGKJTOv7brrrsOBAwfwzW9+E0uWLMHg4CDz2nSOwRoVhFNNLAwfK0VkLJn5aL/85S81z0crls7OTrzyyitqXtvp06dx3333Ma9N5xisUUFmm8R1//5a3HvvYnz2s5/BQw81Y/v2Bjz1VCPuvXcxfvtby4L3v369bdbtFLLOfCz02PhYKSLj0Hs+WrFk5rU98cQTzGvTuaLNs6Y3nJeo+NLpNOLxOM6fP5/z9WTShMsuuwB/+tOHaG2dvKy++91WXHnlJ9i8+fS8971nTz2uuOKTrO3OZ535WsixNTQ08Bosomq8t6vxmMtpYmICPp8Pjz/+OE6cOKHOj/bMM8+gs7NT6+KVzdT52i699FL4/X5s2LBB45JVrrLPs0aVb74tRI8/nsLDDy9GMjn/UZBXX31u1iCskHWKbbZj42OliPQrMx/tvvvuw+nTp/G9731PzUerpkANmJ7X9uc//5l5bTrBYI3mZD65V62taaxZ8wm2b6+8KUBmO7ampibm+hHpzLvvvouvfvWraj5aW1ubmo/285//vOrTFjLz2m699dasvLZvf/vbzGvTAIM1mrPm5uY5zxX2uc+NY9++OvXvPXvq8dRTjfjtby146KHJivHQoRo89FAzfvtbC7Zvb0AyacL+/bVYv96mBkTJpAnbtzdgz5569f1T1wHkXDNlH0891YhDh2rUfSvr7tlTj+3bG/Dd77bO+3xMPTZFTU0N56gj0pHf/OY3+MIXvoBVq1bh9ddfV/PRjh07VlH5aMXS3NyMZ555Jiuv7Ve/+hVsNhu+8pWvMK+tjHhl0pzV1dXBYpl7In8qJQd4hw7V4OGHm7F582lcf/0YPv/5cTz1VCOSSRM2brTi+9//GNdfP4YPPqjB9u0NWLPmPG644ay6ne3bG7B8+Tiuvvqc+v6p60zdx+bNp7FpUyuSSROuvvocvvzlc9i9ux5XX30ON998BqmUHBTOl3JsmTg/HZH2JiYmMDg4iCVLluCb3/wmDhw4oHbx6XV+NL0xm8248847cezYMbz22mtYtWoVdu/ejVWrVuGyyy7jfG1lwE8Smpe5tq793/9bg9Wr5YEJzz/fAKt1Anv21GPPHrlLdd++OuzcuQjLl4+reWff//7HuPnmM9O2df31Y9i0qRXr19vw1FONWUGa4vnnG9T9KT73uXHs3ClPStvWNoErr/xEfa2lJY1EYn63Q+axKWprazkBLpGGEokEvv3tb+fMR3vllVeqLh+tWHp7e7F///6ceW0/+clPmNdWIgzWaF7m2sV36FANvvWtycBr9erzuPrqc2rL1nPPJZFMmtDSMjlAoLU1nXPAgNU6gT/96TgeeyyF0VEzNm2afxdmMUw9NmB+XcVEtHCZ+Wi/+tWv0NbWhieeeIL5aEWWK6/thz/8IfPaSoTBGs1bod189967GP/4j2ewfPk4AGDDhrN4443sQQp79tTj+uvH8PbbtdOWK5QRl08+2YRDh2qwZs153H//qawAT1kn1z7efrs2ZyvcQkw9NgCor6+fVzcxEc3fb37zG1x22WU589HuvPNOpiSUSGZe25NPPsm8thLhPGu0IKdPn8bJkyexf38ttm9vwPbtjbj99o/x+c+PI5k04dChGjW3LNOePfXYvbte7YpUpt3ItfzQoRrcc08LrNYJPProSfz2txa0tqZhtU4gkTDDap3A8uXjWessXz6OPXvqsX9/LZYvlwcAbNhwFmvWnMf+/bW45x75mnjssZSa37Z6tRz8ZQZeAOZ0bCaTCW1tbairmz7ggIqjGu/tajzmQuSaH623txdPP/00uzk1FIlE8M///M94++23AcjztT3yyCP4+7//e41Lpj+F3tsM1mhB0uk0Tpw4gfHx8dlXrgKLFi1Ca6u23bKVrhrv7Wo85pkkEgls2bIF//7v/46xsTE0NDTg29/+Nvx+P7s5dSQWi2Hz5s147bXXMDExgfb2dtx1110YGBhgS+enOCkulQUfpTSJ54KotN5991185StfyZmP9swzz/D+05nOzk7853/+Z868tn/6p39iXtscMFijBbNYLOz2g/xYKU6AS1R8mfloypQRr732GvPRDCJXXtvzzz+v5rUpj7ei/HiF04KxRUmeh4iPlSIqnomJCfzkJz9R50fLnCpi//796O3tLcl+RRFwuwGTCfB6gWAQ8PvlZeHwwrff1TX7dgpZZz5KfWyzMZvNuOOOO3Ds2DFEo1E1+F69ejUuvfRSvPTSS6UvhEExZ42KJpFIYGxsbPYVK1BzczODtTKpxnu7mo5ZD/loiQTQ1gaMjgJW6+Tyvj5g3TrA45n/tqNRoLs7e7vzWWe+Snls83Hw4EHcdtttWXltW7ZswX333VcVLaYcYFBFlZtenD9/HvF4HBV6SeVVU1OD9vZ2zqtWJtV4b1fDMb/77ru4/fbbsWfPHqTTaXz2s5/FwMAANm/eXPYP7XwBTb7lRqLXYzt9+jTuvfde/OIXv8CZM2dgsVjQ39+PrVu3wmazlb9AZcIBBlR21Tprf1NTEwM1onl66aWX8uajff/739dV64rVCtjtcvdhpdH62BobG/H000+reW02mw3PP/88lixZgmuuuabq89r0cxdQRdAicBkfB/77v+vw0kuL8N//XYdyziJSV1dXlQEq0UJk5qPdeOON+POf/4yvfe1rJc9HKwZBAIaHJ/+ORuW8r3BYzgNTSJL8dzgsB0CJhJwz1tU1GRAlEvLv0ejk+6euA8jLlH34/fK2lX0r60aj8r99fcU7Ni0oeW1Hjx5V89r27NlT9Xlt839ydZmIoohNmzZhZGRE66JQAWpqatDY2IiPP/64LPt7+WULfvjDxTh2bHIU5oUXjuPhh0/iG98off4cHytFVLhEIoE777wTO3bsUPPRbr31VsPNj6bMOKEEZMrHUzwuB1MuF9DbKy+3WieT+T0eoL9/cjvBoNya5XBMvt9uz15H2UckMrmsqwvYtUt+n8MhvxYKya+FQnJwZ7cv7Nj0oKenB/v378fBgwdx++2349VXX8WNN94Im82Gu+66q2ry2gCdt6yFPx2eIoqixiWhuWhsbCzLDfTyyxZ897utOHYse19//asZ3/1uK15+ubSPfLJYLKivr599RaIq984776jzoz3//PNoa2vDk08+acj50SRpMhAKBACbTW7VikblZcPDwNCQ3Eql5H4NDMgB3FROp9wS1tUlB3kbN05fJxCYHngJgrwPAGhvlwcGKKxWOehb6LHpyYoVK/C73/0OJ0+exG233YazZ8/i/vvvR2NjI771rW8hPt8DNhBdB2tOpxN2PV45NKNyTGMxPg788IeLIY9lyG7ZSqflv++/f3HJukQ5XQnR7F566SVceumlWL16tZqPFolEcOzYMdxxxx2GbBWRJHmqC4XSMuZwyAFZKCS3TmUm6VutuZP2bTY5oX/bNuDEiYV1YRbD1GPTGyWv7eTJk/jZz34Gm82G7du3V0Vem/HulDzGxsaQSqWyfkg7DQ0NqK0tXS/7m2/Wfdr1mbsLMp024ejRGrz5Zmkm6120aFFJj48qiyiK8Pv98Pv96Ovrq+iZ2ycmJvDwww+r+WixWAxf+9rXIEkS9u/fD4fS52dAbrcckAmC/Hd//2SLmiIalVvMpnYIZa6n/PcPDk62Zvl800dn5tuHKOZuhVuIqcemZ2azGZs3b1bz2lavXl3xeW0V82kzODiIBx98UOti0KdMJhOampqQTCZLsv0PPyzsSQHyep8Udd/KsREVKhqNwvPpBFZ+vx89PT0Vl4cbj8dx1113ZeWj3XbbbXj00UfR2NiodfEKJopy1yMgB1OdnXLgFIvJeWhO5+S6SpDl9U52RTocctAVCExfLorAjh1yi5rTKXdhRqPy3/G4HJhNXUfZh98/OQAgFJL3oayrbF+SJssvCNMDr7kcm1H09PTgj3/8Y868tjvvvBP33XdfRXyxNsQ8ayaTada5u8bGxrImZE2lUli2bFlFz0tkBPF4HJ98UtxgCZBHf9500+xz77zwQhxf+lJx99/U1MQuUA0Zbc4xURTR09OD0dFRAIAkSejs7EQsFoNQYDOGno/5nXfewe2334433nhDnR/tvvvuw+23327Ibk4yttOnT8Pr9eJf/uVfcPr0adTX16O/vx9PPPGELudr0+2kuMFgELFYLO/rvb2905rJCwnWptJz5VZNzp07p35IFdP4ONDdvQR//atZzVHLZDKlceGFExge/gjFfFyn2WxGe3s7P4Q0ZMR7OxwOw/lps4Uoiujq6sLo6CiseWYfNcKXz5deeglerxcHDhwAAKxevRpbt25FT0+PxiUjkrvjn3nmGfz0pz/FsWPHYDKZ8OUvfxlPP/00Vq1apXXxVLoN1uaDwZqxJZNJnD17tujbVUaDAsgK2Ewm+Vp57rlk0afvWLx4saG6dCqR0e9tr9cLURQRyZyLYYoHHnggZ1qH1sc8MTGBn/70p3jiiSdw4sQJmM1mXHfddXj66aexYsUKzcpFNJNdu3bh7rvvxv79+wEAl1xyCQYHB3HTTTdpXLIKfIJBJSfkVrpSTZT7jW+M4bnnkvjsZyeyll944URJArXa2lo0NDQUdZtUXRKJBMLhMELKpFh5DAwMIJlMqj+HDx8uUwlzi8fj+Na3voXGxkbcf//9OHPmDG677TacPHkSv/vd7xioka4peW2SJOHrX/86JEmC0+lEe3s7fvzjH+P8+fNaF3FWum5Zi0ajiEQi8Pv98Hg8WLdundqVMBujf/uuNCdPnsTp06dLsu3xcXl06Icf1uCCC8Zx1VWfFLXrU9Ha2sqnFeiAXu7t+aR0uN1ueL3egnPVFFod89R8tAsvvBD33XcfbrvtNqYCkGHpKa+torpB50MvFTrJJiYmcOLECUxMTMy+sg7V1dXpMjm1Ghn13vb7/XA6nRAEQe0pyJezNlW5j5n5aFQNcuW1/e3f/i2eeuoprFmzpixlqLhuUDI2s9ls6Fwvjv6khQiHw7Db7WqgNjQ0VHCgVi7K/Gjt7e3q/Gh/93d/p86PxkCNKk3mfG27du3C6tWr8cYbb+CKK67ApZdeihdeeEHrIqrYskZlk06nceLECYyX80nrRWCxWHT3wVrNjHZvK1N1ZLJarXMaJV3KY47H49iyZQuGhoYwNjaGxsZG3HLLLfD7/Yb+gkU0HwcPHsTmzZvx6quvYnx8vOTztbFljXTHiJPJ8rFStFCCICCdTmf9lGI6m7l65513cM0112DJkiXYvn07bDYbfvazn+HkyZN46qmnGKhRVVqxYgVefvllpFIpbN68GWfPnsWPfvQjNDU1afocUgZrVFZGe0yT0cpLNJsXXnhBfV6n8oieaDSKo0ePYvPmzRw4QAT5OaTKl5enn34a7e3t6nNIr776anUakHLhXUllZaSWKiO2BBLlcv78efz4xz9Ge3s7nE5nVj7aH//4R+ajEeVhNptx2223qXlta9asUfPaLrnkEoTD4fKUoyx7IcpgsVhQX1+vdTFm1djYiJpSzAFCVCbK/GhNTU340Y9+hLNnz2Lz5s2cH41oHq699lrs27cPH3zwAb7+9a/j4MGD6OvrK8t8bQzWSBPNzc0lmSi3WGpqapizQ4Y1NR+tvb1d7dL52c9+xmubaAGWL1+u5rXdcccdWXlt//iP/1iSvDYGa6SJuro6WCwWrYuRV1NTE3N3yHBy5aPt2rWL+WhEJdDY2Ignn3xSzWtbsmQJ/vVf/xVLlizBl7/85aLmtfHOJc3otXWttraWTyogw5iaj5b5SJ0//vGPuPbaa7UuIlFFU/La/vKXv6h5bf/1X/9V1Lw2BmukmZqaGl0+a1OvQSRRpnz5aKlUCi+//DLz0Yg0kC+vzWaz4cEHH5x3XhuDNdKU3rob6+vrdd09S7R//35cffXVzEcj0rGpeW3nzp3DAw88MO+8Nv18SlJVMpvNupkew0jTilB1stvtuOKKK/DGG28wH43IAJS8tlQqhWeeeWZaXts777xT0HZ4d5PmGhoadDFFhsViQV1dndbFIMpL6Vr54IMPmI9GZCBmsxm33nrrtLy2L33pS4W9v8TlI5qVHlq09FAGotkcOXIEL7/8MpYvX651UYhonjLz2q677rqC3sNgjXRB61YtvbTuEc2E+WhElWP58uUYGhoqaF0Ga6QLWrZs6SlvjoiIaCoGa6QbWo3EbGxsZHI2ERHpFj+hSFfKPccZHytFRER6x2CNdKXcTw9oamriBLhERKRrDNZId8oVQNXV1fGxUkREpHsM1kh3ytU1yVY1IiIyglqtC0CVQRRFBAIBBINBeDwedHZ2IpFIIBaLobe3F06nc07ba2xsxJkzZzAxMQEAWL9+Pe644w5cf/31ed9TyDqK+Q5mCAaDiMVi6OzshM1mg9VqhSRJcDgcEARhztsjIiKajSmdTqe1LkQppFIptLa2IplMoqWlReviVIVEIoG2tjaMjo7CarWqy/v6+rBu3Tp4PJ45be/06dM4efIkAGDPnj244oor0Nramnf9QtYB5GlC2tra5jyvW29vL/r6+uByudRloiiiq6sLsViMwVqZVOO9XY3HTFQNCr232bJGJbdt2za0tbXB5XJlBXGzaWhowJkzZ3D+/HlcffXVs65fyDoAsGjRojkHan6/HwCyAjVAflbj1GVERETFxJw1Kjmr1Qq73Y5gMDin95lMpqJPVjvfbQ4ODsLtdud8ra+vb6HFIiIiyosta1QWgiBgeHhY/TsajUIURXW5z+cDAEiShEAggHXr1iEej2Pjxo147733sGXLFtx88824+eabkUwmsXPnTixfvhzJZBL79u3Dhg0bcM8996jrAMD+/fuxZ88eLF++HIcOHcL111+PlStX4g9/+AO8Xi/cbjcEQYAkSYhEIgiFQjnLLkkSEolE3m5Oh8NR5LNFREQ0icEalU0ikQAgBz9erxcjIyMAgHg8Dr/fD5fLhd7eXoyMjMBqtcLr9SIYDGLLli244YYb1O1s374da9asUbs9E4kE1qxZk7XOoUOH8PDDD2c9d239+vX4wx/+AIfDAYfDkRWghUIhiKIIu91e6tNAREQ0JwzWqCyUEZMAEAgEYLPZEI1G1deHh4dhtVohCIKa1zYwMABAHrmZmWN2/fXXY/369Vi+fDluuOEGtSUt0/PPP4/Vq1dnLevs7EQ4HIbL5UJ7ezva29vV16xWK+LxeM6yKy1qkiTlDOYkSVJHhhIRERUbc9aoLCRJysr5stvtaguXy+VCKBRCIpHICnisVqv6d319fdbyP/3pT3jssccwOjqKTZs2zbr/2tpa1NTUzLv8Ho8HgUAg52uiKDJQIyKikmGwRiXndrvhcrnUFqr+/v6sVjVAzmFzOp0QRXHacgAwm804c+YMAODJJ5/EoUOHsGbNGtx///1Zw52TySQAYMOGDXjjjTfU5U1NTRBFERs3bpzXMSg5dVMHSShdu0RUOURRhNvthslkUtMx/H4/3G43wuHwgrff1dU163YKWWehgsGgenzhcBjRaBTBYBCSJJV0vzR3nGeNimKuk+JGo1FEIhGsW7cOgJykb7Vacy6XJAmbNm1CW1sbBgcHsXPnTrS2tsJqtaqtccuXL8c999wDq9WKRx99FMuXL8eePXuwf/9+dHZ24v3330d/fz/sdjtEUVRb47Zt26bm0Nntdvh8vhnnS/P7/Thx4oQ6KS6AOU/4Swtj9Hvb6/ViYGBgTq2xRj9mIyr2vJGZotEouru7Z7wGCllnIThvpD4Uem8zWCND+fjjj3Hq1Kk5vaetrS2rG5WMzcj3tvJhODUAmI2Rj9mo8gVr+ZYbid/vRyQSQSQSmfaa2+2G1+tlsFYmhd7b7AYlQ2lsbJxT7pnFYmGgRrohSRI/BA1uvvNG6gnnjTQeBmtkKHOZ1NZkMqG5ubnEJSIqTDgcLrjLfGxsDKlUKuuH9CPXvJF+vx/hcBher1ddrqRYhMNhBINBJBIJtXVVCfYSiQSCwSCi0aj6/qnrAHKrrLIPv9+v5pVFo1F1XSXnbKaAq5B5I/mFQn84dQcZzqJFi3D69GmcP39+1vVqa3mJk/amjnSezeDgIB588MHSFYgWbL7zRno8HvT396vbCQaD6uh45f12uz1rHWUfmd2WXV1d2LVrF+eNrBL8JCPDUVrMZhqJWYpHVRHN19DQ0JyeITswMIC7775b/TuVSmHZsmWlKBrNw0LmjZzK6XSiq6sLgiCgv78/53USCASmBV6CIKjXFeeNrHwM1siQlFy0c+fO5Xx9rrltRHMVDAYRi8Xyvt7b2wuHw4FoNDrnKWMsFgssFstCi0glkm/eSIXL5YLf7582b2QuNpsNo6OjEEURO3bsQF9fX87E/2JS5o3M1S0viiJHuOsQgzUyrObmZoyOjmLqgOaamho0NjZqVCqqFnNpKct87JkkSRgcHFSnkiFjyTVv5NSJuZV5I6dOpB2NRtWgTukZUJL97XY77HZ7Vr6Zsk6ufYiiiG3bts3rGHw+H3p7exEMBrOuY84bqV+cuoMMLZlM4uzZs1nLWlpa0NDQoFGJqNSMfm+bTKY5z2Nl9GM2mnLMG2mz2RAIBBAOh2G1WmGz2RCPx2Gz2SAIQtY6giAgGo1CFEV1cAPnjawMFTHPmiiKah7A8PAwtm3bVnA/Oiu36pBMJjE4OIjnn38e//u//4vPfOYz+N73voe7776bI0ErlFHvbWXUn9frhcvlUltTCmHUYyaimVVEsOb3+9VZov1+P3bs2KGOuJkNK7fKd+rUKVxzzTXYt28fJiYm1OVmsxlXXnkldu/ezYCtAlXjvV2Nx0xUDQw/Ka4oihgcHFT/Vp4byWeWkWLr1q3TAjUAmJiYwL59+7B161aNSkZERFQ8ug3W7HZ7VvKkkvio9KtPxUkkq08wGJwWqCkmJiYMPcM4ERGRQrfBGpCd6Lhjxw41aTOXwcFBtLa2qj+ck6jyHT16dEGvExERGYGugzVFIpFAOBxWZ2fOZWBgAMlkUv05fPhwGUtIWrjooosW9DoREZERlH2etUInksykPGZjppGgnESy+rhcLjzwwAM5u0LNZvOc5sEiIiLSK12PBgXkUaBOpxOCIKh5a4VM38HRU5WPo0GrUzXe29V4zETVwPCjQQEgHA7DbrergdrQ0BCfV0aq5uZm7N69Gw888AA6OjpgNpvR0dGBBx54gIEaERFVDN22rEmShM7OzqxlVqsVo6OjBb2f30SJKlM13tvVeMxE1aDQe1u3zwYVBGHaMx+JiIiIqo2uu0GJiIiIqh2DNSIiIiId02036EIpXah8kgFRZVHu6WpKk2B9RlSZCq3PKjZYO3nyJADwSQZEFerkyZNobW3VuhhlwfqMqLLNVp/pdjToQk1MTODo0aNYvHgxTCZTWfaZSqWwbNkyHD58mCO2yoznXjvlPvfpdBonT57ERRddBLO5OjI5Sl2fVcr9UwnHUQnHAFTGcZTjGAqtzyq2ZU2Zc0sLLS0thr04jY7nXjvlPPfV0qKmKFd9Vin3TyUcRyUcA1AZx1HqYyikPquOr6VEREREBsVgjYiIiEjHGKwVkcViwY9+9CM+UF4DPPfa4bk3vkr5P6yE46iEYwAq4zj0dAwVO8CAiIiIqBKwZY2IiIhIxxisEREREekYgzUiIiIiHavYeda0JooiotEoAGB4eBjbtm2D1WrVtlAVSJIkhMNhCIIASZLgcrl4nsuI13nl83q9GBgYMNz/qxGvzUqoz4x43meji3sgTSXh8/myfrfb7RqWpnJlntdYLJZ2Op0alqb68DqvbCMjI2kA6dHRUa2LMmdGvDYroT4z4nmfiV7uAXaDloAoihgcHFT/djqdEEURkiRpWKrKM/V8CoKgfqOj0uN1XvkkSYIgCFoXY86MeG1WQn1mxPM+G73cAwzWSsBut2Pbtm3q34lEAgBgs9k0KlFlikaj086pzWaDKIoalai68DqvbOFwGE6nU+tizIsRr81KqM+MeN5noqd7gMFaiWT+B+/YsQMOh8Pw/fZ6o1QEU8Xj8fIWpIrxOq9MiUTC8P+PRrs2K6U+M9p5z0dv9wAHGJRYIpFAOBzGyMiI1kWpGvkqPSodXueVZWhoCC6XS+tiFIXRr02j1mdGP+96uwcYrM1BMBhELBbL+3pvby8cDkfWMq/Xi0gkoqsIvVJYrdZp3zrj8TjPtQZ4netfofVXNBrFxo0by1iywlVyHVxp9ZlRznsuerwH+LipEvL7/XA6nRAEQf12ZMQLV68kSUJfX1/WN7e2tjYcPHiQ57mMeJ1Xlmg0mpUQ7na74fF40N/fD7vdrmHJ5s5I12Yl1WdGOu+56PEeYLBWIuFwGFarFQ6HA4lEQndNqpWiq6tLrdwkSYLb7UYkEtG4VNWD13nlM5lMiMViuhgRNxdGvDYroT4z4nmfjR7uAQZrJSBJEjo7O7OWWa1WjI6OalSiyiVJEgKBANatW4fh4WHtJy6sIrzOK1sikUAwGITX64XL5YLb7TZMy5pRr02j12dGPe/56OkeYLBGREREpGOcuoOIiIhIxxisEREREekYgzUiIiIiHWOwRkRERKRjDNaIiIiIdIzBGhEREZGOMVgjIiIi0jEGa0REREQ6xmCNiIiISMcYrBERERHpGIM1MqxgMIi2tjaIoohEIgFRFLUuEhERUdExWCNDSiQSAIBdu3bB6/Vi7969hnnINBGRIhgMwu12q3VaIpGA1+vVtlCkOwzWyJCsVitcLhcEQYDP54PD4QAwWdGxlY2I9C4cDsPlciEej2Pv3r0AgKGhIY1LRXrEYI0MSxRFxONx2O12NTjbu3ev+g2ViEjPnE4nALkuU75wRiIR9Pb2AuCXT5rEYI0Mye/3IxAIIBqNQhRF7NixAwDgcDhgtVq1LRwRUYHC4bAaqAFANBpV/+aXT1LUal0AorkSRRFOpxM2mw09PT0IhUKIRCJaF4uIaM4kSUJXVxcAuW7r7u5WX3M4HKzbCACDNTKgzIEEIyMjGpaEiGhhnE4nfD4fwuEwAoGA2gVKlIndoERERBqx2WwIBAJq/pryL1EmtqxRRVFy2BSczoOI9EoURWzatAkjIyMQRRGCIEAQBK2LRTpkSqfTaa0LQUREVI3C4TAAOXfN4/FkvRaNRuHz+WC329Hf388vn1WMwRoRERGRjjFnjYiIiEjHGKwRERER6RiDNSIiIiIdY7BGREREpGMM1oiIiIh0jMEaERERkY4xWCMiIiLSMQZrRERERDr2/wM8LFK/0emt8gAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 630x280 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# get probability visualizations\n",
    "xx, yy = np.meshgrid(np.linspace(-5, 5, 100), np.linspace(-5, 5, 100))\n",
    "xx_, yy_ = xx.flatten(), yy.flatten()\n",
    "xy = np.stack([xx_, yy_], 1)          # [ ngrids, 2 ]\n",
    "zz_sampler  = sampler.pdf(xy).reshape(xx.shape)\n",
    "zz_model    = model.pdf(xy).reshape(xx.shape) \n",
    "\n",
    "plt_scale = 0.7\n",
    "fig, axes = plt.subplots(1, 2, figsize = [9 * plt_scale, 4 * plt_scale])\n",
    "\n",
    "# plt.figure(figsize=[4, 3])\n",
    "ax = axes[0]\n",
    "ax.set_title(r'Decision space $\\mathcal{Z}$')\n",
    "# ------------\n",
    "ax.scatter(*dra.vertices.T, color = 'black', label = 'Vertices', zorder = 99, s = 30) # placeholder\n",
    "patch = plt.Polygon(dra.vertices, label = 'Feasible region', facecolor = 'lightgray', edgecolor = 'none', lw = 0, alpha = 0.5)\n",
    "ax.text(0, 0 + 0.2, 'Feasible region', color = 'gray', ha = 'center', va = 'center')\n",
    "ax.add_patch(patch)\n",
    "names = 'ABCDEFG'\n",
    "for i in range(len(dra.vertices)):\n",
    "    v = dra.vertices[i]\n",
    "    ax.text(v[0], v[1] + 0.2, s = 'Decision ' + names[i], va = 'bottom', ha = 'center', color= 'black')\n",
    "# ------------\n",
    "ax.set_ylim(-2.2, 1.6)\n",
    "ax.set_xlim(-2.6, 2.6)\n",
    "# ax.legend(bbox_to_anchor = [0.9, -0.2], ncol = 2)\n",
    "# ax.legend(loc=  'center')\n",
    "ax.set_ylabel(r'$z_2$')\n",
    "ax.set_xlabel(r'$z_1$')\n",
    "\n",
    "ax = axes[1]\n",
    "# ------------\n",
    "for i in range(len(dra.vertices_inverse_list)):\n",
    "    v   = dra.vertices_inverse_list[i]\n",
    "    ax.scatter(*v.T, color = 'none')\n",
    "    patch = plt.Polygon(v, facecolor = 'none', lw = 1, ls = '-', edgecolor = 'black', zorder = 99)\n",
    "    ax.add_patch(patch)\n",
    "# ------------\n",
    "ax.text(-3, 4, 'Decision A', va = 'center', ha = 'center', color = 'black')\n",
    "ax.text(3, 4, 'Decision B', va = 'center', ha = 'center', color = 'black')\n",
    "ax.text(0, -4, 'Decision C', va = 'center', ha = 'center', color = 'black')\n",
    "ax.set_xlim(-5, 5)\n",
    "ax.set_ylim(-5, 5)\n",
    "ax.set_ylabel(r'$y_2$')\n",
    "ax.set_xlabel(r'$y_1$')\n",
    "ax.set_title(r'Outcome space $\\mathcal{Y}$')\n",
    "\n",
    "\n",
    "ax = axes[0]\n",
    "ax.scatter(0, -1, color = 'blue')\n",
    "ax.text(0, -1 + 0.2, s = 'Decision D', color = 'blue', ha = 'center', va = 'bottom')\n",
    "ax.scatter(0, 1, color = 'red')\n",
    "ax.text(0, 1 + 0.2, s = 'Decision E', color = 'red', ha = 'center', va = 'bottom')\n",
    "\n",
    "ax = axes[1]\n",
    "ax.text(0, 0 - 2.0, s = 'Decision D', color = 'blue', ha = 'center', va = 'bottom')\n",
    "ax.scatter(0, 0, color = 'blue', zorder = 100)\n",
    "ax.plot([0, 0], [5, 0], color = 'red', zorder = 99, lw = 3)\n",
    "ax.text(0, 0 + 2.0, s = 'Decision E', color = 'red', ha = 'center', va = 'bottom', zorder = 101)\n",
    "\n",
    "# contours = ax.contourf(xx, yy, zz_sampler, 10, cmap = 'Blues', zorder = -1)\n",
    "# fig.colorbar(contours, ax=ax, label = 'Density')\n",
    "\n",
    "plt.tight_layout()\n",
    "# plt.savefig('figs/syn_explanation.pdf')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "35fb8b6f",
   "metadata": {},
   "source": [
    "# Risk vs. Methods"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "1d7720c4",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 99/99 [00:02<00:00, 33.53it/s]\n"
     ]
    }
   ],
   "source": [
    "from tqdm import tqdm\n",
    "\n",
    "config()\n",
    "\n",
    "xs = np.arange(1, 100)\n",
    "\n",
    "offset = 0.2\n",
    "\n",
    "A, B, C, D = [], [], [], []\n",
    "for x in tqdm(xs):\n",
    "    kwds = {\n",
    "        'mu1':       np.array([[-3, 0], [3, 0]]),           # [ ncomp, data_dim ] np, the mean of GMs\n",
    "        'scale1':    np.array([2, 2]),                      # [ ncomp ] np, the variance of GMs \n",
    "        'weights1':  np.array([0.5-offset, 0.5+offset]),    # [ ncomp ]\n",
    "        'mu2':       np.array([[-3, 0], [3, 0]]),    # [ ncomp, data_dim ] np, the mean of GMs\n",
    "        'scale2':    np.array([2, 2]),           # [ ncomp ] np, the variance of GMs \n",
    "        'weights2':  np.array([0.5+offset, 0.5-offset]),              # [ ncomp ] np, the weights of GMs \n",
    "        'ncal': 100,\n",
    "        'k':    100,\n",
    "        'A':    np.array([\n",
    "            [np.sqrt(3),    -1],\n",
    "            [-np.sqrt(3),   -1],\n",
    "            [0,             1]\n",
    "        ]),\n",
    "        'b':    np.array([2, 2, 1])\n",
    "    }\n",
    "    a, b, c, d = synthetic_experiment(**kwds)\n",
    "    A.append(a)\n",
    "    B.append(b)\n",
    "    C.append(c)\n",
    "    D.append(d)\n",
    "\n",
    "A = np.array(A)\n",
    "B = np.array(B)\n",
    "C = np.array(C)\n",
    "D = np.array(D)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "d637d852",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 600x300 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import pandas as pd\n",
    "import seaborn as sns\n",
    "\n",
    "# name = [ r'\\textbf{CREDO}', 'NS', 'Point']\n",
    "\n",
    "methods     = [r'\\textbf{CREDO}', 'NS', 'Point']\n",
    "data_list   = [A, B, C]  # A, B, C are arrays of shape (n_samples, n_decisions)\n",
    "n_decisions = A.shape[1]\n",
    "\n",
    "fig, axes = plt.subplots(1, n_decisions, figsize=(2 * n_decisions, 3), sharey=True)\n",
    "\n",
    "for i in range(n_decisions):\n",
    "    # Prepare long-format DataFrame for violin plot\n",
    "    df = pd.DataFrame({\n",
    "        'Estimated confidence': np.concatenate([M[:, i] for M in data_list]),\n",
    "        'Method': np.concatenate([[methods[j]] * len(data_list[j]) for j in range(len(data_list))])\n",
    "    })\n",
    "    sns.boxplot(x='Method', y='Estimated confidence', data=df, ax=axes[i], fill=False, color = 'tab:gray')\n",
    "    axes[i].set_title(f'Decision {i+1}')\n",
    "    axes[i].axhline(D[:, i].mean(), color ='red', ls = '--')\n",
    "    axes[i].axhspan(D[:, i].mean(), 1.0, color='red', alpha=0.2)\n",
    "    axes[i].set_ylim(None, 1.0)\n",
    "    axes[i].grid(axis = 'y')\n",
    "\n",
    "plt.tight_layout()\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
}
