{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 3,
   "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": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "Pre-Attack Results for MTFL with SFD\n",
      "=========================================\n",
      "BALANCE: Mean = 0.971, Std = 0.0\n",
      "MIN_CLUSTER_RATIO: Mean = 1.012, Std = 0.0\n",
      "CLUSTER_DIST_L1: Mean = 0.021, Std = 0.0\n",
      "CLUSTER_DIST_KL: Mean = 0.001, Std = 0.0\n",
      "SILHOUETTE_DIFF: Mean = 0.003, Std = 0.0\n",
      "ENTROPY: Mean = 0.692, Std = 0.0\n",
      "ENTROPY_GROUP_A: Mean = 0.668, Std = 0.0\n",
      "ENTROPY_GROUP_B: Mean = 0.657, Std = 0.0\n",
      "ACC: Mean = 0.529, Std = 0.0\n",
      "NMI: Mean = 0.001, Std = 0.0\n",
      "ARI: Mean = -0.005, Std = 0.0\n",
      "SIL: Mean = 0.139, Std = 0.0\n",
      "\n",
      "Post-Attack Results for MTFL with SFD\n",
      "=========================================\n",
      "BALANCE: Mean = 0.967, Std = 0.0\n",
      "MIN_CLUSTER_RATIO: Mean = 0.989, Std = 0.0\n",
      "CLUSTER_DIST_L1: Mean = 0.03, Std = 0.0\n",
      "CLUSTER_DIST_KL: Mean = 0.002, Std = 0.0\n",
      "SILHOUETTE_DIFF: Mean = 0.008, Std = 0.0\n",
      "ENTROPY: Mean = 0.692, Std = 0.0\n",
      "ENTROPY_GROUP_A: Mean = 0.692, Std = 0.0\n",
      "ENTROPY_GROUP_B: Mean = 0.688, Std = 0.0\n",
      "ACC: Mean = 0.512, Std = 0.0\n",
      "NMI: Mean = 0.0, Std = 0.0\n",
      "ARI: Mean = -0.001, Std = 0.0\n",
      "SIL: Mean = 0.12, Std = 0.0\n",
      "\n",
      "Random-Attack Results for MTFL with SFD\n",
      "=========================================\n",
      "BALANCE: Mean = 0.967, Std = 0.0\n",
      "MIN_CLUSTER_RATIO: Mean = 0.989, Std = 0.0\n",
      "CLUSTER_DIST_L1: Mean = 0.03, Std = 0.0\n",
      "CLUSTER_DIST_KL: Mean = 0.002, Std = 0.0\n",
      "SILHOUETTE_DIFF: Mean = 0.008, Std = 0.0\n",
      "ENTROPY: Mean = 0.692, Std = 0.0\n",
      "ENTROPY_GROUP_A: Mean = 0.692, Std = 0.0\n",
      "ENTROPY_GROUP_B: Mean = 0.688, Std = 0.0\n",
      "ACC: Mean = 0.512, Std = 0.0\n",
      "NMI: Mean = 0.0, Std = 0.0\n",
      "ARI: Mean = -0.001, Std = 0.0\n",
      "SIL: Mean = 0.12, Std = 0.0\n",
      "\n",
      "Percentage Difference between Post and Pre Attack for MTFL with SFD\n",
      "BALANCE: Percentage Difference = -0.005\n",
      "MIN_CLUSTER_RATIO: Percentage Difference = -0.022\n",
      "CLUSTER_DIST_L1: Percentage Difference = 0.418\n",
      "CLUSTER_DIST_KL: Percentage Difference = 0.897\n",
      "SILHOUETTE_DIFF: Percentage Difference = 1.252\n",
      "ENTROPY: Percentage Difference = -0.0\n",
      "ENTROPY_GROUP_A: Percentage Difference = 0.036\n",
      "ENTROPY_GROUP_B: Percentage Difference = 0.047\n",
      "ACC: Percentage Difference = -0.031\n",
      "NMI: Percentage Difference = -0.999\n",
      "ARI: Percentage Difference = -0.862\n",
      "SIL: Percentage Difference = -0.14\n",
      "\n",
      "Percentage Difference between Random and Pre Attack for MTFL with SFD\n",
      "BALANCE: Percentage Difference = -0.005\n",
      "MIN_CLUSTER_RATIO: Percentage Difference = -0.022\n",
      "CLUSTER_DIST_L1: Percentage Difference = 0.418\n",
      "CLUSTER_DIST_KL: Percentage Difference = 0.897\n",
      "SILHOUETTE_DIFF: Percentage Difference = 1.252\n",
      "ENTROPY: Percentage Difference = -0.0\n",
      "ENTROPY_GROUP_A: Percentage Difference = 0.036\n",
      "ENTROPY_GROUP_B: Percentage Difference = 0.047\n",
      "ACC: Percentage Difference = -0.031\n",
      "NMI: Percentage Difference = -0.999\n",
      "ARI: Percentage Difference = -0.862\n",
      "SIL: Percentage Difference = -0.14\n",
      "\n",
      "\n",
      "Pre-Attack Results for MTFL with FSC\n",
      "=========================================\n",
      "BALANCE: Mean = 0.992, Std = 0.0\n",
      "MIN_CLUSTER_RATIO: Mean = 1.031, Std = 0.0\n",
      "CLUSTER_DIST_L1: Mean = 0.006, Std = 0.0\n",
      "CLUSTER_DIST_KL: Mean = 0.0, Std = 0.0\n",
      "SILHOUETTE_DIFF: Mean = 0.001, Std = 0.0\n",
      "ENTROPY: Mean = 0.693, Std = 0.0\n",
      "ENTROPY_GROUP_A: Mean = 0.658, Std = 0.0\n",
      "ENTROPY_GROUP_B: Mean = 0.661, Std = 0.0\n",
      "ACC: Mean = 0.546, Std = 0.0\n",
      "NMI: Mean = 0.0, Std = 0.0\n",
      "ARI: Mean = -0.001, Std = 0.0\n",
      "SIL: Mean = 0.14, Std = 0.0\n",
      "\n",
      "Post-Attack Results for MTFL with FSC\n",
      "=========================================\n",
      "BALANCE: Mean = 0.986, Std = 0.005\n",
      "MIN_CLUSTER_RATIO: Mean = 1.018, Std = 0.01\n",
      "CLUSTER_DIST_L1: Mean = 0.011, Std = 0.004\n",
      "CLUSTER_DIST_KL: Mean = 0.0, Std = 0.0\n",
      "SILHOUETTE_DIFF: Mean = 0.001, Std = 0.0\n",
      "ENTROPY: Mean = 0.693, Std = 0.0\n",
      "ENTROPY_GROUP_A: Mean = 0.662, Std = 0.005\n",
      "ENTROPY_GROUP_B: Mean = 0.667, Std = 0.006\n",
      "ACC: Mean = 0.544, Std = 0.0\n",
      "NMI: Mean = 0.0, Std = 0.0\n",
      "ARI: Mean = -0.0, Std = 0.001\n",
      "SIL: Mean = 0.139, Std = 0.002\n",
      "\n",
      "Random-Attack Results for MTFL with FSC\n",
      "=========================================\n",
      "BALANCE: Mean = 0.991, Std = 0.002\n",
      "MIN_CLUSTER_RATIO: Mean = 1.028, Std = 0.004\n",
      "CLUSTER_DIST_L1: Mean = 0.007, Std = 0.001\n",
      "CLUSTER_DIST_KL: Mean = 0.0, Std = 0.0\n",
      "SILHOUETTE_DIFF: Mean = 0.001, Std = 0.0\n",
      "ENTROPY: Mean = 0.693, Std = 0.0\n",
      "ENTROPY_GROUP_A: Mean = 0.659, Std = 0.0\n",
      "ENTROPY_GROUP_B: Mean = 0.663, Std = 0.001\n",
      "ACC: Mean = 0.546, Std = 0.001\n",
      "NMI: Mean = 0.0, Std = 0.0\n",
      "ARI: Mean = -0.0, Std = 0.0\n",
      "SIL: Mean = 0.14, Std = 0.0\n",
      "\n",
      "Percentage Difference between Post and Pre Attack for MTFL with FSC\n",
      "BALANCE: Percentage Difference = -0.007\n",
      "MIN_CLUSTER_RATIO: Percentage Difference = -0.013\n",
      "CLUSTER_DIST_L1: Percentage Difference = 0.961\n",
      "CLUSTER_DIST_KL: Percentage Difference = 3.365\n",
      "SILHOUETTE_DIFF: Percentage Difference = 0.648\n",
      "ENTROPY: Percentage Difference = -0.0\n",
      "ENTROPY_GROUP_A: Percentage Difference = 0.006\n",
      "ENTROPY_GROUP_B: Percentage Difference = 0.009\n",
      "ACC: Percentage Difference = -0.003\n",
      "NMI: Percentage Difference = 54.584\n",
      "ARI: Percentage Difference = -0.797\n",
      "SIL: Percentage Difference = -0.009\n",
      "\n",
      "Percentage Difference between Random and Pre Attack for MTFL with FSC\n",
      "BALANCE: Percentage Difference = -0.002\n",
      "MIN_CLUSTER_RATIO: Percentage Difference = -0.004\n",
      "CLUSTER_DIST_L1: Percentage Difference = 0.252\n",
      "CLUSTER_DIST_KL: Percentage Difference = 0.626\n",
      "SILHOUETTE_DIFF: Percentage Difference = 0.282\n",
      "ENTROPY: Percentage Difference = -0.0\n",
      "ENTROPY_GROUP_A: Percentage Difference = 0.001\n",
      "ENTROPY_GROUP_B: Percentage Difference = 0.002\n",
      "ACC: Percentage Difference = -0.0\n",
      "NMI: Percentage Difference = 0.262\n",
      "ARI: Percentage Difference = -0.386\n",
      "SIL: Percentage Difference = -0.001\n",
      "\n",
      "\n",
      "Pre-Attack Results for MTFL with KFC\n",
      "=========================================\n",
      "BALANCE: Mean = 0.87, Std = 0.143\n",
      "MIN_CLUSTER_RATIO: Mean = 0.851, Std = 0.215\n",
      "CLUSTER_DIST_L1: Mean = 0.01, Std = 0.013\n",
      "CLUSTER_DIST_KL: Mean = 0.002, Std = 0.003\n",
      "SILHOUETTE_DIFF: Mean = 0.003, Std = 0.002\n",
      "ENTROPY: Mean = 0.684, Std = 0.019\n",
      "ENTROPY_GROUP_A: Mean = 0.142, Std = 0.088\n",
      "ENTROPY_GROUP_B: Mean = 0.166, Std = 0.114\n",
      "ACC: Mean = 0.669, Std = 0.011\n",
      "NMI: Mean = 0.0, Std = 0.001\n",
      "ARI: Mean = -0.001, Std = 0.005\n",
      "SIL: Mean = 0.122, Std = 0.043\n",
      "\n",
      "Post-Attack Results for MTFL with KFC\n",
      "=========================================\n",
      "BALANCE: Mean = 0.778, Std = 0.108\n",
      "MIN_CLUSTER_RATIO: Mean = 0.734, Std = 0.199\n",
      "CLUSTER_DIST_L1: Mean = 0.015, Std = 0.012\n",
      "CLUSTER_DIST_KL: Mean = 0.003, Std = 0.003\n",
      "SILHOUETTE_DIFF: Mean = 0.004, Std = 0.002\n",
      "ENTROPY: Mean = 0.678, Std = 0.018\n",
      "ENTROPY_GROUP_A: Mean = 0.134, Std = 0.085\n",
      "ENTROPY_GROUP_B: Mean = 0.167, Std = 0.112\n",
      "ACC: Mean = 0.67, Std = 0.011\n",
      "NMI: Mean = 0.0, Std = 0.0\n",
      "ARI: Mean = -0.0, Std = 0.004\n",
      "SIL: Mean = 0.126, Std = 0.046\n",
      "\n",
      "Random-Attack Results for MTFL with KFC\n",
      "=========================================\n",
      "BALANCE: Mean = 0.826, Std = 0.127\n",
      "MIN_CLUSTER_RATIO: Mean = 0.806, Std = 0.206\n",
      "CLUSTER_DIST_L1: Mean = 0.012, Std = 0.012\n",
      "CLUSTER_DIST_KL: Mean = 0.002, Std = 0.003\n",
      "SILHOUETTE_DIFF: Mean = 0.003, Std = 0.002\n",
      "ENTROPY: Mean = 0.682, Std = 0.018\n",
      "ENTROPY_GROUP_A: Mean = 0.141, Std = 0.087\n",
      "ENTROPY_GROUP_B: Mean = 0.167, Std = 0.113\n",
      "ACC: Mean = 0.668, Std = 0.012\n",
      "NMI: Mean = 0.0, Std = 0.0\n",
      "ARI: Mean = -0.003, Std = 0.002\n",
      "SIL: Mean = 0.124, Std = 0.046\n",
      "\n",
      "Percentage Difference between Post and Pre Attack for MTFL with KFC\n",
      "BALANCE: Percentage Difference = -0.105\n",
      "MIN_CLUSTER_RATIO: Percentage Difference = -0.137\n",
      "CLUSTER_DIST_L1: Percentage Difference = 0.4\n",
      "CLUSTER_DIST_KL: Percentage Difference = 0.572\n",
      "SILHOUETTE_DIFF: Percentage Difference = 0.065\n",
      "ENTROPY: Percentage Difference = -0.008\n",
      "ENTROPY_GROUP_A: Percentage Difference = -0.054\n",
      "ENTROPY_GROUP_B: Percentage Difference = 0.001\n",
      "ACC: Percentage Difference = 0.001\n",
      "NMI: Percentage Difference = -0.334\n",
      "ARI: Percentage Difference = -0.553\n",
      "SIL: Percentage Difference = 0.031\n",
      "\n",
      "Percentage Difference between Random and Pre Attack for MTFL with KFC\n",
      "BALANCE: Percentage Difference = -0.05\n",
      "MIN_CLUSTER_RATIO: Percentage Difference = -0.053\n",
      "CLUSTER_DIST_L1: Percentage Difference = 0.187\n",
      "CLUSTER_DIST_KL: Percentage Difference = 0.184\n",
      "SILHOUETTE_DIFF: Percentage Difference = 0.017\n",
      "ENTROPY: Percentage Difference = -0.003\n",
      "ENTROPY_GROUP_A: Percentage Difference = -0.003\n",
      "ENTROPY_GROUP_B: Percentage Difference = 0.004\n",
      "ACC: Percentage Difference = -0.002\n",
      "NMI: Percentage Difference = -0.32\n",
      "ARI: Percentage Difference = 2.981\n",
      "SIL: Percentage Difference = 0.011\n",
      "\n",
      "\n",
      "Pre-Attack Results for Yale_alter with SFD\n",
      "=========================================\n",
      "BALANCE: Mean = 0.115, Std = 0.116\n",
      "MIN_CLUSTER_RATIO: Mean = 0.058, Std = 0.059\n",
      "CLUSTER_DIST_L1: Mean = 0.248, Std = 0.005\n",
      "CLUSTER_DIST_KL: Mean = 0.194, Std = 0.01\n",
      "SILHOUETTE_DIFF: Mean = -0.003, Std = 0.002\n",
      "ENTROPY: Mean = 12.007, Std = 0.194\n",
      "ENTROPY_GROUP_A: Mean = 3.234, Std = 0.015\n",
      "ENTROPY_GROUP_B: Mean = 3.348, Std = 0.005\n",
      "ACC: Mean = 0.404, Std = 0.003\n",
      "NMI: Mean = 0.693, Std = 0.002\n",
      "ARI: Mean = 0.293, Std = 0.001\n",
      "SIL: Mean = 0.145, Std = 0.005\n",
      "\n",
      "Post-Attack Results for Yale_alter with SFD\n",
      "=========================================\n",
      "BALANCE: Mean = 0.031, Std = 0.039\n",
      "MIN_CLUSTER_RATIO: Mean = 0.035, Std = 0.05\n",
      "CLUSTER_DIST_L1: Mean = 0.346, Std = 0.053\n",
      "CLUSTER_DIST_KL: Mean = 0.623, Std = 0.262\n",
      "SILHOUETTE_DIFF: Mean = -0.002, Std = 0.004\n",
      "ENTROPY: Mean = 11.675, Std = 0.195\n",
      "ENTROPY_GROUP_A: Mean = 3.184, Std = 0.022\n",
      "ENTROPY_GROUP_B: Mean = 3.357, Std = 0.011\n",
      "ACC: Mean = 0.412, Std = 0.008\n",
      "NMI: Mean = 0.687, Std = 0.005\n",
      "ARI: Mean = 0.303, Std = 0.01\n",
      "SIL: Mean = 0.162, Std = 0.009\n",
      "\n",
      "Random-Attack Results for Yale_alter with SFD\n",
      "=========================================\n",
      "BALANCE: Mean = 0.074, Std = 0.101\n",
      "MIN_CLUSTER_RATIO: Mean = 0.04, Std = 0.051\n",
      "CLUSTER_DIST_L1: Mean = 0.277, Std = 0.053\n",
      "CLUSTER_DIST_KL: Mean = 0.322, Std = 0.238\n",
      "SILHOUETTE_DIFF: Mean = -0.001, Std = 0.003\n",
      "ENTROPY: Mean = 11.908, Std = 0.222\n",
      "ENTROPY_GROUP_A: Mean = 3.215, Std = 0.036\n",
      "ENTROPY_GROUP_B: Mean = 3.358, Std = 0.013\n",
      "ACC: Mean = 0.418, Std = 0.011\n",
      "NMI: Mean = 0.696, Std = 0.007\n",
      "ARI: Mean = 0.3, Std = 0.008\n",
      "SIL: Mean = 0.154, Std = 0.008\n",
      "\n",
      "Percentage Difference between Post and Pre Attack for Yale_alter with SFD\n",
      "BALANCE: Percentage Difference = -0.735\n",
      "MIN_CLUSTER_RATIO: Percentage Difference = -0.398\n",
      "CLUSTER_DIST_L1: Percentage Difference = 0.397\n",
      "CLUSTER_DIST_KL: Percentage Difference = 2.21\n",
      "SILHOUETTE_DIFF: Percentage Difference = -0.428\n",
      "ENTROPY: Percentage Difference = -0.028\n",
      "ENTROPY_GROUP_A: Percentage Difference = -0.016\n",
      "ENTROPY_GROUP_B: Percentage Difference = 0.003\n",
      "ACC: Percentage Difference = 0.021\n",
      "NMI: Percentage Difference = -0.008\n",
      "ARI: Percentage Difference = 0.032\n",
      "SIL: Percentage Difference = 0.118\n",
      "\n",
      "Percentage Difference between Random and Pre Attack for Yale_alter with SFD\n",
      "BALANCE: Percentage Difference = -0.362\n",
      "MIN_CLUSTER_RATIO: Percentage Difference = -0.308\n",
      "CLUSTER_DIST_L1: Percentage Difference = 0.118\n",
      "CLUSTER_DIST_KL: Percentage Difference = 0.657\n",
      "SILHOUETTE_DIFF: Percentage Difference = -0.749\n",
      "ENTROPY: Percentage Difference = -0.008\n",
      "ENTROPY_GROUP_A: Percentage Difference = -0.006\n",
      "ENTROPY_GROUP_B: Percentage Difference = 0.003\n",
      "ACC: Percentage Difference = 0.034\n",
      "NMI: Percentage Difference = 0.005\n",
      "ARI: Percentage Difference = 0.025\n",
      "SIL: Percentage Difference = 0.064\n",
      "\n",
      "\n",
      "Pre-Attack Results for Yale_alter with FSC\n",
      "=========================================\n",
      "BALANCE: Mean = 0.0, Std = 0.0\n",
      "MIN_CLUSTER_RATIO: Mean = 0.03, Std = 0.004\n",
      "CLUSTER_DIST_L1: Mean = 0.271, Std = 0.002\n",
      "CLUSTER_DIST_KL: Mean = inf, Std = nan\n",
      "SILHOUETTE_DIFF: Mean = 0.054, Std = 0.0\n",
      "ENTROPY: Mean = 11.106, Std = 0.03\n",
      "ENTROPY_GROUP_A: Mean = 3.467, Std = 0.001\n",
      "ENTROPY_GROUP_B: Mean = 3.348, Std = 0.003\n",
      "ACC: Mean = 0.769, Std = 0.001\n",
      "NMI: Mean = 0.88, Std = 0.0\n",
      "ARI: Mean = 0.654, Std = 0.001\n",
      "SIL: Mean = 0.136, Std = 0.0\n",
      "\n",
      "Post-Attack Results for Yale_alter with FSC\n",
      "=========================================\n",
      "BALANCE: Mean = 0.0, Std = 0.0\n",
      "MIN_CLUSTER_RATIO: Mean = 0.03, Std = 0.004\n",
      "CLUSTER_DIST_L1: Mean = 0.272, Std = 0.003\n",
      "CLUSTER_DIST_KL: Mean = inf, Std = nan\n",
      "SILHOUETTE_DIFF: Mean = 0.054, Std = 0.0\n",
      "ENTROPY: Mean = 11.066, Std = 0.016\n",
      "ENTROPY_GROUP_A: Mean = 3.467, Std = 0.001\n",
      "ENTROPY_GROUP_B: Mean = 3.344, Std = 0.002\n",
      "ACC: Mean = 0.769, Std = 0.001\n",
      "NMI: Mean = 0.879, Std = 0.0\n",
      "ARI: Mean = 0.653, Std = 0.001\n",
      "SIL: Mean = 0.137, Std = 0.0\n",
      "\n",
      "Random-Attack Results for Yale_alter with FSC\n",
      "=========================================\n",
      "BALANCE: Mean = 0.0, Std = 0.0\n",
      "MIN_CLUSTER_RATIO: Mean = 0.029, Std = 0.003\n",
      "CLUSTER_DIST_L1: Mean = 0.271, Std = 0.002\n",
      "CLUSTER_DIST_KL: Mean = inf, Std = nan\n",
      "SILHOUETTE_DIFF: Mean = 0.054, Std = 0.0\n",
      "ENTROPY: Mean = 11.132, Std = 0.058\n",
      "ENTROPY_GROUP_A: Mean = 3.469, Std = 0.002\n",
      "ENTROPY_GROUP_B: Mean = 3.345, Std = 0.002\n",
      "ACC: Mean = 0.768, Std = 0.0\n",
      "NMI: Mean = 0.88, Std = 0.0\n",
      "ARI: Mean = 0.653, Std = 0.001\n",
      "SIL: Mean = 0.137, Std = 0.0\n",
      "\n",
      "Percentage Difference between Post and Pre Attack for Yale_alter with FSC\n",
      "BALANCE: Percentage Difference = nan\n",
      "MIN_CLUSTER_RATIO: Percentage Difference = -0.017\n",
      "CLUSTER_DIST_L1: Percentage Difference = 0.007\n",
      "CLUSTER_DIST_KL: Percentage Difference = nan\n",
      "SILHOUETTE_DIFF: Percentage Difference = 0.004\n",
      "ENTROPY: Percentage Difference = -0.004\n",
      "ENTROPY_GROUP_A: Percentage Difference = -0.0\n",
      "ENTROPY_GROUP_B: Percentage Difference = -0.001\n",
      "ACC: Percentage Difference = -0.0\n",
      "NMI: Percentage Difference = -0.0\n",
      "ARI: Percentage Difference = -0.001\n",
      "SIL: Percentage Difference = 0.001\n",
      "\n",
      "Percentage Difference between Random and Pre Attack for Yale_alter with FSC\n",
      "BALANCE: Percentage Difference = nan\n",
      "MIN_CLUSTER_RATIO: Percentage Difference = -0.05\n",
      "CLUSTER_DIST_L1: Percentage Difference = -0.0\n",
      "CLUSTER_DIST_KL: Percentage Difference = nan\n",
      "SILHOUETTE_DIFF: Percentage Difference = 0.004\n",
      "ENTROPY: Percentage Difference = 0.002\n",
      "ENTROPY_GROUP_A: Percentage Difference = 0.001\n",
      "ENTROPY_GROUP_B: Percentage Difference = -0.001\n",
      "ACC: Percentage Difference = -0.001\n",
      "NMI: Percentage Difference = -0.0\n",
      "ARI: Percentage Difference = -0.001\n",
      "SIL: Percentage Difference = 0.0\n",
      "\n",
      "\n",
      "Pre-Attack Results for Yale_alter with KFC\n",
      "=========================================\n",
      "BALANCE: Mean = 0.774, Std = 0.295\n",
      "MIN_CLUSTER_RATIO: Mean = 0.603, Std = 0.266\n",
      "CLUSTER_DIST_L1: Mean = 0.001, Std = 0.001\n",
      "CLUSTER_DIST_KL: Mean = 0.0, Std = 0.001\n",
      "SILHOUETTE_DIFF: [-0.04271801308672463, -0.025668523933025947, -0.05983519371352697, 'N/A', 'N/A', -0.04276074563845056, 'N/A', -0.04331195161167166, -0.04840501434335176, 'N/A']\n",
      "ENTROPY: Mean = 0.503, Std = 0.16\n",
      "ENTROPY_GROUP_A: Mean = 0.007, Std = 0.01\n",
      "ENTROPY_GROUP_B: Mean = 0.012, Std = 0.013\n",
      "ACC: Mean = 0.032, Std = 0.001\n",
      "NMI: Mean = 0.002, Std = 0.002\n",
      "ARI: Mean = -0.0, Std = 0.0\n",
      "SIL: [0.2800396942208054, 0.26369668989976863, 0.41394602194126723, 'N/A', 'N/A', 0.31459157056068926, 'N/A', 0.22598682987699129, 0.3240088942805181, 'N/A']\n",
      "\n",
      "Post-Attack Results for Yale_alter with KFC\n",
      "=========================================\n",
      "BALANCE: Mean = 0.728, Std = 0.379\n",
      "MIN_CLUSTER_RATIO: Mean = 0.57, Std = 0.314\n",
      "CLUSTER_DIST_L1: Mean = 0.001, Std = 0.001\n",
      "CLUSTER_DIST_KL: Mean = 0.0, Std = 0.0\n",
      "SILHOUETTE_DIFF: ['N/A', -0.04103959730718265, -0.04118740212626257, 'N/A', 'N/A', -0.04103959730718265, 'N/A', -0.041501251264867825, -0.05259708195446164, 'N/A']\n",
      "ENTROPY: Mean = 0.441, Std = 0.147\n",
      "ENTROPY_GROUP_A: Mean = 0.005, Std = 0.01\n",
      "ENTROPY_GROUP_B: Mean = 0.009, Std = 0.013\n",
      "ACC: Mean = 0.032, Std = 0.001\n",
      "NMI: Mean = 0.001, Std = 0.002\n",
      "ARI: Mean = 0.0, Std = 0.0\n",
      "SIL: ['N/A', 0.42259574744414524, 0.3250435809660701, 'N/A', 'N/A', 0.42259574744414524, 'N/A', 0.23925499246857904, 0.3361361396890258, 'N/A']\n",
      "\n",
      "Random-Attack Results for Yale_alter with KFC\n",
      "=========================================\n",
      "BALANCE: Mean = 0.745, Std = 0.383\n",
      "MIN_CLUSTER_RATIO: Mean = 0.602, Std = 0.322\n",
      "CLUSTER_DIST_L1: Mean = 0.001, Std = 0.001\n",
      "CLUSTER_DIST_KL: Mean = 0.0, Std = 0.001\n",
      "SILHOUETTE_DIFF: ['N/A', -0.025668523933025947, -0.05720006967678479, 'N/A', 'N/A', -0.028899111618286302, 'N/A', -0.04269702884638715, -0.05983519371352697, 'N/A']\n",
      "ENTROPY: Mean = 0.444, Std = 0.152\n",
      "ENTROPY_GROUP_A: Mean = 0.005, Std = 0.01\n",
      "ENTROPY_GROUP_B: Mean = 0.01, Std = 0.013\n",
      "ACC: Mean = 0.032, Std = 0.001\n",
      "NMI: Mean = 0.002, Std = 0.002\n",
      "ARI: Mean = -0.0, Std = 0.0\n",
      "SIL: ['N/A', 0.26369668989976863, 0.33488313704073347, 'N/A', 'N/A', 0.256876725508874, 'N/A', 0.22845771678477336, 0.41394602194126723, 'N/A']\n",
      "\n",
      "Percentage Difference between Post and Pre Attack for Yale_alter with KFC\n",
      "BALANCE: Percentage Difference = -0.059\n",
      "MIN_CLUSTER_RATIO: Percentage Difference = -0.055\n",
      "CLUSTER_DIST_L1: Percentage Difference = -0.259\n",
      "CLUSTER_DIST_KL: Percentage Difference = -0.207\n",
      "ENTROPY: Percentage Difference = -0.125\n",
      "ENTROPY_GROUP_A: Percentage Difference = -0.275\n",
      "ENTROPY_GROUP_B: Percentage Difference = -0.238\n",
      "ACC: Percentage Difference = -0.006\n",
      "NMI: Percentage Difference = -0.255\n",
      "ARI: Percentage Difference = -2.386\n",
      "\n",
      "Percentage Difference between Random and Pre Attack for Yale_alter with KFC\n",
      "BALANCE: Percentage Difference = -0.038\n",
      "MIN_CLUSTER_RATIO: Percentage Difference = -0.001\n",
      "CLUSTER_DIST_L1: Percentage Difference = -0.075\n",
      "CLUSTER_DIST_KL: Percentage Difference = 0.327\n",
      "ENTROPY: Percentage Difference = -0.119\n",
      "ENTROPY_GROUP_A: Percentage Difference = -0.275\n",
      "ENTROPY_GROUP_B: Percentage Difference = -0.18\n",
      "ACC: Percentage Difference = -0.006\n",
      "NMI: Percentage Difference = -0.215\n",
      "ARI: Percentage Difference = -0.931\n",
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "c:\\Users\\user\\.conda\\envs\\nlp1-practical1\\lib\\site-packages\\numpy\\core\\_methods.py:173: RuntimeWarning: invalid value encountered in subtract\n",
      "  x = asanyarray(arr - arrmean)\n",
      "C:\\Users\\user\\AppData\\Local\\Temp\\ipykernel_17800\\2706933443.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_17800\\2706933443.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_17800\\2706933443.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_17800\\2706933443.py:31: RuntimeWarning: invalid value encountered in scalar subtract\n",
      "  perc_diff = (random_mean - pre_mean) / pre_mean\n"
     ]
    }
   ],
   "source": [
    "\n",
    "datasets = [\"MTFL\", \"Yale_alter\"]\n",
    "cl_algo = [\"SFD\", \"FSC\", \"KFC\"]\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
}
