{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "443017ba-25af-4fa6-ac5e-868f0c48650a",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/pahde/anaconda3/envs/pytorch/lib/python3.10/site-packages/tqdm/auto.py:22: TqdmWarning: IProgress not found. Please update jupyter and ipywidgets. See https://ipywidgets.readthedocs.io/en/stable/user_install.html\n",
      "  from .autonotebook import tqdm as notebook_tqdm\n"
     ]
    }
   ],
   "source": [
    "import sys\n",
    "sys.path.append('../../')\n",
    "\n",
    "import pandas as pd\n",
    "import numpy as np\n",
    "import math\n",
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "from utils.cav import compute_cav\n",
    "from sklearn.svm import LinearSVC\n",
    "import torch\n",
    "from sklearn.model_selection import train_test_split\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "id": "5b49dc9c-0bcf-4d95-ac12-9bad9ef85386",
   "metadata": {},
   "outputs": [],
   "source": [
    "def add_noise(X, degree=0, var=0.25):\n",
    "    mean = 0\n",
    "    e = np.random.normal(mean, var, len(X)).reshape(-1, 1)\n",
    "    r = degree * math.pi / 180\n",
    "    dirX = math.sin(r)\n",
    "    dirY = math.cos(r)\n",
    "    dir_noise = np.array([dirX,dirY]).reshape(1, 2)\n",
    "    noise = e * dir_noise \n",
    "    X = X + noise \n",
    "    \n",
    "    return X, dir_noise"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "id": "307a15dc-8279-475e-9638-a515b1f51915",
   "metadata": {},
   "outputs": [],
   "source": [
    "from warnings import simplefilter\n",
    "from sklearn.exceptions import ConvergenceWarning\n",
    "\n",
    "simplefilter(\"ignore\", category=ConvergenceWarning)\n",
    "\n",
    "def get_cav(X, y, cav_type, fit_intercept=False, loss=\"hinge\"):\n",
    "    if cav_type == \"svm\":\n",
    "        linear = LinearSVC(random_state=0, fit_intercept=fit_intercept, max_iter=10000)\n",
    "        linear.fit(X, y)\n",
    "        w = torch.Tensor(linear.coef_)\n",
    "        w = w / torch.sqrt((w ** 2).sum())\n",
    "    else:\n",
    "        w = compute_cav(X, y, cav_type)\n",
    "    return w"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "531574cb-53c4-452c-8ede-d8d5d228cac7",
   "metadata": {},
   "source": [
    "## Fixed Classifier"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "id": "c7567fe5-2735-4ff3-880f-2d0238aff500",
   "metadata": {},
   "outputs": [],
   "source": [
    "w = np.array([1, -1])\n",
    "b = 0#-3\n",
    "c = np.array([1, 1])\n",
    "# c = np.array([-1, 1])\n",
    "\n",
    "model = lambda x: (x@w + b > 0) * 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "id": "514d76b9-8dc2-471c-ae9f-f5c53cceea0f",
   "metadata": {},
   "outputs": [],
   "source": [
    "def construct_data(degree, N=1000):\n",
    "    np.random.seed(0)\n",
    "    N_art = int(N/10)\n",
    "    cov_val = .35 #15\n",
    "    cov = np.array([[cov_val, 0], [0, cov_val]])\n",
    "    cov_art = np.array([[cov_val / 5, 0], [0, cov_val / 5]])\n",
    "    mean_a = np.array([2, 6.5])\n",
    "    \n",
    "    mean_b = mean_a + 4.5 * w\n",
    "    mean_a_art = mean_a + 2.5 * c\n",
    "\n",
    "    X_a = np.random.multivariate_normal(mean_a, cov, N)\n",
    "    X_a_art = np.random.multivariate_normal(mean_a_art, cov_art, N_art)\n",
    "    X_b = np.random.multivariate_normal(mean_b, cov, N)\n",
    "\n",
    "    var_noise = 1#.6 #.5\n",
    "    X_a, dir_noise = add_noise(X_a, degree=degree, var=var_noise)\n",
    "    X_a_art, _ = add_noise(X_a_art, degree=degree, var=var_noise)\n",
    "    X_b, _ = add_noise(X_b, degree=degree, var=var_noise)\n",
    "    \n",
    "    return X_a, X_a_art, X_b, dir_noise"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "id": "5a8c80d2-1a50-46c3-bc87-eccec0b5630f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 400x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "nrows = 1\n",
    "ncols = 1\n",
    "size = 4\n",
    "fig, axs = plt.subplots(nrows, ncols, figsize=(size*ncols,size*nrows), squeeze=False)\n",
    "ax = axs[0][0]\n",
    "fit_intercept = False\n",
    "scale_vector = 3\n",
    "\n",
    "X_a, X_a_art, X_b, dir_noise = construct_data(315, N=2000)\n",
    "\n",
    "X = np.concatenate([X_a, X_b, X_a_art])\n",
    "y = np.concatenate([\n",
    "    np.ones(len(X_a)),\n",
    "    np.zeros(len(X_b)),\n",
    "    np.ones(len(X_a_art))\n",
    "])\n",
    "\n",
    "t = np.concatenate([\n",
    "    np.zeros(len(X_a)),\n",
    "    np.zeros(len(X_b)),\n",
    "    np.ones(len(X_a_art))\n",
    "])\n",
    "\n",
    "mean_a = X_a.mean(0)\n",
    "\n",
    "# sns.scatterplot(x=X[:, 0], \n",
    "#                 y=X[:, 1], \n",
    "#                 hue=y, \n",
    "#                 ax=ax,\n",
    "#                 alpha=.3,\n",
    "#                 s=5)\n",
    "\n",
    "alpha = .8\n",
    "sns.kdeplot(x=X[(y == 1) & (t == 0), 0], y=X[(y == 1) & (t == 0), 1], cmap=\"Blues\", fill=True, ax=ax, alpha=alpha)\n",
    "sns.kdeplot(x=X[(y == 1) & (t == 1), 0], y=X[(y == 1) & (t == 1), 1], cmap=\"Purples\", fill=True, ax=ax, alpha=alpha)\n",
    "sns.kdeplot(x=X[y == 0, 0], y=X[y == 0, 1], cmap=\"Greens\", fill=True, ax=ax, alpha=alpha)\n",
    "\n",
    "ax.quiver(mean_a[0], mean_a[1], *(dir_noise[0]), color=\"grey\", scale_units='width', scale=scale_vector+1)\n",
    "\n",
    "\n",
    "x_points = np.linspace(-3, 10)    # generating x-points from -1 to 1\n",
    "y_points = -(w[0] / w[1]) * x_points - b / w[1]  # getting corresponding y-points\n",
    "# Plotting a red hyperplane\n",
    "ax.plot(x_points, y_points, c='black', linewidth=.8)\n",
    "\n",
    "cav_config = {\n",
    "    \"signal\": \"#52b791ff\",\n",
    "    \"svm\": \"#e94692ff\",\n",
    "#     \"lasso\": \"magenta\",\n",
    "#     \"ridge\": \"grey\",\n",
    "#     \"logistic\": \"yellow\"\n",
    "}\n",
    "\n",
    "X_concept = np.concatenate([X_a, X_a_art])\n",
    "y_concept = np.concatenate([\n",
    "    np.zeros(len(X_a)),\n",
    "    np.ones(len(X_a_art))\n",
    "])\n",
    "\n",
    "\n",
    "cav_mode = \"svm\"\n",
    "col = cav_config[cav_mode]\n",
    "\n",
    "for cav_mode, col in cav_config.items():\n",
    "    cav = get_cav(X_concept, y_concept, cav_mode, fit_intercept=True).numpy()[0]\n",
    "    ax.quiver(mean_a[0], mean_a[1], *(cav), color=[col], scale_units='width', scale=scale_vector)\n",
    "\n",
    "if np.array(c == [-1,1]).all():\n",
    "    xlim = (0,10)\n",
    "    ylim = (0,10)\n",
    "else:\n",
    "    xlim = (0,10)\n",
    "    ylim = (0,10)\n",
    "lims = (-3,7)\n",
    "ax.set_xlim(xlim)\n",
    "ax.set_ylim(ylim)\n",
    "# ax.get_legend().remove()\n",
    "plt.savefig(\"figs/tcav_2d.pdf\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "id": "926f8175-88b2-4526-b889-795809bee5fd",
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_tcav_sens(cav, w):\n",
    "    return (cav * w).sum()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 71,
   "id": "278130dd-bde6-4004-ab2f-0ad747a7d106",
   "metadata": {},
   "outputs": [],
   "source": [
    "tcavs = {c: [] for c in cav_config.keys()}\n",
    "\n",
    "degrees = [i for i in range(0, 181, 1)]\n",
    "# degrees = [i for i in range(0, 361, 2)]\n",
    "\n",
    "for d in degrees:\n",
    "    X_a, X_a_art, X_b, _ = construct_data(d, N=10000)\n",
    "    X_concept = np.concatenate([X_a, X_a_art])\n",
    "    y_concept = np.concatenate([\n",
    "        np.zeros(len(X_a)),\n",
    "        np.ones(len(X_a_art))\n",
    "    ])\n",
    "\n",
    "    cavs = {cav_mode: get_cav(X_concept, y_concept, cav_mode, fit_intercept=True).numpy()[0] for cav_mode in cav_config.keys()}\n",
    "    for cav_mode, cav in cavs.items():\n",
    "        tcavs[cav_mode].append(get_tcav_sens(cav, w))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 72,
   "id": "416295e7-5549-4604-8bed-ace24de64e8d",
   "metadata": {},
   "outputs": [],
   "source": [
    "results_pd = pd.DataFrame(tcavs)\n",
    "results_pd[\"rotation\"] = degrees\n",
    "results_pd = results_pd.melt(id_vars=\"rotation\", value_name=\"TCAV Sensitivity\", var_name=\"CAV Type\")\n",
    "results_pd[\"CAV Type\"] = results_pd[\"CAV Type\"].str.replace(\"signal\", \"pattern\")\n",
    "results_pd[\"CAV Type\"] = results_pd[\"CAV Type\"].str.replace(\"svm\", \"filter\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 73,
   "id": "3322b0b3-9e69-49cc-8061-a1c53f8681ee",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<svg  width=\"110\" height=\"55\"><rect x=\"0\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#52b791;stroke-width:2;stroke:rgb(255,255,255)\"/><rect x=\"55\" y=\"0\" width=\"55\" height=\"55\" style=\"fill:#e94692;stroke-width:2;stroke:rgb(255,255,255)\"/></svg>"
      ],
      "text/plain": [
       "[(0.3215686274509804, 0.7176470588235294, 0.5686274509803921),\n",
       " (0.9137254901960784, 0.27450980392156865, 0.5725490196078431)]"
      ]
     },
     "execution_count": 73,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "COLORS = [\n",
    "#     ['#1c4365ff', '#418bcaff'], # blue\n",
    "    ['#2f7157ff', '#52b791ff'], # green\n",
    "#     ['#957500ff', '#e5b400ff'], # yellow\n",
    "    ['#e94692ff', '#e94692ff'], # pink\n",
    "]\n",
    "\n",
    "custom_palette = sns.color_palette([c[1] for c in COLORS])\n",
    "custom_palette"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 74,
   "id": "723c65fa-4428-4b16-89b7-2073adb6ee59",
   "metadata": {},
   "outputs": [],
   "source": [
    "minx, maxx = 0, 181 #182\n",
    "miny, maxy = -1.1, 1.1\n",
    "xx, yy = np.meshgrid(np.arange(minx, maxx, 0.1), np.arange(miny, maxy, 0.01))\n",
    "zz = (yy < 0) * 1.0"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 75,
   "id": "d8b928a4-175a-4ced-947f-fbf4d8fb2555",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 560x350 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "nrows = 1\n",
    "ncols = 1\n",
    "size = 3.5\n",
    "sns.set(style=\"ticks\")\n",
    "#sns.set_style(\"whitegrid\")\n",
    "\n",
    "plt.rc('text', usetex=True)\n",
    "plt.rc('font', family='serif')\n",
    "\n",
    "# fig, axs = plt.subplots(nrows, ncols, figsize=(size*ncols*2,size*nrows), squeeze=False)\n",
    "fig, axs = plt.subplots(nrows, ncols, figsize=(size*ncols*1.6,size*nrows), squeeze=False)\n",
    "ax = axs[0][0]\n",
    "sns.lineplot(data=results_pd, x=\"rotation\", y=\"TCAV Sensitivity\", hue=\"CAV Type\", ax=ax,\n",
    "            palette=custom_palette, linewidth=2)\n",
    "# ax.grid(axis='y')\n",
    "# ax.set_ylabel(\"TCAV$_{sens}$\")\n",
    "ax.set_ylabel(\"TCAV (Sensitivity)\")\n",
    "ax.set_xlabel(\"Distractor Rotation\")\n",
    "\n",
    "ax.contourf(xx, yy, zz, cmap='turbo', alpha=0.1)\n",
    "\n",
    "ax.set_xticks([0, 90, 180, 270, 360])\n",
    "# ax.set_xticks([0, 90, 180])\n",
    "ax.set_xticklabels([\"$0$\", \"$\\pi/2$\", \"$\\pi$\", \"$3\\pi/2$\", \"$2\\pi$\"])\n",
    "ax.set_yticks([i/10 for i in range(-10, 11, 5)])\n",
    "# ax.set_xlim((0, 360))\n",
    "ax.set_xlim((0, 180))\n",
    "ax.set_ylim((-1, 1))\n",
    "plt.savefig(\"figs/tcav_over_rotation.pdf\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "337619f0-f15f-4da8-946f-8ffd736fb088",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "pytorch",
   "language": "python",
   "name": "pytorch"
  },
  "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.10.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
