{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import pickle"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "def print_results(result_dict, result_name, name, cl_algo):\n",
    "    '''Prints and saves the results in a pickle file.'''\n",
    "    print(\"\")\n",
    "    print(f'{result_name} Results for {name} with {cl_algo}')\n",
    "    print(\"=========================================\")\n",
    "    for metric in result_dict.keys():\n",
    "        if \"N/A\" in result_dict[metric]:\n",
    "            print(f'{metric}: {result_dict[metric]}')\n",
    "            continue\n",
    "        mean_val = np.mean(result_dict[metric])\n",
    "        std_val = np.std(result_dict[metric])\n",
    "        mean_val = round(mean_val, 3)\n",
    "        std_val = round(std_val, 3)\n",
    "        print(f'{metric}: Mean = {mean_val}, Std = {std_val}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "Pre-Attack Results for DIGITS with SFD\n",
      "=========================================\n",
      "BALANCE: Mean = 0.021, Std = 0.0\n",
      "MIN_CLUSTER_RATIO: Mean = 0.395, Std = 0.001\n",
      "CLUSTER_DIST_L1: Mean = 0.344, Std = 0.001\n",
      "CLUSTER_DIST_KL: Mean = 0.722, Std = 0.002\n",
      "SILHOUETTE_DIFF: Mean = -0.06, Std = 0.0\n",
      "ENTROPY: Mean = 2.921, Std = 0.003\n",
      "ENTROPY_GROUP_A: Mean = 2.271, Std = 0.0\n",
      "ENTROPY_GROUP_B: Mean = 1.983, Std = 0.002\n",
      "ACC: Mean = 0.399, Std = 0.0\n",
      "NMI: Mean = 0.278, Std = 0.0\n",
      "ARI: Mean = 0.157, Std = 0.0\n",
      "SIL: Mean = -0.072, Std = 0.0\n",
      "\n",
      "Post-Attack Results for DIGITS with SFD\n",
      "=========================================\n",
      "BALANCE: Mean = 0.0, Std = 0.0\n",
      "MIN_CLUSTER_RATIO: Mean = 0.0, Std = 0.0\n",
      "CLUSTER_DIST_L1: Mean = 1.0, Std = 0.0\n",
      "CLUSTER_DIST_KL: Mean = inf, Std = nan\n",
      "SILHOUETTE_DIFF: Mean = -0.09, Std = 0.124\n",
      "ENTROPY: Mean = -0.0, Std = 0.0\n",
      "ENTROPY_GROUP_A: Mean = 1.739, Std = 0.869\n",
      "ENTROPY_GROUP_B: Mean = 0.435, Std = 0.869\n",
      "ACC: Mean = 0.436, Std = 0.006\n",
      "NMI: Mean = 0.393, Std = 0.003\n",
      "ARI: Mean = 0.094, Std = 0.001\n",
      "SIL: Mean = 0.322, Std = 0.003\n",
      "\n",
      "Random-Attack Results for DIGITS with SFD\n",
      "=========================================\n",
      "BALANCE: Mean = 0.0, Std = 0.0\n",
      "MIN_CLUSTER_RATIO: Mean = 0.0, Std = 0.0\n",
      "CLUSTER_DIST_L1: Mean = 1.0, Std = 0.0\n",
      "CLUSTER_DIST_KL: Mean = inf, Std = nan\n",
      "SILHOUETTE_DIFF: Mean = -0.06, Std = 0.142\n",
      "ENTROPY: Mean = -0.0, Std = 0.0\n",
      "ENTROPY_GROUP_A: Mean = 1.525, Std = 0.998\n",
      "ENTROPY_GROUP_B: Mean = 0.652, Std = 0.996\n",
      "ACC: Mean = 0.438, Std = 0.001\n",
      "NMI: Mean = 0.394, Std = 0.002\n",
      "ARI: Mean = 0.094, Std = 0.0\n",
      "SIL: Mean = 0.321, Std = 0.001\n",
      "\n",
      "Percentage Difference between Post and Pre Attack for DIGITS with SFD\n",
      "BALANCE: Percentage Difference = -1.0\n",
      "MIN_CLUSTER_RATIO: Percentage Difference = -1.0\n",
      "CLUSTER_DIST_L1: Percentage Difference = 1.908\n",
      "CLUSTER_DIST_KL: Percentage Difference = inf\n",
      "SILHOUETTE_DIFF: Percentage Difference = 0.507\n",
      "ENTROPY: Percentage Difference = -1.0\n",
      "ENTROPY_GROUP_A: Percentage Difference = -0.234\n",
      "ENTROPY_GROUP_B: Percentage Difference = -0.781\n",
      "ACC: Percentage Difference = 0.092\n",
      "NMI: Percentage Difference = 0.412\n",
      "ARI: Percentage Difference = -0.399\n",
      "SIL: Percentage Difference = -5.483\n",
      "\n",
      "Percentage Difference between Random and Pre Attack for DIGITS with SFD\n",
      "BALANCE: Percentage Difference = -1.0\n",
      "MIN_CLUSTER_RATIO: Percentage Difference = -1.0\n",
      "CLUSTER_DIST_L1: Percentage Difference = 1.908\n",
      "CLUSTER_DIST_KL: Percentage Difference = inf\n",
      "SILHOUETTE_DIFF: Percentage Difference = -0.0\n",
      "ENTROPY: Percentage Difference = -1.0\n",
      "ENTROPY_GROUP_A: Percentage Difference = -0.328\n",
      "ENTROPY_GROUP_B: Percentage Difference = -0.671\n",
      "ACC: Percentage Difference = 0.098\n",
      "NMI: Percentage Difference = 0.413\n",
      "ARI: Percentage Difference = -0.397\n",
      "SIL: Percentage Difference = -5.469\n",
      "\n",
      "\n",
      "Pre-Attack Results for DIGITS with FSC\n",
      "=========================================\n",
      "BALANCE: Mean = 0.0, Std = 0.0\n",
      "MIN_CLUSTER_RATIO: Mean = 0.0, Std = 0.0\n",
      "CLUSTER_DIST_L1: Mean = 0.404, Std = 0.0\n",
      "CLUSTER_DIST_KL: Mean = inf, Std = nan\n",
      "SILHOUETTE_DIFF: Mean = -0.017, Std = 0.0\n",
      "ENTROPY: Mean = 0.346, Std = 0.0\n",
      "ENTROPY_GROUP_A: Mean = 1.028, Std = 0.006\n",
      "ENTROPY_GROUP_B: Mean = 1.281, Std = 0.0\n",
      "ACC: Mean = 0.314, Std = 0.001\n",
      "NMI: Mean = 0.564, Std = 0.002\n",
      "ARI: Mean = 0.156, Std = 0.0\n",
      "SIL: Mean = -0.139, Std = 0.0\n",
      "\n",
      "Post-Attack Results for DIGITS with FSC\n",
      "=========================================\n",
      "BALANCE: Mean = 0.0, Std = 0.0\n",
      "MIN_CLUSTER_RATIO: Mean = 0.0, Std = 0.0\n",
      "CLUSTER_DIST_L1: Mean = 0.404, Std = 0.0\n",
      "CLUSTER_DIST_KL: Mean = inf, Std = nan\n",
      "SILHOUETTE_DIFF: Mean = -0.017, Std = 0.0\n",
      "ENTROPY: Mean = 0.346, Std = 0.0\n",
      "ENTROPY_GROUP_A: Mean = 1.024, Std = 0.009\n",
      "ENTROPY_GROUP_B: Mean = 1.281, Std = 0.0\n",
      "ACC: Mean = 0.313, Std = 0.002\n",
      "NMI: Mean = 0.565, Std = 0.003\n",
      "ARI: Mean = 0.156, Std = 0.0\n",
      "SIL: Mean = -0.14, Std = 0.0\n",
      "\n",
      "Random-Attack Results for DIGITS with FSC\n",
      "=========================================\n",
      "BALANCE: Mean = 0.0, Std = 0.0\n",
      "MIN_CLUSTER_RATIO: Mean = 0.0, Std = 0.0\n",
      "CLUSTER_DIST_L1: Mean = 0.419, Std = 0.044\n",
      "CLUSTER_DIST_KL: Mean = inf, Std = nan\n",
      "SILHOUETTE_DIFF: Mean = -0.018, Std = 0.005\n",
      "ENTROPY: Mean = 0.374, Std = 0.085\n",
      "ENTROPY_GROUP_A: Mean = 1.033, Std = 0.017\n",
      "ENTROPY_GROUP_B: Mean = 1.322, Std = 0.124\n",
      "ACC: Mean = 0.318, Std = 0.011\n",
      "NMI: Mean = 0.56, Std = 0.011\n",
      "ARI: Mean = 0.158, Std = 0.008\n",
      "SIL: Mean = -0.138, Std = 0.003\n",
      "\n",
      "Percentage Difference between Post and Pre Attack for DIGITS with FSC\n",
      "BALANCE: Percentage Difference = nan\n",
      "MIN_CLUSTER_RATIO: Percentage Difference = nan\n",
      "CLUSTER_DIST_L1: Percentage Difference = 0.0\n",
      "CLUSTER_DIST_KL: Percentage Difference = nan\n",
      "SILHOUETTE_DIFF: Percentage Difference = 0.0\n",
      "ENTROPY: Percentage Difference = -0.0\n",
      "ENTROPY_GROUP_A: Percentage Difference = -0.004\n",
      "ENTROPY_GROUP_B: Percentage Difference = 0.0\n",
      "ACC: Percentage Difference = -0.003\n",
      "NMI: Percentage Difference = 0.002\n",
      "ARI: Percentage Difference = 0.0\n",
      "SIL: Percentage Difference = 0.001\n",
      "\n",
      "Percentage Difference between Random and Pre Attack for DIGITS with FSC\n",
      "BALANCE: Percentage Difference = nan\n",
      "MIN_CLUSTER_RATIO: Percentage Difference = nan\n",
      "CLUSTER_DIST_L1: Percentage Difference = 0.037\n",
      "CLUSTER_DIST_KL: Percentage Difference = nan\n",
      "SILHOUETTE_DIFF: Percentage Difference = 0.097\n",
      "ENTROPY: Percentage Difference = 0.082\n",
      "ENTROPY_GROUP_A: Percentage Difference = 0.005\n",
      "ENTROPY_GROUP_B: Percentage Difference = 0.032\n",
      "ACC: Percentage Difference = 0.012\n",
      "NMI: Percentage Difference = -0.006\n",
      "ARI: Percentage Difference = 0.017\n",
      "SIL: Percentage Difference = -0.007\n",
      "\n",
      "\n",
      "Pre-Attack Results for DIGITS with KFC/attack_entropy/\n",
      "=========================================\n",
      "BALANCE: Mean = 0.707, Std = 0.132\n",
      "MIN_CLUSTER_RATIO: Mean = 0.683, Std = 0.128\n",
      "CLUSTER_DIST_L1: Mean = 0.094, Std = 0.011\n",
      "CLUSTER_DIST_KL: Mean = 0.022, Std = 0.005\n",
      "SILHOUETTE_DIFF: Mean = -0.014, Std = 0.021\n",
      "ENTROPY: Mean = 3.376, Std = 0.106\n",
      "ENTROPY_GROUP_A: Mean = 1.82, Std = 0.169\n",
      "ENTROPY_GROUP_B: Mean = 1.82, Std = 0.168\n",
      "ACC: Mean = 0.174, Std = 0.018\n",
      "NMI: Mean = 0.058, Std = 0.009\n",
      "ARI: Mean = 0.022, Std = 0.009\n",
      "SIL: Mean = -0.07, Std = 0.032\n",
      "\n",
      "Post-Attack Results for DIGITS with KFC/attack_entropy/\n",
      "=========================================\n",
      "BALANCE: Mean = 0.375, Std = 0.209\n",
      "MIN_CLUSTER_RATIO: Mean = 0.498, Std = 0.168\n",
      "CLUSTER_DIST_L1: Mean = 0.121, Std = 0.009\n",
      "CLUSTER_DIST_KL: Mean = inf, Std = nan\n",
      "SILHOUETTE_DIFF: Mean = -0.038, Std = 0.057\n",
      "ENTROPY: Mean = 3.133, Std = 0.22\n",
      "ENTROPY_GROUP_A: Mean = 1.859, Std = 0.166\n",
      "ENTROPY_GROUP_B: Mean = 1.84, Std = 0.175\n",
      "ACC: Mean = 0.175, Std = 0.016\n",
      "NMI: Mean = 0.056, Std = 0.008\n",
      "ARI: Mean = 0.022, Std = 0.008\n",
      "SIL: Mean = -0.133, Std = 0.043\n",
      "\n",
      "Random-Attack Results for DIGITS with KFC/attack_entropy/\n",
      "=========================================\n",
      "BALANCE: Mean = 0.351, Std = 0.273\n",
      "MIN_CLUSTER_RATIO: Mean = 0.457, Std = 0.254\n",
      "CLUSTER_DIST_L1: Mean = 0.12, Std = 0.01\n",
      "CLUSTER_DIST_KL: Mean = inf, Std = nan\n",
      "SILHOUETTE_DIFF: Mean = -0.031, Std = 0.042\n",
      "ENTROPY: Mean = 3.161, Std = 0.254\n",
      "ENTROPY_GROUP_A: Mean = 1.845, Std = 0.182\n",
      "ENTROPY_GROUP_B: Mean = 1.826, Std = 0.188\n",
      "ACC: Mean = 0.176, Std = 0.016\n",
      "NMI: Mean = 0.058, Std = 0.008\n",
      "ARI: Mean = 0.023, Std = 0.008\n",
      "SIL: Mean = -0.147, Std = 0.073\n",
      "\n",
      "Percentage Difference between Post and Pre Attack for DIGITS with KFC/attack_entropy/\n",
      "BALANCE: Percentage Difference = -0.47\n",
      "MIN_CLUSTER_RATIO: Percentage Difference = -0.271\n",
      "CLUSTER_DIST_L1: Percentage Difference = 0.286\n",
      "CLUSTER_DIST_KL: Percentage Difference = inf\n",
      "SILHOUETTE_DIFF: Percentage Difference = 1.788\n",
      "ENTROPY: Percentage Difference = -0.072\n",
      "ENTROPY_GROUP_A: Percentage Difference = 0.022\n",
      "ENTROPY_GROUP_B: Percentage Difference = 0.011\n",
      "ACC: Percentage Difference = 0.003\n",
      "NMI: Percentage Difference = -0.036\n",
      "ARI: Percentage Difference = 0.01\n",
      "SIL: Percentage Difference = 0.898\n",
      "\n",
      "Percentage Difference between Random and Pre Attack for DIGITS with KFC/attack_entropy/\n",
      "BALANCE: Percentage Difference = -0.503\n",
      "MIN_CLUSTER_RATIO: Percentage Difference = -0.33\n",
      "CLUSTER_DIST_L1: Percentage Difference = 0.272\n",
      "CLUSTER_DIST_KL: Percentage Difference = inf\n",
      "SILHOUETTE_DIFF: Percentage Difference = 1.23\n",
      "ENTROPY: Percentage Difference = -0.064\n",
      "ENTROPY_GROUP_A: Percentage Difference = 0.014\n",
      "ENTROPY_GROUP_B: Percentage Difference = 0.003\n",
      "ACC: Percentage Difference = 0.011\n",
      "NMI: Percentage Difference = -0.001\n",
      "ARI: Percentage Difference = 0.026\n",
      "SIL: Percentage Difference = 1.099\n",
      "\n",
      "\n",
      "Pre-Attack Results for Yale with SFD\n",
      "=========================================\n",
      "BALANCE: Mean = 0.0, Std = 0.0\n",
      "MIN_CLUSTER_RATIO: Mean = 0.0, Std = 0.0\n",
      "CLUSTER_DIST_L1: Mean = 0.797, Std = 0.009\n",
      "CLUSTER_DIST_KL: Mean = inf, Std = nan\n",
      "SILHOUETTE_DIFF: Mean = -0.002, Std = 0.005\n",
      "ENTROPY: Mean = 3.969, Std = 0.232\n",
      "ENTROPY_GROUP_A: Mean = 1.788, Std = 0.1\n",
      "ENTROPY_GROUP_B: Mean = 3.505, Std = 0.016\n",
      "ACC: Mean = 0.094, Std = 0.002\n",
      "NMI: Mean = 0.16, Std = 0.003\n",
      "ARI: Mean = 0.007, Std = 0.001\n",
      "SIL: Mean = 0.065, Std = 0.004\n",
      "\n",
      "Post-Attack Results for Yale with SFD\n",
      "=========================================\n",
      "BALANCE: Mean = 0.0, Std = 0.0\n",
      "MIN_CLUSTER_RATIO: Mean = 0.0, Std = 0.0\n",
      "CLUSTER_DIST_L1: Mean = 0.804, Std = 0.014\n",
      "CLUSTER_DIST_KL: Mean = inf, Std = nan\n",
      "SILHOUETTE_DIFF: Mean = -0.008, Std = 0.004\n",
      "ENTROPY: Mean = 3.741, Std = 0.193\n",
      "ENTROPY_GROUP_A: Mean = 1.816, Std = 0.18\n",
      "ENTROPY_GROUP_B: Mean = 3.491, Std = 0.016\n",
      "ACC: Mean = 0.092, Std = 0.005\n",
      "NMI: Mean = 0.16, Std = 0.012\n",
      "ARI: Mean = 0.009, Std = 0.006\n",
      "SIL: Mean = 0.06, Std = 0.004\n",
      "\n",
      "Random-Attack Results for Yale with SFD\n",
      "=========================================\n",
      "BALANCE: Mean = 0.0, Std = 0.0\n",
      "MIN_CLUSTER_RATIO: Mean = 0.0, Std = 0.0\n",
      "CLUSTER_DIST_L1: Mean = 0.779, Std = 0.015\n",
      "CLUSTER_DIST_KL: Mean = inf, Std = nan\n",
      "SILHOUETTE_DIFF: Mean = -0.008, Std = 0.005\n",
      "ENTROPY: Mean = 4.277, Std = 0.394\n",
      "ENTROPY_GROUP_A: Mean = 1.752, Std = 0.166\n",
      "ENTROPY_GROUP_B: Mean = 3.5, Std = 0.014\n",
      "ACC: Mean = 0.094, Std = 0.006\n",
      "NMI: Mean = 0.163, Std = 0.011\n",
      "ARI: Mean = 0.008, Std = 0.006\n",
      "SIL: Mean = 0.061, Std = 0.006\n",
      "\n",
      "Percentage Difference between Post and Pre Attack for Yale with SFD\n",
      "BALANCE: Percentage Difference = nan\n",
      "MIN_CLUSTER_RATIO: Percentage Difference = nan\n",
      "CLUSTER_DIST_L1: Percentage Difference = 0.009\n",
      "CLUSTER_DIST_KL: Percentage Difference = nan\n",
      "SILHOUETTE_DIFF: Percentage Difference = 2.261\n",
      "ENTROPY: Percentage Difference = -0.058\n",
      "ENTROPY_GROUP_A: Percentage Difference = 0.015\n",
      "ENTROPY_GROUP_B: Percentage Difference = -0.004\n",
      "ACC: Percentage Difference = -0.023\n",
      "NMI: Percentage Difference = -0.002\n",
      "ARI: Percentage Difference = 0.259\n",
      "SIL: Percentage Difference = -0.08\n",
      "\n",
      "Percentage Difference between Random and Pre Attack for Yale with SFD\n",
      "BALANCE: Percentage Difference = nan\n",
      "MIN_CLUSTER_RATIO: Percentage Difference = nan\n",
      "CLUSTER_DIST_L1: Percentage Difference = -0.022\n",
      "CLUSTER_DIST_KL: Percentage Difference = nan\n",
      "SILHOUETTE_DIFF: Percentage Difference = 2.274\n",
      "ENTROPY: Percentage Difference = 0.078\n",
      "ENTROPY_GROUP_A: Percentage Difference = -0.02\n",
      "ENTROPY_GROUP_B: Percentage Difference = -0.001\n",
      "ACC: Percentage Difference = -0.004\n",
      "NMI: Percentage Difference = 0.016\n",
      "ARI: Percentage Difference = 0.208\n",
      "SIL: Percentage Difference = -0.064\n",
      "\n",
      "\n",
      "Pre-Attack Results for Yale with FSC\n",
      "=========================================\n",
      "BALANCE: Mean = 0.0, Std = 0.0\n",
      "MIN_CLUSTER_RATIO: Mean = 0.0, Std = 0.0\n",
      "CLUSTER_DIST_L1: Mean = 0.76, Std = 0.025\n",
      "CLUSTER_DIST_KL: Mean = inf, Std = nan\n",
      "SILHOUETTE_DIFF: Mean = 0.004, Std = 0.004\n",
      "ENTROPY: Mean = 3.402, Std = 0.083\n",
      "ENTROPY_GROUP_A: Mean = 2.966, Std = 0.021\n",
      "ENTROPY_GROUP_B: Mean = 2.28, Std = 0.024\n",
      "ACC: Mean = 0.273, Std = 0.002\n",
      "NMI: Mean = 0.367, Std = 0.003\n",
      "ARI: Mean = 0.062, Std = 0.002\n",
      "SIL: Mean = -0.009, Std = 0.012\n",
      "\n",
      "Post-Attack Results for Yale with FSC\n",
      "=========================================\n",
      "BALANCE: Mean = 0.0, Std = 0.0\n",
      "MIN_CLUSTER_RATIO: Mean = 0.0, Std = 0.0\n",
      "CLUSTER_DIST_L1: Mean = 0.744, Std = 0.052\n",
      "CLUSTER_DIST_KL: Mean = inf, Std = nan\n",
      "SILHOUETTE_DIFF: Mean = 0.008, Std = 0.005\n",
      "ENTROPY: Mean = 3.261, Std = 0.071\n",
      "ENTROPY_GROUP_A: Mean = 2.918, Std = 0.087\n",
      "ENTROPY_GROUP_B: Mean = 2.257, Std = 0.032\n",
      "ACC: Mean = 0.274, Std = 0.004\n",
      "NMI: Mean = 0.365, Std = 0.004\n",
      "ARI: Mean = 0.058, Std = 0.007\n",
      "SIL: Mean = -0.02, Std = 0.017\n",
      "\n",
      "Random-Attack Results for Yale with FSC\n",
      "=========================================\n",
      "BALANCE: Mean = 0.0, Std = 0.0\n",
      "MIN_CLUSTER_RATIO: Mean = 0.0, Std = 0.0\n",
      "CLUSTER_DIST_L1: Mean = 0.762, Std = 0.013\n",
      "CLUSTER_DIST_KL: Mean = inf, Std = nan\n",
      "SILHOUETTE_DIFF: Mean = 0.002, Std = 0.005\n",
      "ENTROPY: Mean = 3.405, Std = 0.13\n",
      "ENTROPY_GROUP_A: Mean = 2.984, Std = 0.038\n",
      "ENTROPY_GROUP_B: Mean = 2.272, Std = 0.033\n",
      "ACC: Mean = 0.275, Std = 0.003\n",
      "NMI: Mean = 0.368, Std = 0.004\n",
      "ARI: Mean = 0.062, Std = 0.002\n",
      "SIL: Mean = -0.006, Std = 0.005\n",
      "\n",
      "Percentage Difference between Post and Pre Attack for Yale with FSC\n",
      "BALANCE: Percentage Difference = nan\n",
      "MIN_CLUSTER_RATIO: Percentage Difference = nan\n",
      "CLUSTER_DIST_L1: Percentage Difference = -0.021\n",
      "CLUSTER_DIST_KL: Percentage Difference = nan\n",
      "SILHOUETTE_DIFF: Percentage Difference = 1.089\n",
      "ENTROPY: Percentage Difference = -0.041\n",
      "ENTROPY_GROUP_A: Percentage Difference = -0.016\n",
      "ENTROPY_GROUP_B: Percentage Difference = -0.01\n",
      "ACC: Percentage Difference = 0.002\n",
      "NMI: Percentage Difference = -0.005\n",
      "ARI: Percentage Difference = -0.059\n",
      "SIL: Percentage Difference = 1.181\n",
      "\n",
      "Percentage Difference between Random and Pre Attack for Yale with FSC\n",
      "BALANCE: Percentage Difference = nan\n",
      "MIN_CLUSTER_RATIO: Percentage Difference = nan\n",
      "CLUSTER_DIST_L1: Percentage Difference = 0.002\n",
      "CLUSTER_DIST_KL: Percentage Difference = nan\n",
      "SILHOUETTE_DIFF: Percentage Difference = -0.515\n",
      "ENTROPY: Percentage Difference = 0.001\n",
      "ENTROPY_GROUP_A: Percentage Difference = 0.006\n",
      "ENTROPY_GROUP_B: Percentage Difference = -0.004\n",
      "ACC: Percentage Difference = 0.006\n",
      "NMI: Percentage Difference = 0.002\n",
      "ARI: Percentage Difference = 0.001\n",
      "SIL: Percentage Difference = -0.383\n",
      "\n",
      "\n",
      "Pre-Attack Results for Yale with KFC/attack_entropy/\n",
      "=========================================\n",
      "BALANCE: Mean = 0.789, Std = 0.396\n",
      "MIN_CLUSTER_RATIO: Mean = 0.64, Std = 0.32\n",
      "CLUSTER_DIST_L1: Mean = 0.001, Std = 0.001\n",
      "CLUSTER_DIST_KL: Mean = inf, Std = nan\n",
      "SILHOUETTE_DIFF: ['N/A', 'N/A', 'N/A', -0.042701490107797016, 'N/A', 'N/A', 'N/A', 0.06996285919731153, 0.021689878986012143, 'N/A']\n",
      "ENTROPY: Mean = 0.609, Std = 0.512\n",
      "ENTROPY_GROUP_A: Mean = 0.015, Std = 0.029\n",
      "ENTROPY_GROUP_B: Mean = 0.014, Std = 0.029\n",
      "ACC: Mean = 0.031, Std = 0.002\n",
      "NMI: Mean = 0.004, Std = 0.007\n",
      "ARI: Mean = 0.0, Std = 0.0\n",
      "SIL: ['N/A', 'N/A', 'N/A', 0.21127310362779136, 'N/A', 'N/A', 'N/A', 0.0010177308399879426, 0.08365449463766256, 'N/A']\n",
      "\n",
      "Post-Attack Results for Yale with KFC/attack_entropy/\n",
      "=========================================\n",
      "BALANCE: Mean = 0.845, Std = 0.326\n",
      "MIN_CLUSTER_RATIO: Mean = 0.665, Std = 0.276\n",
      "CLUSTER_DIST_L1: Mean = 0.001, Std = 0.002\n",
      "CLUSTER_DIST_KL: Mean = inf, Std = nan\n",
      "SILHOUETTE_DIFF: ['N/A', 'N/A', 'N/A', 'N/A', 'N/A', 'N/A', 'N/A', 0.09809049688379859, 0.08146708906112898, 'N/A']\n",
      "ENTROPY: Mean = 0.602, Std = 0.517\n",
      "ENTROPY_GROUP_A: Mean = 0.014, Std = 0.03\n",
      "ENTROPY_GROUP_B: Mean = 0.012, Std = 0.023\n",
      "ACC: Mean = 0.031, Std = 0.001\n",
      "NMI: Mean = 0.003, Std = 0.006\n",
      "ARI: Mean = 0.0, Std = 0.0\n",
      "SIL: ['N/A', 'N/A', 'N/A', 'N/A', 'N/A', 'N/A', 'N/A', 0.053139436942885254, -0.03209458680024516, 'N/A']\n",
      "\n",
      "Random-Attack Results for Yale with KFC/attack_entropy/\n",
      "=========================================\n",
      "BALANCE: Mean = 0.86, Std = 0.31\n",
      "MIN_CLUSTER_RATIO: Mean = 0.72, Std = 0.24\n",
      "CLUSTER_DIST_L1: Mean = 0.001, Std = 0.002\n",
      "CLUSTER_DIST_KL: Mean = inf, Std = nan\n",
      "SILHOUETTE_DIFF: ['N/A', 'N/A', 'N/A', 'N/A', 'N/A', 'N/A', 'N/A', 0.005002767687460163, 0.07909460505697534, 'N/A']\n",
      "ENTROPY: Mean = 0.611, Std = 0.536\n",
      "ENTROPY_GROUP_A: Mean = 0.014, Std = 0.03\n",
      "ENTROPY_GROUP_B: Mean = 0.01, Std = 0.02\n",
      "ACC: Mean = 0.031, Std = 0.001\n",
      "NMI: Mean = 0.003, Std = 0.006\n",
      "ARI: Mean = 0.0, Std = 0.0\n",
      "SIL: ['N/A', 'N/A', 'N/A', 'N/A', 'N/A', 'N/A', 'N/A', 0.18719566231833343, -0.034082390636430704, 'N/A']\n",
      "\n",
      "Percentage Difference between Post and Pre Attack for Yale with KFC/attack_entropy/\n",
      "BALANCE: Percentage Difference = 0.071\n",
      "MIN_CLUSTER_RATIO: Percentage Difference = 0.039\n",
      "CLUSTER_DIST_L1: Percentage Difference = 0.423\n",
      "CLUSTER_DIST_KL: Percentage Difference = nan\n",
      "ENTROPY: Percentage Difference = -0.011\n",
      "ENTROPY_GROUP_A: Percentage Difference = -0.053\n",
      "ENTROPY_GROUP_B: Percentage Difference = -0.2\n",
      "ACC: Percentage Difference = -0.004\n",
      "NMI: Percentage Difference = -0.137\n",
      "ARI: Percentage Difference = -0.169\n",
      "\n",
      "Percentage Difference between Random and Pre Attack for Yale with KFC/attack_entropy/\n",
      "BALANCE: Percentage Difference = 0.09\n",
      "MIN_CLUSTER_RATIO: Percentage Difference = 0.125\n",
      "CLUSTER_DIST_L1: Percentage Difference = 0.346\n",
      "CLUSTER_DIST_KL: Percentage Difference = nan\n",
      "ENTROPY: Percentage Difference = 0.005\n",
      "ENTROPY_GROUP_A: Percentage Difference = -0.053\n",
      "ENTROPY_GROUP_B: Percentage Difference = -0.332\n",
      "ACC: Percentage Difference = -0.004\n",
      "NMI: Percentage Difference = -0.176\n",
      "ARI: Percentage Difference = -0.18\n",
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\user\\AppData\\Local\\Temp\\ipykernel_28924\\734513971.py:20: RuntimeWarning: invalid value encountered in scalar divide\n",
      "  perc_diff = (post_mean - pre_mean) / pre_mean\n",
      "C:\\Users\\user\\AppData\\Local\\Temp\\ipykernel_28924\\734513971.py:20: RuntimeWarning: invalid value encountered in scalar subtract\n",
      "  perc_diff = (post_mean - pre_mean) / pre_mean\n",
      "C:\\Users\\user\\AppData\\Local\\Temp\\ipykernel_28924\\734513971.py:31: RuntimeWarning: invalid value encountered in scalar divide\n",
      "  perc_diff = (random_mean - pre_mean) / pre_mean\n",
      "C:\\Users\\user\\AppData\\Local\\Temp\\ipykernel_28924\\734513971.py:31: RuntimeWarning: invalid value encountered in scalar subtract\n",
      "  perc_diff = (random_mean - pre_mean) / pre_mean\n"
     ]
    }
   ],
   "source": [
    "\n",
    "datasets = [\"DIGITS\", \"Yale\"]\n",
    "cl_algo = [\"SFD\", \"FSC\", \"KFC/attack_entropy/\"]\n",
    "for d in datasets: \n",
    "    for cl in cl_algo:\n",
    "        path_name = f\"Fair-Clustering-Codebase/extra_metrics_results/{d}/{cl}/\"\n",
    "        pre_attack_res = pickle.load(open(path_name + \"pre_attack_res.pkl\", \"rb\"))\n",
    "        post_attack_res = pickle.load(open(path_name + \"post_attack_res.pkl\", \"rb\"))\n",
    "        random_attack_res = pickle.load(open(path_name + \"random_attack_res.pkl\", \"rb\"))\n",
    "        print_results(pre_attack_res, \"Pre-Attack\", d, cl)\n",
    "        print_results(post_attack_res, \"Post-Attack\", d, cl)\n",
    "        print_results(random_attack_res, \"Random-Attack\", d, cl)\n",
    "        print(\"\")\n",
    "        # Calculate the percentage difference between post and pre attack\n",
    "        print(f'Percentage Difference between Post and Pre Attack for {d} with {cl}')\n",
    "        for metric in post_attack_res.keys():\n",
    "            if \"N/A\" in post_attack_res[metric]:\n",
    "                continue\n",
    "            post_mean = np.mean(post_attack_res[metric])\n",
    "            pre_mean = np.mean(pre_attack_res[metric])\n",
    "            perc_diff = (post_mean - pre_mean) / pre_mean\n",
    "            perc_diff = round(perc_diff, 3)\n",
    "            print(f'{metric}: Percentage Difference = {perc_diff}')\n",
    "        print(\"\")\n",
    "        # Calculate the percentage difference between random and pre attack\n",
    "        print(f'Percentage Difference between Random and Pre Attack for {d} with {cl}')\n",
    "        for metric in random_attack_res.keys():\n",
    "            if \"N/A\" in random_attack_res[metric]:\n",
    "                continue\n",
    "            random_mean = np.mean(random_attack_res[metric])\n",
    "            pre_mean = np.mean(pre_attack_res[metric])\n",
    "            perc_diff = (random_mean - pre_mean) / pre_mean\n",
    "            perc_diff = round(perc_diff, 3)\n",
    "            print(f'{metric}: Percentage Difference = {perc_diff}')\n",
    "        print(\"\")"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "rbf",
   "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.10.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
