{
 "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/figure8/'):\n",
    "    os.makedirs('result/figure8/')"
   ]
  },
  {
   "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, 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",
    "    cost = np.mean(np.linalg.norm((all_x_opt - X_recourse[:num_samples, :]), ord=1, axis=1))\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), cost"
   ]
  },
  {
   "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, cost_l = np.zeros(len(delta_l)), 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], cost_l[i] = recourse_delta_param(delta_l[i], opt, 10)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "8d217a3a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([0.7796 , 0.85715, 0.9041 , 0.92595, 0.9371 , 0.94815, 0.9581 ,\n",
       "        0.9674 , 0.97355, 0.97805, 0.9822 ]),\n",
       " array([0.23902686, 0.17417341, 0.12658274, 0.10718721, 0.09848142,\n",
       "        0.08949345, 0.07996493, 0.06926211, 0.06081034, 0.05408972,\n",
       "        0.04778242]),\n",
       " array([5.78931945, 5.80240395, 5.80922321, 5.8138981 , 5.8331361 ,\n",
       "        5.85171671, 5.87025479, 5.88966178, 5.91352081, 5.93596621,\n",
       "        5.96212693]))"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "orig_model_mixture_val, orig_model_mixture_std, cost_l"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "d8c24b6d",
   "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(cost_l, orig_model_mixture_val, orig_model_mixture_std, label='DiRRAc', marker='+', alpha=0.8)\n",
    "\n",
    "ax.set(xlabel='$l_{1}\\ cost$', 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/figure8/cost_robustness_DiRRAc.pdf', dpi=400, 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
}
