{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "from tensorflow.keras.models import load_model\n",
    "import pandas as pd\n",
    "from test_utils import *"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Video to Frames"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Extracting frames from VXG8I556ZKLP.mp4\n"
     ]
    }
   ],
   "source": [
    "video_id = \"VXG8I556ZKLP.mp4\"\n",
    "vid_path = f'Test_videos/{video_id}'\n",
    "frames_dir = 'Test_Frames'\n",
    "\n",
    "try:\n",
    "    video_to_frames(video_path=vid_path, frames_dir=frames_dir, overwrite=False, every=1)\n",
    "except:\n",
    "    print(f\"Error in {filename}\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Prediction"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "FEATURE_EXTRACTOR = \"ResNet50V2\"\n",
    "# FEATURE_EXTRACTOR = \"ResNet101V2\"\n",
    "# FEATURE_EXTRACTOR = \"InceptionV3\"\n",
    "\n",
    "num_classes = 5\n",
    "concepts_text = pd.read_csv('../Extract_Concepts/concepts_100.csv')\n",
    "\n",
    "classes = ['strike', 'ball', 'play', 'foul', 'out']\n",
    "\n",
    "class_dict = {\n",
    "    'strike': 0,\n",
    "    'ball':1,\n",
    "    'play':2,\n",
    "    'foul':3,\n",
    "    'out':4 }\n",
    "\n",
    "inv_class_dict = {v: k for k, v in class_dict.items()}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "model = load_model('Trained_Models/best_concept_attn_1621942185.h5')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Predicted Concepts: [ 0  4 11 17 21 33 34]\n",
      "Predicted Class: foul\n"
     ]
    },
    {
     "data": {
      "image/png": "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KmZbhN2va9euzJkzh3nz5lG6dOl8vb439t+CBQs4deoUbdu2NY1oNmjQgOeee46ff/6ZmjVr0rRp0yzXz5gxgw0bNrBmzRoaN26cZ3v3e/nll9m2bRuBgYEcP36cevXqcf78eb744gtKlChh9gcRunXrxoIFC3j//fdJSkrC3t6eqKgo/vjjj4e2EEwyKWEVEZHHlqOjI2vXruXjjz9mx44dbNy4kTJlytCoUSOCgoLM9gCtVasWy5Yt48MPP+TTTz/FxsYGV1dXFi9ezEcffZRnwlqvXj3Wrl3LvHnzWLJkCdevX6d69eq8/fbb9O/f31Ru4MCBREVFERUVxeHDh+ncuTMAkydPpl69eqxZs4Z3332Xu3fvUrNmTd566y2GDRtm1tZHH33E7NmziYyMZNu2bdSoUQM/Pz8qVqyYa8Jq3MpqyJAhud5L9erVadeuHTt27ODnn3/G1dWVl19+mSpVqrBy5UrefvttrK2tadq0KR999JFZ8jtx4kSmT5/OokWLaN++fa4Ja7Vq1WjcuDE///wz3t7eeW4fBpkjnN988w3/+c9/iI+Px9nZ2ex87969OXLkyENdbHWvChUqsGbNGj766CMiIiJITEzE3t4ed3d3Xn75ZbO+qFOnDvPmzWP+/Pn861//ws7Ojg4dOrBo0SJ69+6taQEPkVVGRkZGcQchIiIikh9Tp05lw4YNfP/991nmLcv/Ls1hFRERkcdCXFwc69evp1evXkpW/2I0wioiIiIWbceOHcTHx7NkyRKsra35+uuveeKJJ4o7LHmElLCKiIiIRfPy8iIhIQFXV1dmzZqlvzL1F6SEVUREREQsmuawiog8ZDExMcUdgojIYye3fzu1rZWISBFQ0ioi8vAoYRURKQLZbWguD9exY8do2LBhcYfxP0/9XPTUx5ly+0VfUwJERERExKIpYRURERERi6aEVUREREQsmhJWEREREbFoSlhFRERExKIpYRURERERi6aEVUREREQsmhJWEREREbFoSlhFRERExKIpYRURERERi6Y/zSoiUgRq+m8q7hDy5fR7XYs7BBGRPGmEVUREREQsmhJWEREREbFoSlhFRERExKIpYRURERERi6aEVUREREQsmhJWEREREbFoSlhFRERExKIpYRURERERi6aEVSQH69evx2AwkJSU9FDrjY6OxmAwsG/fvodab1EbPHgw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aYOzszPPP/88ixYtMt3LmDFjgMxX/P7+/qbvP/30U1544QWcnZ25fft2likB99u1axdOTk6mUdgHidVgMGT7FRISYiqzZcsWevbsibOzM82aNeOll17i9OnTpvP+/v74+vry448/4uPjQ6NGjejWrRs//fSTWVthYWH07NmTxo0b06ZNG4KDg7l9+3au8YmISOEpYZXHVpUqVUxJVEhISLaJTbNmzShVqpRZMrlnzx6qVKlCTEyM6di+ffswGAw8+eSTzJw5k6ioKObOncu3337LhAkTWLRoEV9++SWQOdL58ssv06hRIzZs2MC6deuoXbs2//znP0lNTc13/AcPHmT79u2EhITw+eefk5qaajbVIb/3Gh8fz/bt25k/fz4rVqzg4sWLzJgxw3R+2rRprFmzhrFjxxIREUH//v0JDAxk8+bNOcY2a9Ys4uLimD9/Pt9++y2vvfYa8+fPJzw8nC5dujB69GgAoqKizOYTr169mq5du/LNN99QsmTJXO8/Pj6ecePGMXLkSAYMGPDAsUZFRZl9vfrqq5QqVYr27dsD8MMPPzBu3Dj+/ve/Ex4ezrJly0hMTGTYsGHcuHHDVM/58+dZvnw5s2bN4quvvsLR0ZG33nqLW7duAbBhwwamTJlCp06d2LhxI9OmTWP9+vW88847ud6niIgUnqYEyGPLxsYGBwcHABwcHMymChiVKVOGxo0bExMTQ9euXblz5w779+9nxIgRREVFmcrt3buXVq1aAfDmm2+Snp5OtWrVAKhatSqrVq1i586d+Pr68ttvv5GamkrXrl2pUaMGAIGBgfTq1YsSJfL/n9Sff/7Je++9h52dHQC9evXigw8+4MaNG5QpUybf95qcnExQUJDpGm9vb9atWwfAhQsX2LhxI2+88QY+Pj4ADB8+nNjYWJYsWUKXLl2yje2XX36hadOmuLi4mPqgdu3aPPnkk9ja2lK2bFkAKlasaHZd9erVGTRoUL7uffTo0XTs2JFx48YVKtZ7Yzh27BgLFy5k0qRJODs7A7BixQpcXV154403TOXef/99vLy82L59O127dgXgjz/+4IsvvqBKlSoAvPDCC4wfP55z585Rt25dFi1aRLt27Rg7diwANWvW5MKFC7z77ru8/vrrlC9fPs/7FhGRB6OEVf7ntWzZku+++w6AI0eOYGtrS8+ePfnkk0+4ffs2GRkZ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\n",
      "text/plain": [
       "<Figure size 432x360 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "test_features = extract_features(frames_dir, video_id, FEATURE_EXTRACTOR)\n",
    "pred, pred_label, pred_concepts, pred_attn = visualize_concepts(test_features, model, \n",
    "                                                                concepts_text, inv_class_dict)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Optional: Nearest training example Explanation"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "Shows the explanation of the similar top-3 training examples whose concepts are similar to the given test video."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "from heapq import nlargest\n",
    "from sklearn.metrics.pairwise import cosine_similarity\n",
    "import numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "pred_train_concepts = np.load('Activations/pred_train_concepts.npy')\n",
    "pred_train_labels = np.load('Activations/pred_labels_train.npy')\n",
    "labels = pd.read_pickle('../Extacted_Concepts/labels_df_filtered_100.pkl')\n",
    "explanations = pd.read_pickle('../Extacted_Concepts/Explanations.pkl')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "sim = cosine_similarity(pred_train_concepts,pred[0])\n",
    "topk = nlargest(3, range(len(sim)),\n",
    "                key=lambda idx: sim[idx] if pred_label == pred_train_labels[idx] else 0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1225    MTK3RDV99H6C\n",
      "1396    PZ2EOMHHCAOF\n",
      "1437    QUYLJ3FDAJFM\n",
      "Name: Id, dtype: object\n"
     ]
    }
   ],
   "source": [
    "print(labels.iloc[topk]['Id'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['then the batter swung and made contact with the ball, sending it up and back into the stands.']\n",
      "['the batter hits the ball behind the foul line.']\n",
      "['the batter swung and hit the ball. However the ball was hit foul outside of the line of play.']\n"
     ]
    }
   ],
   "source": [
    "for i in labels.iloc[topk]['Id']:\n",
    "    print(list(explanations[explanations['Id']==i]['Explanation']))"
   ]
  }
 ],
 "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.7.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
