{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "ensemble_df = pd.read_csv(\"experiments/Outlier_Detection/Results_ENSEMBLED_['COPOD']_all_datasets.csv\")\n",
    "vgan_df = pd.read_csv(\"experiments/Outlier_Detection/Results_VGAN_['COPOD']_all_datasets.csv\")\n",
    "full_df =  pd.read_csv(\"experiments/Outlier_Detection/Results_['COPOD']_all_datasets.csv\")\n",
    "pvalue_df = pd.read_csv(\"experiments/Outlier_Detection/Results_GOF_VGAN_all_datasets.csv\")\n",
    "statistics_df = pd.read_csv(\"experiments/Outlier_Detection/dataset_statistics.csv\")\n",
    "\n",
    "# Function to group by Dataset and Method, and calculate the average AUC\n",
    "def group_by_dataset_method_avg_auc(df):\n",
    "    grouped_df = df.groupby(['Dataset', 'Method'])['AUC'].mean().reset_index()\n",
    "    return grouped_df\n",
    "\n",
    "# Apply the function to the loaded dataframe\n",
    "vgan_df = group_by_dataset_method_avg_auc(vgan_df)\n",
    "ensemble_df = group_by_dataset_method_avg_auc(ensemble_df)\n",
    "full_df = group_by_dataset_method_avg_auc(full_df)\n",
    "\n",
    "grouped_df_1 = pd.merge(ensemble_df,full_df[['Dataset','AUC']], on = 'Dataset', how = 'outer')\n",
    "grouped_df = pd.merge(grouped_df_1, vgan_df[['Dataset','AUC']], on = 'Dataset', how = 'outer')\n",
    "grouped_df = grouped_df.rename(columns = {'AUC_x': 'ENSEMBLE', 'AUC_y': 'FULL SPACE', 'AUC':'VGAN'})\n",
    "\n",
    "joined_df = pd.merge(grouped_df, pvalue_df[['Dataset', 'p-value']], on='Dataset', how='inner')\n",
    "final_df = pd.merge(statistics_df[['Dataset','# Samples','# Features','# Anomaly','% Anomaly']], joined_df, on='Dataset', how='inner')\n",
    "\n",
    "final_df.to_csv(\"res.csv\", sep=\";\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/home/i40/cribeiro/anaconda3/envs/subsel_torch/bin:/home/i40/cribeiro/anaconda3/condabin:/home/i40/cribeiro/.vscode-server/bin/8b3775030ed1a69b13e4f4c628c612102e30a681/bin/remote-cli:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/snap/bin:/usr/local/cuda/bin:/home/i40/cribeiro/usr/local/texlive/2024/bin/x86_64-linux\n"
     ]
    }
   ],
   "source": [
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import os\n",
    "\n",
    "os.environ[\"PATH\"] += os.pathsep + '/home/i40/cribeiro/usr/local/texlive/2024/bin/x86_64-linux'\n",
    "print(os.getenv(\"PATH\"))\n",
    "latex_preamble = \"\"\"\n",
    "\\\\usepackage[utf8]{inputenc}\n",
    "\\\\usepackage{microtype}\n",
    "\\\\usepackage{amsmath}\n",
    "\\\\renewcommand{\\\\rmdefault}{ptm}\n",
    "\\\\renewcommand{\\\\sfdefault}{phv}\n",
    "\"\"\"\n",
    "fs = 12\n",
    "column_width = 3.3249219444  # inch\n",
    "text_width = 7.02625  # inch\n",
    "plt.rcParams.update({\n",
    "    \"text.usetex\": True,\n",
    "    \"text.latex.preamble\": latex_preamble,\n",
    "    \"font.family\": \"serif\",\n",
    "    \"font.serif\": [],\n",
    "    \"font.sans-serif\": [],\n",
    "    \"font.monospace\": [],\n",
    "    \"font.size\": fs,\n",
    "    \"xtick.labelsize\": fs,\n",
    "    \"ytick.labelsize\": fs,\n",
    "    \"legend.fontsize\": fs,\n",
    "    \"savefig.bbox\": \"tight\",\n",
    "})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 466.667x266.667 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# Load the CSV file\n",
    "df = pd.read_csv('experiments/Outlier_Detection/Full_table_with_ranks.csv', delimiter=';')\n",
    "\n",
    "# Correcting the p-value for the \"optdigits\" dataset\n",
    "df.loc[df['Data'] == 'optdigits', 'p-value'] = 0\n",
    "\n",
    "# Convert p-value column to numeric\n",
    "#df['p-value'] = pd.to_numeric(df['p-value'].str.replace(',',\n",
    "#                              '.'), errors='coerce')\n",
    "\n",
    "# Filter the datasets where p-value > 0.10\n",
    "filtered_pvalue_df = df\n",
    "filtered_pvalue_df = df[df['p-value'] > 0.10]\n",
    "\n",
    "#Define the colors to use\n",
    "vgan_color = \"#72AD44\"\n",
    "ensemble_color = \"#FF7046\"\n",
    "fs_color = \"#00A9FF\"\n",
    "\n",
    "\n",
    "# Further filter by the feature ranges\n",
    "filtered_pvalue_0_10 = filtered_pvalue_df[(\n",
    "    filtered_pvalue_df['# Features'] > 0) & (filtered_pvalue_df['# Features'] <= 8)]\n",
    "filtered_pvalue_10_30 = filtered_pvalue_df[(\n",
    "    filtered_pvalue_df['# Features'] >= 10) & (filtered_pvalue_df['# Features'] <= 30)]\n",
    "filtered_pvalue_30_50 = filtered_pvalue_df[(\n",
    "    filtered_pvalue_df['# Features'] > 30) & (filtered_pvalue_df['# Features'] < 200)]\n",
    "filtered_pvalue_50_100 = filtered_pvalue_df[(\n",
    "    filtered_pvalue_df['# Features'] >= 50) & (filtered_pvalue_df['# Features'] < 200)]\n",
    "filtered_pvalue_100_300 = filtered_pvalue_df[(\n",
    "    filtered_pvalue_df['# Features'] >= 200) & (filtered_pvalue_df['# Features'] <= 2000)]\n",
    "filtered_pvalue_300_700 = filtered_pvalue_df[(\n",
    "    filtered_pvalue_df['# Features'] >= 550) & (filtered_pvalue_df['# Features'] <= 2000)]\n",
    "filtered_pvalue_700_2000 = filtered_pvalue_df[(\n",
    "    filtered_pvalue_df['# Features'] >= 700) & (filtered_pvalue_df['# Features'] <= 2000)]\n",
    "\n",
    "# Extract VGAN, ENSEMBLE, and FS ranks for these filtered datasets\n",
    "vgan_pvalue_ranks_0_10 = filtered_pvalue_0_10['RANK VGAN']\n",
    "vgan_pvalue_ranks_10_30 = filtered_pvalue_10_30['RANK VGAN']\n",
    "vgan_pvalue_ranks_30_50 = filtered_pvalue_30_50['RANK VGAN']\n",
    "vgan_pvalue_ranks_50_100 = filtered_pvalue_50_100['RANK VGAN']\n",
    "vgan_pvalue_ranks_100_300 = filtered_pvalue_100_300['RANK VGAN']\n",
    "vgan_pvalue_ranks_300_700 = filtered_pvalue_300_700['RANK VGAN']\n",
    "vgan_pvalue_ranks_700_2000 = filtered_pvalue_700_2000['RANK VGAN']\n",
    "\n",
    "ensemble_pvalue_ranks_0_10 = filtered_pvalue_0_10['RANK ENS']\n",
    "ensemble_pvalue_ranks_10_30 = filtered_pvalue_10_30['RANK ENS']\n",
    "ensemble_pvalue_ranks_30_50 = filtered_pvalue_30_50['RANK ENS']\n",
    "ensemble_pvalue_ranks_50_100 = filtered_pvalue_50_100['RANK ENS']\n",
    "ensemble_pvalue_ranks_100_300 = filtered_pvalue_100_300['RANK ENS']\n",
    "ensemble_pvalue_ranks_300_700 = filtered_pvalue_300_700['RANK ENS']\n",
    "ensemble_pvalue_ranks_700_2000 = filtered_pvalue_700_2000['RANK ENS']\n",
    "\n",
    "fs_pvalue_ranks_0_10 = filtered_pvalue_0_10['RANK FS']\n",
    "fs_pvalue_ranks_10_30 = filtered_pvalue_10_30['RANK FS']\n",
    "fs_pvalue_ranks_30_50 = filtered_pvalue_30_50['RANK FS']\n",
    "fs_pvalue_ranks_50_100 = filtered_pvalue_50_100['RANK FS']\n",
    "fs_pvalue_ranks_100_300 = filtered_pvalue_100_300['RANK FS']\n",
    "fs_pvalue_ranks_300_700 = filtered_pvalue_300_700['RANK FS']\n",
    "fs_pvalue_ranks_700_2000 = filtered_pvalue_700_2000['RANK FS']\n",
    "\n",
    "# Calculating the average ranks for each group\n",
    "all_averages = {\n",
    "    \"0-10\": vgan_pvalue_ranks_0_10.mean(),\n",
    "    \"10-30\": vgan_pvalue_ranks_10_30.mean(),\n",
    "    \"30-50\": vgan_pvalue_ranks_30_50.mean(),\n",
    "    \"50-100\": vgan_pvalue_ranks_50_100.mean(),\n",
    "    \"100-300\": vgan_pvalue_ranks_100_300.mean(),\n",
    "    \"300-700\": vgan_pvalue_ranks_300_700.mean(),\n",
    "    \"700-2000\": vgan_pvalue_ranks_700_2000.mean()\n",
    "}\n",
    "\n",
    "\n",
    "# Creating the combined boxplot with individual boxplots, line plots of the average ranks, and vertical lines to indicate group limits\n",
    "plt.figure(figsize=(2*7/3, 2*4/3))\n",
    "\n",
    "# Creating the boxplots for VGAN, ENSEMBLE, and FS\n",
    "boxplot_vgan = plt.boxplot(\n",
    "    [vgan_pvalue_ranks_0_10, vgan_pvalue_ranks_10_30, vgan_pvalue_ranks_30_50,\n",
    "        vgan_pvalue_ranks_100_300],\n",
    "    positions=[1, 4, 7, 10],\n",
    "    widths=0.6,\n",
    "    patch_artist=True,\n",
    "    boxprops=dict(facecolor=vgan_color, color=vgan_color, alpha=0.3),\n",
    "    whiskerprops=dict(color=vgan_color, alpha=0.3),\n",
    "    capprops=dict(color=vgan_color, alpha=0.3),\n",
    "    medianprops=dict(color=vgan_color,linewidth=2),\n",
    "    flierprops=dict(marker='o', markersize=5,\n",
    "                    linestyle='none', linewidth=2, color=vgan_color)\n",
    ")\n",
    "\n",
    "boxplot_ensemble = plt.boxplot(\n",
    "    [ensemble_pvalue_ranks_0_10, ensemble_pvalue_ranks_10_30, ensemble_pvalue_ranks_30_50, \n",
    "        ensemble_pvalue_ranks_100_300],\n",
    "    positions=[2, 5, 8, 11],\n",
    "    widths=0.6,\n",
    "    patch_artist=True,\n",
    "    boxprops=dict(facecolor=ensemble_color, color=ensemble_color, alpha=0.3),\n",
    "    whiskerprops=dict(color=ensemble_color, alpha=0.3),\n",
    "    capprops=dict(color=ensemble_color, alpha=0.3),\n",
    "    medianprops=dict(color=ensemble_color,linewidth=2),\n",
    "    flierprops=dict(marker='o', markersize=5, linestyle='none',\n",
    "                    linewidth=2, color=ensemble_color)\n",
    ")\n",
    "\n",
    "boxplot_fs = plt.boxplot(\n",
    "    [fs_pvalue_ranks_0_10, fs_pvalue_ranks_10_30, fs_pvalue_ranks_30_50,\n",
    "        fs_pvalue_ranks_100_300],\n",
    "    positions=[3, 6, 9, 12],\n",
    "    widths=0.6,\n",
    "    patch_artist=True,\n",
    "    boxprops=dict(facecolor=fs_color, color=fs_color, alpha=0.3),\n",
    "    whiskerprops=dict(color=fs_color, alpha=0.3),\n",
    "    capprops=dict(color=fs_color, alpha=0.3),\n",
    "    medianprops=dict(color=fs_color,linewidth=2),\n",
    "    flierprops=dict(marker='o', markersize=5, linestyle='none',\n",
    "                    linewidth=2, color=fs_color)\n",
    ")\n",
    "\n",
    "# Plotting the average ranks for VGAN, ENSEMBLE, and FS as line plots on top of the boxplots\n",
    "plt.plot(\n",
    "    [1, 4, 7, 10],\n",
    "    [all_averages[\"0-10\"], all_averages[\"10-30\"], all_averages[\"30-50\"],\n",
    "        all_averages[\"100-300\"]],\n",
    "    color=vgan_color, marker='o', linestyle='-', linewidth=1.5, label='VGAN'\n",
    ")\n",
    "\n",
    "plt.plot(\n",
    "    [2, 5, 8, 11],\n",
    "    [ensemble_pvalue_ranks_0_10.mean(), ensemble_pvalue_ranks_10_30.mean(), ensemble_pvalue_ranks_30_50.mean(),\n",
    "     ensemble_pvalue_ranks_100_300.mean()],\n",
    "    color=ensemble_color, marker='o', linestyle='-', linewidth=1.5, label='FB'\n",
    ")\n",
    "\n",
    "plt.plot(\n",
    "    [3, 6, 9, 12],\n",
    "    [fs_pvalue_ranks_0_10.mean(), fs_pvalue_ranks_10_30.mean(), fs_pvalue_ranks_30_50.mean(),\n",
    "     fs_pvalue_ranks_100_300.mean()],\n",
    "    color=fs_color, marker='o', linestyle='-', linewidth=1.5, label='Full Space'\n",
    ")\n",
    "\n",
    "# Adding vertical lines to indicate the limits of each group on the x-axis\n",
    "for x in [3.5, 6.5, 9.5, 12.5]:\n",
    "    plt.axvline(x=x, color='gray', linestyle='--', linewidth=1)\n",
    "\n",
    "# Setting the x-axis labels\n",
    "plt.xticks([2, 5, 8, 11], ['0-10', '10-30',\n",
    "           '30-200', '200-2000'])\n",
    "\n",
    "plt.xlabel('Features')\n",
    "plt.ylabel('Rank')\n",
    "#legend = plt.legend(fancybox=True,framealpha=1, shadow=True)\n",
    "#legend.set_bbox_to_anchor((0.5,.3))\n",
    "plt.savefig('experiments/Outlier_Detection/ENSEMBLE/LOF_non_lense.png',dpi=1000)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 466.667x266.667 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# Define the colors and labels\n",
    "vgan_color = \"#72AD44\"\n",
    "ensemble_color = \"#FF7046\"\n",
    "fs_color = \"#00A9FF\"\n",
    "labels = ['V-GAN', 'Feature Bagging', 'Full Space']\n",
    "\n",
    "# Create a dummy plot\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(2*7/3, 2*4/3))\n",
    "for color, label in zip([vgan_color, ensemble_color, fs_color], labels):\n",
    "    ax.plot([], [], color=color, label=label, marker='o', linestyle='-', linewidth=1.5)\n",
    "\n",
    "# Create the legend\n",
    "legend = ax.legend(fancybox=True, framealpha=1, shadow=True, loc = 'center')\n",
    "\n",
    "# Remove the axes\n",
    "ax.axis('off')\n",
    "\n",
    "# Save the legend as a separate figure\n",
    "fig.savefig('experiments/Outlier_Detection/ENSEMBLE/legend.png', dpi=1000, bbox_inches='tight', pad_inches = 0)\n",
    "\n",
    "# Show the legend (optional)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import scipy.stats as stats\n",
    "import scikit_posthocs as sp\n",
    "\n",
    "# Load the data\n",
    "df = pd.read_csv('experiments/Outlier_Detection/Full_table_with_ranks.csv', delimiter=';')\n",
    "\n",
    "\n",
    "df['p-value'] = pd.to_numeric(df['p-value'].str.replace(',',\n",
    "                              '.'), errors='coerce')\n",
    "df = df[df['p-value'] > 0.10]\n",
    "\n",
    "# Extracting the ranks for each model\n",
    "ranks_ens = df['RANK ENS']\n",
    "ranks_fs = df['RANK FS']\n",
    "ranks_vgan = df['RANK VGAN']\n",
    "\n",
    "# Performing the Kruskal-Wallis test\n",
    "kruskal_result = stats.kruskal(ranks_ens, ranks_fs, ranks_vgan)\n",
    "print(f\"Kruskal-Wallis Test Result: {kruskal_result}\")\n",
    "\n",
    "# If the p-value from Kruskal-Wallis test is significant, perform Conover-Iman test\n",
    "if kruskal_result.pvalue < 0.05:\n",
    "    conover_result = sp.posthoc_conover([ranks_ens, ranks_fs, ranks_vgan], p_adjust='holm')\n",
    "    conover_result.index = [\"Feature Bagging\", \"Full-Space\", \"VGAN\"]\n",
    "    conover_result.columns =  [\"Feature Bagging\", \"Full-Space\", \"VGAN\"]\n",
    "    print(\"Conover-Iman Test Result:\\n\", conover_result)\n",
    "    \n",
    "else:\n",
    "    print(\"Kruskal-Wallis test is not significant; no need to perform Conover-Iman test.\")\n",
    "print(f\"Count of datasets:{df.index.__len__()}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Kruskal-Wallis Test Result: KruskalResult(statistic=10.06128888946965, pvalue=0.006534598026026722)\n",
      "Conover-Iman Test Result:\n",
      "                  Feature Bagging  Full-Space      VGAN\n",
      "Feature Bagging         1.000000    0.017277  0.578376\n",
      "Full-Space              0.017277    1.000000  0.005784\n",
      "VGAN                    0.578376    0.005784  1.000000\n",
      "Count of datasets:14\n"
     ]
    }
   ],
   "source": [
    "import pandas as pd\n",
    "import scipy.stats as stats\n",
    "import scikit_posthocs as sp\n",
    "\n",
    "# Load the data\n",
    "df = pd.read_csv('experiments/Outlier_Detection/Full_table_with_ranks.csv', delimiter=';')\n",
    "\n",
    "# Correcting the p-value for the \"optdigits\" dataset\n",
    "df.loc[df['Data'] == 'optdigits', 'p-value'] = 0\n",
    "df['p-value'] = pd.to_numeric(df['p-value'].str.replace(',',\n",
    "                              '.'), errors='coerce')\n",
    "df = df[df['p-value'] < 0.10]\n",
    "\n",
    "# Extracting the ranks for each model\n",
    "ranks_ens = df['RANK ENS']\n",
    "ranks_fs = df['RANK FS']\n",
    "ranks_vgan = df['RANK VGAN']\n",
    "\n",
    "# Performing the Kruskal-Wallis test\n",
    "kruskal_result = stats.kruskal(ranks_ens, ranks_fs, ranks_vgan)\n",
    "print(f\"Kruskal-Wallis Test Result: {kruskal_result}\")\n",
    "\n",
    "# If the p-value from Kruskal-Wallis test is significant, perform Conover-Iman test\n",
    "if kruskal_result.pvalue < 0.05:\n",
    "    conover_result = sp.posthoc_conover([ranks_ens, ranks_fs, ranks_vgan], p_adjust='holm')\n",
    "    conover_result.index = [\"Feature Bagging\", \"Full-Space\", \"VGAN\"]\n",
    "    conover_result.columns =  [\"Feature Bagging\", \"Full-Space\", \"VGAN\"]\n",
    "    print(\"Conover-Iman Test Result:\\n\", conover_result)\n",
    "    \n",
    "else:\n",
    "    print(\"Kruskal-Wallis test is not significant; no need to perform Conover-Iman test.\")\n",
    "print(f\"Count of datasets:{df.index.__len__()}\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# KNN"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 466.667x266.667 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "#Define the dataset \n",
    "dataset = \"KNN\"\n",
    "# Load the CSV file\n",
    "df = pd.read_csv(f'experiments/Outlier_Detection/Full_table_with_ranks-{dataset}.csv', delimiter=',',)\n",
    "\n",
    "# Filter the datasets where p-value > 0.10\n",
    "filtered_pvalue_df = df\n",
    "filtered_pvalue_df = df[df['p-value'] < 0.10]\n",
    "\n",
    "#Define the colors to use\n",
    "vgan_color = \"#72AD44\"\n",
    "ensemble_color = \"#FF7046\"\n",
    "fs_color = \"#00A9FF\"\n",
    "\n",
    "\n",
    "# Further filter by the feature ranges\n",
    "filtered_pvalue_0_10 = filtered_pvalue_df[(\n",
    "    filtered_pvalue_df['# Features'] > 0) & (filtered_pvalue_df['# Features'] <= 8)]\n",
    "filtered_pvalue_10_30 = filtered_pvalue_df[(\n",
    "    filtered_pvalue_df['# Features'] >= 10) & (filtered_pvalue_df['# Features'] <= 30)]\n",
    "filtered_pvalue_30_50 = filtered_pvalue_df[(\n",
    "    filtered_pvalue_df['# Features'] > 30) & (filtered_pvalue_df['# Features'] < 50)]\n",
    "filtered_pvalue_50_100 = filtered_pvalue_df[(\n",
    "    filtered_pvalue_df['# Features'] >= 50) & (filtered_pvalue_df['# Features'] <= 200)]\n",
    "filtered_pvalue_100_300 = filtered_pvalue_df[(\n",
    "    filtered_pvalue_df['# Features'] >= 200) & (filtered_pvalue_df['# Features'] <= 550)]\n",
    "filtered_pvalue_300_700 = filtered_pvalue_df[(\n",
    "    filtered_pvalue_df['# Features'] >= 550) & (filtered_pvalue_df['# Features'] <= 2000)]\n",
    "filtered_pvalue_700_2000 = filtered_pvalue_df[(\n",
    "    filtered_pvalue_df['# Features'] >= 700) & (filtered_pvalue_df['# Features'] <= 2000)]\n",
    "\n",
    "# Extract VGAN, ENSEMBLE, and FS ranks for these filtered datasets\n",
    "vgan_pvalue_ranks_0_10 = filtered_pvalue_0_10['RANK VGAN']\n",
    "vgan_pvalue_ranks_10_30 = filtered_pvalue_10_30['RANK VGAN']\n",
    "vgan_pvalue_ranks_30_50 = filtered_pvalue_30_50['RANK VGAN']\n",
    "vgan_pvalue_ranks_50_100 = filtered_pvalue_50_100['RANK VGAN']\n",
    "vgan_pvalue_ranks_100_300 = filtered_pvalue_100_300['RANK VGAN']\n",
    "vgan_pvalue_ranks_300_700 = filtered_pvalue_300_700['RANK VGAN']\n",
    "vgan_pvalue_ranks_700_2000 = filtered_pvalue_700_2000['RANK VGAN']\n",
    "\n",
    "ensemble_pvalue_ranks_0_10 = filtered_pvalue_0_10['RANK ENS']\n",
    "ensemble_pvalue_ranks_10_30 = filtered_pvalue_10_30['RANK ENS']\n",
    "ensemble_pvalue_ranks_30_50 = filtered_pvalue_30_50['RANK ENS']\n",
    "ensemble_pvalue_ranks_50_100 = filtered_pvalue_50_100['RANK ENS']\n",
    "ensemble_pvalue_ranks_100_300 = filtered_pvalue_100_300['RANK ENS']\n",
    "ensemble_pvalue_ranks_300_700 = filtered_pvalue_300_700['RANK ENS']\n",
    "ensemble_pvalue_ranks_700_2000 = filtered_pvalue_700_2000['RANK ENS']\n",
    "\n",
    "fs_pvalue_ranks_0_10 = filtered_pvalue_0_10['RANK FS']\n",
    "fs_pvalue_ranks_10_30 = filtered_pvalue_10_30['RANK FS']\n",
    "fs_pvalue_ranks_30_50 = filtered_pvalue_30_50['RANK FS']\n",
    "fs_pvalue_ranks_50_100 = filtered_pvalue_50_100['RANK FS']\n",
    "fs_pvalue_ranks_100_300 = filtered_pvalue_100_300['RANK FS']\n",
    "fs_pvalue_ranks_300_700 = filtered_pvalue_300_700['RANK FS']\n",
    "fs_pvalue_ranks_700_2000 = filtered_pvalue_700_2000['RANK FS']\n",
    "\n",
    "# Calculating the average ranks for each group\n",
    "all_averages = {\n",
    "    \"0-10\": vgan_pvalue_ranks_0_10.mean(),\n",
    "    \"10-30\": vgan_pvalue_ranks_10_30.mean(),\n",
    "    \"30-50\": vgan_pvalue_ranks_30_50.mean(),\n",
    "    \"50-100\": vgan_pvalue_ranks_50_100.mean(),\n",
    "    \"100-300\": vgan_pvalue_ranks_100_300.mean(),\n",
    "    \"300-700\": vgan_pvalue_ranks_300_700.mean(),\n",
    "    \"700-2000\": vgan_pvalue_ranks_700_2000.mean()\n",
    "}\n",
    "\n",
    "\n",
    "# Creating the combined boxplot with individual boxplots, line plots of the average ranks, and vertical lines to indicate group limits\n",
    "plt.figure(figsize=(2*7/3, 2*4/3))\n",
    "\n",
    "\n",
    "# Creating the boxplots for VGAN, ENSEMBLE, and FS\n",
    "boxplot_vgan = plt.boxplot(\n",
    "    [vgan_pvalue_ranks_0_10, vgan_pvalue_ranks_10_30, vgan_pvalue_ranks_30_50,\n",
    "        vgan_pvalue_ranks_100_300],\n",
    "    positions=[1, 4, 7, 10],\n",
    "    widths=0.6,\n",
    "    patch_artist=True,\n",
    "    boxprops=dict(facecolor=vgan_color, color=vgan_color, alpha=0.3),\n",
    "    whiskerprops=dict(color=vgan_color, alpha=0.3),\n",
    "    capprops=dict(color=vgan_color, alpha=0.3),\n",
    "    medianprops=dict(color=vgan_color,linewidth=2),\n",
    "    flierprops=dict(marker='o', markersize=5,\n",
    "                    linestyle='none', linewidth=2, color=vgan_color)\n",
    ")\n",
    "\n",
    "boxplot_ensemble = plt.boxplot(\n",
    "    [ensemble_pvalue_ranks_0_10, ensemble_pvalue_ranks_10_30, ensemble_pvalue_ranks_30_50, \n",
    "        ensemble_pvalue_ranks_100_300],\n",
    "    positions=[2, 5, 8, 11],\n",
    "    widths=0.6,\n",
    "    patch_artist=True,\n",
    "    boxprops=dict(facecolor=ensemble_color, color=ensemble_color, alpha=0.3),\n",
    "    whiskerprops=dict(color=ensemble_color, alpha=0.3),\n",
    "    capprops=dict(color=ensemble_color, alpha=0.3),\n",
    "    medianprops=dict(color=ensemble_color,linewidth=2),\n",
    "    flierprops=dict(marker='o', markersize=5, linestyle='none',\n",
    "                    linewidth=2, color=ensemble_color)\n",
    ")\n",
    "\n",
    "boxplot_fs = plt.boxplot(\n",
    "    [fs_pvalue_ranks_0_10, fs_pvalue_ranks_10_30, fs_pvalue_ranks_30_50,\n",
    "        fs_pvalue_ranks_100_300],\n",
    "    positions=[3, 6, 9, 12],\n",
    "    widths=0.6,\n",
    "    patch_artist=True,\n",
    "    boxprops=dict(facecolor=fs_color, color=fs_color, alpha=0.3),\n",
    "    whiskerprops=dict(color=fs_color, alpha=0.3),\n",
    "    capprops=dict(color=fs_color, alpha=0.3),\n",
    "    medianprops=dict(color=fs_color,linewidth=2),\n",
    "    flierprops=dict(marker='o', markersize=5, linestyle='none',\n",
    "                    linewidth=2, color=fs_color)\n",
    ")\n",
    "\n",
    "# Plotting the average ranks for VGAN, ENSEMBLE, and FS as line plots on top of the boxplots\n",
    "plt.plot(\n",
    "    [1, 4, 7, 10],\n",
    "    [all_averages[\"0-10\"], all_averages[\"10-30\"], all_averages[\"30-50\"],\n",
    "        all_averages[\"100-300\"]],\n",
    "    color=vgan_color, marker='o', linestyle='-', linewidth=1.5, label='VGAN'\n",
    ")\n",
    "\n",
    "plt.plot(\n",
    "    [2, 5, 8, 11],\n",
    "    [ensemble_pvalue_ranks_0_10.mean(), ensemble_pvalue_ranks_10_30.mean(), ensemble_pvalue_ranks_30_50.mean(),\n",
    "     ensemble_pvalue_ranks_100_300.mean()],\n",
    "    color=ensemble_color, marker='o', linestyle='-', linewidth=1.5, label='Feature Bagging'\n",
    ")\n",
    "\n",
    "plt.plot(\n",
    "    [3, 6, 9, 12],\n",
    "    [fs_pvalue_ranks_0_10.mean(), fs_pvalue_ranks_10_30.mean(), fs_pvalue_ranks_30_50.mean(),\n",
    "     fs_pvalue_ranks_100_300.mean()],\n",
    "    color=fs_color, marker='o', linestyle='-', linewidth=1.5, label='Full Space'\n",
    ")\n",
    "\n",
    "# Adding vertical lines to indicate the limits of each group on the x-axis\n",
    "for x in [3.5, 6.5, 9.5, 12.5]:\n",
    "    plt.axvline(x=x, color='gray', linestyle='--', linewidth=1)\n",
    "\n",
    "# Setting the x-axis labels\n",
    "plt.xticks([2, 5, 8, 11], ['0-10', '10-30',\n",
    "           '30-200', '200-2000'])\n",
    "\n",
    "\n",
    "plt.xlabel('Features')\n",
    "plt.ylabel('Rank')\n",
    "plt.savefig(f'{dataset}_non_lense.png',dpi=1000)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Kruskal-Wallis Test Result: KruskalResult(statistic=8.57596371882086, pvalue=0.013732611691505504)\n",
      "Conover-Iman Test Result:\n",
      "                  Feature Bagging  Full-Space      VGAN\n",
      "Feature Bagging         1.000000    0.843185  0.012255\n",
      "Full-Space              0.843185    1.000000  0.007220\n",
      "VGAN                    0.012255    0.007220  1.000000\n",
      "Count of datasets:21\n"
     ]
    }
   ],
   "source": [
    "import pandas as pd\n",
    "import scipy.stats as stats\n",
    "import scikit_posthocs as sp\n",
    "\n",
    "# Load the data\n",
    "df = pd.read_csv('experiments/Outlier_Detection/Full_table_with_ranks-KNN.csv', delimiter=',')\n",
    "\n",
    "\n",
    "df = df[df['p-value'] > 0.10]\n",
    "\n",
    "# Extracting the ranks for each model\n",
    "ranks_ens = df['RANK ENS']\n",
    "ranks_fs = df['RANK FS']\n",
    "ranks_vgan = df['RANK VGAN']\n",
    "\n",
    "# Performing the Kruskal-Wallis test\n",
    "kruskal_result = stats.kruskal(ranks_ens, ranks_fs, ranks_vgan)\n",
    "print(f\"Kruskal-Wallis Test Result: {kruskal_result}\")\n",
    "\n",
    "# If the p-value from Kruskal-Wallis test is significant, perform Conover-Iman test\n",
    "if kruskal_result.pvalue < 0.05:\n",
    "    conover_result = sp.posthoc_conover([ranks_ens, ranks_fs, ranks_vgan])\n",
    "    conover_result.index = [\"Feature Bagging\", \"Full-Space\", \"VGAN\"]\n",
    "    conover_result.columns =  [\"Feature Bagging\", \"Full-Space\", \"VGAN\"]\n",
    "    print(\"Conover-Iman Test Result:\\n\", conover_result)\n",
    "    \n",
    "else:\n",
    "    print(\"Kruskal-Wallis test is not significant; no need to perform Conover-Iman test.\")\n",
    "print(f\"Count of datasets:{df.index.__len__()}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Kruskal-Wallis Test Result: KruskalResult(statistic=0.5914342372968273, pvalue=0.7439978613755436)\n",
      "Conover-Iman Test Result:\n",
      "                  Feature Bagging  Full-Space      VGAN\n",
      "Feature Bagging         1.000000    0.450491  0.685985\n",
      "Full-Space              0.450491    1.000000  0.725114\n",
      "VGAN                    0.685985    0.725114  1.000000\n",
      "Count of datasets:21\n"
     ]
    }
   ],
   "source": [
    "import pandas as pd\n",
    "import scipy.stats as stats\n",
    "import scikit_posthocs as sp\n",
    "\n",
    "# Load the data\n",
    "df = pd.read_csv('experiments/Outlier_Detection/Full_table_with_ranks-KNN.csv', delimiter=',')\n",
    "\n",
    "\n",
    "df = df[df['p-value'] < 0.10]\n",
    "\n",
    "# Extracting the ranks for each model\n",
    "ranks_ens = df['RANK ENS']\n",
    "ranks_fs = df['RANK FS']\n",
    "ranks_vgan = df['RANK VGAN']\n",
    "\n",
    "# Performing the Kruskal-Wallis test\n",
    "kruskal_result = stats.kruskal(ranks_ens, ranks_fs, ranks_vgan)\n",
    "print(f\"Kruskal-Wallis Test Result: {kruskal_result}\")\n",
    "\n",
    "# If the p-value from Kruskal-Wallis test is significant, perform Conover-Iman test\n",
    "conover_result = sp.posthoc_conover([ranks_ens, ranks_fs, ranks_vgan])\n",
    "conover_result.index = [\"Feature Bagging\", \"Full-Space\", \"VGAN\"]\n",
    "conover_result.columns =  [\"Feature Bagging\", \"Full-Space\", \"VGAN\"]\n",
    "print(\"Conover-Iman Test Result:\\n\", conover_result)\n",
    "    \n",
    "print(f\"Count of datasets:{df.index.__len__()}\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# CBLOF"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 466.667x266.667 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "#Define the dataset \n",
    "dataset = \"CBLOF\"\n",
    "# Load the CSV file\n",
    "df = pd.read_csv(f'experiments/Outlier_Detection/Full_table_with_ranks-{dataset}.csv', delimiter=',',)\n",
    "\n",
    "# Filter the datasets where p-value > 0.10\n",
    "filtered_pvalue_df = df\n",
    "filtered_pvalue_df = df[df['p-value'] < 0.10]\n",
    "\n",
    "#Define the colors to use\n",
    "vgan_color = \"#72AD44\"\n",
    "ensemble_color = \"#FF7046\"\n",
    "fs_color = \"#00A9FF\"\n",
    "\n",
    "\n",
    "# Further filter by the feature ranges\n",
    "filtered_pvalue_0_10 = filtered_pvalue_df[(\n",
    "    filtered_pvalue_df['# Features'] > 0) & (filtered_pvalue_df['# Features'] <= 8)]\n",
    "filtered_pvalue_10_30 = filtered_pvalue_df[(\n",
    "    filtered_pvalue_df['# Features'] >= 10) & (filtered_pvalue_df['# Features'] <= 30)]\n",
    "filtered_pvalue_30_50 = filtered_pvalue_df[(\n",
    "    filtered_pvalue_df['# Features'] > 30) & (filtered_pvalue_df['# Features'] < 50)]\n",
    "filtered_pvalue_50_100 = filtered_pvalue_df[(\n",
    "    filtered_pvalue_df['# Features'] >= 50) & (filtered_pvalue_df['# Features'] <= 200)]\n",
    "filtered_pvalue_100_300 = filtered_pvalue_df[(\n",
    "    filtered_pvalue_df['# Features'] > 200) & (filtered_pvalue_df['# Features'] <= 550)]\n",
    "filtered_pvalue_300_700 = filtered_pvalue_df[(\n",
    "    filtered_pvalue_df['# Features'] > 550) & (filtered_pvalue_df['# Features'] <= 2000)]\n",
    "filtered_pvalue_700_2000 = filtered_pvalue_df[(\n",
    "    filtered_pvalue_df['# Features'] >= 700) & (filtered_pvalue_df['# Features'] <= 2000)]\n",
    "\n",
    "# Extract VGAN, ENSEMBLE, and FS ranks for these filtered datasets\n",
    "vgan_pvalue_ranks_0_10 = filtered_pvalue_0_10['RANK VGAN']\n",
    "vgan_pvalue_ranks_10_30 = filtered_pvalue_10_30['RANK VGAN']\n",
    "vgan_pvalue_ranks_30_50 = filtered_pvalue_30_50['RANK VGAN']\n",
    "vgan_pvalue_ranks_50_100 = filtered_pvalue_50_100['RANK VGAN']\n",
    "vgan_pvalue_ranks_100_300 = filtered_pvalue_100_300['RANK VGAN']\n",
    "vgan_pvalue_ranks_300_700 = filtered_pvalue_300_700['RANK VGAN']\n",
    "vgan_pvalue_ranks_700_2000 = filtered_pvalue_700_2000['RANK VGAN']\n",
    "\n",
    "ensemble_pvalue_ranks_0_10 = filtered_pvalue_0_10['RANK ENS']\n",
    "ensemble_pvalue_ranks_10_30 = filtered_pvalue_10_30['RANK ENS']\n",
    "ensemble_pvalue_ranks_30_50 = filtered_pvalue_30_50['RANK ENS']\n",
    "ensemble_pvalue_ranks_50_100 = filtered_pvalue_50_100['RANK ENS']\n",
    "ensemble_pvalue_ranks_100_300 = filtered_pvalue_100_300['RANK ENS']\n",
    "ensemble_pvalue_ranks_300_700 = filtered_pvalue_300_700['RANK ENS']\n",
    "ensemble_pvalue_ranks_700_2000 = filtered_pvalue_700_2000['RANK ENS']\n",
    "\n",
    "fs_pvalue_ranks_0_10 = filtered_pvalue_0_10['RANK FS']\n",
    "fs_pvalue_ranks_10_30 = filtered_pvalue_10_30['RANK FS']\n",
    "fs_pvalue_ranks_30_50 = filtered_pvalue_30_50['RANK FS']\n",
    "fs_pvalue_ranks_50_100 = filtered_pvalue_50_100['RANK FS']\n",
    "fs_pvalue_ranks_100_300 = filtered_pvalue_100_300['RANK FS']\n",
    "fs_pvalue_ranks_300_700 = filtered_pvalue_300_700['RANK FS']\n",
    "fs_pvalue_ranks_700_2000 = filtered_pvalue_700_2000['RANK FS']\n",
    "\n",
    "# Calculating the average ranks for each group\n",
    "all_averages = {\n",
    "    \"0-10\": vgan_pvalue_ranks_0_10.mean(),\n",
    "    \"10-30\": vgan_pvalue_ranks_10_30.mean(),\n",
    "    \"30-50\": vgan_pvalue_ranks_30_50.mean(),\n",
    "    \"50-100\": vgan_pvalue_ranks_50_100.mean(),\n",
    "    \"100-300\": vgan_pvalue_ranks_100_300.mean(),\n",
    "    \"300-700\": vgan_pvalue_ranks_300_700.mean(),\n",
    "    \"700-2000\": vgan_pvalue_ranks_700_2000.mean()\n",
    "}\n",
    "\n",
    "\n",
    "# Creating the combined boxplot with individual boxplots, line plots of the average ranks, and vertical lines to indicate group limits\n",
    "plt.figure(figsize=(2*7/3, 2*4/3))\n",
    "\n",
    "\n",
    "# Creating the boxplots for VGAN, ENSEMBLE, and FS\n",
    "boxplot_vgan = plt.boxplot(\n",
    "    [vgan_pvalue_ranks_0_10, vgan_pvalue_ranks_10_30, vgan_pvalue_ranks_30_50,\n",
    "        vgan_pvalue_ranks_100_300],\n",
    "    positions=[1, 4, 7, 10],\n",
    "    widths=0.6,\n",
    "    patch_artist=True,\n",
    "    boxprops=dict(facecolor=vgan_color, color=vgan_color, alpha=0.3),\n",
    "    whiskerprops=dict(color=vgan_color, alpha=0.3),\n",
    "    capprops=dict(color=vgan_color, alpha=0.3),\n",
    "    medianprops=dict(color=vgan_color,linewidth=2),\n",
    "    flierprops=dict(marker='o', markersize=5,\n",
    "                    linestyle='none', linewidth=2, color=vgan_color)\n",
    ")\n",
    "\n",
    "boxplot_ensemble = plt.boxplot(\n",
    "    [ensemble_pvalue_ranks_0_10, ensemble_pvalue_ranks_10_30, ensemble_pvalue_ranks_30_50, \n",
    "        ensemble_pvalue_ranks_100_300],\n",
    "    positions=[2, 5, 8, 11],\n",
    "    widths=0.6,\n",
    "    patch_artist=True,\n",
    "    boxprops=dict(facecolor=ensemble_color, color=ensemble_color, alpha=0.3),\n",
    "    whiskerprops=dict(color=ensemble_color, alpha=0.3),\n",
    "    capprops=dict(color=ensemble_color, alpha=0.3),\n",
    "    medianprops=dict(color=ensemble_color,linewidth=2),\n",
    "    flierprops=dict(marker='o', markersize=5, linestyle='none',\n",
    "                    linewidth=2, color=ensemble_color)\n",
    ")\n",
    "\n",
    "boxplot_fs = plt.boxplot(\n",
    "    [fs_pvalue_ranks_0_10, fs_pvalue_ranks_10_30, fs_pvalue_ranks_30_50,\n",
    "        fs_pvalue_ranks_100_300],\n",
    "    positions=[3, 6, 9, 12],\n",
    "    widths=0.6,\n",
    "    patch_artist=True,\n",
    "    boxprops=dict(facecolor=fs_color, color=fs_color, alpha=0.3),\n",
    "    whiskerprops=dict(color=fs_color, alpha=0.3),\n",
    "    capprops=dict(color=fs_color, alpha=0.3),\n",
    "    medianprops=dict(color=fs_color,linewidth=2),\n",
    "    flierprops=dict(marker='o', markersize=5, linestyle='none',\n",
    "                    linewidth=2, color=fs_color)\n",
    ")\n",
    "\n",
    "# Plotting the average ranks for VGAN, ENSEMBLE, and FS as line plots on top of the boxplots\n",
    "plt.plot(\n",
    "    [1, 4, 7, 10],\n",
    "    [all_averages[\"0-10\"], all_averages[\"10-30\"], all_averages[\"30-50\"],\n",
    "        all_averages[\"100-300\"]],\n",
    "    color=vgan_color, marker='o', linestyle='-', linewidth=1.5, label='VGAN'\n",
    ")\n",
    "\n",
    "plt.plot(\n",
    "    [2, 5, 8, 11],\n",
    "    [ensemble_pvalue_ranks_0_10.mean(), ensemble_pvalue_ranks_10_30.mean(), ensemble_pvalue_ranks_30_50.mean(),\n",
    "     ensemble_pvalue_ranks_100_300.mean()],\n",
    "    color=ensemble_color, marker='o', linestyle='-', linewidth=1.5, label='Feature Bagging'\n",
    ")\n",
    "\n",
    "plt.plot(\n",
    "    [3, 6, 9, 12],\n",
    "    [fs_pvalue_ranks_0_10.mean(), fs_pvalue_ranks_10_30.mean(), fs_pvalue_ranks_30_50.mean(),\n",
    "     fs_pvalue_ranks_100_300.mean()],\n",
    "    color=fs_color, marker='o', linestyle='-', linewidth=1.5, label='Full Space'\n",
    ")\n",
    "\n",
    "# Adding vertical lines to indicate the limits of each group on the x-axis\n",
    "for x in [3.5, 6.5, 9.5, 12.5]:\n",
    "    plt.axvline(x=x, color='gray', linestyle='--', linewidth=1)\n",
    "\n",
    "# Setting the x-axis labels\n",
    "plt.xticks([2, 5, 8, 11], ['0-10', '10-30',\n",
    "           '30-200', '200-2000'])\n",
    "\n",
    "\n",
    "plt.xlabel('Features')\n",
    "plt.ylabel('Rank')\n",
    "plt.savefig(f'{dataset}_non_lense.png',dpi=1000)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Kruskal-Wallis Test Result: KruskalResult(statistic=13.178571428571436, pvalue=0.0013750217713419494)\n",
      "Conover-Iman Test Result:\n",
      "                  Feature Bagging  Full-Space      VGAN\n",
      "Feature Bagging         1.000000    0.421570  0.002386\n",
      "Full-Space              0.421570    1.000000  0.000228\n",
      "VGAN                    0.002386    0.000228  1.000000\n",
      "Count of datasets:14\n"
     ]
    }
   ],
   "source": [
    "import pandas as pd\n",
    "import scipy.stats as stats\n",
    "import scikit_posthocs as sp\n",
    "\n",
    "# Load the data\n",
    "df = pd.read_csv('experiments/Outlier_Detection/Full_table_with_ranks-CBLOF.csv', delimiter=',')\n",
    "\n",
    "\n",
    "df = df[df['p-value'] > 0.10].drop(\"Columna 1\", axis=1).dropna()\n",
    "\n",
    "# Extracting the ranks for each model\n",
    "ranks_ens = df['RANK ENS']\n",
    "ranks_fs = df['RANK FS']\n",
    "ranks_vgan = df['RANK VGAN']\n",
    "\n",
    "# Performing the Kruskal-Wallis test\n",
    "kruskal_result = stats.kruskal(ranks_ens, ranks_fs, ranks_vgan)\n",
    "print(f\"Kruskal-Wallis Test Result: {kruskal_result}\")\n",
    "\n",
    "# If the p-value from Kruskal-Wallis test is significant, perform Conover-Iman test\n",
    "\n",
    "conover_result = sp.posthoc_conover([ranks_ens, ranks_fs, ranks_vgan])\n",
    "conover_result.index = [\"Feature Bagging\", \"Full-Space\", \"VGAN\"]\n",
    "conover_result.columns =  [\"Feature Bagging\", \"Full-Space\", \"VGAN\"]\n",
    "print(\"Conover-Iman Test Result:\\n\", conover_result)\n",
    "    \n",
    "print(f\"Count of datasets:{df.index.__len__()}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Kruskal-Wallis Test Result: KruskalResult(statistic=6.705268595041319, pvalue=0.03499205310134737)\n",
      "Conover-Iman Test Result:\n",
      "                  Feature Bagging  Full-Space      VGAN\n",
      "Feature Bagging         1.000000    0.061278  0.799820\n",
      "Full-Space              0.061278    1.000000  0.049964\n",
      "VGAN                    0.799820    0.049964  1.000000\n",
      "Count of datasets:16\n"
     ]
    }
   ],
   "source": [
    "import pandas as pd\n",
    "import scipy.stats as stats\n",
    "import scikit_posthocs as sp\n",
    "\n",
    "# Load the data\n",
    "df = pd.read_csv('experiments/Outlier_Detection/Full_table_with_ranks.csv', delimiter=';')\n",
    "\n",
    "\n",
    "df = df[df['p-value'] < 0.10]\n",
    "\n",
    "# Extracting the ranks for each model\n",
    "ranks_ens = df['RANK ENS']\n",
    "ranks_fs = df['RANK FS']\n",
    "ranks_vgan = df['RANK VGAN']\n",
    "\n",
    "# Performing the Kruskal-Wallis test\n",
    "kruskal_result = stats.kruskal(ranks_ens, ranks_fs, ranks_vgan)\n",
    "print(f\"Kruskal-Wallis Test Result: {kruskal_result}\")\n",
    "\n",
    "# If the p-value from Kruskal-Wallis test is significant, perform Conover-Iman test\n",
    "if kruskal_result.pvalue < 0.05:\n",
    "    conover_result = sp.posthoc_conover([ranks_ens, ranks_fs, ranks_vgan], p_adjust='holm')\n",
    "    conover_result.index = [\"Feature Bagging\", \"Full-Space\", \"VGAN\"]\n",
    "    conover_result.columns =  [\"Feature Bagging\", \"Full-Space\", \"VGAN\"]\n",
    "    print(\"Conover-Iman Test Result:\\n\", conover_result)\n",
    "    \n",
    "else:\n",
    "    print(\"Kruskal-Wallis test is not significant; no need to perform Conover-Iman test.\")\n",
    "print(f\"Count of datasets:{df.index.__len__()}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[1.75, 2.375, 1.6875]"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "[ranks_ens.mean(),ranks_fs.mean(),ranks_vgan.mean()]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "fig,ax = plt.subplots()\n",
    "for i,lst in enumerate([ranks_ens,ranks_fs,ranks_vgan]):\n",
    "    ax.boxplot(lst, positions=[i])\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# ECOD "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 466.667x266.667 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "#Define the dataset \n",
    "dataset = \"ECOD\"\n",
    "# Load the CSV file\n",
    "df = pd.read_csv(f'experiments/Outlier_Detection/Full_table_with_ranks-{dataset}.csv', delimiter=',',)\n",
    "\n",
    "# Filter the datasets where p-value > 0.10\n",
    "filtered_pvalue_df = df\n",
    "filtered_pvalue_df = df[df['p-value'] < 0.10]\n",
    "\n",
    "#Define the colors to use\n",
    "vgan_color = \"#72AD44\"\n",
    "ensemble_color = \"#FF7046\"\n",
    "fs_color = \"#00A9FF\"\n",
    "\n",
    "\n",
    "# Further filter by the feature ranges\n",
    "filtered_pvalue_0_10 = filtered_pvalue_df[(\n",
    "    filtered_pvalue_df['# Features'] > 0) & (filtered_pvalue_df['# Features'] <= 8)]\n",
    "filtered_pvalue_10_30 = filtered_pvalue_df[(\n",
    "    filtered_pvalue_df['# Features'] >= 10) & (filtered_pvalue_df['# Features'] <= 30)]\n",
    "filtered_pvalue_30_50 = filtered_pvalue_df[(\n",
    "    filtered_pvalue_df['# Features'] > 30) & (filtered_pvalue_df['# Features'] < 50)]\n",
    "filtered_pvalue_50_100 = filtered_pvalue_df[(\n",
    "    filtered_pvalue_df['# Features'] >= 50) & (filtered_pvalue_df['# Features'] <= 200)]\n",
    "filtered_pvalue_100_300 = filtered_pvalue_df[(\n",
    "    filtered_pvalue_df['# Features'] >= 200) & (filtered_pvalue_df['# Features'] <= 550)]\n",
    "filtered_pvalue_300_700 = filtered_pvalue_df[(\n",
    "    filtered_pvalue_df['# Features'] >= 550) & (filtered_pvalue_df['# Features'] <= 2000)]\n",
    "filtered_pvalue_700_2000 = filtered_pvalue_df[(\n",
    "    filtered_pvalue_df['# Features'] >= 700) & (filtered_pvalue_df['# Features'] <= 2000)]\n",
    "\n",
    "# Extract VGAN, ENSEMBLE, and FS ranks for these filtered datasets\n",
    "vgan_pvalue_ranks_0_10 = filtered_pvalue_0_10['RANK VGAN']\n",
    "vgan_pvalue_ranks_10_30 = filtered_pvalue_10_30['RANK VGAN']\n",
    "vgan_pvalue_ranks_30_50 = filtered_pvalue_30_50['RANK VGAN']\n",
    "vgan_pvalue_ranks_50_100 = filtered_pvalue_50_100['RANK VGAN']\n",
    "vgan_pvalue_ranks_100_300 = filtered_pvalue_100_300['RANK VGAN']\n",
    "vgan_pvalue_ranks_300_700 = filtered_pvalue_300_700['RANK VGAN']\n",
    "vgan_pvalue_ranks_700_2000 = filtered_pvalue_700_2000['RANK VGAN']\n",
    "\n",
    "ensemble_pvalue_ranks_0_10 = filtered_pvalue_0_10['RANK ENS']\n",
    "ensemble_pvalue_ranks_10_30 = filtered_pvalue_10_30['RANK ENS']\n",
    "ensemble_pvalue_ranks_30_50 = filtered_pvalue_30_50['RANK ENS']\n",
    "ensemble_pvalue_ranks_50_100 = filtered_pvalue_50_100['RANK ENS']\n",
    "ensemble_pvalue_ranks_100_300 = filtered_pvalue_100_300['RANK ENS']\n",
    "ensemble_pvalue_ranks_300_700 = filtered_pvalue_300_700['RANK ENS']\n",
    "ensemble_pvalue_ranks_700_2000 = filtered_pvalue_700_2000['RANK ENS']\n",
    "\n",
    "fs_pvalue_ranks_0_10 = filtered_pvalue_0_10['RANK FS']\n",
    "fs_pvalue_ranks_10_30 = filtered_pvalue_10_30['RANK FS']\n",
    "fs_pvalue_ranks_30_50 = filtered_pvalue_30_50['RANK FS']\n",
    "fs_pvalue_ranks_50_100 = filtered_pvalue_50_100['RANK FS']\n",
    "fs_pvalue_ranks_100_300 = filtered_pvalue_100_300['RANK FS']\n",
    "fs_pvalue_ranks_300_700 = filtered_pvalue_300_700['RANK FS']\n",
    "fs_pvalue_ranks_700_2000 = filtered_pvalue_700_2000['RANK FS']\n",
    "\n",
    "# Calculating the average ranks for each group\n",
    "all_averages = {\n",
    "    \"0-10\": vgan_pvalue_ranks_0_10.mean(),\n",
    "    \"10-30\": vgan_pvalue_ranks_10_30.mean(),\n",
    "    \"30-50\": vgan_pvalue_ranks_30_50.mean(),\n",
    "    \"50-100\": vgan_pvalue_ranks_50_100.mean(),\n",
    "    \"100-300\": vgan_pvalue_ranks_100_300.mean(),\n",
    "    \"300-700\": vgan_pvalue_ranks_300_700.mean(),\n",
    "    \"700-2000\": vgan_pvalue_ranks_700_2000.mean()\n",
    "}\n",
    "\n",
    "\n",
    "# Creating the combined boxplot with individual boxplots, line plots of the average ranks, and vertical lines to indicate group limits\n",
    "plt.figure(figsize=(2*7/3, 2*4/3))\n",
    "\n",
    "\n",
    "# Creating the boxplots for VGAN, ENSEMBLE, and FS\n",
    "boxplot_vgan = plt.boxplot(\n",
    "    [vgan_pvalue_ranks_0_10, vgan_pvalue_ranks_10_30, vgan_pvalue_ranks_30_50,\n",
    "        vgan_pvalue_ranks_100_300],\n",
    "    positions=[1, 4, 7, 10],\n",
    "    widths=0.6,\n",
    "    patch_artist=True,\n",
    "    boxprops=dict(facecolor=vgan_color, color=vgan_color, alpha=0.3),\n",
    "    whiskerprops=dict(color=vgan_color, alpha=0.3),\n",
    "    capprops=dict(color=vgan_color, alpha=0.3),\n",
    "    medianprops=dict(color=vgan_color,linewidth=2),\n",
    "    flierprops=dict(marker='o', markersize=5,\n",
    "                    linestyle='none', linewidth=2, color=vgan_color)\n",
    ")\n",
    "\n",
    "boxplot_ensemble = plt.boxplot(\n",
    "    [ensemble_pvalue_ranks_0_10, ensemble_pvalue_ranks_10_30, ensemble_pvalue_ranks_30_50, \n",
    "        ensemble_pvalue_ranks_100_300],\n",
    "    positions=[2, 5, 8, 11],\n",
    "    widths=0.6,\n",
    "    patch_artist=True,\n",
    "    boxprops=dict(facecolor=ensemble_color, color=ensemble_color, alpha=0.3),\n",
    "    whiskerprops=dict(color=ensemble_color, alpha=0.3),\n",
    "    capprops=dict(color=ensemble_color, alpha=0.3),\n",
    "    medianprops=dict(color=ensemble_color,linewidth=2),\n",
    "    flierprops=dict(marker='o', markersize=5, linestyle='none',\n",
    "                    linewidth=2, color=ensemble_color)\n",
    ")\n",
    "\n",
    "boxplot_fs = plt.boxplot(\n",
    "    [fs_pvalue_ranks_0_10, fs_pvalue_ranks_10_30, fs_pvalue_ranks_30_50,\n",
    "        fs_pvalue_ranks_100_300],\n",
    "    positions=[3, 6, 9, 12],\n",
    "    widths=0.6,\n",
    "    patch_artist=True,\n",
    "    boxprops=dict(facecolor=fs_color, color=fs_color, alpha=0.3),\n",
    "    whiskerprops=dict(color=fs_color, alpha=0.3),\n",
    "    capprops=dict(color=fs_color, alpha=0.3),\n",
    "    medianprops=dict(color=fs_color,linewidth=2),\n",
    "    flierprops=dict(marker='o', markersize=5, linestyle='none',\n",
    "                    linewidth=2, color=fs_color)\n",
    ")\n",
    "\n",
    "# Plotting the average ranks for VGAN, ENSEMBLE, and FS as line plots on top of the boxplots\n",
    "plt.plot(\n",
    "    [1, 4, 7, 10],\n",
    "    [all_averages[\"0-10\"], all_averages[\"10-30\"], all_averages[\"30-50\"],\n",
    "        all_averages[\"100-300\"]],\n",
    "    color=vgan_color, marker='o', linestyle='-', linewidth=1.5, label='VGAN'\n",
    ")\n",
    "\n",
    "plt.plot(\n",
    "    [2, 5, 8, 11],\n",
    "    [ensemble_pvalue_ranks_0_10.mean(), ensemble_pvalue_ranks_10_30.mean(), ensemble_pvalue_ranks_30_50.mean(),\n",
    "     ensemble_pvalue_ranks_100_300.mean()],\n",
    "    color=ensemble_color, marker='o', linestyle='-', linewidth=1.5, label='Feature Bagging'\n",
    ")\n",
    "\n",
    "plt.plot(\n",
    "    [3, 6, 9, 12],\n",
    "    [fs_pvalue_ranks_0_10.mean(), fs_pvalue_ranks_10_30.mean(), fs_pvalue_ranks_30_50.mean(),\n",
    "     fs_pvalue_ranks_100_300.mean()],\n",
    "    color=fs_color, marker='o', linestyle='-', linewidth=1.5, label='Full Space'\n",
    ")\n",
    "\n",
    "# Adding vertical lines to indicate the limits of each group on the x-axis\n",
    "for x in [3.5, 6.5, 9.5, 12.5]:\n",
    "    plt.axvline(x=x, color='gray', linestyle='--', linewidth=1)\n",
    "\n",
    "# Setting the x-axis labels\n",
    "plt.xticks([2, 5, 8, 11], ['0-10', '10-30',\n",
    "           '30-200', '200-2000'])\n",
    "\n",
    "\n",
    "plt.xlabel('Features')\n",
    "plt.ylabel('Rank')\n",
    "plt.savefig(f'{dataset}_non_lense.png',dpi=1000)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Kruskal-Wallis Test Result: KruskalResult(statistic=8.066481994459814, pvalue=0.017716816650088577)\n",
      "Conover-Iman Test Result:\n",
      "                  Feature Bagging  Full-Space      VGAN\n",
      "Feature Bagging         1.000000    0.406795  0.041323\n",
      "Full-Space              0.406795    1.000000  0.005010\n",
      "VGAN                    0.041323    0.005010  1.000000\n",
      "Count of datasets:19\n"
     ]
    }
   ],
   "source": [
    "import pandas as pd\n",
    "import scipy.stats as stats\n",
    "import scikit_posthocs as sp\n",
    "\n",
    "# Load the data\n",
    "df = pd.read_csv('experiments/Outlier_Detection/Full_table_with_ranks-ECOD.csv', delimiter=',')\n",
    "\n",
    "\n",
    "\n",
    "df = df[df['p-value'] > 0.10]\n",
    "\n",
    "# Extracting the ranks for each model\n",
    "ranks_ens = df['RANK ENS']\n",
    "ranks_fs = df['RANK FS']\n",
    "ranks_vgan = df['RANK VGAN']\n",
    "\n",
    "# Performing the Kruskal-Wallis test\n",
    "kruskal_result = stats.kruskal(ranks_ens, ranks_fs, ranks_vgan)\n",
    "print(f\"Kruskal-Wallis Test Result: {kruskal_result}\")\n",
    "\n",
    "# If the p-value from Kruskal-Wallis test is significant, perform Conover-Iman test\n",
    "if kruskal_result.pvalue < 0.05:\n",
    "    conover_result = sp.posthoc_conover([ranks_ens, ranks_fs, ranks_vgan])\n",
    "    conover_result.index = [\"Feature Bagging\", \"Full-Space\", \"VGAN\"]\n",
    "    conover_result.columns =  [\"Feature Bagging\", \"Full-Space\", \"VGAN\"]\n",
    "    print(\"Conover-Iman Test Result:\\n\", conover_result)\n",
    "    \n",
    "else:\n",
    "    print(\"Kruskal-Wallis test is not significant; no need to perform Conover-Iman test.\")\n",
    "print(f\"Count of datasets:{df.index.__len__()}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Kruskal-Wallis Test Result: KruskalResult(statistic=0.1285444234404692, pvalue=0.9377496983257851)\n",
      "Conover-Iman Test Result:\n",
      "                  Feature Bagging  Full-Space      VGAN\n",
      "Feature Bagging         1.000000    0.860225  0.860225\n",
      "Full-Space              0.860225    1.000000  0.724800\n",
      "VGAN                    0.860225    0.724800  1.000000\n",
      "Count of datasets:23\n"
     ]
    }
   ],
   "source": [
    "import pandas as pd\n",
    "import scipy.stats as stats\n",
    "import scikit_posthocs as sp\n",
    "\n",
    "# Load the data\n",
    "df = pd.read_csv('experiments/Outlier_Detection/Full_table_with_ranks-ECOD.csv', delimiter=',')\n",
    "\n",
    "\n",
    "\n",
    "df = df[df['p-value'] < 0.10]\n",
    "\n",
    "# Extracting the ranks for each model\n",
    "ranks_ens = df['RANK ENS']\n",
    "ranks_fs = df['RANK FS']\n",
    "ranks_vgan = df['RANK VGAN']\n",
    "\n",
    "# Performing the Kruskal-Wallis test\n",
    "kruskal_result = stats.kruskal(ranks_ens, ranks_fs, ranks_vgan)\n",
    "print(f\"Kruskal-Wallis Test Result: {kruskal_result}\")\n",
    "\n",
    "# If the p-value from Kruskal-Wallis test is significant, perform Conover-Iman test\n",
    "\n",
    "conover_result = sp.posthoc_conover([ranks_ens, ranks_fs, ranks_vgan])\n",
    "conover_result.index = [\"Feature Bagging\", \"Full-Space\", \"VGAN\"]\n",
    "conover_result.columns =  [\"Feature Bagging\", \"Full-Space\", \"VGAN\"]\n",
    "print(\"Conover-Iman Test Result:\\n\", conover_result)\n",
    "    \n",
    "print(f\"Count of datasets:{df.index.__len__()}\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# COPOD"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 466.667x266.667 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "#Define the dataset \n",
    "dataset = \"COPOD\"\n",
    "# Load the CSV file\n",
    "df = pd.read_csv(f'experiments/Outlier_Detection/Full_table_with_ranks-{dataset}.csv', delimiter=',',)\n",
    "\n",
    "# Filter the datasets where p-value > 0.10\n",
    "filtered_pvalue_df = df\n",
    "filtered_pvalue_df = df[df['p-value'] < 0.10]\n",
    "\n",
    "#Define the colors to use\n",
    "vgan_color = \"#72AD44\"\n",
    "ensemble_color = \"#FF7046\"\n",
    "fs_color = \"#00A9FF\"\n",
    "\n",
    "\n",
    "# Further filter by the feature ranges\n",
    "filtered_pvalue_0_10 = filtered_pvalue_df[(\n",
    "    filtered_pvalue_df['# Features'] > 0) & (filtered_pvalue_df['# Features'] <= 8)]\n",
    "filtered_pvalue_10_30 = filtered_pvalue_df[(\n",
    "    filtered_pvalue_df['# Features'] >= 10) & (filtered_pvalue_df['# Features'] <= 30)]\n",
    "filtered_pvalue_30_50 = filtered_pvalue_df[(\n",
    "    filtered_pvalue_df['# Features'] > 30) & (filtered_pvalue_df['# Features'] < 50)]\n",
    "filtered_pvalue_50_100 = filtered_pvalue_df[(\n",
    "    filtered_pvalue_df['# Features'] >= 50) & (filtered_pvalue_df['# Features'] <= 200)]\n",
    "filtered_pvalue_100_300 = filtered_pvalue_df[(\n",
    "    filtered_pvalue_df['# Features'] >= 200) & (filtered_pvalue_df['# Features'] <= 550)]\n",
    "filtered_pvalue_300_700 = filtered_pvalue_df[(\n",
    "    filtered_pvalue_df['# Features'] >= 550) & (filtered_pvalue_df['# Features'] <= 2000)]\n",
    "filtered_pvalue_700_2000 = filtered_pvalue_df[(\n",
    "    filtered_pvalue_df['# Features'] >= 700) & (filtered_pvalue_df['# Features'] <= 2000)]\n",
    "\n",
    "# Extract VGAN, ENSEMBLE, and FS ranks for these filtered datasets\n",
    "vgan_pvalue_ranks_0_10 = filtered_pvalue_0_10['RANK VGAN']\n",
    "vgan_pvalue_ranks_10_30 = filtered_pvalue_10_30['RANK VGAN']\n",
    "vgan_pvalue_ranks_30_50 = filtered_pvalue_30_50['RANK VGAN']\n",
    "vgan_pvalue_ranks_50_100 = filtered_pvalue_50_100['RANK VGAN']\n",
    "vgan_pvalue_ranks_100_300 = filtered_pvalue_100_300['RANK VGAN']\n",
    "vgan_pvalue_ranks_300_700 = filtered_pvalue_300_700['RANK VGAN']\n",
    "vgan_pvalue_ranks_700_2000 = filtered_pvalue_700_2000['RANK VGAN']\n",
    "\n",
    "ensemble_pvalue_ranks_0_10 = filtered_pvalue_0_10['RANK ENS']\n",
    "ensemble_pvalue_ranks_10_30 = filtered_pvalue_10_30['RANK ENS']\n",
    "ensemble_pvalue_ranks_30_50 = filtered_pvalue_30_50['RANK ENS']\n",
    "ensemble_pvalue_ranks_50_100 = filtered_pvalue_50_100['RANK ENS']\n",
    "ensemble_pvalue_ranks_100_300 = filtered_pvalue_100_300['RANK ENS']\n",
    "ensemble_pvalue_ranks_300_700 = filtered_pvalue_300_700['RANK ENS']\n",
    "ensemble_pvalue_ranks_700_2000 = filtered_pvalue_700_2000['RANK ENS']\n",
    "\n",
    "fs_pvalue_ranks_0_10 = filtered_pvalue_0_10['RANK FS']\n",
    "fs_pvalue_ranks_10_30 = filtered_pvalue_10_30['RANK FS']\n",
    "fs_pvalue_ranks_30_50 = filtered_pvalue_30_50['RANK FS']\n",
    "fs_pvalue_ranks_50_100 = filtered_pvalue_50_100['RANK FS']\n",
    "fs_pvalue_ranks_100_300 = filtered_pvalue_100_300['RANK FS']\n",
    "fs_pvalue_ranks_300_700 = filtered_pvalue_300_700['RANK FS']\n",
    "fs_pvalue_ranks_700_2000 = filtered_pvalue_700_2000['RANK FS']\n",
    "\n",
    "# Calculating the average ranks for each group\n",
    "all_averages = {\n",
    "    \"0-10\": vgan_pvalue_ranks_0_10.mean(),\n",
    "    \"10-30\": vgan_pvalue_ranks_10_30.mean(),\n",
    "    \"30-50\": vgan_pvalue_ranks_30_50.mean(),\n",
    "    \"50-100\": vgan_pvalue_ranks_50_100.mean(),\n",
    "    \"100-300\": vgan_pvalue_ranks_100_300.mean(),\n",
    "    \"300-700\": vgan_pvalue_ranks_300_700.mean(),\n",
    "    \"700-2000\": vgan_pvalue_ranks_700_2000.mean()\n",
    "}\n",
    "\n",
    "\n",
    "# Creating the combined boxplot with individual boxplots, line plots of the average ranks, and vertical lines to indicate group limits\n",
    "plt.figure(figsize=(2*7/3, 2*4/3))\n",
    "\n",
    "\n",
    "# Creating the boxplots for VGAN, ENSEMBLE, and FS\n",
    "boxplot_vgan = plt.boxplot(\n",
    "    [vgan_pvalue_ranks_0_10, vgan_pvalue_ranks_10_30, vgan_pvalue_ranks_30_50,\n",
    "        vgan_pvalue_ranks_100_300],\n",
    "    positions=[1, 4, 7, 10],\n",
    "    widths=0.6,\n",
    "    patch_artist=True,\n",
    "    boxprops=dict(facecolor=vgan_color, color=vgan_color, alpha=0.3),\n",
    "    whiskerprops=dict(color=vgan_color, alpha=0.3),\n",
    "    capprops=dict(color=vgan_color, alpha=0.3),\n",
    "    medianprops=dict(color=vgan_color,linewidth=2),\n",
    "    flierprops=dict(marker='o', markersize=5,\n",
    "                    linestyle='none', linewidth=2, color=vgan_color)\n",
    ")\n",
    "\n",
    "boxplot_ensemble = plt.boxplot(\n",
    "    [ensemble_pvalue_ranks_0_10, ensemble_pvalue_ranks_10_30, ensemble_pvalue_ranks_30_50, \n",
    "        ensemble_pvalue_ranks_100_300],\n",
    "    positions=[2, 5, 8, 11],\n",
    "    widths=0.6,\n",
    "    patch_artist=True,\n",
    "    boxprops=dict(facecolor=ensemble_color, color=ensemble_color, alpha=0.3),\n",
    "    whiskerprops=dict(color=ensemble_color, alpha=0.3),\n",
    "    capprops=dict(color=ensemble_color, alpha=0.3),\n",
    "    medianprops=dict(color=ensemble_color,linewidth=2),\n",
    "    flierprops=dict(marker='o', markersize=5, linestyle='none',\n",
    "                    linewidth=2, color=ensemble_color)\n",
    ")\n",
    "\n",
    "boxplot_fs = plt.boxplot(\n",
    "    [fs_pvalue_ranks_0_10, fs_pvalue_ranks_10_30, fs_pvalue_ranks_30_50,\n",
    "        fs_pvalue_ranks_100_300],\n",
    "    positions=[3, 6, 9, 12],\n",
    "    widths=0.6,\n",
    "    patch_artist=True,\n",
    "    boxprops=dict(facecolor=fs_color, color=fs_color, alpha=0.3),\n",
    "    whiskerprops=dict(color=fs_color, alpha=0.3),\n",
    "    capprops=dict(color=fs_color, alpha=0.3),\n",
    "    medianprops=dict(color=fs_color,linewidth=2),\n",
    "    flierprops=dict(marker='o', markersize=5, linestyle='none',\n",
    "                    linewidth=2, color=fs_color)\n",
    ")\n",
    "\n",
    "# Plotting the average ranks for VGAN, ENSEMBLE, and FS as line plots on top of the boxplots\n",
    "plt.plot(\n",
    "    [1, 4, 7, 10],\n",
    "    [all_averages[\"0-10\"], all_averages[\"10-30\"], all_averages[\"30-50\"],\n",
    "        all_averages[\"100-300\"]],\n",
    "    color=vgan_color, marker='o', linestyle='-', linewidth=1.5, label='VGAN'\n",
    ")\n",
    "\n",
    "plt.plot(\n",
    "    [2, 5, 8, 11],\n",
    "    [ensemble_pvalue_ranks_0_10.mean(), ensemble_pvalue_ranks_10_30.mean(), ensemble_pvalue_ranks_30_50.mean(),\n",
    "     ensemble_pvalue_ranks_100_300.mean()],\n",
    "    color=ensemble_color, marker='o', linestyle='-', linewidth=1.5, label='Feature Bagging'\n",
    ")\n",
    "\n",
    "plt.plot(\n",
    "    [3, 6, 9, 12],\n",
    "    [fs_pvalue_ranks_0_10.mean(), fs_pvalue_ranks_10_30.mean(), fs_pvalue_ranks_30_50.mean(),\n",
    "     fs_pvalue_ranks_100_300.mean()],\n",
    "    color=fs_color, marker='o', linestyle='-', linewidth=1.5, label='Full Space'\n",
    ")\n",
    "\n",
    "# Adding vertical lines to indicate the limits of each group on the x-axis\n",
    "for x in [3.5, 6.5, 9.5, 12.5]:\n",
    "    plt.axvline(x=x, color='gray', linestyle='--', linewidth=1)\n",
    "\n",
    "# Setting the x-axis labels\n",
    "plt.xticks([2, 5, 8, 11], ['0-10', '10-30',\n",
    "           '30-200', '200-2000'])\n",
    "\n",
    "\n",
    "plt.xlabel('Features')\n",
    "plt.ylabel('Rank')\n",
    "plt.savefig(f'{dataset}_non_lense.png',dpi=1000)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Kruskal-Wallis Test Result: KruskalResult(statistic=17.85487528344671, pvalue=0.00013269760809115318)\n",
      "Conover-Iman Test Result:\n",
      "                  Feature Bagging  Full-Space      VGAN\n",
      "Feature Bagging         1.000000    0.827731  0.000106\n",
      "Full-Space              0.827731    1.000000  0.000050\n",
      "VGAN                    0.000106    0.000050  1.000000\n",
      "Count of datasets:21\n"
     ]
    }
   ],
   "source": [
    "import pandas as pd\n",
    "import scipy.stats as stats\n",
    "import scikit_posthocs as sp\n",
    "\n",
    "# Load the data\n",
    "df = pd.read_csv('experiments/Outlier_Detection/Full_table_with_ranks-COPOD.csv', delimiter=',')\n",
    "\n",
    "\n",
    "\n",
    "df = df[df['p-value'] > 0.10]\n",
    "\n",
    "# Extracting the ranks for each model\n",
    "ranks_ens = df['RANK ENS']\n",
    "ranks_fs = df['RANK FS']\n",
    "ranks_vgan = df['RANK VGAN']\n",
    "\n",
    "# Performing the Kruskal-Wallis test\n",
    "kruskal_result = stats.kruskal(ranks_ens, ranks_fs, ranks_vgan)\n",
    "print(f\"Kruskal-Wallis Test Result: {kruskal_result}\")\n",
    "\n",
    "# If the p-value from Kruskal-Wallis test is significant, perform Conover-Iman test\n",
    "\n",
    "conover_result = sp.posthoc_conover([ranks_ens, ranks_fs, ranks_vgan])\n",
    "conover_result.index = [\"Feature Bagging\", \"Full-Space\", \"VGAN\"]\n",
    "conover_result.columns =  [\"Feature Bagging\", \"Full-Space\", \"VGAN\"]\n",
    "print(\"Conover-Iman Test Result:\\n\", conover_result)\n",
    "    \n",
    "print(f\"Count of datasets:{df.index.__len__()}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Kruskal-Wallis Test Result: KruskalResult(statistic=2.921280593916538, pvalue=0.23208762214542708)\n",
      "Conover-Iman Test Result:\n",
      "                  Feature Bagging  Full-Space      VGAN\n",
      "Feature Bagging         1.000000    0.142808  0.989274\n",
      "Full-Space              0.142808    1.000000  0.139275\n",
      "VGAN                    0.989274    0.139275  1.000000\n",
      "Count of datasets:21\n"
     ]
    }
   ],
   "source": [
    "import pandas as pd\n",
    "import scipy.stats as stats\n",
    "import scikit_posthocs as sp\n",
    "\n",
    "# Load the data\n",
    "df = pd.read_csv('experiments/Outlier_Detection/Full_table_with_ranks-COPOD.csv', delimiter=',')\n",
    "\n",
    "\n",
    "\n",
    "df = df[df['p-value'] < 0.10]\n",
    "\n",
    "# Extracting the ranks for each model\n",
    "ranks_ens = df['RANK ENS']\n",
    "ranks_fs = df['RANK FS']\n",
    "ranks_vgan = df['RANK VGAN']\n",
    "\n",
    "# Performing the Kruskal-Wallis test\n",
    "kruskal_result = stats.kruskal(ranks_ens, ranks_fs, ranks_vgan)\n",
    "print(f\"Kruskal-Wallis Test Result: {kruskal_result}\")\n",
    "\n",
    "# If the p-value from Kruskal-Wallis test is significant, perform Conover-Iman test\n",
    "\n",
    "conover_result = sp.posthoc_conover([ranks_ens, ranks_fs, ranks_vgan])\n",
    "conover_result.index = [\"Feature Bagging\", \"Full-Space\", \"VGAN\"]\n",
    "conover_result.columns =  [\"Feature Bagging\", \"Full-Space\", \"VGAN\"]\n",
    "print(\"Conover-Iman Test Result:\\n\", conover_result)\n",
    "    \n",
    "print(f\"Count of datasets:{df.index.__len__()}\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "FOR TESTING UNIFORMITY"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 370,
   "metadata": {},
   "outputs": [],
   "source": [
    "import math \n",
    "from decimal import Decimal, getcontext\n",
    "from fractions import Fraction\n",
    "from joblib import Parallel, delayed\n",
    "import numpy as np\n",
    "\n",
    "def choose(n,k):\n",
    "    if k > n//2: k = n - k\n",
    "    p = Fraction(1)\n",
    "    for i in range(1,k+1):\n",
    "        p *= Fraction(n - i + 1, i)\n",
    "    return int(p)\n",
    "\n",
    "getcontext().prec = 500\n",
    "\n",
    "def pmf(x,sub_number, number_of_experiments): \n",
    "    assert x < number_of_experiments + 1\n",
    "    print(x)\n",
    "    getcontext().prec = 500\n",
    "    summatory = 0\n",
    "    sub_number = Decimal(sub_number)\n",
    "    for k in range(x+1):\n",
    "        summatory += (-1)**k*math.comb(x,k)*(Decimal(x-k)/sub_number)**number_of_experiments\n",
    "    return summatory*math.comb(int(sub_number),x)\n",
    "def cdf(x,feat_number, number_of_experiments):\n",
    "    summatory_parallel = Parallel(n_jobs=-1)(delayed(pmf)(k,feat_number,number_of_experiments) for k in range(x+1))\n",
    "    return np.array(summatory_parallel).sum()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "subsel_torch",
   "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.12.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
