{
 "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 metric in [\"BALANCE\", \"ENTROPY\", \"ACC\", \"NMI\"]:\n",
    "            continue\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": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "Pre-Attack Results for MNIST_USPS with SFD\n",
      "=========================================\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_GROUP_A: Mean = 2.264, Std = 0.006\n",
      "ENTROPY_GROUP_B: Mean = 2.004, Std = 0.16\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",
      "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_GROUP_A: Mean = 2.266, Std = 0.01\n",
      "ENTROPY_GROUP_B: Mean = 2.07, Std = 0.069\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",
      "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_GROUP_A: Mean = 2.173, Std = 0.291\n",
      "ENTROPY_GROUP_B: Mean = 2.127, Std = 0.074\n",
      "ARI: Mean = 0.248, Std = 0.046\n",
      "SIL: Mean = 0.039, Std = 0.011\n",
      "\n",
      "\n",
      "Pre-Attack Results for MNIST_USPS with FSC\n",
      "=========================================\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_GROUP_A: Mean = 1.15, Std = 0.002\n",
      "ENTROPY_GROUP_B: Mean = 1.854, Std = 0.031\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",
      "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_GROUP_A: Mean = 1.151, Std = 0.001\n",
      "ENTROPY_GROUP_B: Mean = 1.862, Std = 0.031\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",
      "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_GROUP_A: Mean = 1.151, Std = 0.003\n",
      "ENTROPY_GROUP_B: Mean = 1.868, Std = 0.032\n",
      "ARI: Mean = 0.26, Std = 0.017\n",
      "SIL: Mean = 0.04, Std = 0.008\n",
      "\n",
      "\n",
      "Pre-Attack Results for MNIST_USPS with KFC\n",
      "=========================================\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_GROUP_A: Mean = 0.238, Std = 0.143\n",
      "ENTROPY_GROUP_B: Mean = 0.275, Std = 0.164\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\n",
      "=========================================\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_GROUP_A: Mean = 0.201, Std = 0.132\n",
      "ENTROPY_GROUP_B: Mean = 0.254, Std = 0.168\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\n",
      "=========================================\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_GROUP_A: Mean = 0.223, Std = 0.143\n",
      "ENTROPY_GROUP_B: Mean = 0.258, Std = 0.17\n",
      "ARI: Mean = -0.0, Std = 0.002\n",
      "SIL: Mean = 0.101, Std = 0.057\n",
      "\n",
      "\n",
      "Pre-Attack Results for Office-31 with SFD\n",
      "=========================================\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_GROUP_A: Mean = 3.363, Std = 0.002\n",
      "ENTROPY_GROUP_B: Mean = 3.353, Std = 0.005\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",
      "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_GROUP_A: Mean = 3.292, Std = 0.014\n",
      "ENTROPY_GROUP_B: Mean = 3.357, Std = 0.008\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",
      "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_GROUP_A: Mean = 3.305, Std = 0.024\n",
      "ENTROPY_GROUP_B: Mean = 3.354, Std = 0.01\n",
      "ARI: Mean = 0.683, Std = 0.019\n",
      "SIL: Mean = 0.159, Std = 0.004\n",
      "\n",
      "\n",
      "Pre-Attack Results for Office-31 with FSC\n",
      "=========================================\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_GROUP_A: Mean = 2.299, Std = 0.037\n",
      "ENTROPY_GROUP_B: Mean = 2.385, Std = 0.047\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",
      "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_GROUP_A: Mean = 2.489, Std = 0.091\n",
      "ENTROPY_GROUP_B: Mean = 2.542, Std = 0.11\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",
      "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_GROUP_A: Mean = 2.471, Std = 0.103\n",
      "ENTROPY_GROUP_B: Mean = 2.569, Std = 0.094\n",
      "ARI: Mean = 0.235, Std = 0.029\n",
      "SIL: Mean = 0.018, Std = 0.01\n",
      "\n",
      "\n",
      "Pre-Attack Results for Office-31 with KFC\n",
      "=========================================\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_GROUP_A: Mean = 0.007, Std = 0.015\n",
      "ENTROPY_GROUP_B: Mean = 0.007, Std = 0.017\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\n",
      "=========================================\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_GROUP_A: Mean = 0.007, Std = 0.015\n",
      "ENTROPY_GROUP_B: Mean = 0.007, Std = 0.017\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\n",
      "=========================================\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_GROUP_A: Mean = 0.006, Std = 0.012\n",
      "ENTROPY_GROUP_B: Mean = 0.007, Std = 0.017\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",
      "\n",
      "Pre-Attack Results for DIGITS with SFD\n",
      "=========================================\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_GROUP_A: Mean = 2.271, Std = 0.0\n",
      "ENTROPY_GROUP_B: Mean = 1.983, Std = 0.002\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",
      "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_GROUP_A: Mean = 1.739, Std = 0.869\n",
      "ENTROPY_GROUP_B: Mean = 0.435, Std = 0.869\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",
      "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_GROUP_A: Mean = 1.525, Std = 0.998\n",
      "ENTROPY_GROUP_B: Mean = 0.652, Std = 0.996\n",
      "ARI: Mean = 0.094, Std = 0.0\n",
      "SIL: Mean = 0.321, Std = 0.001\n",
      "\n",
      "\n",
      "Pre-Attack Results for DIGITS with FSC\n",
      "=========================================\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_GROUP_A: Mean = 1.028, Std = 0.006\n",
      "ENTROPY_GROUP_B: Mean = 1.281, Std = 0.0\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",
      "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_GROUP_A: Mean = 1.024, Std = 0.009\n",
      "ENTROPY_GROUP_B: Mean = 1.281, Std = 0.0\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",
      "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_GROUP_A: Mean = 1.033, Std = 0.017\n",
      "ENTROPY_GROUP_B: Mean = 1.322, Std = 0.124\n",
      "ARI: Mean = 0.158, Std = 0.008\n",
      "SIL: Mean = -0.138, Std = 0.003\n",
      "\n",
      "\n",
      "Pre-Attack Results for DIGITS with KFC\n",
      "=========================================\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_GROUP_A: Mean = 1.82, Std = 0.169\n",
      "ENTROPY_GROUP_B: Mean = 1.82, Std = 0.168\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\n",
      "=========================================\n",
      "MIN_CLUSTER_RATIO: Mean = 0.426, Std = 0.197\n",
      "CLUSTER_DIST_L1: Mean = 0.12, Std = 0.011\n",
      "CLUSTER_DIST_KL: Mean = inf, Std = nan\n",
      "SILHOUETTE_DIFF: Mean = -0.034, Std = 0.052\n",
      "ENTROPY_GROUP_A: Mean = 1.869, Std = 0.157\n",
      "ENTROPY_GROUP_B: Mean = 1.853, Std = 0.173\n",
      "ARI: Mean = 0.023, Std = 0.008\n",
      "SIL: Mean = -0.152, Std = 0.059\n",
      "\n",
      "Random-Attack Results for DIGITS with KFC\n",
      "=========================================\n",
      "MIN_CLUSTER_RATIO: Mean = 0.494, Std = 0.246\n",
      "CLUSTER_DIST_L1: Mean = 0.117, Std = 0.011\n",
      "CLUSTER_DIST_KL: Mean = inf, Std = nan\n",
      "SILHOUETTE_DIFF: Mean = -0.026, Std = 0.051\n",
      "ENTROPY_GROUP_A: Mean = 1.85, Std = 0.185\n",
      "ENTROPY_GROUP_B: Mean = 1.831, Std = 0.194\n",
      "ARI: Mean = 0.023, Std = 0.008\n",
      "SIL: Mean = -0.13, Std = 0.048\n",
      "\n",
      "\n",
      "Pre-Attack Results for Yale with SFD\n",
      "=========================================\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_GROUP_A: Mean = 1.788, Std = 0.1\n",
      "ENTROPY_GROUP_B: Mean = 3.505, Std = 0.016\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",
      "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_GROUP_A: Mean = 1.816, Std = 0.18\n",
      "ENTROPY_GROUP_B: Mean = 3.491, Std = 0.016\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",
      "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_GROUP_A: Mean = 1.752, Std = 0.166\n",
      "ENTROPY_GROUP_B: Mean = 3.5, Std = 0.014\n",
      "ARI: Mean = 0.008, Std = 0.006\n",
      "SIL: Mean = 0.061, Std = 0.006\n",
      "\n",
      "\n",
      "Pre-Attack Results for Yale with FSC\n",
      "=========================================\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_GROUP_A: Mean = 2.966, Std = 0.021\n",
      "ENTROPY_GROUP_B: Mean = 2.28, Std = 0.024\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",
      "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_GROUP_A: Mean = 2.918, Std = 0.087\n",
      "ENTROPY_GROUP_B: Mean = 2.257, Std = 0.032\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",
      "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_GROUP_A: Mean = 2.984, Std = 0.038\n",
      "ENTROPY_GROUP_B: Mean = 2.272, Std = 0.033\n",
      "ARI: Mean = 0.062, Std = 0.002\n",
      "SIL: Mean = -0.006, Std = 0.005\n",
      "\n",
      "\n",
      "Pre-Attack Results for Yale with KFC\n",
      "=========================================\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_GROUP_A: Mean = 0.015, Std = 0.029\n",
      "ENTROPY_GROUP_B: Mean = 0.014, Std = 0.029\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\n",
      "=========================================\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', -0.04254209388514542, 'N/A', 'N/A', 'N/A', 0.09809049688379859, 0.08961875036650974, 'N/A']\n",
      "ENTROPY_GROUP_A: Mean = 0.015, Std = 0.029\n",
      "ENTROPY_GROUP_B: Mean = 0.016, Std = 0.031\n",
      "ARI: Mean = 0.0, Std = 0.0\n",
      "SIL: ['N/A', 'N/A', 'N/A', 0.24044336580639392, 'N/A', 'N/A', 'N/A', 0.053139436942885254, -0.07197840150941479, 'N/A']\n",
      "\n",
      "Random-Attack Results for Yale with KFC\n",
      "=========================================\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.10336256072298831, 'N/A']\n",
      "ENTROPY_GROUP_A: Mean = 0.014, Std = 0.03\n",
      "ENTROPY_GROUP_B: Mean = 0.014, Std = 0.028\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.10721498679116763, 'N/A']\n",
      "\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "c:\\Users\\user\\.conda\\envs\\nlp1-practical1\\lib\\site-packages\\numpy\\core\\_methods.py:233: RuntimeWarning: invalid value encountered in subtract\n",
      "  x = asanyarray(arr - arrmean)\n"
     ]
    }
   ],
   "source": [
    "\n",
    "datasets = [\"MNIST_USPS\", \"Office-31\",  \"DIGITS\", \"Yale\"]\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",
    "        if cl == \"KFC\":\n",
    "            path_name = f\"Fair-Clustering-Codebase/extra_metrics_results/{d}/KFC/attack_balance/\"\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(\"\")"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "2024",
   "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
}
