{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "c909fc22",
   "metadata": {},
   "source": [
    "# Import libraries"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "3ebccad7",
   "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 pandas as pd\n",
    "from sklearn.model_selection import train_test_split\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "from dirrac.classifier.logistic import logistic_classifier, logistic_visualize\n",
    "from dirrac.data.synthetic_data import DataSynthesizer\n",
    "from dirrac.gen_counterfactual import DRRA\n",
    "from ar.gen_counterfactual import LinearAR\n",
    "from mace.loadModel import loadModelForDataset\n",
    "from mace.batchTest import runExperiments\n",
    "from utils import pad_ones, cal_validity"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "189e0680",
   "metadata": {},
   "outputs": [],
   "source": [
    "if not os.path.exists('result/figure3/'):\n",
    "    os.makedirs('result/figure3/')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 203,
   "id": "8edad1fc",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Matplotlib config\n",
    "SMALL_SIZE = 8\n",
    "MEDIUM_SIZE = 12\n",
    "BIGGER_SIZE = 18\n",
    "\n",
    "plt.rc('font', size=BIGGER_SIZE)          # controls default text sizes\n",
    "plt.rc('axes', titlesize=BIGGER_SIZE)     # fontsize of the axes title\n",
    "plt.rc('axes', labelsize=BIGGER_SIZE - 2)    # fontsize of the x and y labels\n",
    "plt.rc('xtick', labelsize=MEDIUM_SIZE)    # fontsize of the tick labels\n",
    "plt.rc('ytick', labelsize=MEDIUM_SIZE)    # fontsize of the tick labels\n",
    "plt.rc('legend', fontsize=BIGGER_SIZE)    # legend fontsize"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f0aab625",
   "metadata": {},
   "source": [
    "# Synthesize data and train original classifier"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 125,
   "id": "931f28ca",
   "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.3, 0.4, 0.3]\n",
    "\n",
    "sd = DataSynthesizer(mean_0, cov_0, mean_1, cov_1, n)\n",
    "features, labels = sd.synthesize_modes_data(100, [0.3, 0.4, 0.3], [0.1, 0.1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 126,
   "id": "dae370e7",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Train 101 logistic classifiers - the first classifier is on original data, other\n",
    "all_coef = np.zeros((101, 3))\n",
    "for i in range(101):\n",
    "    coef = logistic_classifier(pad_ones(features[i]), labels[i])[1].T\n",
    "    all_coef[i] = np.squeeze(coef)\n",
    "\n",
    "# Get theta\n",
    "mean_shift = all_coef[1:31]\n",
    "cov_shift = all_coef[31:71]\n",
    "both_shift = all_coef[71:101]\n",
    "\n",
    "theta = np.zeros((3, 3))\n",
    "sigma = np.zeros((3, 3, 3))\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": "markdown",
   "id": "f1c01d32",
   "metadata": {},
   "source": [
    "# Save to csv"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "cff900ad",
   "metadata": {},
   "outputs": [],
   "source": [
    "df = pd.DataFrame(columns=['label', 'x0', 'x1'])\n",
    "df['label'] = labels[0]\n",
    "df['x0'] = features[0][:, 0]\n",
    "df['x1'] = features[0][:, 1]\n",
    "df.to_csv('mace/_data_main/processed_data/synthetic_data.csv', index=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "72686eac",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>label</th>\n",
       "      <th>x0</th>\n",
       "      <th>x1</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.0</td>\n",
       "      <td>-2.776021</td>\n",
       "      <td>-2.255409</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.0</td>\n",
       "      <td>-3.334269</td>\n",
       "      <td>-1.610828</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0.0</td>\n",
       "      <td>-5.296095</td>\n",
       "      <td>-1.858795</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0.0</td>\n",
       "      <td>-2.944552</td>\n",
       "      <td>-3.082760</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.0</td>\n",
       "      <td>-3.651688</td>\n",
       "      <td>-3.016022</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>995</th>\n",
       "      <td>1.0</td>\n",
       "      <td>1.891151</td>\n",
       "      <td>4.456270</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>996</th>\n",
       "      <td>1.0</td>\n",
       "      <td>1.099763</td>\n",
       "      <td>4.243181</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>997</th>\n",
       "      <td>1.0</td>\n",
       "      <td>2.240315</td>\n",
       "      <td>3.742204</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>998</th>\n",
       "      <td>1.0</td>\n",
       "      <td>3.128713</td>\n",
       "      <td>2.557857</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>999</th>\n",
       "      <td>1.0</td>\n",
       "      <td>2.977528</td>\n",
       "      <td>4.220530</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>1000 rows × 3 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "     label        x0        x1\n",
       "0      0.0 -2.776021 -2.255409\n",
       "1      0.0 -3.334269 -1.610828\n",
       "2      0.0 -5.296095 -1.858795\n",
       "3      0.0 -2.944552 -3.082760\n",
       "4      0.0 -3.651688 -3.016022\n",
       "..     ...       ...       ...\n",
       "995    1.0  1.891151  4.456270\n",
       "996    1.0  1.099763  4.243181\n",
       "997    1.0  2.240315  3.742204\n",
       "998    1.0  3.128713  2.557857\n",
       "999    1.0  2.977528  4.220530\n",
       "\n",
       "[1000 rows x 3 columns]"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "b0a771ee",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Train the original classifier and get the instances that are classified as negative class\n",
    "model_trained, X_train, y_train, X_test, y_test = loadModelForDataset('lr', 'synthetic')\n",
    "X_recourse = X_test[model_trained.predict(X_test) == 0]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8433315b",
   "metadata": {},
   "source": [
    "# Initialization"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "5b081b60",
   "metadata": {},
   "outputs": [],
   "source": [
    "# DDRA \n",
    "delta = 0.2\n",
    "k = 3\n",
    "dim = 3\n",
    "rho = np.array([0, 0, 0])\n",
    "lmbda = 0.7\n",
    "zeta = 1\n",
    "\n",
    "drra_module = DRRA(delta, k, dim, p, theta, sigma, rho, lmbda, zeta, padding=True)\n",
    "ar_module = LinearAR(X_train, model_trained.coef_, model_trained.intercept_)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8002e231",
   "metadata": {},
   "source": [
    "# Generate counterfactual"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "b05ecbd3",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Generate counterfactual for DiRRAc\n",
      "Generate counterfactual for Gaussian DiRRAc\n",
      "Generate counterfactual for AR\n",
      "Generate counterfactual for MACE\n"
     ]
    }
   ],
   "source": [
    "print(\"Generate counterfactual for DiRRAc\")\n",
    "counterfactual_drra_nm = drra_module.fit_data(pad_ones(X_recourse), model='nm')\n",
    "print(\"Generate counterfactual for Gaussian DiRRAc\")\n",
    "counterfactual_drra_gm = drra_module.fit_data(pad_ones(X_recourse), model='gm')\n",
    "print(\"Generate counterfactual for AR\")\n",
    "counterfactual_ar = ar_module.fit_data(X_recourse)\n",
    "print(\"Generate counterfactual for MACE\")\n",
    "counterfactual_mace = runExperiments(['synthetic'], ['lr'], ['one_norm'], ['MACE_eps_1e-5'], 0, len(X_recourse), 'neg_only', '0')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "1371fdd8",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Define shift params\n",
    "alpha_l = [0.1 * i for i in range(11)]\n",
    "beta_l = [0.1 * i for i in range(11)]\n",
    "\n",
    "def run_experiments(shift_type='mean'):\n",
    "    \"\"\" Run experiments for 3 types of data distribution shifts \"\"\"\n",
    "    # Init\n",
    "    validity_drra_nm, std_drra_nm = np.zeros(len(alpha_l)), np.zeros(len(alpha_l))\n",
    "    validity_drra_gm, std_drra_gm = np.zeros(len(alpha_l)), np.zeros(len(alpha_l))\n",
    "    validity_ar, std_ar = np.zeros(len(alpha_l)), np.zeros(len(alpha_l))\n",
    "    validity_mace, std_mace = np.zeros(len(alpha_l)), np.zeros(len(alpha_l))\n",
    "\n",
    "    for i in range(1, len(alpha_l)):      \n",
    "        \n",
    "        mean_shift = mean_0 + [alpha_l[i], 0] if shift_type in ['mean', 'both'] else mean_0\n",
    "        cov_shift = cov_0 * (1 + beta_l[i]) if shift_type in ['cov', 'both'] else cov_0\n",
    "        \n",
    "        iter_drra_nm = np.zeros(100)\n",
    "        iter_drra_gm = np.zeros(100)\n",
    "        iter_ar = np.zeros(100)\n",
    "        iter_mace = np.zeros(100)\n",
    "        features, labels = sd.synthesize_data(mean_shift, cov_shift, mean_1, cov_1)\n",
    "        for j in range(100):\n",
    "            features, labels = sd.synthesize_data(mean_shift, cov_shift, mean_1, cov_1)\n",
    "            clf_shift, coef_shift = logistic_classifier(features, labels)\n",
    "\n",
    "            iter_drra_nm[j] = cal_validity(clf_shift.predict(counterfactual_drra_nm[:, :-1]))\n",
    "            iter_drra_gm[j] = cal_validity(clf_shift.predict(counterfactual_drra_gm[:, :-1]))\n",
    "            iter_ar[j] = cal_validity(clf_shift.predict(counterfactual_ar))\n",
    "            iter_mace[j] = cal_validity(clf_shift.predict(counterfactual_mace))\n",
    "        \n",
    "        validity_drra_nm[i], std_drra_nm[i] = np.mean(iter_drra_nm), np.std(iter_drra_nm)\n",
    "        validity_drra_gm[i], std_drra_gm[i] = np.mean(iter_drra_gm), np.std(iter_drra_gm)\n",
    "        validity_ar[i], std_ar[i] = np.mean(iter_ar), np.std(iter_ar)\n",
    "        validity_mace[i], std_mace[i] = np.mean(iter_mace), np.std(iter_mace)\n",
    "\n",
    "    # Validity for original data\n",
    "    validity_drra_nm[0] = cal_validity(model_trained.predict(counterfactual_drra_nm[:, :-1]))\n",
    "    validity_drra_gm[0] = cal_validity(model_trained.predict(counterfactual_drra_gm[:, :-1]))\n",
    "    validity_ar[0] = cal_validity(model_trained.predict(counterfactual_ar))\n",
    "    validity_mace[0] = cal_validity(model_trained.predict(counterfactual_mace))\n",
    "\n",
    "    return validity_drra_nm, validity_drra_gm, validity_ar, validity_mace, std_drra_nm, std_drra_gm, std_ar, std_mace"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8f207a0e",
   "metadata": {},
   "source": [
    "# Data distribution shift"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "4745357c",
   "metadata": {},
   "source": [
    "# Mean shift"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 206,
   "id": "1aad87c4",
   "metadata": {},
   "outputs": [],
   "source": [
    "validity_drra_nm, validity_drra_gm, validity_ar, validity_mace, std_drra_nm, std_drra_gm, std_ar, std_mace = run_experiments(shift_type='mean')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 215,
   "id": "4fe5dc19",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAZkAAAEJCAYAAABGw1qNAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjQuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/MnkTPAAAACXBIWXMAAAsTAAALEwEAmpwYAAA1v0lEQVR4nO3deXhU5dn48e89k31lRwEhAcGqiJS2iAIS3FrAtiq4QNm0lp/69q20tWixFlBr1fdVa611TVhEQFFBW3ErEhWXqq8LSlUEEhZZA5J9z/P748xMJslMMpNkzkky9+e6zjUzZ545534SmDvPcp4jxhiUUkqpSHA5HYBSSqmuS5OMUkqpiNEko5RSKmI0ySillIoYTTJKKaUiRpOMUkqpiNEko5RSKmJsTzIi8ksR+VBEKkVkWQtlfy0iB0SkSERyRCTepjCVUkq1AydaMvuA24Gc5gqJyA+Bm4BzgUHAYGBJCMc3bdnefffdNn2+s2/RXP9orrvWX+vfxvoHJU5d8S8itwMDjDFzg7y/Csg3xiz0vD4XeNIYc1wLh25VhUx1JdPvv5TY+IO89c1CIKY1h1FKqU4r/84prf2oBHujI3+Tngo87/f6U6CviPQ0xhzxLygi84B5AAsWLGDSpEnhn80YDnXfweEYF4MPf8HOqtNaH7lSSnVCubm5rfpcVlZW0Pc6cpJJAQr9XnufpwINkowx5lHgUe/L1p5w1Tc9OFx7jEXjCphwQaszeqeWm5vb7D+Yriya6w5af61/ZOrfkWeXlQBpfq+9z4sjdcKM7kMByDvwYaROoZRSUaUjJ5mtwOl+r08HDjbuKmtPmQPOBCC/eC9Ul0fqNEopFTWcmMIcIyIJgBtwi0iCiATqtlsB/FxEThGRbsAfgGWRjC2zjzUOkxcjsPvdSJ5KKaWighMtmT8A5VjTk2d6nv9BRAaKSImIDAQwxrwM3A1sAnYDu4BFkQwsIy0DgLzYWNi+MZKnUkqpqGD7wL8xZjGwOMjbKY3K3gvcG+GQfPom9SWeGL51w7Edr9PNrhMrpVQX1ZHHZGwnIvSJtS7DyS/cDsUHHI5IKaU6N00yjfT1JJm82FjY8brD0SilVOemSaaRvrF9AU0ySinVHjTJNFKfZGJgxyaoq3M4IqWU6rw0yTTSJ7YPAPkJiVBWAAc/czgipZTqvDTJNNI7pjeCsMctVINOZVZKqTbQJNNInCuOfin9qAX2xMbouIxSEZRx04tk3PSi02GoCNIkE0BGegYAeXFxsPs9qCp1NiCllOqkNMkEkJmWCUBej0FQVw35mx2OSCnVES1btgwRafUS+dFAk0wAmelWkslPsyYBaJeZUl3fJ598goj4NrfbTffu3Rk+fDhz5szh5ZdfJpSbPObm5jY4joiQkpLCqFGjuO+++6ipqWnymaysrAblY2Nj6devH5dffjmff/55s+c744wzEBF+/vOft7rukdSR7yfjGG+SyYvx3OxNk4xSUWP69OlMnjwZYwzFxcV89dVXrF+/nhUrVnDeeeexdu1aunXrBsCsWbO44ooriIuLa/Y4Bw4cYMWKFfzmN7/hiy++4NFHH21SPj4+nscffxyA8vJy/u///o+lS5eyYcMGPvzwQ0466aQmn/n88895//33GTJkCE8//TR//etfSU5Obt8fSBtpkgnAl2QqDmPi05CCbXBsD3Q7weHIlFKRNmrUKGbOnNlg37333suCBQu49957mT59Oi+99BIAbrcbt9sd0nGuu+46vvOd7/D444/zpz/9id69ezcoHxMT06D8L37xC0455RSuv/56/va3v/HAAw80OUd2djapqamsXLmSM888k6effporr7yy1XWPBO0uC6BnQk9SY1MprirmaMZZ1k5tzSgVtdxuN/fccw/jxo3j5ZdfZvNma5w2nDGZ5ORkxowZgzGGHTt2hHTec889F4Cvv/66yXtVVVWsXLmSadOmMWbMGL773e+SnZ0d9FjPPvssWVlZdOvWjaSkJE466SR+9atfUVVVFVIsraVJJgARqW/NHH+KtVOTjFJRzzvu8eKLrZt27U0uPXr0aHP5559/noKCAubMmQPA3Llzefvtt/nqq6+alL355puZNm0ahw8f5te//jV/+ctfuOiii9iwYQNlZWWtqkuotLssiIz0DLYUbCEvvQ/fB9iZC3W14ArcNFYqmrT3tS3tdbz8O6e0y3GCGTFiBADbtm1rsWxZWRkFBQW+MZmHH36Yjz/+mNGjRzNs2LCAnykoKADqx2Tmz58P0KT7DiAnJ4eMjAzOPvtsAGbMmMENN9xATk4Od911l6/c+++/zx133MHEiRPZsGEDCQkJvvfuvPPO0CreBtqSCcI3w6ymBLpnQsUx2Pexs0EppRyVlpYGQFFRUYtlFy1aRO/evenTpw8jRozg73//O5dccgnPP/98wPKlpaX07t2b3r17M3DgQC6++GKqqqpYvnw5kydPblB2z549vPrqq8yePRsRa4JSr169mDJlCitWrGgwg+3JJ58E4M9//nODBAP4ZrNFkrZkgvBdK1OYB0POgQ+zrS6zAd93ODKlnNdeLQZvCybSLZD24k0u3mTTnHnz5nHppZdSXV3NZ599xl133cXevXubfNF7JSQk8I9//AOAo0ePsmLFCl577TXqAizSu2zZMurq6hg7dizbt2/37T/nnHNYv349GzZs4Cc/+QlgjeeICKeffnrY9W0PmmSC8F31X5gHp/xXfZKZsMDZwJRSjtmyZQtAwOnEjQ0dOpTzzjsPgEmTJjFu3DjGjRvHNddcw5o1a5qUd7vdvvIA06ZN48ILL2TevHmMGjXK11VnjGHp0qUA/PCHPwx47pycHF+SAXtaLMFod1kQJ6SegFvc7CvdR+XAM0DcsOd9qGi5mayU6pq8s7emTAm/5XXWWWcxa9YsnnrqKd55550Wy7tcLu6//36MMdxwww2+/Zs2bSIvL4/58+ezdu3aJtsll1zCiy++yMGDBwEYNmwYdXV1fPrpp2HH3B40yQQR545jQOoA6kwdu6uOwQmjwdRC3ptOh6aUslltbS033HADmzdvZvLkyYwdO7ZVx7nllltwu9388Y9/DKn80KFDmTFjBq+99ppv2nR2djZut5uFCxcybdq0JtuvfvUrampqWLFiBWBNCABYuHBhwOnKoaxi0BaaZJqRkZYB+I3LgE5lVqqL++ijj1i5ciUrV67koYceYv78+QwZMoR77rmHCy64gFWrVrX62CeeeCJXXHEFGzdu5K233grpMwsXLsTlcrFo0SKOHTvGc889x/jx45tczOk1fvx4+vTpQ05ODgCjR4/mxhtvZOPGjYwaNYrbbruNxx57jIULFzJs2DAKCwtbXZ9QaJJphu9amcI8GGJdFKVJRqmubfXq1cyaNYs5c+Zw00038dprrzFhwgReeuklXnnlFdLT09t0/JtvvhmXyxVya+akk07isssu4/XXX+f++++noqKCSy65JGh5l8vFRRddxJdffunrlrvzzjtZtWoV6enp3H333cyfP5/nnnuOyZMnk5SU1Kb6tEQH/pvhm8ZclA+nXQ0J3eDbPDi6E3oMdjQ2pVT7GjlyZNhdR3PnzmXu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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Plot\n",
    "fig, ax = plt.subplots()\n",
    "\n",
    "ax.errorbar(alpha_l, validity_drra_nm, std_drra_nm, label='DiRRAc')\n",
    "ax.errorbar(alpha_l, validity_ar, std_ar, label='AR')\n",
    "ax.errorbar(alpha_l, validity_mace, std_mace, label='MACE')\n",
    "\n",
    "ax.set(xlabel='$\\\\alpha$', ylabel='validity')\n",
    "ax.grid()\n",
    "ax.legend(loc='upper right', frameon=False)\n",
    "plt.ylim(0, 1.01)\n",
    "plt.savefig('result/figure3/mean_shift_DiRAAc-NM.pdf', dpi=400)\n",
    "plt.tight_layout()\n",
    "\n",
    "plt.show()# Define shift params"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 216,
   "id": "f4996056",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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9/zixYuprq7m6quvZurUqeTl5fHBB95Pu8jPz+fWW2+lX79+rs9izJgxrFq1yq9Ymir87dNWSETISM1gfcF6crufRNrmd60kM2JKuENTEeq1114D4LrrrgvouPXr1/PGG28wfvx4+vfvT1VVFe+++y733HMP27dv529/+1uT4vnoo4/4xS9+weDBg7n33ns57rjj2LNnD6tXr2br1q0MGjSI6upqxowZw48//shNN93EoEGDKCwsZP369axdu5YpUxr+//T4449zxhlncOutt9KxY0e+/fZb5s2bx4cffsiGDRtIS0vzKP/1119zySWXcM011zBx4kRycnLIysoiKirKZ1dTIEaPHk3fvn356KOPKC0tJTExMeDXcCaKjh07tsgx2dnZjBw5kvT0dHr16kWXLl3Izs5m9OjRHuXy8vI4++yz2bdvH5MnT+anP/0ppaWlfPrpp6xevZoxY8YEXBd/aZLxIT013UoyqV34KcD2HKitgajoMEemGtOsc1verX9sS50rk/fIxU0+9ttvvyUlJYWMjAyP/TU1NRw+fNhjX2JiIvHx8QCMHDmS7du3e4wZTJ8+nauvvpp58+Yxe/ZsunfvHnA8K1asoLa2llWrVtGlSxfX/pkzZ7ruf/fdd2zevJlHH32UGTNmBPweGzZsqPdF/otf/ILRo0eTlZVV7zXXr1/PJ598wumnnw7A9ddfT1FREfPnz+eJJ54gKcnjSiJNMnToUHbs2MH27dsZMmRIo+ULCgqAY2My06dPB2DSpEleyx89epSCggLXmMwLL7zAV199xWmnncagQYM8yn722Wds3LiR+fPnA2Cz2Zg4cSIvvPAChw8fpkOHDq6yN910E3v27OHdd9/lwgsv9Hid2iAvnaXdZT64ZphVl0CHDCg/Anu+Cm9QKmIVFRWRkpJSb//3339P586dPbZnn33W9Xx8fLwrwVRWVnLo0CEKCgq48MILqa2t5YsvvmhSPKmpqQC8/vrrPmc+OcusWbOG/fv3B/wezgRTW1tLYWEhBQUFDBs2jNTUVD777LN65c8880xXgnEaNWoU1dXVXrvYmsL5GRQVFTVatrS01PWZ9OnTh/Hjx1NZWcnChQsZN26c12NmzZpF586d6dKlC0OHDuW5557j0ksvZcWKFfXKZmVlkZiYyGWXXebaN3XqVMrLy1myZIlr36FDh3j33Xe56KKL6iUYgKio4KYBbcn44DpXpjAX+o+CL7KsLrNePw1zZKoxTW0x5OTkePStO1swzWmBtJSUlBSvX2wZGRmuPvVvvvmGO++80+P56upqHnnkERYtWsTWrVsxxng8X7cV5K+bb76ZFStWcNNNN3H33XdzzjnncNFFF3HVVVfRuXNnwJo1dv/99/Pwww/TvXt3hg8fzvnnn8/ll1/Oqaee2uh7fPjhh8ydO5fPPvuM8vLyRuPu169fvX3OLrWDBw82pZr1OD8Dbwm/rri4ON5++23A+qJftGgRq1atarDlMG3aNC6//HKqqqrYsGEDjz76KLt37yYuLs6jXGlpKUuXLiUzM9NjanViYiIDBgwgKyuL3/3udwCuz/0nP/lJwPVtCdqS8cF11r8zyYAO/quwGTx4MEVFReTm5nrsT0xMZPTo0YwePZoRI0bUO+72229n5syZnHLKKa7ps6tWreLRRx8FPLtKvE3DdarbWklLS+Pzzz9nzZo13HLLLRQXF3PbbbcxaNAgPvnkE1e5Bx98kB9++IG//vWv9O/fn3nz5nHaaadx9913N1jfzz//nAsuuID8/HweeeQRVqxYwfvvv8+qVatIS0vz+kUdHe27K7tucm2q9evXY7fbvSY0b/E4P5tf//rXvPXWW5x//vlMmzaN9evXez1m4MCBjB49mrFjxzJjxgzefvttPv/8c2644QaPcsuWLaO4uJiVK1cycOBAj23r1q189dVXfP311y1R5WbTlowPvZN7Ey3R7CndQ0Wf04mVaNj1XygvgrjGf8Uo1ZIuu+wy/v3vfzNv3jz+9Kc/+X3c4sWL+dnPfsbSpUs99m/durVe2eTkZMD61Z2enu7aX15ezt69exkwYIBH+ejoaDIzM12tv/Xr1zNixAgefPBBVq48No7Vr18/brnlFm655RbKy8u58MILeeyxx7jjjjs8xnPcLVmyhJqaGt555x2PcajS0tImt76aa/Xq1ezYsYPRo0c3adA/KiqKp556ipNOOok777yT999/v9FjzjrrLK6++moWLVrErbfeyllnWbNds7Oz6dGjB0899VS9YyorK5k8eTJZWVk8/fTTDBgwABEJW9LRlowPMdEx9EruRa2pZWflEeh9GpgayP13uENTEei6667jhBNO4M9//jPLly/3Wsbbr/Xo6Oh6+0tLS3nyySfrle3VqxdgfZm6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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Plot\n",
    "fig, ax = plt.subplots()\n",
    "\n",
    "ax.errorbar(alpha_l, validity_drra_gm, std_drra_gm, label='Gaussian DiRRAc')\n",
    "ax.errorbar(alpha_l, validity_ar, std_ar, label='AR')\n",
    "ax.errorbar(alpha_l, validity_mace, std_mace, label='MACE')\n",
    "\n",
    "ax.set(xlabel='$\\\\alpha$', ylabel='validity')\n",
    "ax.grid()\n",
    "ax.legend(loc='upper right', frameon=False)\n",
    "plt.ylim(0, 1.01)\n",
    "plt.savefig('result/figure3/mean_shift_DiRAAc-GM.pdf', dpi=400)\n",
    "plt.tight_layout()\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "4e65133a",
   "metadata": {},
   "source": [
    "# Covariance shift"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 217,
   "id": "71eac209",
   "metadata": {},
   "outputs": [],
   "source": [
    "validity_drra_nm, validity_drra_gm, validity_ar, validity_mace, std_drra_nm, std_drra_gm, std_ar, std_mace = run_experiments(shift_type='cov')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 218,
   "id": "1dde0406",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAZkAAAEJCAYAAABGw1qNAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjQuMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/MnkTPAAAACXBIWXMAAAsTAAALEwEAmpwYAAA+K0lEQVR4nO3deXxU1fn48c8z2XfIBkLIClhlFdGigIRiraCtG62CKGotX9uvbak/Sy2tAt2+6u+nXbR1ZRUFS+vWr7ZuJQhqBWQRcEEggQRIwpaVkG3O7487M2SZLJNkZjKZ5/163dfM3Hvuvc9JYJ6ce849V4wxKKWUUt5g83cASiml+i5NMkoppbxGk4xSSimv0SSjlFLKazTJKKWU8hpNMkoppbxGk4xSSimv8XmSEZG7RWSriNSKyIoOyv5ERIpFpEJElolIhI/CVEop1QP80ZI5AvwGWNZeIRH5BnAfMA3IALKBJZ04vunO8uGHH3Zr/0Bfgrn+wVx3rb/Wv5v1b5P4645/EfkNkGaMua2N7S8ABcaYhY7P04DnjTEDOzh0lypk6muZ/di12CKO8UHhLzGEdeUwSikVsAoevKqru0pbG0K7ekQfGAG82uTzTmCAiCQZY040LSgi84B5AAsWLGD69Omen80YjsUfoiTMxtDwPXxZN7bLgSulVCDKy8vr0n65ubltbuvNSSYWKG/y2fk+DmiWZIwxTwNPOz929YRrjyRR0nCKhROPM/UbXc7oAS0vL6/dfzB9WTDXHbT+Wn/v1L83jy6rAuKbfHa+r/TWCbMShwOQf3Srt06hlFJBpTcnmT3AmCafxwAlLS+V9aSstIkAHKg+ArVV3jqNUkoFDX8MYQ4VkUggBAgRkUgRcXfZbhXwXRE5X0T6Ab8EVngztqyUkQDkh4ZAwSZvnkoppYKCP1oyvwRqsIYnz3G8/6WIpItIlYikAxhj/gU8DKwHDgEHgUXeDCwrIQuA/LAwzL53vHkqpZQKCj7v+DfGLAYWt7E5tkXZR4FHvRySS1JkEtGEUxlSx4kD75LsqxMrpVQf1Zv7ZHxOREgNPweA/OrDcKrAvwEppVSA0yTTQmrYAMC6ZMa+d/0cjVJKBTZNMi0MDLMmFMgPC4X9//ZzNEopFdg0ybQwoGlL5sAGaKz3c0RKKRW4NMm04EwyBZFRUFcJRVv8HJFSSgUuTTItJIcmEyqhHLFBjYj2yyilVDdokmkhREIYEj8EAxwKC4X9mmSU8pbM+14n877X/R2G8iJNMm5kxTtuyoyIgiM7oNprM9kopVSfpknGDded/8mZgIED6/0aj1Kqd1qxYgUi0uUp8oOBJhk3nEnmQGyitUL7ZZTq83bs2IGIuJaQkBD69+/PyJEjmTt3Lv/617/ozEMe8/Lymh1HRIiNjWXcuHH8/ve/p6GhodU+ubm5zcqHhYUxaNAgbrzxRnbv3t3u+b761a8iInz3u9/tct29qTc/T8ZvXC0ZabRW7P83GAPS5sPflFJ9xKxZs5gxYwbGGCorK/niiy945ZVXWLVqFZdffjnr1q2jX79+ANxyyy3cdNNNhIeHt3uc4uJiVq1axT333MNnn33G008/3ap8REQEzz77LAA1NTV8/PHHLF++nDfeeIOtW7dy7rnnttpn9+7dbN68mZycHP7617/ypz/9iZiYmJ79gXSTJhk3MhMyASg4XYw9diC2qmIo2QMDR/o3MKWU140bN445c+Y0W/foo4+yYMECHn30UWbNmsU///lPAEJCQggJCenUcX7wgx/wla98hWeffZbf/va3pKSkNCsfGhrarPz3vvc9zj//fH784x/z+OOP89hjj7U6x9KlS4mLi2P16tVccskl/PWvf+X222/vct29QS+XuREfHk9yVDK1jbUczbrUWql3/ysVtEJCQnjkkUeYNGkS//rXv9i0yXoUiCd9MjExMUyYMAFjDPv37+/UeadNmwbAl19+2WpbXV0dq1evZubMmUyYMIELLriApUuXtnmsv//97+Tm5tKvXz+io6M599xz+dGPfkRdXV2nYukqTTJtcF0yG+BooupQZqWCnrPf4/XXuzbs2plcEhMTu13+1Vdf5fjx48ydOxeA2267jffff58vvviiVdlf/OIXzJw5k2PHjvGTn/yEP/zhD1x77bW88cYbnD59ukt16Sy9XNaGrPgsthRvIT+2H5MQOPgh1J2G8Gh/h6aU3/X0vS09dbyCB6/qkeO0ZfTo0QDs3bu3w7KnT5/m+PHjrj6ZJ598ku3bt3PxxRczfPhwt/scP34cONsnM3/+fIBWl+8Ali1bRmZmJpdddhkAs2fP5t5772XZsmU89NBDrnKbN2/md7/7HVOnTuWNN94gMjLSte3BBx/sXMW7QVsybcjulw1Afk0pDBoLjbVw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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Plot\n",
    "fig, ax = plt.subplots()\n",
    "\n",
    "ax.errorbar(alpha_l, validity_drra_nm, std_drra_nm, label='DiRRAc')\n",
    "ax.errorbar(alpha_l, validity_ar, std_ar, label='AR')\n",
    "ax.errorbar(alpha_l, validity_mace, std_mace, label='MACE')\n",
    "\n",
    "ax.set(xlabel='$\\\\beta$', ylabel='validity')\n",
    "ax.grid()\n",
    "ax.legend(loc='upper right', frameon=False)\n",
    "plt.ylim(0, 1.01)\n",
    "plt.savefig('result/figure3/covariance_shift_DiRAAc-NM.pdf', dpi=400)\n",
    "plt.tight_layout()\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 219,
   "id": "7602f633",
   "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": [
    "# Plot\n",
    "fig, ax = plt.subplots()\n",
    "\n",
    "ax.errorbar(alpha_l, validity_drra_gm, std_drra_gm, label='Gaussian DiRRAc')\n",
    "ax.errorbar(alpha_l, validity_ar, std_ar, label='AR')\n",
    "ax.errorbar(alpha_l, validity_mace, std_mace, label='MACE')\n",
    "\n",
    "ax.set(xlabel='$\\\\beta$', ylabel='validity')\n",
    "ax.grid()\n",
    "ax.legend(loc='upper right', frameon=False)\n",
    "plt.ylim(0, 1.01)\n",
    "plt.savefig('result/figure3/covariance_shift_DiRAAc-GM.pdf', dpi=400)\n",
    "plt.tight_layout()\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e57d6d1c",
   "metadata": {},
   "source": [
    "# Mean and Covariance shift"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 220,
   "id": "364e17b9",
   "metadata": {},
   "outputs": [],
   "source": [
    "validity_drra_nm, validity_drra_gm, validity_ar, validity_mace, std_drra_nm, std_drra_gm, std_ar, std_mace = run_experiments(shift_type='both')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 221,
   "id": "d4ffb273",
   "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": [
    "# Plot\n",
    "ax = plt.gca()\n",
    "\n",
    "ax.errorbar(alpha_l, validity_drra_nm, std_drra_nm, label='DiRRAc')\n",
    "ax.errorbar(alpha_l, validity_ar, std_ar, label='AR')\n",
    "ax.errorbar(alpha_l, validity_mace, std_mace, label='MACE')\n",
    "\n",
    "ax.set(xlabel='$\\\\alpha, \\\\beta$', ylabel='validity')\n",
    "ax.grid()\n",
    "ax.legend(loc='upper right', frameon=False)\n",
    "ax.set_xlim(0, 1)\n",
    "plt.ylim(0, 1.01)\n",
    "plt.savefig('result/figure3/both_shift_DiRAAc-NM.pdf', dpi=400)\n",
    "plt.tight_layout()\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 222,
   "id": "67633b53",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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OHAgxhh+/PHHascXLFhAWVkZt956KxMmTGDXrl18+KH72/s5OTncc889dO3a1flZDB06lJUr/TvjfPDrp41U18Su/FT4EzuTupIMVrvM0BlBzpUKVW+++SYAEydO9Om8jRs3snTpUkaOHEm3bt0oLS3lvffe46GHHmLnzp28/PLLdcrPmjVruPbaa+nduzcPP/wwZ5xxBgcOHGDVqlXs2LGDnj17UlZWxtChQ9m/fz933XUXPXv2JDc3l40bN/LJJ58wfvz4Gt/j73//OwMHDuSee+6hVatWbN68mTlz5vDRRx+xadMmWrduXSn9N998wzXXXMNtt93GmDFjyMrKIj09nbCwMI+3mnyRlpZGly5dWLNmDYWFhdhsNp+v4QgUrVq1apBzMjIyGDx4MMnJyXTq1Im2bduSkZFBWlpapXS7du3ikksu4eDBg4wbN47zzz+fwsJCPv30U1atWsXQoUN9Lou3NMh4kJKYwroD68iOjoHIODi4CfJ+goT2wc6aqkW9xra8V/3chhors2vW1XU+d/PmzSQkJJCSklJpf3l5OcePH6+0z2azERsbC8DgwYPZuXNnpTaDyZMnc+uttzJnzhymT59O+/a+/5t+++23qaioYOXKlbRt29a5f+rUqc7n3333HT/88ANPPvkkU6ZM8fk9Nm3aVO2L/NprryUtLY309PRq19y4cSPr16/noosuAuCOO+4gLy+PzMxMnn76aeLjK60kUid9+/Zl9+7d7Ny5kz59+tSa/siRI8DpNpnJkycDMHbsWLfpT548yZEjR5xtMrNnz+brr7/mwgsvpGfPnpXSbtiwgS1btpCZmQlAREQEY8aMYfbs2Rw/fpyWLVs60951110cOHCA9957jyuvvLLSdSoqKrwuf13o7TIPnGNl8vdA8qXWzh8/CmKOVCjLy8sjISGh2v7vv/+epKSkStsLL7zgPB4bG+sMMCUlJRw7dowjR45w5ZVXUlFRwRdffFGn/CQmJgLw1ltveez55EizevVqDh065PN7OAJMRUUFubm5HDlyhPPOO4/ExEQ2bNhQLf3FF1/sDDAOl19+OWVlZW5vsdWF4zPIy6t9efbCwkLnZ9K5c2dGjhxJSUkJ8+bNY8SIEW7PmTZtGklJSbRt25a+ffvy4osvct111/H2229XS5ueno7NZmP06NHOfRMmTKC4uJhFixY59x07doz33nuPq666qlqAAQgL828Y0JqMB44gsyt3F3RPg+3vW+0yP78luBlTtaprjSErK6vSvXVHDaY+NZCGkpCQ4PaLLSUlxXlP/dtvv+X++++vdLysrIxZs2Yxf/58duzYgTGm0vGqtSBv3X333bz99tvcddddPPjgg/ziF7/gqquu4uabbyYpKQmweo39+c9/5q9//Svt27enX79+XHHFFVx//fVccMEFtb7HRx99xGOPPcaGDRsoLi6uNd9du3atts9xS+3o0aN1KWY1js/AXcCvKiYmhnfffRewvujnz5/PypUra6w5TJo0ieuvv57S0lI2bdrEk08+yb59+4iJiamUrrCwkMWLF5Oamlqpa7XNZqN79+6kp6fz+9//HsD5uf/85z/3ubwNQWsyHjhrMrk7Md0ut3b++BFUlNdwllL+0bt3b/Ly8sjOzq6032azkZaWRlpaGgMGDKh23r333svUqVPp37+/s/vsypUrefLJJ4HKt0rcdcN1qFpbad26NZ9//jmrV6/mD3/4A/n5+fzpT3+iZ8+erF+/3pnu8ccfZ/v27fzzn/+kW7duzJkzhwsvvJAHH3ywxvJ+/vnnDBs2jJycHGbNmsXbb7/NBx98wMqVK2ndurXbL+rw8HCP16saXOtq48aNREZGug1o7vLj+GxuuOEG3nnnHa644gomTZrExo0b3Z7To0cP0tLSGD58OFOmTOHdd9/l888/584776yUbsmSJeTn57N8+XJ69OhRaduxYwdff/0133zzTUMUud60JuNB65jWJEQlkFeSx5G4RJJapsDxbNj/FZxV+68wpRrS6NGj+fjjj5kzZw5PPPGE1+ctWLCAyy67jMWLF1fav2PHjmppW7RoAVi/upOTk537i4uL+emnn+jevXul9OHh4aSmpjprfxs3bmTAgAE8/vjjLF9+uh2ra9eu/OEPf+APf/gDxcXFXHnllTz11FPcd999ldpzXC1atIjy8nJWrFhRqR2qsLCwzrWv+lq1ahW7d+8mLS2tTo3+YWFhPPvss5xzzjncf//9fPDBB7WeM2jQIG699Vbmz5/PPffcw6BBgwCrwb9Dhw48++yz1c4pKSlh3LhxpKen89xzz9G9e3dEJGhBR2syHojI6UGZudnWLTPQrswqKCZOnEivXr3429/+xrJly9ymcfdrPTw8vNr+wsJCnnnmmWppO3Xq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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Plot\n",
    "ax = plt.gca()\n",
    "\n",
    "ax.errorbar(alpha_l, validity_drra_gm, std_drra_gm, label='Gaussian DiRRAc')\n",
    "ax.errorbar(alpha_l, validity_ar, std_ar, label='AR')\n",
    "ax.errorbar(alpha_l, validity_mace, std_mace, label='MACE')\n",
    "\n",
    "ax.set(xlabel='$\\\\alpha, \\\\beta$', ylabel='validity')\n",
    "ax.grid()\n",
    "ax.legend(loc='upper right', frameon=False)\n",
    "plt.ylim(0, 1.01)\n",
    "# ax.set_aspect('equal')\n",
    "plt.savefig('result/figure3/both_shift_DiRAAc-GM.pdf', dpi=400)\n",
    "plt.tight_layout()\n",
    "\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
}
