{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e0349d41",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import torch\n",
    "import pandas as pd\n",
    "import numpy as np\n",
    "\n",
    "from scipy import stats"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "30175038",
   "metadata": {},
   "outputs": [],
   "source": [
    "absolute_path = \"/\".join(os.path.abspath(os.getcwd()).split('/')[:-2])\n",
    "absolute_path"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a89eac6e",
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys\n",
    "sys.path.append(absolute_path)\n",
    "\n",
    "from utils.experiments import visualization, df_analysis"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "77651b4b",
   "metadata": {},
   "outputs": [],
   "source": [
    "path_to_save = os.path.join(absolute_path, 'experiments/dump_results')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "1c6d9733",
   "metadata": {},
   "source": [
    "### Get similarities"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "908e6b77",
   "metadata": {},
   "outputs": [],
   "source": [
    "seed1 = str(0)\n",
    "arch1 = 'r18'\n",
    "\n",
    "dataset = 'cifar10'\n",
    "\n",
    "layer = 17\n",
    "sim_mx_path = 'logs/similarity_matrix/pnka/'\n",
    "\n",
    "neurons = [261, 202, 94]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "sweet-server",
   "metadata": {},
   "outputs": [],
   "source": [
    "# resnet_layer_names = ['conv_bn_relu', 'conv_bn_relu', 'conv_bn_shortcut', 'conv_bn_relu', 'conv_bn_shortcut', 'conv_bn_relu', 'conv_bn_shortcut', 'conv_bn_relu', 'conv_bn_shortcut', 'conv_bn_relu', 'conv_bn_shortcut', 'conv_bn_relu', 'conv_bn_shortcut', 'conv_bn_relu', 'conv_bn_shortcut', 'conv_bn_relu', 'conv_bn_shortcut', 'avg_pool2d', 'linear']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "filled-frontier",
   "metadata": {},
   "outputs": [],
   "source": [
    "import math\n",
    "def truncate(f, n):\n",
    "    return math.floor(f * 10 ** n) / 10 ** n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "governmental-subsection",
   "metadata": {
    "scrolled": false
   },
   "outputs": [],
   "source": [
    "for neuron_id in neurons:\n",
    "    sim_mx_folder = f'M1_{dataset}-{arch1}-seed{seed1}_l{layer}_l{layer}'\n",
    "    sim_mx = torch.load(\n",
    "        os.path.join(\n",
    "            absolute_logs_path, sim_mx_path, sim_mx_folder, \n",
    "            f'remove_dimension/1/all/neuron_{neuron_id}',\n",
    "            'pnka.pt'))\n",
    "    sim = torch.diag(sim_mx)\n",
    "\n",
    "    sim_mx_logs_cka = 'logs/similarity_matrix/cka/'\n",
    "    sim_mx_cka = torch.load(\n",
    "            os.path.join(\n",
    "                absolute_logs_path, sim_mx_logs_cka, sim_mx_folder,\n",
    "                f'remove_dimension/1/all/neuron_{neuron_id}',\n",
    "                'final_sim_xxtyyt.pt'))\n",
    "    norm_cka = torch.load(\n",
    "            os.path.join(\n",
    "                absolute_logs_path, sim_mx_logs_cka, sim_mx_folder,\n",
    "                f'remove_dimension/1/all/neuron_{neuron_id}',\n",
    "                'norm.pt'))\n",
    "    cka_score = torch.trace(sim_mx_cka) / norm_cka\n",
    "    df = pd.DataFrame({'sim':sim})\n",
    "    min_sim = min(df['sim'])\n",
    "    print(min_sim, truncate(min_sim, 4))\n",
    "    print(df.sort_values('sim')[:30])\n",
    "    visualization.plot_histogram(\n",
    "        all_x=[df['sim']], all_names=['count'],\n",
    "#         histnorm='probability density',\n",
    "        xaxis=dict(\n",
    "                linecolor = \"black\"),\n",
    "        yaxis=dict(\n",
    "                linecolor = \"black\",),\n",
    "        xrange=[truncate(min_sim, 4),1],\n",
    "        yrange=[0,2000],\n",
    "        x_vline=cka_score,\n",
    "        linecolor='red',\n",
    "        vline_annotation=f'CKA={round(cka_score.item(),6)}',\n",
    "        save_path=os.path.join(path_to_save, f'hist_probdensity_{sim_mx_folder}_removeneuron{neuron_id}.pdf')\n",
    "    )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b8539368",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "acting-contact",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "hispanic-graphics",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "(newadv2)",
   "language": "python",
   "name": "newadv2"
  },
  "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.8.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
