{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "e7abf6a9",
   "metadata": {},
   "outputs": [],
   "source": [
    "#Select a dataset from: ImageNet, COCO, CelebA\n",
    "dataset = 'COCO'\n",
    "\n",
    "#Select a class from that dataset\n",
    "#-  For COCO, spaces have been replaced with a '+'\n",
    "name = 'frisbee'\n",
    "\n",
    "folder = 'frisbee+gym'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "7fe4158e",
   "metadata": {},
   "outputs": [],
   "source": [
    "import json\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import os\n",
    "from scipy.spatial.distance import cdist\n",
    "import sys\n",
    "\n",
    "os.chdir(dataset)\n",
    "sys.path.insert(0, os.getcwd())\n",
    "sys.path.insert(0, '../Common/')\n",
    "from ModelWrapper import ModelWrapper\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "58e73ca4",
   "metadata": {},
   "outputs": [],
   "source": [
    "if dataset == 'ImageNet':\n",
    "    \n",
    "    from Config import get_class_map\n",
    "    from ResNet50 import get_model, get_features\n",
    "    \n",
    "    # Get the index for this class\n",
    "    class_map = get_class_map()\n",
    "    index = int(get_class_map()[name][1])\n",
    "\n",
    "    # Setup the model\n",
    "    model = get_model()\n",
    "    model.eval()\n",
    "    model.cuda()\n",
    "    feature_hook = get_features(model)\n",
    "    \n",
    "    # Setup the transform\n",
    "    transform_mode = 'imagenet'\n",
    "\n",
    "else:\n",
    "    from Config import get_data_dir, get_out_features\n",
    "    from ResNet import get_model, get_features\n",
    "    \n",
    "    # Get the index for this class\n",
    "    with open('{}/maps.json'.format(get_data_dir()), 'r') as f:\n",
    "        name2index, _ = json.load(f)\n",
    "    index = name2index[name]\n",
    "\n",
    "    # Setup the model\n",
    "    model = get_model(out_features = get_out_features(), mode = 'eval', parent = './Outputs/initial-tune/trial0/model.pt')\n",
    "    model.eval()\n",
    "    model.cuda()\n",
    "    feature_hook = get_features(model)\n",
    "    \n",
    "    # Setup the transform\n",
    "    transform_mode = 'full'\n",
    "    \n",
    "wrapper = ModelWrapper(model, transform_mode = transform_mode, feature_hook = feature_hook)\n",
    "out = wrapper.predict_directory('./ExternalData/{}'.format(folder))\n",
    "    \n",
    "# Run the model\n",
    "files = list(out)\n",
    "reps = []\n",
    "preds = []\n",
    "\n",
    "for i in files:\n",
    "    reps.append(out[i]['rep'])\n",
    "    preds.append(out[i]['pred'])\n",
    "    \n",
    "reps = np.array(reps)\n",
    "preds = np.array(preds)\n",
    "    \n",
    "n = len(files)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "66a77d8d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 288x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Check for duplicate images\n",
    "threshold = 5\n",
    "\n",
    "v = cdist(reps, reps)\n",
    "\n",
    "plt.matshow(v)\n",
    "plt.colorbar()\n",
    "plt.show()\n",
    "plt.close()\n",
    "\n",
    "indices = np.where(v <= threshold)\n",
    "similar = []\n",
    "for i in range(n):\n",
    "    for j in range(i + 1, n):\n",
    "        if v[i, j] < threshold:\n",
    "            print(files[i].split('/')[-1], files[j].split('/')[-1])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "6c3ba17f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy\n",
      "0.0 0 50\n",
      "Errors\n",
      "./ExternalData/frisbee+gym/36.jpg\n",
      "./ExternalData/frisbee+gym/46.jpg\n",
      "./ExternalData/frisbee+gym/40.jpg\n",
      "./ExternalData/frisbee+gym/39.jpg\n",
      "./ExternalData/frisbee+gym/14.jpg\n",
      "./ExternalData/frisbee+gym/12.jpg\n",
      "./ExternalData/frisbee+gym/31.jpg\n",
      "./ExternalData/frisbee+gym/44.jpg\n",
      "./ExternalData/frisbee+gym/6.jpg\n",
      "./ExternalData/frisbee+gym/18.jpg\n",
      "./ExternalData/frisbee+gym/21.jpg\n",
      "./ExternalData/frisbee+gym/4.jpg\n",
      "./ExternalData/frisbee+gym/41.jpg\n",
      "./ExternalData/frisbee+gym/42.jpg\n",
      "./ExternalData/frisbee+gym/9.jpg\n",
      "./ExternalData/frisbee+gym/5.jpg\n",
      "./ExternalData/frisbee+gym/26.jpg\n",
      "./ExternalData/frisbee+gym/30.jpg\n",
      "./ExternalData/frisbee+gym/15.jpg\n",
      "./ExternalData/frisbee+gym/27.jpg\n",
      "./ExternalData/frisbee+gym/47.jpg\n",
      "./ExternalData/frisbee+gym/37.jpg\n",
      "./ExternalData/frisbee+gym/23.jpg\n",
      "./ExternalData/frisbee+gym/29.jpg\n",
      "./ExternalData/frisbee+gym/35.jpg\n",
      "./ExternalData/frisbee+gym/1.jpg\n",
      "./ExternalData/frisbee+gym/3.jpg\n",
      "./ExternalData/frisbee+gym/7.jpg\n",
      "./ExternalData/frisbee+gym/50.jpg\n",
      "./ExternalData/frisbee+gym/43.jpg\n",
      "./ExternalData/frisbee+gym/34.jpg\n",
      "./ExternalData/frisbee+gym/28.jpg\n",
      "./ExternalData/frisbee+gym/32.jpg\n",
      "./ExternalData/frisbee+gym/13.jpg\n",
      "./ExternalData/frisbee+gym/16.jpg\n",
      "./ExternalData/frisbee+gym/25.jpg\n",
      "./ExternalData/frisbee+gym/11.jpg\n",
      "./ExternalData/frisbee+gym/22.jpg\n",
      "./ExternalData/frisbee+gym/38.jpg\n",
      "./ExternalData/frisbee+gym/24.jpg\n",
      "./ExternalData/frisbee+gym/20.jpg\n",
      "./ExternalData/frisbee+gym/17.jpg\n",
      "./ExternalData/frisbee+gym/33.jpg\n",
      "./ExternalData/frisbee+gym/10.jpg\n",
      "./ExternalData/frisbee+gym/2.jpg\n",
      "./ExternalData/frisbee+gym/8.jpg\n",
      "./ExternalData/frisbee+gym/45.jpg\n",
      "./ExternalData/frisbee+gym/49.jpg\n",
      "./ExternalData/frisbee+gym/48.jpg\n",
      "./ExternalData/frisbee+gym/19.jpg\n"
     ]
    }
   ],
   "source": [
    "# Find the error rate\n",
    "if dataset == 'ImageNet':\n",
    "    correct = (np.argmax(preds, axis = 1) == index)\n",
    "else:\n",
    "    correct = (preds[:, index] >= 0.5)\n",
    "    \n",
    "count = np.sum(correct)\n",
    "print('Accuracy')\n",
    "print(np.round(count / n, 2), count, n)\n",
    "print('Errors')\n",
    "for i, name in enumerate(files):\n",
    "    if not correct[i]:\n",
    "        print(name)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ce55cde6",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python [conda env:blindspots]",
   "language": "python",
   "name": "conda-env-blindspots-py"
  },
  "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.7.11"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
