{
 "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": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "Pre-Attack Results for Office-31 with SFD\n",
      "=========================================\n",
      "BALANCE: Mean = 0.546, Std = 0.025\n",
      "MIN_CLUSTER_RATIO: Mean = 0.269, Std = 0.015\n",
      "CLUSTER_DIST_L1: Mean = 0.17, Std = 0.008\n",
      "CLUSTER_DIST_KL: Mean = 0.082, Std = 0.006\n",
      "SILHOUETTE_DIFF: Mean = -0.006, Std = 0.001\n",
      "ENTROPY: Mean = 10.09, Std = 0.025\n",
      "ENTROPY_GROUP_A: Mean = 3.363, Std = 0.002\n",
      "ENTROPY_GROUP_B: Mean = 3.353, Std = 0.005\n",
      "ACC: Mean = 0.841, Std = 0.004\n",
      "NMI: Mean = 0.888, Std = 0.003\n",
      "ARI: Mean = 0.752, Std = 0.009\n",
      "SIL: Mean = 0.172, Std = 0.002\n",
      "\n",
      "Post-Attack Results for Office-31 with SFD\n",
      "=========================================\n",
      "BALANCE: Mean = 0.158, Std = 0.021\n",
      "MIN_CLUSTER_RATIO: Mean = 0.065, Std = 0.01\n",
      "CLUSTER_DIST_L1: Mean = 0.18, Std = 0.006\n",
      "CLUSTER_DIST_KL: Mean = 0.1, Std = 0.005\n",
      "SILHOUETTE_DIFF: Mean = -0.008, Std = 0.002\n",
      "ENTROPY: Mean = 9.783, Std = 0.07\n",
      "ENTROPY_GROUP_A: Mean = 3.292, Std = 0.014\n",
      "ENTROPY_GROUP_B: Mean = 3.357, Std = 0.008\n",
      "ACC: Mean = 0.765, Std = 0.018\n",
      "NMI: Mean = 0.861, Std = 0.009\n",
      "ARI: Mean = 0.687, Std = 0.022\n",
      "SIL: Mean = 0.158, Std = 0.005\n",
      "\n",
      "Random-Attack Results for Office-31 with SFD\n",
      "=========================================\n",
      "BALANCE: Mean = 0.307, Std = 0.122\n",
      "MIN_CLUSTER_RATIO: Mean = 0.138, Std = 0.065\n",
      "CLUSTER_DIST_L1: Mean = 0.178, Std = 0.011\n",
      "CLUSTER_DIST_KL: Mean = 0.098, Std = 0.008\n",
      "SILHOUETTE_DIFF: Mean = -0.008, Std = 0.002\n",
      "ENTROPY: Mean = 9.862, Std = 0.087\n",
      "ENTROPY_GROUP_A: Mean = 3.305, Std = 0.024\n",
      "ENTROPY_GROUP_B: Mean = 3.354, Std = 0.01\n",
      "ACC: Mean = 0.764, Std = 0.02\n",
      "NMI: Mean = 0.857, Std = 0.007\n",
      "ARI: Mean = 0.683, Std = 0.019\n",
      "SIL: Mean = 0.159, Std = 0.004\n",
      "\n",
      "Percentage Difference between Post and Pre Attack for Office-31 with SFD\n",
      "BALANCE: Percentage Difference = -0.711\n",
      "MIN_CLUSTER_RATIO: Percentage Difference = -0.757\n",
      "CLUSTER_DIST_L1: Percentage Difference = 0.061\n",
      "CLUSTER_DIST_KL: Percentage Difference = 0.228\n",
      "SILHOUETTE_DIFF: Percentage Difference = 0.307\n",
      "ENTROPY: Percentage Difference = -0.03\n",
      "ENTROPY_GROUP_A: Percentage Difference = -0.021\n",
      "ENTROPY_GROUP_B: Percentage Difference = 0.001\n",
      "ACC: Percentage Difference = -0.09\n",
      "NMI: Percentage Difference = -0.029\n",
      "ARI: Percentage Difference = -0.087\n",
      "SIL: Percentage Difference = -0.081\n",
      "\n",
      "Percentage Difference between Random and Pre Attack for Office-31 with SFD\n",
      "BALANCE: Percentage Difference = -0.439\n",
      "MIN_CLUSTER_RATIO: Percentage Difference = -0.486\n",
      "CLUSTER_DIST_L1: Percentage Difference = 0.047\n",
      "CLUSTER_DIST_KL: Percentage Difference = 0.194\n",
      "SILHOUETTE_DIFF: Percentage Difference = 0.206\n",
      "ENTROPY: Percentage Difference = -0.023\n",
      "ENTROPY_GROUP_A: Percentage Difference = -0.017\n",
      "ENTROPY_GROUP_B: Percentage Difference = 0.0\n",
      "ACC: Percentage Difference = -0.091\n",
      "NMI: Percentage Difference = -0.034\n",
      "ARI: Percentage Difference = -0.092\n",
      "SIL: Percentage Difference = -0.072\n",
      "\n",
      "\n",
      "Pre-Attack Results for Office-31 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.112, Std = 0.01\n",
      "CLUSTER_DIST_KL: Mean = 0.069, Std = 0.004\n",
      "SILHOUETTE_DIFF: Mean = -0.009, Std = 0.002\n",
      "ENTROPY: Mean = 9.243, Std = 0.035\n",
      "ENTROPY_GROUP_A: Mean = 2.299, Std = 0.037\n",
      "ENTROPY_GROUP_B: Mean = 2.385, Std = 0.047\n",
      "ACC: Mean = 0.389, Std = 0.016\n",
      "NMI: Mean = 0.659, Std = 0.009\n",
      "ARI: Mean = 0.207, Std = 0.008\n",
      "SIL: Mean = 0.002, Std = 0.004\n",
      "\n",
      "Post-Attack Results for Office-31 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.117, Std = 0.014\n",
      "CLUSTER_DIST_KL: Mean = 0.064, Std = 0.008\n",
      "SILHOUETTE_DIFF: Mean = -0.004, Std = 0.008\n",
      "ENTROPY: Mean = 9.311, Std = 0.18\n",
      "ENTROPY_GROUP_A: Mean = 2.489, Std = 0.091\n",
      "ENTROPY_GROUP_B: Mean = 2.542, Std = 0.11\n",
      "ACC: Mean = 0.437, Std = 0.021\n",
      "NMI: Mean = 0.681, Std = 0.02\n",
      "ARI: Mean = 0.223, Std = 0.033\n",
      "SIL: Mean = 0.021, Std = 0.013\n",
      "\n",
      "Random-Attack Results for Office-31 with FSC\n",
      "=========================================\n",
      "BALANCE: Mean = 0.125, Std = 0.19\n",
      "MIN_CLUSTER_RATIO: Mean = 0.06, Std = 0.092\n",
      "CLUSTER_DIST_L1: Mean = 0.113, Std = 0.015\n",
      "CLUSTER_DIST_KL: Mean = 0.058, Std = 0.009\n",
      "SILHOUETTE_DIFF: Mean = -0.007, Std = 0.007\n",
      "ENTROPY: Mean = 9.433, Std = 0.239\n",
      "ENTROPY_GROUP_A: Mean = 2.471, Std = 0.103\n",
      "ENTROPY_GROUP_B: Mean = 2.569, Std = 0.094\n",
      "ACC: Mean = 0.425, Std = 0.027\n",
      "NMI: Mean = 0.682, Std = 0.02\n",
      "ARI: Mean = 0.235, Std = 0.029\n",
      "SIL: Mean = 0.018, Std = 0.01\n",
      "\n",
      "Percentage Difference between Post and Pre Attack for Office-31 with FSC\n",
      "BALANCE: Percentage Difference = nan\n",
      "MIN_CLUSTER_RATIO: Percentage Difference = nan\n",
      "CLUSTER_DIST_L1: Percentage Difference = 0.047\n",
      "CLUSTER_DIST_KL: Percentage Difference = -0.069\n",
      "SILHOUETTE_DIFF: Percentage Difference = -0.615\n",
      "ENTROPY: Percentage Difference = 0.007\n",
      "ENTROPY_GROUP_A: Percentage Difference = 0.083\n",
      "ENTROPY_GROUP_B: Percentage Difference = 0.066\n",
      "ACC: Percentage Difference = 0.123\n",
      "NMI: Percentage Difference = 0.034\n",
      "ARI: Percentage Difference = 0.079\n",
      "SIL: Percentage Difference = 8.176\n",
      "\n",
      "Percentage Difference between Random and Pre Attack for Office-31 with FSC\n",
      "BALANCE: Percentage Difference = inf\n",
      "MIN_CLUSTER_RATIO: Percentage Difference = inf\n",
      "CLUSTER_DIST_L1: Percentage Difference = 0.009\n",
      "CLUSTER_DIST_KL: Percentage Difference = -0.161\n",
      "SILHOUETTE_DIFF: Percentage Difference = -0.23\n",
      "ENTROPY: Percentage Difference = 0.021\n",
      "ENTROPY_GROUP_A: Percentage Difference = 0.075\n",
      "ENTROPY_GROUP_B: Percentage Difference = 0.078\n",
      "ACC: Percentage Difference = 0.093\n",
      "NMI: Percentage Difference = 0.035\n",
      "ARI: Percentage Difference = 0.136\n",
      "SIL: Percentage Difference = 6.992\n",
      "\n",
      "\n",
      "Pre-Attack Results for Office-31 with KFC/attack_balance/\n",
      "=========================================\n",
      "BALANCE: Mean = 0.971, Std = 0.068\n",
      "MIN_CLUSTER_RATIO: Mean = 0.626, Std = 0.018\n",
      "CLUSTER_DIST_L1: Mean = 0.0, Std = 0.0\n",
      "CLUSTER_DIST_KL: Mean = 0.0, Std = 0.0\n",
      "SILHOUETTE_DIFF: ['N/A', 'N/A', 'N/A', 0.0020763326374944047, 'N/A', 'N/A', 'N/A', -0.0005099777737818528, 'N/A', 'N/A']\n",
      "ENTROPY: Mean = 0.401, Std = 0.135\n",
      "ENTROPY_GROUP_A: Mean = 0.007, Std = 0.015\n",
      "ENTROPY_GROUP_B: Mean = 0.007, Std = 0.017\n",
      "ACC: Mean = 0.05, Std = 0.001\n",
      "NMI: Mean = 0.001, Std = 0.003\n",
      "ARI: Mean = 0.0, Std = 0.0\n",
      "SIL: ['N/A', 'N/A', 'N/A', 0.13810820086061593, 'N/A', 'N/A', 'N/A', 0.08857550114396506, 'N/A', 'N/A']\n",
      "\n",
      "Post-Attack Results for Office-31 with KFC/attack_balance/\n",
      "=========================================\n",
      "BALANCE: Mean = 0.971, Std = 0.068\n",
      "MIN_CLUSTER_RATIO: Mean = 0.626, Std = 0.018\n",
      "CLUSTER_DIST_L1: Mean = 0.0, Std = 0.0\n",
      "CLUSTER_DIST_KL: Mean = 0.0, Std = 0.0\n",
      "SILHOUETTE_DIFF: ['N/A', 'N/A', 'N/A', 0.0020763326374944047, 'N/A', 'N/A', 'N/A', -0.0002200015829245741, 'N/A', 'N/A']\n",
      "ENTROPY: Mean = 0.401, Std = 0.135\n",
      "ENTROPY_GROUP_A: Mean = 0.007, Std = 0.015\n",
      "ENTROPY_GROUP_B: Mean = 0.007, Std = 0.017\n",
      "ACC: Mean = 0.05, Std = 0.001\n",
      "NMI: Mean = 0.001, Std = 0.003\n",
      "ARI: Mean = 0.0, Std = 0.0\n",
      "SIL: ['N/A', 'N/A', 'N/A', 0.13810820086061593, 'N/A', 'N/A', 'N/A', 0.09325276817481463, 'N/A', 'N/A']\n",
      "\n",
      "Random-Attack Results for Office-31 with KFC/attack_balance/\n",
      "=========================================\n",
      "BALANCE: Mean = 0.955, Std = 0.09\n",
      "MIN_CLUSTER_RATIO: Mean = 0.612, Std = 0.061\n",
      "CLUSTER_DIST_L1: Mean = 0.0, Std = 0.001\n",
      "CLUSTER_DIST_KL: Mean = 0.0, Std = 0.0\n",
      "SILHOUETTE_DIFF: ['N/A', 'N/A', 'N/A', 0.0020763326374944047, 'N/A', 'N/A', 'N/A', -0.00028441953927356434, 'N/A', 'N/A']\n",
      "ENTROPY: Mean = 0.399, Std = 0.131\n",
      "ENTROPY_GROUP_A: Mean = 0.006, Std = 0.012\n",
      "ENTROPY_GROUP_B: Mean = 0.007, Std = 0.017\n",
      "ACC: Mean = 0.05, Std = 0.001\n",
      "NMI: Mean = 0.001, Std = 0.003\n",
      "ARI: Mean = 0.0, Std = 0.0\n",
      "SIL: ['N/A', 'N/A', 'N/A', 0.13810820086061593, 'N/A', 'N/A', 'N/A', 0.09396806910117929, 'N/A', 'N/A']\n",
      "\n",
      "Percentage Difference between Post and Pre Attack for Office-31 with KFC/attack_balance/\n",
      "BALANCE: Percentage Difference = 0.0\n",
      "MIN_CLUSTER_RATIO: Percentage Difference = 0.0\n",
      "CLUSTER_DIST_L1: Percentage Difference = 0.0\n",
      "CLUSTER_DIST_KL: Percentage Difference = 0.0\n",
      "ENTROPY: Percentage Difference = 0.0\n",
      "ENTROPY_GROUP_A: Percentage Difference = 0.0\n",
      "ENTROPY_GROUP_B: Percentage Difference = 0.0\n",
      "ACC: Percentage Difference = -0.002\n",
      "NMI: Percentage Difference = -0.002\n",
      "ARI: Percentage Difference = -0.103\n",
      "\n",
      "Percentage Difference between Random and Pre Attack for Office-31 with KFC/attack_balance/\n",
      "BALANCE: Percentage Difference = -0.017\n",
      "MIN_CLUSTER_RATIO: Percentage Difference = -0.023\n",
      "CLUSTER_DIST_L1: Percentage Difference = 1.257\n",
      "CLUSTER_DIST_KL: Percentage Difference = 2.143\n",
      "ENTROPY: Percentage Difference = -0.006\n",
      "ENTROPY_GROUP_A: Percentage Difference = -0.162\n",
      "ENTROPY_GROUP_B: Percentage Difference = 0.0\n",
      "ACC: Percentage Difference = 0.0\n",
      "NMI: Percentage Difference = -0.0\n",
      "ARI: Percentage Difference = 0.057\n",
      "\n",
      "\n",
      "Pre-Attack Results for MNIST_USPS with SFD\n",
      "=========================================\n",
      "BALANCE: Mean = 0.282, Std = 0.059\n",
      "MIN_CLUSTER_RATIO: Mean = 0.425, Std = 0.094\n",
      "CLUSTER_DIST_L1: Mean = 0.276, Std = 0.077\n",
      "CLUSTER_DIST_KL: Mean = 0.294, Std = 0.134\n",
      "SILHOUETTE_DIFF: Mean = -0.015, Std = 0.008\n",
      "ENTROPY: Mean = 3.063, Std = 0.151\n",
      "ENTROPY_GROUP_A: Mean = 2.264, Std = 0.006\n",
      "ENTROPY_GROUP_B: Mean = 2.004, Std = 0.16\n",
      "ACC: Mean = 0.419, Std = 0.036\n",
      "NMI: Mean = 0.315, Std = 0.027\n",
      "ARI: Mean = 0.201, Std = 0.037\n",
      "SIL: Mean = 0.021, Std = 0.011\n",
      "\n",
      "Post-Attack Results for MNIST_USPS with SFD\n",
      "=========================================\n",
      "BALANCE: Mean = 0.3, Std = 0.092\n",
      "MIN_CLUSTER_RATIO: Mean = 0.5, Std = 0.022\n",
      "CLUSTER_DIST_L1: Mean = 0.27, Std = 0.034\n",
      "CLUSTER_DIST_KL: Mean = 0.235, Std = 0.053\n",
      "SILHOUETTE_DIFF: Mean = -0.02, Std = 0.009\n",
      "ENTROPY: Mean = 3.104, Std = 0.076\n",
      "ENTROPY_GROUP_A: Mean = 2.266, Std = 0.01\n",
      "ENTROPY_GROUP_B: Mean = 2.07, Std = 0.069\n",
      "ACC: Mean = 0.473, Std = 0.017\n",
      "NMI: Mean = 0.358, Std = 0.02\n",
      "ARI: Mean = 0.264, Std = 0.017\n",
      "SIL: Mean = 0.035, Std = 0.003\n",
      "\n",
      "Random-Attack Results for MNIST_USPS with SFD\n",
      "=========================================\n",
      "BALANCE: Mean = 0.358, Std = 0.16\n",
      "MIN_CLUSTER_RATIO: Mean = 0.466, Std = 0.156\n",
      "CLUSTER_DIST_L1: Mean = 0.276, Std = 0.122\n",
      "CLUSTER_DIST_KL: Mean = 0.269, Std = 0.301\n",
      "SILHOUETTE_DIFF: Mean = -0.019, Std = 0.006\n",
      "ENTROPY: Mean = 3.039, Std = 0.471\n",
      "ENTROPY_GROUP_A: Mean = 2.173, Std = 0.291\n",
      "ENTROPY_GROUP_B: Mean = 2.127, Std = 0.074\n",
      "ACC: Mean = 0.458, Std = 0.038\n",
      "NMI: Mean = 0.345, Std = 0.028\n",
      "ARI: Mean = 0.248, Std = 0.046\n",
      "SIL: Mean = 0.039, Std = 0.011\n",
      "\n",
      "Percentage Difference between Post and Pre Attack for MNIST_USPS with SFD\n",
      "BALANCE: Percentage Difference = 0.065\n",
      "MIN_CLUSTER_RATIO: Percentage Difference = 0.178\n",
      "CLUSTER_DIST_L1: Percentage Difference = -0.024\n",
      "CLUSTER_DIST_KL: Percentage Difference = -0.201\n",
      "SILHOUETTE_DIFF: Percentage Difference = 0.326\n",
      "ENTROPY: Percentage Difference = 0.013\n",
      "ENTROPY_GROUP_A: Percentage Difference = 0.001\n",
      "ENTROPY_GROUP_B: Percentage Difference = 0.033\n",
      "ACC: Percentage Difference = 0.13\n",
      "NMI: Percentage Difference = 0.136\n",
      "ARI: Percentage Difference = 0.315\n",
      "SIL: Percentage Difference = 0.626\n",
      "\n",
      "Percentage Difference between Random and Pre Attack for MNIST_USPS with SFD\n",
      "BALANCE: Percentage Difference = 0.271\n",
      "MIN_CLUSTER_RATIO: Percentage Difference = 0.098\n",
      "CLUSTER_DIST_L1: Percentage Difference = -0.002\n",
      "CLUSTER_DIST_KL: Percentage Difference = -0.086\n",
      "SILHOUETTE_DIFF: Percentage Difference = 0.248\n",
      "ENTROPY: Percentage Difference = -0.008\n",
      "ENTROPY_GROUP_A: Percentage Difference = -0.04\n",
      "ENTROPY_GROUP_B: Percentage Difference = 0.061\n",
      "ACC: Percentage Difference = 0.093\n",
      "NMI: Percentage Difference = 0.096\n",
      "ARI: Percentage Difference = 0.232\n",
      "SIL: Percentage Difference = 0.832\n",
      "\n",
      "\n",
      "Pre-Attack Results for MNIST_USPS 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.728, Std = 0.001\n",
      "CLUSTER_DIST_KL: Mean = inf, Std = nan\n",
      "SILHOUETTE_DIFF: Mean = -0.069, Std = 0.002\n",
      "ENTROPY: Mean = 0.327, Std = 0.041\n",
      "ENTROPY_GROUP_A: Mean = 1.15, Std = 0.002\n",
      "ENTROPY_GROUP_B: Mean = 1.854, Std = 0.031\n",
      "ACC: Mean = 0.45, Std = 0.014\n",
      "NMI: Mean = 0.549, Std = 0.016\n",
      "ARI: Mean = 0.259, Std = 0.01\n",
      "SIL: Mean = 0.036, Std = 0.0\n",
      "\n",
      "Post-Attack Results for MNIST_USPS 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.846, Std = 0.08\n",
      "CLUSTER_DIST_KL: Mean = inf, Std = nan\n",
      "SILHOUETTE_DIFF: Mean = -0.068, Std = 0.003\n",
      "ENTROPY: Mean = 0.241, Std = 0.056\n",
      "ENTROPY_GROUP_A: Mean = 1.151, Std = 0.001\n",
      "ENTROPY_GROUP_B: Mean = 1.862, Std = 0.031\n",
      "ACC: Mean = 0.454, Std = 0.01\n",
      "NMI: Mean = 0.543, Std = 0.008\n",
      "ARI: Mean = 0.275, Std = 0.009\n",
      "SIL: Mean = 0.05, Std = 0.009\n",
      "\n",
      "Random-Attack Results for MNIST_USPS 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.063\n",
      "CLUSTER_DIST_KL: Mean = inf, Std = nan\n",
      "SILHOUETTE_DIFF: Mean = -0.07, Std = 0.002\n",
      "ENTROPY: Mean = 0.318, Std = 0.064\n",
      "ENTROPY_GROUP_A: Mean = 1.151, Std = 0.003\n",
      "ENTROPY_GROUP_B: Mean = 1.868, Std = 0.032\n",
      "ACC: Mean = 0.446, Std = 0.019\n",
      "NMI: Mean = 0.54, Std = 0.022\n",
      "ARI: Mean = 0.26, Std = 0.017\n",
      "SIL: Mean = 0.04, Std = 0.008\n",
      "\n",
      "Percentage Difference between Post and Pre Attack for MNIST_USPS with FSC\n",
      "BALANCE: Percentage Difference = nan\n",
      "MIN_CLUSTER_RATIO: Percentage Difference = nan\n",
      "CLUSTER_DIST_L1: Percentage Difference = 0.162\n",
      "CLUSTER_DIST_KL: Percentage Difference = nan\n",
      "SILHOUETTE_DIFF: Percentage Difference = -0.019\n",
      "ENTROPY: Percentage Difference = -0.264\n",
      "ENTROPY_GROUP_A: Percentage Difference = 0.0\n",
      "ENTROPY_GROUP_B: Percentage Difference = 0.004\n",
      "ACC: Percentage Difference = 0.009\n",
      "NMI: Percentage Difference = -0.011\n",
      "ARI: Percentage Difference = 0.061\n",
      "SIL: Percentage Difference = 0.396\n",
      "\n",
      "Percentage Difference between Random and Pre Attack for MNIST_USPS with FSC\n",
      "BALANCE: Percentage Difference = nan\n",
      "MIN_CLUSTER_RATIO: Percentage Difference = nan\n",
      "CLUSTER_DIST_L1: Percentage Difference = 0.043\n",
      "CLUSTER_DIST_KL: Percentage Difference = nan\n",
      "SILHOUETTE_DIFF: Percentage Difference = 0.009\n",
      "ENTROPY: Percentage Difference = -0.028\n",
      "ENTROPY_GROUP_A: Percentage Difference = 0.001\n",
      "ENTROPY_GROUP_B: Percentage Difference = 0.007\n",
      "ACC: Percentage Difference = -0.008\n",
      "NMI: Percentage Difference = -0.016\n",
      "ARI: Percentage Difference = 0.002\n",
      "SIL: Percentage Difference = 0.111\n",
      "\n",
      "\n",
      "Pre-Attack Results for MNIST_USPS with KFC/attack_balance/\n",
      "=========================================\n",
      "BALANCE: Mean = 0.557, Std = 0.324\n",
      "MIN_CLUSTER_RATIO: Mean = 0.603, Std = 0.341\n",
      "CLUSTER_DIST_L1: Mean = 0.013, Std = 0.008\n",
      "CLUSTER_DIST_KL: Mean = 0.003, Std = 0.001\n",
      "SILHOUETTE_DIFF: Mean = 0.026, Std = 0.023\n",
      "ENTROPY: Mean = 1.355, Std = 0.374\n",
      "ENTROPY_GROUP_A: Mean = 0.238, Std = 0.143\n",
      "ENTROPY_GROUP_B: Mean = 0.275, Std = 0.164\n",
      "ACC: Mean = 0.147, Std = 0.012\n",
      "NMI: Mean = 0.03, Std = 0.018\n",
      "ARI: Mean = 0.0, Std = 0.002\n",
      "SIL: Mean = 0.099, Std = 0.058\n",
      "\n",
      "Post-Attack Results for MNIST_USPS with KFC/attack_balance/\n",
      "=========================================\n",
      "BALANCE: Mean = 0.35, Std = 0.299\n",
      "MIN_CLUSTER_RATIO: Mean = 0.358, Std = 0.351\n",
      "CLUSTER_DIST_L1: Mean = 0.018, Std = 0.01\n",
      "CLUSTER_DIST_KL: Mean = 0.005, Std = 0.002\n",
      "SILHOUETTE_DIFF: Mean = 0.035, Std = 0.029\n",
      "ENTROPY: Mean = 1.242, Std = 0.418\n",
      "ENTROPY_GROUP_A: Mean = 0.201, Std = 0.132\n",
      "ENTROPY_GROUP_B: Mean = 0.254, Std = 0.168\n",
      "ACC: Mean = 0.145, Std = 0.011\n",
      "NMI: Mean = 0.027, Std = 0.017\n",
      "ARI: Mean = -0.0, Std = 0.001\n",
      "SIL: Mean = 0.113, Std = 0.058\n",
      "\n",
      "Random-Attack Results for MNIST_USPS with KFC/attack_balance/\n",
      "=========================================\n",
      "BALANCE: Mean = 0.554, Std = 0.292\n",
      "MIN_CLUSTER_RATIO: Mean = 0.696, Std = 0.279\n",
      "CLUSTER_DIST_L1: Mean = 0.014, Std = 0.009\n",
      "CLUSTER_DIST_KL: Mean = inf, Std = nan\n",
      "SILHOUETTE_DIFF: Mean = 0.022, Std = 0.026\n",
      "ENTROPY: Mean = 1.349, Std = 0.469\n",
      "ENTROPY_GROUP_A: Mean = 0.223, Std = 0.143\n",
      "ENTROPY_GROUP_B: Mean = 0.258, Std = 0.17\n",
      "ACC: Mean = 0.146, Std = 0.012\n",
      "NMI: Mean = 0.029, Std = 0.019\n",
      "ARI: Mean = -0.0, Std = 0.002\n",
      "SIL: Mean = 0.101, Std = 0.057\n",
      "\n",
      "Percentage Difference between Post and Pre Attack for MNIST_USPS with KFC/attack_balance/\n",
      "BALANCE: Percentage Difference = -0.373\n",
      "MIN_CLUSTER_RATIO: Percentage Difference = -0.406\n",
      "CLUSTER_DIST_L1: Percentage Difference = 0.344\n",
      "CLUSTER_DIST_KL: Percentage Difference = 0.958\n",
      "SILHOUETTE_DIFF: Percentage Difference = 0.316\n",
      "ENTROPY: Percentage Difference = -0.083\n",
      "ENTROPY_GROUP_A: Percentage Difference = -0.154\n",
      "ENTROPY_GROUP_B: Percentage Difference = -0.079\n",
      "ACC: Percentage Difference = -0.012\n",
      "NMI: Percentage Difference = -0.105\n",
      "ARI: Percentage Difference = -22.909\n",
      "SIL: Percentage Difference = 0.143\n",
      "\n",
      "Percentage Difference between Random and Pre Attack for MNIST_USPS with KFC/attack_balance/\n",
      "BALANCE: Percentage Difference = -0.007\n",
      "MIN_CLUSTER_RATIO: Percentage Difference = 0.155\n",
      "CLUSTER_DIST_L1: Percentage Difference = 0.055\n",
      "CLUSTER_DIST_KL: Percentage Difference = inf\n",
      "SILHOUETTE_DIFF: Percentage Difference = -0.146\n",
      "ENTROPY: Percentage Difference = -0.004\n",
      "ENTROPY_GROUP_A: Percentage Difference = -0.062\n",
      "ENTROPY_GROUP_B: Percentage Difference = -0.063\n",
      "ACC: Percentage Difference = -0.005\n",
      "NMI: Percentage Difference = -0.057\n",
      "ARI: Percentage Difference = -8.564\n",
      "SIL: Percentage Difference = 0.023\n",
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\user\\AppData\\Local\\Temp\\ipykernel_28924\\195572798.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\\195572798.py:31: RuntimeWarning: divide by zero encountered in scalar divide\n",
      "  perc_diff = (random_mean - pre_mean) / pre_mean\n",
      "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_28924\\195572798.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\\195572798.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\\195572798.py:31: RuntimeWarning: invalid value encountered in scalar subtract\n",
      "  perc_diff = (random_mean - pre_mean) / pre_mean\n"
     ]
    }
   ],
   "source": [
    "\n",
    "datasets = [\"Office-31\", \"MNIST_USPS\"]\n",
    "cl_algo = [\"SFD\", \"FSC\", \"KFC/attack_balance/\"]\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
}
