{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "42a39b79",
   "metadata": {},
   "source": [
    "# Synthetic Setting I"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "353fedaa",
   "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 \n",
    "\n",
    "config()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "e3ab6a58",
   "metadata": {},
   "outputs": [],
   "source": [
    "sampler_kwds = {\n",
    "    'mu':       np.array([[-1e-1, -1e-1]]),     # [ ncomp, data_dim ] np, the mean of GMs\n",
    "    'scale':    np.array([1]),                  # [ ncomp ] np, the variance of GMs \n",
    "}\n",
    "\n",
    "sampler     = GaussianMixtureSampler(**sampler_kwds)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "433fc897",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Model setup\n",
    "A = np.array([\n",
    "    [1,    1],\n",
    "    [-1,   0],\n",
    "    [0,   -1]\n",
    "])\n",
    "b = np.array([1, 0, 0])\n",
    "\n",
    "init_true_kwds = {\n",
    "    'A':    A,\n",
    "    'b':    b,\n",
    "    'kwds': sampler_kwds,\n",
    "    'boundary_scale':   10\n",
    "}\n",
    "\n",
    "true_dra    = ConformalizedDecisionRiskAssessment(**init_true_kwds)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "b451c941",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 700x280 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# get probability visualizations\n",
    "xx, yy = np.meshgrid(np.linspace(-1, 1, 100), np.linspace(-1, 1, 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    = sampler.pdf(xy).reshape(xx.shape) \n",
    "\n",
    "plt_scale = 0.7\n",
    "fig, axes = plt.subplots(1, 2, figsize = [10 * plt_scale, 4 * plt_scale])\n",
    "\n",
    "kwds = {\n",
    "    'label':        'Feasible region',\n",
    "    'facecolor':   'lightgray',\n",
    "    'edgecolor':   'black',\n",
    "    'lw':           2,\n",
    "}\n",
    "\n",
    "ax = axes[0]\n",
    "ax.set_title(r'Decision space')\n",
    "ax = true_dra.plot_feasible_region(ax, kwds)\n",
    "ax.set_ylabel(r'$z_2$')\n",
    "ax.set_xlabel(r'$z_1$')\n",
    "ax.set_aspect('equal', adjustable='box')\n",
    "ax.scatter(0, 1, color = 'black')\n",
    "ax.scatter(0, 0, color = 'black')\n",
    "ax.scatter(1, 0, color = 'black')\n",
    "\n",
    "kwds = {\n",
    "    'facecolor': 'none',\n",
    "    'lw':   2,\n",
    "    'ls':   '-',\n",
    "    'edgecolor':    'black',\n",
    "    'zorder':  99\n",
    "}\n",
    "\n",
    "ax = axes[1]\n",
    "ax = true_dra.plot_inverse_feasible_region(ax, kwds)\n",
    "ax.set_xlim(-1, 1)\n",
    "ax.set_ylim(-1, 1)\n",
    "ax.set_ylabel(r'$Y_2$')\n",
    "ax.set_xlabel(r'$Y_1$')\n",
    "ax.set_title('Outcome space')\n",
    "\n",
    "from matplotlib.colors import Normalize\n",
    "norm = Normalize(vmin=0, vmax=1.0)  # or your desired limits\n",
    "contours = ax.pcolormesh(xx, yy, zz_model, cmap = 'Blues', zorder = -1, alpha = 0.5, edgecolor = 'none')\n",
    "ax.scatter(-0.1, -0.1, s = 20, color = 'tab:red', label = 'Mean', marker = 'o')\n",
    "ax.set_aspect('equal', adjustable='box')\n",
    "ax.legend()\n",
    "\n",
    "ax.text(-0.5, -0.5, r'$(0, 0)$', va = 'center', ha = 'center')\n",
    "ax.text(-0.5, 0.5, r'$(0, 0)$', va = 'center', ha = 'center')\n",
    "ax.text(0.5, -0.5, r'$(0, 0)$', va = 'center', ha = 'center')\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "4d27ed50",
   "metadata": {},
   "source": [
    "# Synthetic Setting II"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "0ea614f9",
   "metadata": {},
   "outputs": [],
   "source": [
    "sampler_kwds = {\n",
    "    'mu':       np.array([[0.0, -0.8],\n",
    "                          [-0.5, 0.25],\n",
    "                          [0.8, -0.1]]),  # [ ncomp, data_dim ] np, the mean of GMs\n",
    "    'scale':    np.array([1e-2, 3e-2, 2e-2]),                                # [ ncomp ] np, the variance of GMs \n",
    "    'weights':  np.array([0.3, 0.4, 0.3]),                                # [ ncomp ] np, the variance of GMs \n",
    "}\n",
    "\n",
    "sampler     = GaussianMixtureSampler(**sampler_kwds)\n",
    "\n",
    "mean    = sampler_kwds['weights'][:, None] * sampler_kwds['mu']\n",
    "mean    = mean.mean(0) "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "5d7f4e2e",
   "metadata": {},
   "outputs": [],
   "source": [
    "A = np.array([\n",
    "    [-1/2, -1],\n",
    "    [0,   -1],\n",
    "    [-1/2, 1],\n",
    "    [1/2,  1],\n",
    "    [2,   -1],\n",
    "    [1, 0],\n",
    "    [0, 1],\n",
    "    [-1, 0]\n",
    "])\n",
    "b = np.array([-1, 0, 1, 5, 10, 5.5, 2.5, -1])\n",
    "\n",
    "init_true_kwds = {\n",
    "    'A':    A,\n",
    "    'b':    b,\n",
    "    'kwds': sampler_kwds,\n",
    "    'boundary_scale':   10\n",
    "}\n",
    "\n",
    "true_dra         = ConformalizedDecisionRiskAssessment(**init_true_kwds)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "77fee980",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 700x280 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# get probability visualizations\n",
    "xx, yy = np.meshgrid(np.linspace(-1, 1, 100), np.linspace(-1, 1, 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    = sampler.pdf(xy).reshape(xx.shape)\n",
    "\n",
    "plt_scale = 0.7\n",
    "fig, axes = plt.subplots(1, 2, figsize = [10 * plt_scale, 4 * plt_scale])\n",
    "\n",
    "kwds = {\n",
    "    'label':        'Feasible region',\n",
    "    'facecolor':   'lightgray',\n",
    "    'edgecolor':   'black',\n",
    "    'lw':           2,\n",
    "}\n",
    "\n",
    "ax = axes[0]\n",
    "ax.set_title(r'Decision space')\n",
    "ax = true_dra.plot_feasible_region(ax, kwds)\n",
    "ax.set_ylabel(r'$z_2$')\n",
    "ax.set_xlabel(r'$z_1$')\n",
    "for v in true_dra.vertices:\n",
    "    ax.scatter(*v, color = 'black')\n",
    "ax.set_ylim(-1, 3.5)\n",
    "ax.set_xlim(.5, 6)\n",
    "\n",
    "kwds = {\n",
    "    'facecolor': 'none',\n",
    "    'lw':   2,\n",
    "    'ls':   '-',\n",
    "    'edgecolor':    'black',\n",
    "    'zorder':  99\n",
    "}\n",
    "\n",
    "ax = axes[1]\n",
    "ax = true_dra.plot_inverse_feasible_region(ax, kwds)\n",
    "ax.set_xlim(-1, 1)\n",
    "ax.set_ylim(-1, 1)\n",
    "ax.set_ylabel(r'$Y_2$')\n",
    "ax.set_xlabel(r'$Y_1$')\n",
    "ax.set_title('Outcome space')\n",
    "\n",
    "from matplotlib.colors import Normalize\n",
    "norm = Normalize(vmin=0, vmax=1.0)  # or your desired limits\n",
    "\n",
    "contours = ax.pcolormesh(xx, yy, zz_model, cmap = 'Blues', zorder = -1, alpha = 0.8, edgecolor = 'none')\n",
    "ax.set_aspect('equal', adjustable='box')\n",
    "\n",
    "ax.scatter(*mean, s = 20, color = 'tab:red', label = 'Mean', marker = 'o')\n",
    "ax.legend()\n",
    "\n",
    "ax.text(-0.6, 0.5, r'$(1, 1.5)$', ha = 'center', va = 'center')\n",
    "ax.text(-0.2, 0.8, r'$(3, 2.5)$', ha = 'center', va = 'center')\n",
    "ax.text(0.2, 0.8, r'$(5, 2.5)$', ha = 'center', va = 'center')\n",
    "ax.text(0.6, 0.5, r'$(5.5, 2.25)$', ha = 'center', va = 'center')\n",
    "ax.text(0.8, -0.2, r'$(5.5, 1)$', ha = 'center', va = 'center')\n",
    "ax.text(0.5, -0.5, r'$(5, 0)$', ha = 'center', va = 'center')\n",
    "ax.text(-0.2, -0.8, r'$(2, 0)$', ha = 'center', va = 'center')\n",
    "ax.text(-0.6, -0.5, r'$(1, 0.5)$', ha = 'center', va = 'center')\n",
    "\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
}
