{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\n",
    "from pyod.models import dif\n",
    "from pyod.models import deep_svdd\n",
    "from pyod.models import lunar\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Deep Models Multiple Views experiments\n",
    "Adjust the dataset to study in the next cell\n",
    "\n",
    "**CAUTION:** This experiment require ```pyod > 1.1.3```."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "name = \"banana\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 71,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 750x250 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "X = pd.read_csv(f\"experiments/synthetic_data/{name}.csv\", header=None)\n",
    "X_full = pd.read_csv(f\"experiments/synthetic_data/data_with_noise/{name}.csv\", header=None)\n",
    "X_norm = X\n",
    "\n",
    "x_min, x_max = X.min()[0] - 0.05,  X.max()[0] + 0.05\n",
    "y_min, y_max = X.min()[1] - 0.05, X.max()[1] + 0.05\n",
    "xx, yy = np.meshgrid(np.linspace(x_min, x_max, 200), np.linspace(y_min, y_max, 200))\n",
    "output = [xx.ravel().tolist(),yy.ravel().tolist()]\n",
    "for i in range(58):\n",
    "    output.append((0*np.ones(len(output[0]))).tolist())\n",
    "    #output.append(np.random.normal(0,1,len(output[0])).tolist())\n",
    "output\n",
    "train = pd.DataFrame(output).T\n",
    "knn = dif.DIF()\n",
    "knn.fit(X_full) \n",
    "Z_knn = knn.decision_function(train)\n",
    "Z_knn = Z_knn.reshape(xx.shape)\n",
    "Z_knn = (Z_knn-np.min(Z_knn))/(np.max(Z_knn)-np.min(Z_knn))\n",
    "lof = lunar.LUNAR()\n",
    "lof.fit(X_full)\n",
    "Z_lof = lof.decision_function(train)\n",
    "Z_lof = Z_lof.reshape(xx.shape)\n",
    "Z_lof = (Z_lof-np.min(Z_lof))/(np.max(Z_lof)-np.min(Z_lof))\n",
    "\n",
    "dsvdd = deep_svdd.DeepSVDD()\n",
    "dsvdd.fit(X_full)\n",
    "Z_dsvdd = dsvdd.decision_function(train)\n",
    "Z_dsvdd = Z_dsvdd.reshape(xx.shape)\n",
    "Z_dsvdd = (Z_dsvdd-np.min(Z_dsvdd))/(np.max(Z_dsvdd)-np.min(Z_dsvdd))\n",
    "plt.rcParams['font.family'] = ['serif']\n",
    "plt.rcParams['font.serif'] = ['Times New Roman']\n",
    "fig, (ax1, ax2, ax3) = plt.subplots(1, 3, figsize=(7.5,2.5))\n",
    "im = ax1.contourf(xx, yy, Z_lof, cmap=\"YlGnBu_r\")\n",
    "ax1.contour(xx,yy,Z_lof,levels=[0.9], linestyles = \"dashed\", cmap = \"summer\", linewidths=3)\n",
    "ax1.scatter(X.iloc()[:, 0], X.iloc()[:, 1], s=10,color='black')\n",
    "ax2.contourf(xx, yy, Z_knn, cmap=\"YlGnBu_r\")\n",
    "ax2.contour(xx,yy,Z_knn,levels=[0.6], linestyles = \"dashed\", cmap = \"summer\", linewidths=3)\n",
    "ax2.scatter(X.iloc()[:, 0], X.iloc()[:, 1], s=10,color='black')\n",
    "ax3.contourf(xx, yy, Z_dsvdd, cmap=\"YlGnBu_r\")\n",
    "ax3.contour(xx,yy,Z_dsvdd,levels=[0.6], linestyles = \"dashed\", cmap = \"summer\", linewidths=3)\n",
    "ax3.scatter(X.iloc()[:, 0], X.iloc()[:, 1], s=10,color='black')\n",
    "\n",
    "ax1.set_title(\"LUNAR\", fontsize=18)\n",
    "ax2.set_title(\"DIF\", fontsize=18)\n",
    "ax3.set_title(\"DeepSVDD\", fontsize=18)\n",
    "\n",
    "ax1.tick_params(axis='both', which = 'both', bottom = False, top = False, labelbottom = False, right = False, left = False, labelleft = False)\n",
    "ax2.tick_params(axis='both', which = 'both', bottom = False, top = False, labelbottom = False, right = False, left = False, labelleft = False)\n",
    "ax3.tick_params(axis='both', which = 'both', bottom = False, top = False, labelbottom = False, right = False, left = False, labelleft = False)\n",
    "\n",
    "fig.subplots_adjust(right=0.83)\n",
    "cbar_ax = fig.add_axes([0.85, 0.15, 0.01, 0.7])\n",
    "cbar = fig.colorbar(im,cax = cbar_ax)\n",
    "cbar.set_label(label = \"Prob. of outlier\",fontsize = 18)\n",
    "cbar.ax.tick_params(axis='both', which = 'both', bottom = False, top = False, labelbottom = False, right = False, left = False, labelleft = False)\n",
    "cbar.ax.tick_params(labelsize=12)\n",
    "plt.savefig(f\"experiments/heatmaps/{name}/deep_{name}_comparison.png\",dpi=1200, bbox_inches='tight')\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "tf",
   "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.11.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
