{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "72a27a16",
   "metadata": {},
   "source": [
    "# Import libraries"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "f031f752",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[ENV WARNING] deactivate virtualenv to allow for testing Actionable Recourse\n"
     ]
    }
   ],
   "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": 2,
   "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": 3,
   "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": 4,
   "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": 5,
   "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": 6,
   "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):\n",
    "    all_x_opt = np.zeros((len(X_recourse), 2))\n",
    "    for i in range(len(X_recourse)):\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": 7,
   "id": "31ae521d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Start delta 0.001\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": 8,
   "id": "8d217a3a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([0.7848125 , 0.86033333, 0.90664583, 0.93025   , 0.94539583,\n",
       "        0.95714583, 0.96641667, 0.9745    , 0.97966667, 0.98383333,\n",
       "        0.98720833]),\n",
       " array([0.23990265, 0.17797616, 0.12833002, 0.10467148, 0.08856338,\n",
       "        0.07738048, 0.06713202, 0.0566568 , 0.04890034, 0.04228614,\n",
       "        0.03667498]))"
      ]
     },
     "execution_count": 8,
     "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": 9,
   "id": "41752961",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Start delta 0.001\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": [
    "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": 10,
   "id": "b527b814",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([0.78483333, 0.85895833, 0.9058125 , 0.927     , 0.94147917,\n",
       "        0.952375  , 0.96125   , 0.9680625 , 0.97358333, 0.97785417,\n",
       "        0.98210417]),\n",
       " array([0.23988063, 0.17943911, 0.12934054, 0.1097345 , 0.09524848,\n",
       "        0.08653286, 0.07791889, 0.07123937, 0.06391515, 0.05758836,\n",
       "        0.05045418]))"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "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": 11,
   "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": [
    "fig, ax = plt.subplots()\n",
    "ax.errorbar(delta_l, orig_model_mixture_val, orig_model_mixture_std, label='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-NM.pdf', dpi=1000, 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+/a1qlC1RIVARFLGzHj66ad56aWXuPzyy5kwYQLXXHMNd911FwA33HADjzzySP359tzcXAAGDBjA9OnTGTFiBNOn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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "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
}
