{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "source": [
    "import pickle\n",
    "import matplotlib.pyplot as plt\n",
    "from collections import Counter\n",
    "import numpy as np\n",
    "import os\n",
    "import torch\n",
    "from unlabeled_extrapolation.datasets.breeds import Breeds"
   ],
   "outputs": [],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "source": [
    "PATH = 'data_selection/' + \\\n",
    "       'breeds/living17-living17-sentry-swav-simclr/my-results-prune'"
   ],
   "outputs": [],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 62,
   "source": [
    "with open(PATH, 'rb') as f:\n",
    "    accs, paths = pickle.load(f)"
   ],
   "outputs": [],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 63,
   "source": [
    "rounded_accs = [round(a, 1) for a in accs]"
   ],
   "outputs": [],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "source": [
    "counts = Counter(rounded_accs)\n",
    "x = [item[0] for item in sorted(counts.items())]\n",
    "y = [item[1] for item in sorted(counts.items())]\n",
    "plt.bar(x, y, width=0.05)\n",
    "plt.xticks(np.linspace(0, 1, 11))\n",
    "plt.xlabel('Proportion of 10 augmentations labeled correctly')\n",
    "plt.ylabel('Counts')\n",
    "plt.show()"
   ],
   "outputs": [
    {
     "output_type": "display_data",
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     }
    }
   ],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "source": [
    "base_dir = 'prunelist'"
   ],
   "outputs": [],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "source": [
    "def get_list(file_name):\n",
    "    with open(os.path.join(base_dir, file_name), 'rb') as f:\n",
    "        data = pickle.load(f)\n",
    "    return data\n",
    "\n",
    "def get_dataset(domain):\n",
    "    root = '/PATH'\n",
    "    source_ds = Breeds(root, domain, source=True, target=False)\n",
    "    source_paths = {item[0]: item[1] for item in source_ds._image_paths_by_class}\n",
    "    target_ds = Breeds(root, domain, source=False, target=True)\n",
    "    target_paths = {item[0]: item[1] for item in target_ds._image_paths_by_class}\n",
    "    return source_paths, target_paths"
   ],
   "outputs": [],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "source": [
    "def get_class_domain_list(data_list, source_paths, target_paths):\n",
    "    c_d_list = []\n",
    "    for path in data_list:\n",
    "        if path in source_paths:\n",
    "            c_d_list.append((source_paths[path], 0))\n",
    "        else:\n",
    "            c_d_list.append((target_paths[path], 1))\n",
    "    return c_d_list"
   ],
   "outputs": [],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "source": [
    "data_list = get_list('5000_balanced_6,11,12,14_random')\n",
    "source_paths, target_paths = get_dataset('living17')\n",
    "c_d_list = get_class_domain_list(data_list, source_paths, target_paths)"
   ],
   "outputs": [],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "source": [
    "c = Counter(c_d_list)"
   ],
   "outputs": [],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "source": [
    "source, target = [], []\n",
    "for cls in range(17):\n",
    "    if (cls, 0) in c:\n",
    "        source.append(c[(cls, 0)])\n",
    "    else:\n",
    "        source.append(0)\n",
    "    if (cls, 1) in c:\n",
    "        target.append(c[(cls, 1)])\n",
    "    else:\n",
    "        target.append(1)"
   ],
   "outputs": [],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "source": [
    "plt.bar(range(len(source)), source)"
   ],
   "outputs": [
    {
     "output_type": "execute_result",
     "data": {
      "text/plain": [
       "<BarContainer object of 17 artists>"
      ]
     },
     "metadata": {},
     "execution_count": 8
    },
    {
     "output_type": "display_data",
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     }
    }
   ],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "source": [
    "plt.bar(range(len(target)), target)"
   ],
   "outputs": [
    {
     "output_type": "execute_result",
     "data": {
      "text/plain": [
       "<BarContainer object of 17 artists>"
      ]
     },
     "metadata": {},
     "execution_count": 9
    },
    {
     "output_type": "display_data",
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     }
    }
   ],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "source": [
    "run_dir = 'connectivity_checkpoints/between-domains/breeds/living17-living17-sentry-swav-simclr'\n",
    "results = []\n",
    "\n",
    "for i in range(17):\n",
    "    ckpt = os.path.join(run_dir, f'same-class-{i}-save-model-final')\n",
    "    result = torch.load(ckpt, map_location='cpu')\n",
    "    results.append((result['test_accs'][-1], i))\n",
    "#     plt.plot(result['train_accs'], label='train')\n",
    "#     plt.plot(result['test_accs'], label='test')\n",
    "#     plt.legend()\n",
    "#     plt.show()"
   ],
   "outputs": [],
   "metadata": {
    "scrolled": false
   }
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "source": [
    "sorted(results)"
   ],
   "outputs": [
    {
     "output_type": "execute_result",
     "data": {
      "text/plain": [
       "[(48.499999084472655, 4),\n",
       " (49.499996948242185, 13),\n",
       " (50.99999938964844, 8),\n",
       " (51.49999816894531, 7),\n",
       " (56.499997253417966, 0),\n",
       " (59.49999633789062, 3),\n",
       " (61.999998779296874, 5),\n",
       " (62.49999755859375, 1),\n",
       " (63.999996948242185, 2),\n",
       " (66.99999694824218, 9),\n",
       " (66.99999877929687, 15),\n",
       " (68.49999694824218, 16),\n",
       " (68.49999877929687, 10),\n",
       " (72.49999877929687, 14),\n",
       " (75.9999951171875, 6),\n",
       " (76.99999877929687, 11),\n",
       " (82.99999633789062, 12)]"
      ]
     },
     "metadata": {},
     "execution_count": 38
    }
   ],
   "metadata": {}
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "source": [],
   "outputs": [],
   "metadata": {}
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.8.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}