{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "72a27a16",
   "metadata": {},
   "source": [
    "# Import libraries"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "f031f752",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from sklearn.model_selection import train_test_split\n",
    "\n",
    "from dirrac.data.synthetic_data import DataSynthesizer\n",
    "from dirrac.classifier.logistic import logistic_classifier\n",
    "from dirrac.optim.opt import Optimization\n",
    "from utils import cal_validity"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "af770047",
   "metadata": {},
   "outputs": [],
   "source": [
    "if not os.path.exists('result/figure6/'):\n",
    "    os.makedirs('result/figure6/')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "cb6a6b67",
   "metadata": {},
   "source": [
    "# Synthesize data and train original classifier"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "b8c0ebac",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Synthesize data\n",
    "mean_0 = np.ones(2) * (-3)\n",
    "mean_1 = np.ones(2) * 3\n",
    "cov_0 = cov_1 = np.identity(2)\n",
    "n = 1000\n",
    "p = [0.4, 0.2, 0.4]\n",
    "\n",
    "sd = DataSynthesizer(mean_0, cov_0, mean_1, cov_1, n)\n",
    "features, labels = sd.synthesize_modes_data(100, [0.4, 0.2, 0.4], [0.1, 0.1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "c5b9e79a",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Train\n",
    "all_coef = np.zeros((101, 2))\n",
    "for i in range(101):\n",
    "    coef = logistic_classifier(features[i], labels[i])[1].T\n",
    "    all_coef[i] = np.squeeze(coef)\n",
    "\n",
    "# Get theta\n",
    "mean_shift = all_coef[1:41]\n",
    "cov_shift = all_coef[41:61]\n",
    "both_shift = all_coef[61:101]\n",
    "\n",
    "theta = np.zeros((3, 2))\n",
    "sigma = np.zeros((3, 2, 2))\n",
    "\n",
    "theta[0], sigma[0] = np.mean(mean_shift, axis=0), np.cov(mean_shift.T)\n",
    "theta[1], sigma[1] = np.mean(cov_shift, axis=0), np.cov(cov_shift.T)\n",
    "theta[2], sigma[2] = np.mean(both_shift, axis=0), np.cov(both_shift.T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "4a983835",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Train a classifier\n",
    "X_train, X_test, y_train, y_test = train_test_split(features[0], labels[0], test_size=0.1, random_state=42)\n",
    "\n",
    "# Train and get theta\n",
    "clf, coef = logistic_classifier(X_train, y_train)\n",
    "\n",
    "yhat = clf.predict(X_test)\n",
    "X_recourse = X_test[yhat == 0]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "6fe1cb22",
   "metadata": {},
   "source": [
    "# Define function"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "479c80a8",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Optimization module\n",
    "delta_l = [1e-3, 0.02, 0.04, 0.06, 0.08, 0.1, 0.12, 0.14, 0.16, 0.18, 0.2]\n",
    "k = 3\n",
    "dim = 2\n",
    "rho = np.array([0, 0, 0])\n",
    "lmbda = 0.7\n",
    "zeta = 1\n",
    "\n",
    "features_shift, labels_shift = sd.synthesize_modes_data(1000, [0.1, 0.8, 0.1], [0.2, 0.2])\n",
    "clf_shift = [logistic_classifier(features_shift[i + 1], labels_shift[i + 1])[0] for i in range(len(features_shift) - 1)]\n",
    "\n",
    "def recourse_delta_param(delta, opt, num_samples=10):\n",
    "    all_x_opt = np.zeros((num_samples, 2))\n",
    "    for i in range(num_samples):\n",
    "        out = opt.recourse_action(X_recourse[i], 10)\n",
    "        f_opt, x_opt = out\n",
    "        all_x_opt[i] = x_opt\n",
    "        \n",
    "    all_val = np.zeros(len(features_shift) - 1)\n",
    "    for i in range(len(features_shift) - 1):\n",
    "        # Train and get theta\n",
    "        yhat = clf_shift[i].predict(all_x_opt)\n",
    "        all_val[i] = cal_validity(yhat)\n",
    "    \n",
    "    return np.mean(all_val), np.std(all_val)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "7d0e862c",
   "metadata": {},
   "source": [
    "# Non-parametric mixture"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "31ae521d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Start delta 0.001\n",
      "\n",
      "Interrupt request received\n",
      "Start delta 0.02\n",
      "Start delta 0.04\n",
      "Start delta 0.06\n",
      "Start delta 0.08\n",
      "Start delta 0.1\n",
      "Start delta 0.12\n",
      "Start delta 0.14\n",
      "Start delta 0.16\n",
      "Start delta 0.18\n",
      "Start delta 0.2\n"
     ]
    }
   ],
   "source": [
    "orig_model_mixture_val, orig_model_mixture_std = np.zeros(len(delta_l)), np.zeros(len(delta_l))\n",
    "for i in range(len(delta_l)):\n",
    "    print(f\"Start delta {delta_l[i]}\")\n",
    "    opt = Optimization(delta_l[i], k, dim, p, theta, sigma, rho, lmbda, zeta, gaussian=False)\n",
    "    orig_model_mixture_val[i], orig_model_mixture_std[i] = recourse_delta_param(delta_l[i], opt)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "8d217a3a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([0.8442, 0.9207, 0.9453, 0.9569, 0.9653, 0.9717, 0.977 , 0.9816,\n",
       "        0.9847, 0.9872, 0.9885]),\n",
       " array([0.18683244, 0.1110023 , 0.08317397, 0.07356895, 0.06516065,\n",
       "        0.05629485, 0.04828043, 0.04100537, 0.03682268, 0.03340898,\n",
       "        0.03190219]))"
      ]
     },
     "execution_count": 17,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "orig_model_mixture_val, orig_model_mixture_std"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "14cad087",
   "metadata": {},
   "source": [
    "# Non-parametric mixture worst case"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a5958fcd",
   "metadata": {},
   "source": [
    "# Gaussian mixture"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "41752961",
   "metadata": {},
   "outputs": [],
   "source": [
    "gaussian_mixture_val, gaussian_mixture_std = np.zeros(len(delta_l)), np.zeros(len(delta_l))\n",
    "for i in range(len(delta_l)):\n",
    "    print(f\"Start delta {delta_l[i]}\")\n",
    "    opt = Optimization(delta_l[i], k, dim, p, theta, sigma, rho, lmbda, zeta, gaussian=True, model_type='mixture')\n",
    "    gaussian_mixture_val[i], gaussian_mixture_std[i] = recourse_delta_param(delta_l[i], opt)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b527b814",
   "metadata": {},
   "outputs": [],
   "source": [
    "gaussian_mixture_val, gaussian_mixture_std"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "2314a80d",
   "metadata": {},
   "source": [
    "# Gaussian worst case"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8a212d3c",
   "metadata": {},
   "source": [
    "# Visualization"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "a770a7d5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.rcParams.update({'font.size': 13})\n",
    "fig, ax = plt.subplots()\n",
    "ax.errorbar(delta_l, orig_model_mixture_val, orig_model_mixture_std, label='DiRRAc', marker='+', alpha=0.8)\n",
    "\n",
    "ax.set(xlabel='$\\delta_{add}$', ylabel='$M_{2}$ validity')\n",
    "ax.grid()\n",
    "ax.legend(loc='lower right', frameon=False)\n",
    "ax.set_ylim([0, 1])\n",
    "\n",
    "plt.savefig('result/figure6/delta_add_DiRRAc-NM.pdf', dpi=400, transparent=True)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "7c162e29",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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57YLhjc5fvXq1YwbN67J8X379mXx4sVkZ2fz/vvvc/nll7N8+fImp9+1axdPPfUU69atw8zqT8/cfvvtLFq0iP79+x90yqbOySefzNKlS0lPT+f555/nJz/5CU8++SQAGzduZO3atWRlZXHSSSdx0003MWDAgGb/3bFYjNGjR7Nu3TpGjx7d6DQVFRW88cYb/OpXv6rvf/7553nggQfYs2cPc+bMqT+lBDBv3jwWL17MunXr+Ld/+zeuuOIKqqurufTSS5k3bx6nnHIKJSUl5OTkNJutNfSJQES6zI033sjo0aM55ZRTAKiurua6665j5MiRfOMb32DNmjXNzt+zZ0+ys7O59tpr+e///m969OgBwGmnnca3vvUtHnroIWpraw+Zb+/evXzjG99gxIgR/OAHP2D16tX148aNG1e/3GHDhvHnP/+5Vf+Whqd26mzatIkxY8ZQWFhIv379GDVqFAB/+MMfmDJlCjk5OVx88cU8/fTT9VmXL19OQUEBAwcO5Ktf/Spvv/02u3fv5qOPPqJfv3712ys/P5/09I4fz+sTgUhENXfknqzuk8C86yd1eJ3Dhw+vP/IGuPfee9m5cyfjx48HYPbs2RQWFvLuu+8Sj8fJzs4GID09nXg8Xj9fRUVF/fA333yTF154gSeeeIJ77rmHF198kfvvv5833niDZ599lqKiIlasWHFQjp/97GdMmTKFp556ii1btjB58uT6cRkZGfXdsViMmpqaFv9dtbW1rFq1ii996UuHjKu7RrBz505OO+00FixYwIUXXsicOXN45ZVXGDRoEJD4dPPiiy9y9tlnM2fOHNatW1c/rqSkhCeffJJYLNZilvbQJwIRSZkzzzyTiooK7rvvvvph5eXl9d179+6lX79+pKWl8eijj9YfIR9//PGsWbOGyspK9uzZwwsvvABAaWkpe/fu5bzzzmP27Nn15+g3bdrExIkTuf322+nTpw8fffTRQTn27t1L//79AeqvNbRXdXU1s2bNYsCAAfVH+40pKCjgzjvv5I477qCkpISlS5fy4YcfsmXLFrZs2cK9997LnDlziMfjzJ8/n1WrVtWPe+aZZ5gzZw4DBgxg27ZtLFu2DIB9+/a1qlC1RIVARFLGzHj66ad56aWXuPzyy5kwYQLXXHMNd911FwA33HADjzzySP359tzcXAAGDBjA9OnTGTFiBNOnT2fs2LFAoiE8//zzGTVqFF/5ylf45S9/CcCPf/xjRo4cyYgRI+ovrCa7+eabmTVrFmPHjm13Q3rllVcyatQoRowYQVlZ2UEXdJty0UUXUV5ezuzZsznzzDPJysqqHzdt2jR+//vfs3TpUvr378+xxx5bP+6MM85gzZo1lJSUMG/ePG666SZGjx7N2WefXf/pqEPc/bB6FRUVeXssWbKkXfOFTbnaprvmcu++2Tqaa/r9r/r0+1/tnDBJjtTtFaaOZAOWexPtqq4RiEizOuPagHRvOjUkIhJxKgQiIhGnQiAiEnEqBCIiEadCICIScaEWAjObambrzWyjmR3ynFUzyzKzecH4N8xsUJh5RETkUKEVAjOLAfcC5wLDgMvNbFiDya4FPnf3LwKzgbvCyiMiIo0L8xPBBGCju2929ypgLjCtwTTTgEeC7ieAr5qZhZhJREQaCPOGsv5A8gM+tgITm5rG3WvMbC/wBWBn8kRmNgOYEfSWmtn6duQpaLjcbkK52qa75oLum0252qa75oKOZTu+qRGHxZ3F7v4g8GBHlmFmy919fCdF6jTK1TbdNRd032zK1TbdNReEly3MU0MfA8m/5nBcMKzRacwsHegJ7Aoxk4iINBBmIVgGDDWzwWaWCVwGLGgwzQLgmqD7EuDF4OFIIiKSIqGdGgrO+c8EFgEx4LfuvtrMbifxFLwFwL8Dj5rZRmA3iWIRlg6dWgqRcrVNd80F3TebcrVNd80FIWUzHYCLiESb7iwWEYk4FQIRkYg7LAtBRx5dYWazguHrzeyc1i4zzFxmdraZrTCzVcHfM5PmKQ6W+U7w6pvibIPMbH/S+u9PmqcoyLzRzH7dnpsBO5DryqRM75hZ3MzGBOM6vM1akesMM3vLzGrM7JIG464xs/eD1zVJw1OxvRrNZWZjzOw1M1ttZivN7NKkcQ+b2QdJ22tMW3N1JFswrjZp/QuShg8O3veNwX6QmapcZjalwT5WYWYXBeM6vM1akeuHZrYmeL9eMLPjk8Z17j7W1E+XddcXiQvPm4AhQCbwLjCswTQ3APcH3ZcB84LuYcH0WcDgYDmx1iwz5FxjgWOD7hHAx0nzFAPju3CbDQLea2K5bwJfBgz4I3BuqnI1mGYksKmztlkrcw0CRgH/CVySNPxoYHPwt3fQ3TuF26upXCcCQ4PuY4FtQK+g/+HkaVO9zYJxpU0sdz5wWdB9P/C9VOZq8L7uBnp0xjZrZa4pSev7Hgf+T3b6PnY4fiLoyKMrpgFz3b3S3T8ANgbLa80yQ8vl7m+7+yfB8NVAjpll0Xk6/XEfZtYPyHf31z2xB/4ncFEX5bo8mLeztJjL3be4+0og3mDec4DF7r7b3T8HFgNTU7W9msrl7hvc/f2g+xPgU6BPG9cfSramBO/zmSTed0jsBxd1Ua5LgD+6e3kb19+RXEuS1vc6iXuxIIR97HAsBI09uqJ/U9O4ew1Q9+iKpuZtzTLDzJXsYuAtd69MGvYfwcfPn7XndEInZBtsZm+b2UtmdnrS9FtbWGbYuepcCsxpMKwj26wj+0Nz+1gqtleLzGwCiaPQTUmD/29wCmJ2Ow9COpot28yWm9nrdadfSLzPe4L3vT3L7IxcdS7j0H2sI9usrbmuJXGE39y87d7HDsdCcMQys+EknsB6fdLgK919JHB68Lo6xbG2AQPdfSzwQ+AxM8tPcYYmmdlEoNzd30sa3NXbrNsKjhofBb7t7nVHwLOAk4FTSJxu+LsuiHa8Jx6dcAXwr2Z2QhdkaFSwzUaSuCeqTsq2mZldBYwH/iWsdRyOhaAjj65oat7WLDPMXJjZccBTwDfdvf5Izd0/Dv7uAx4j8ZGyrdqdLTiNtivIsILEUeSJwfTHJc2f8m0WOORIrRO2WUf2h+b2sVRsryYFBfxZ4Kfu/nrdcHff5gmVwH8Q3j7WpKT3bDOJazxjSbzPvYL3vc3L7IxcgenAU+5enZS3o9usVbnM7Czgp8CFSWcJOn8fa+/Fjq56kbgbejOJi711F1mGN5jmRg6+wDg/6B7OwReLN5O4aNPiMkPO1SuY/uuNLLMg6M4gca70uyneZn2AWNA9JNixjvbGL0ydl6pcQX9akGdIZ26ztuwPNLhoSOLo8AMSF/F6B90p217N5MoEXgD+ppFp+wV/DfhX4M4w9rFmsvUGsoLuAuB9ggunwOMcfLH4hlTlShr+OjClM7dZK/f9sSQOvIY2GN7p+1ib3uzu8gLOAzYEG+mnwbDbSVRNgOxgB9oYbJjkhuKnwXzrSbqi3tgyU5UL+HugDHgn6dUXyAVWACtJXET+FUGjnMJsFwfrfgd4C7ggaZnjgfeCZd5DcKd6Ct/LycDrDZbXKdusFblOIXEOtozEkevqpHn/T5B3I4lTMKncXo3mAq4CqhvsY2OCcS8Cq4Js/wXkhbSPNZXt1GD97wZ/r01a5pDgfd8Y7AdZKX4vB5E42EhrsMwOb7NW5Hoe2JH0fi0Iax/TIyZERCLucLxGICIinUiFQEQk4lQIREQiToVARCTiVAhERCJOhUBEJOJUCERaycx6mtlTduCR4d/p6kwinSG03ywWOQJdDOxz9yIAM8vp4jwinUKfCERa7y3gL4KnZP4cqGxpBpHDgQqBSCuYWU/gbhI/YPJlEj8a0tbfrBDpllQIRFrnemCRu+/1xPPxXwOOaW4GMzvHzK5uql+ku9A1ApHWGcuBX0qr6/89gJn9A4mnQO4C7gR+CZQAE4EfmNk9Sf03pi6ySOvoE4FI63xOovHHzP4SyAdeNbP+JA6o9gCnkfht2Ufc/SckHnc+pUH/+tRHF2meCoFI6/wL8Fdm9i5wHYnfjogD/0jiV+UeIfG44rHAKjM7CtjZsN/1uF/phvQYapEOMLO/JfHp4AskjvZ3kvhx8XKgFHg7ud/db+6iqCJNUiEQEYk4nRoSEYk4FQIRkYhTIRARiTgVAhGRiFMhEBGJOBUCEZGIUyEQEYk4FQIRkYhTIRARibj/BUP2MMXMlfDZAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.rcParams.update({'font.size': 13})\n",
    "fig, ax = plt.subplots()\n",
    "ax.errorbar(delta_l, gaussian_mixture_val, gaussian_mixture_std, label='Gaussian DiRAAc')\n",
    "\n",
    "ax.set(xlabel='$\\delta_{add}$', ylabel='validity')\n",
    "ax.grid()\n",
    "ax.legend(loc='lower right', frameon=False)\n",
    "ax.set_ylim([0, 1])\n",
    "\n",
    "plt.savefig('result/figure6/delta_add_DiRAAc-GM.pdf', transparent=True)\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.7.11"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
