{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Plot Classwise Effective Sample Sizes of UCF101clip50 and UCF101clip150\n",
    "- You can plot things about train ,val, or test set.\n",
    "- \"Effective sample size\" means the effective number proposed in [Cui, Yin, et al. \"Class-balanced loss based on effective number of samples.\" Proceedings of the IEEE/CVF Conference on Computer Vision and Pattern Recognition. 2019. (https://arxiv.org/abs/1901.05555)]."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "from glob import glob\n",
    "import matplotlib.pyplot as plt\n",
    "import tensorflow as tf\n",
    "import numpy as np\n",
    "from datasets.data_processing import sequential_slice, sequential_concat\n",
    "from utils.performance_metrics import calc_llrs, calc_oblivious_llrs, threshold_generator, thresh_sanity_check\n",
    "from utils.misc import load_yaml, set_gpu_devices, fix_random_seed\n",
    "\n",
    "def cost_weight_generator(classwise_sample_sizes, beta):\n",
    "    \"\"\"\n",
    "    Instructions:\n",
    "    - TL;DR: beta = 1 - 1e-2, 1 - 1e-3, 1 - 1e-4, and 1 - 1e-5 are\n",
    "      recommended for classwise sample sizes < 10k,\n",
    "      while beta = 1 - 1e-6 and beta = 1e-7 are also recommended for\n",
    "      classwise sample sizes > 100k.\n",
    "    - Larger beta leads to more discriminative weights.\n",
    "    - beta = 1 - 1e-1, 1 - 1e-2, 1 - 1e-3, ..., up to 1 - 1e-7 are allowed; \n",
    "      beta = 1 - 1e-8 = 0.99999999 is rounded to 1 in float32 calculations.\n",
    "    - When beta = 1 - 1e-1, the weights are 0.15, 0.1, 0.1, and 0.1 \n",
    "      for classwise sample size 10, 100, 10k, and 100k, respectively;\n",
    "      thus beta = 1 - 1e-1 is almost meaningless.\n",
    "    - beta = 1 - 1e-5, 1 - 1e-6, and 1 - 1e-7 give almost the same weights \n",
    "      for classwise sample sizes less than 10k.\n",
    "    Args:\n",
    "        classwise_sample_sizes: A list of integers. \n",
    "            The length is equal to the number of classes.\n",
    "        beta: A float larger than 0.Larger beta leads to more discriminative weights.\n",
    "    Returns:\n",
    "        weights: A Tensor of float32 numbers with shape (num classes,).\n",
    "    \"\"\"\n",
    "    beta = np.float32(beta)\n",
    "    weights = (1. - beta)/(1. - tf.pow(beta, classwise_sample_sizes) + 1e-12) \n",
    "        # shape = (num_classes,)\n",
    "    \n",
    "    return weights"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "gpu = 5\n",
    "set_gpu_devices(gpu)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "# UCF101 train/test splitting number\n",
    "splitnum = 1"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Effective Sample Sizes with Different $\\beta$'s"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<BarContainer object of 101 artists>"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "tvt = [\"train\", \"valid\", \"test\"][0]\n",
    "duration = 50\n",
    "datadir = \"/data/t-miyagawa/UCF101-{}-240-320/{}0{}\".format(duration, tvt, splitnum)\n",
    "classdirs = sorted(glob(datadir + \"/*\"))\n",
    "classnames = sorted([i[i.rfind(\"/{}0{}\".format(tvt, splitnum)) + len(\"/{}0{}\".format(tvt, splitnum)) + 1 : ] for i in classdirs])\n",
    "classwise_sample_sizes = []\n",
    "for label, classdir in enumerate(classdirs):\n",
    "    classwise_sample_sizes.append(len(glob(classdir + \"/*.npy\")))\n",
    "\n",
    "beta = 1 - 1e-2 # from 1e-2 to 1e-5 or 1e-7\n",
    "weights = cost_weight_generator(classwise_sample_sizes, beta)\n",
    "\n",
    "plt.title(\"UCF101 {} set, duration={}, beta={}\\nWeight sum={}\".format(tvt, duration, beta, tf.reduce_sum(weights).numpy()))\n",
    "plt.bar([i + 1 for i in range(101)], weights.numpy())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<BarContainer object of 101 artists>"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "tvt = [\"train\", \"valid\", \"test\"][0]\n",
    "duration = 50\n",
    "datadir = \"/data/t-miyagawa/UCF101-{}-240-320/{}0{}\".format(duration, tvt, splitnum)\n",
    "classdirs = sorted(glob(datadir + \"/*\"))\n",
    "classnames = sorted([i[i.rfind(\"/{}0{}\".format(tvt, splitnum)) + len(\"/{}0{}\".format(tvt, splitnum)) + 1 : ] for i in classdirs])\n",
    "classwise_sample_sizes = []\n",
    "for label, classdir in enumerate(classdirs):\n",
    "    classwise_sample_sizes.append(len(glob(classdir + \"/*.npy\")))\n",
    "\n",
    "beta = 1 - 1e-3 # from 1e-2 to 1e-5 or 1e-7\n",
    "weights = cost_weight_generator(classwise_sample_sizes, beta)\n",
    "\n",
    "plt.title(\"UCF101 {} set, duration={}, beta={}\\nWeight sum={}\".format(tvt, duration, beta, tf.reduce_sum(weights).numpy()))\n",
    "plt.bar([i + 1 for i in range(101)], weights.numpy())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<BarContainer object of 101 artists>"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "tvt = [\"train\", \"valid\", \"test\"][0]\n",
    "duration = 50\n",
    "datadir = \"/data/t-miyagawa/UCF101-{}-240-320/{}0{}\".format(duration, tvt, splitnum)\n",
    "classdirs = sorted(glob(datadir + \"/*\"))\n",
    "classnames = sorted([i[i.rfind(\"/{}0{}\".format(tvt, splitnum)) + len(\"/{}0{}\".format(tvt, splitnum)) + 1 : ] for i in classdirs])\n",
    "classwise_sample_sizes = []\n",
    "for label, classdir in enumerate(classdirs):\n",
    "    classwise_sample_sizes.append(len(glob(classdir + \"/*.npy\")))\n",
    "\n",
    "beta = 1 - 1e-4 # from 1e-2 to 1e-5 or 1e-7\n",
    "weights = cost_weight_generator(classwise_sample_sizes, beta)\n",
    "\n",
    "plt.title(\"UCF101 {} set, duration={}, beta={}\\nWeight sum={}\".format(tvt, duration, beta, tf.reduce_sum(weights).numpy()))\n",
    "plt.bar([i + 1 for i in range(101)], weights.numpy())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<BarContainer object of 101 artists>"
      ]
     },
     "execution_count": 22,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "tvt = [\"train\", \"valid\", \"test\"][0]\n",
    "duration = 50\n",
    "datadir = \"/data/t-miyagawa/UCF101-{}-240-320/{}0{}\".format(duration, tvt, splitnum)\n",
    "classdirs = sorted(glob(datadir + \"/*\"))\n",
    "classnames = sorted([i[i.rfind(\"/{}0{}\".format(tvt, splitnum)) + len(\"/{}0{}\".format(tvt, splitnum)) + 1 : ] for i in classdirs])\n",
    "classwise_sample_sizes = []\n",
    "for label, classdir in enumerate(classdirs):\n",
    "    classwise_sample_sizes.append(len(glob(classdir + \"/*.npy\")))\n",
    "\n",
    "beta = 1 - 1e-5 # from 1e-2 to 1e-5 or 1e-7\n",
    "weights = cost_weight_generator(classwise_sample_sizes, beta)\n",
    "\n",
    "plt.title(\"UCF101 {} set, duration={}, beta={}\\nWeight sum={}\".format(tvt, duration, beta, tf.reduce_sum(weights).numpy()))\n",
    "plt.bar([i + 1 for i in range(101)], weights.numpy())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<BarContainer object of 101 artists>"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYQAAAEXCAYAAACtTzM+AAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADl0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uIDMuMC4yLCBodHRwOi8vbWF0cGxvdGxpYi5vcmcvOIA7rQAAIABJREFUeJzt3X+8VVWd//HXWxDMH6EiWYIGBVroN7UYtBkrC0vIin6oYY5hg1Ez8K2mGr9Qk6kNTlpfrSat4asE/kTDqW5JOmOWZiWK5i9Q6gooqCgB4o8Uvfj5/rHW8W4O59x77uX+POf9fDzO456z1tr7rHX2ufuz99prr6OIwMzMbKferoCZmfUNDghmZgY4IJiZWeaAYGZmgAOCmZllDghmZgY4IFgbJL1D0orerkdHSQpJo3vw/X4paWpPvV93krRa0jG9XQ/rHQ4IZSrtTCSdKenywutXS/qOpEckPSvpofx6n5y/WtLzOa/02C/nzZW0QtLLkk6t8P7/LGmdpKclzZM0uJD3DUn3SWqRdGY77dimzp0REb+NiIN2ZB0dJWm+pH/ryffsiEqfa0RMiogFPViHUyVtLft+HV3IHynp15L+KunBntrBd1cwUXKupA35ca4ktVH2q/l/82lJCyW9upA/XNLPJG2UtFbSZ8uW/6Ck+/Nn+ntJYwt5gyVdIOkxSZskXSRp50L+myXdJGmzpGZJHylb92k5/VlJ15f2CX2JA0IHSRoE/Ao4GJgIvBp4O7ABGF8o+sGI2L3weCyn3wP8E3BXhXUfC8wCJgCvB94AnFUo0gycDlzXBe2QJG//AkkDe7sOHfCHsu/Xbwp5VwF/BIYCXwUWSRrWG5XsItOBDwOHAm8BPgh8pkrZTwKnAH8H7Ae8CviPQv7lwCpgX+A44BxJ7waQNAa4AvgssCfwc6Cp8L2YBYwDDgEOBN4K/GtediDwM+AXwN65zpdLOjDnHw2cA0zO+atI26lviQg/Cg8ggNFlaWcCl+fnpwFPALu3sY7VwDHtvM+twKllaVcC5xReTwDWVVj2cuDMNtY9EXgReAl4Frgnp/8GmAP8DngeGA18CngAeAZYCXymsJ6jgbVl7foycC+wGbga2KVKHUYDN+dyfwGuLuS9CfgfYCOwAjgxp0/PdX4x1/vnNW6zfwEeBx4D/qG4DXObTyuUPRW4tWx7zwD+DKzKad8F1gBPA3cC76jhcz0tP9+JtJN4GHgSuBQYkvNG5vebCjySP5evduI7uk0byvIOBLYAexTSfgt8tsZ1rwZmA8uBTcCPitsY+ABwN/AU8HvgLTn9MuDl/L16Fjg9p/8YWJe/B7cAB3eivb8HphdeTwNuq1J2EfAvhdd/C7wA7Arsnj//YYX8ucBl+flM4LpC3k65PRPy66XACYX8TwBr8vNDcrtVyP9v4Bv5+beBCwt5++W6vLGjn0d3PnyE2HHHANdHxLPdsO6DSWcQJfcA+0oa2pGVRMT1pKORqyMdPR5ayD6FtOPdg9ad1gdIZzqfAi6Q9NY2Vn8iacc4inS0dmqVct8g/UPsBYwgH6VJ2o0UDK4EXgNMAS6SNDYi5pKO0M7L9f5ge22VNJEUpN4LjCFtn476MHAEUOoeuAM4jHQkdyXwY0m7tPO5lpyaH+8mneHtDny/rMxRwEGkgH+GpDfntnxC0lNtPA4orONwSX+R9CdJXyscxR4MrIyIZwpl78nptToZOBZ4IynAlI6CDwfmkY7OhwL/STqCHhwRp5CCXOnM+Ly8rl+StstrSGfFV5TeRNKsttpbqE+l/4u22qOy54NzHVQl/5A2lm0vf4SkIW3Uo61lKcvvdQ4IHTeUdDTanp8Wvtw/rXHdu5OOpEpKz/foSAXbMT8ilkVES0S8FBHXRcRDkdxM2om/o43lvxcRj0XERtIp9WFVyr1E6vbaLyJeiIhbc/oHgNUR8aNchz8C1wIndLI9JwI/ioj7I+I50tlcR/17RGyMiOcBIuLyiNiQ6/d/STuUWq+lnAycHxEr80HDbGBKWXfUWRHxfETcQ9q5HZrf98qI2LONxyN5+VtIO5LXAB8DTiKdJcH23yHy6458h74fEWvyNp6T1w/pQOI/I2JJRGyNdN1kC3BktRVFxLyIeCYitpC2zaGlHWhEfLOt9hZWU+n/Yvcq1xGuB07L11GGAP8np++ag+TvgK9J2iUf+HyMdPYAcCPwLklH567hrwCDCvnXA5+XNEzSa4HPldZNOtN9EvgXSTtLeh/wrrJlT5T0FkmvAs4gnSGU8vsEB4TtbQV2LkvbmbSDg3St4HU1rOfDhS/3h2t872dJR+olpefPVCjbWWuKLyRNknRbvsj2FPB+YJ82ll9XeP5X0j9rJaeTjoJul7RM0j/k9NcDR5QdCZ4MvLYzjSGdehfb9HAn1lH+mXxZ0gP54uBTwBDa/kzK61Osw8PAQFKfdUmtn2FFOdisioiXI+I+4Gzg+Jxd/h0iv+7Id6j88yxd/Hw98KWybbd/IX8bkgZI+qbSoIunSd1RUPtnWVLp/+LZyH0vZeaR+uZ/AywDfp3T1+a/J5PObtcAPyB1v64FiIgHSd153ycd9O1D6jorLTuHdG3mblI31k9J+4UnIuIl0pnmcaTt+yXgmsK6bwS+Tjr4WZ0fzxTW3Sc4IGzvEVJfb9EoWv/JbwSOzV0fXW0Z+WgxO5T0ZdvQiXVVm8b2lXSlEUzXkvo3981HZYvZ9tS2UyJiXUR8OiL2I3UxXKQ0emsNcHPZ0eDuEfGP7dS7msdJO6WSA8ryn2Pbo7BKgaf4mbyDFMxOBPbKn8lmWj+T9ur3GGnHWaxPC+m6U5sknaxtRw6VP8rbVqx/qX7LgDdIKp4RHJrTa1X+eZYGRKwB5pRtu10jonRxtPyz+QTpIuoxpKA6stTU3N6vtNXewnoq/V9UbE8Okl+PiJERMSKXezQ/iIiHI+IDETEsIo4g7fRvLyy/KCIOiYihpB34SFIXIvmsbmZEDI+IN5AODu+MiJdz/r0R8a6IGBoRx5K6DIvrvjAixkTEvqT/u4HA/ZXa0VscELZ3NfCvkkZI2klpGN0HSRerIF08WwNcK+lNuczQ/OV+f3srlzRI0i6kf4qd86lraTtcCkyTNFbSnqS+2/mFZXfOy+4EDMzLDqjyVk8AI9sZSTSI1B2yHmiRNAl4X3ttqIWkEySNyC83kXYWL5NGYRwo6ZTcnp0l/U2pHz3X+w1l65ovaX6Vt7oGODV/ZruS/omL7gY+KmnXHJCmtVP1PUg78PWkz/gMtj06be9zvQr4Z0mjJO1O6zWHlnbel4i4IrYdOVT+eAReOavbNz9/E/A10ggXIuJPuc1fz9+Pj5Cu9Vybyx8tqb2gNiN///cmjVK6Oqf/P+Czko5Qspuk4wrBp3zb7UHqUtpACsrnlLX3nLbaWyh6KfBFpSGj+5GOvudXqrikvSW9MddvLHA+cHZpp600NHSP/H/496Tv+/mF5d+Wz2yGkS44N+Uzh9KQ1f3yuo/Mn/vXC8u+JX/mu0r6MqknYX7O20XSIXnZA/K6vxsRm9rZFj0r+sCV7b70IA1T+xbplG4z6ULYh8rKDAG+QwoMzwIPkb5UQ3P+aqqMMiKdykbZ4+hC/hdJ/1hPk0Z4DC7kza+w7KlV3mcoaSTTJuCuwnufVlZuRn6/p0jBbiHwbznvaLYfZXRM4fWZ5NFXFd7/PNJRWenzKY4SOYg0dHY9aWdxE3BYzhtD6yiWn+a0XwGfbmObzSKdplcaZbQP6bpIqf/4TLYfZTS68HoAqdvhadLZx+nFdrf3uZKC9Rn5u7Ge1CWxV84bmd9vYNn34bRqbavS3m/nbfYcaWTY2cDOhfyReb3Pk/q2i9vsFOB3bax7Na2jjJ4CFpD630v5E0lHzE/lz+fH5BFNpLOBR3Lel0ldYT/Ln/3DpCGh243iq6G9yt+njflxHtuO5nmW1pFgB+Y2/zW/5xfL1vWFvF2ey9txXFn+rbm+G0kXzXcr5L0zfz5/ze9xctmy38rfi2dJF9OL36s9SaPzniN9V/8dGNDd+7OOPpQra9YnKV3cu4c0vPGl9spb2yRdDPw4Im7o7bpY3+OAYGZmgK8hmJlZ5oBgZmaAA4KZmWUOCHVM0g8lfa3Gsn16llEz634OCH2IpNmSflmW9ucqaVPaW19EfDYivtFFdevR3xjYUXm8d61TJr9baVrxp3LZn0gaXsj/dv7Mn1GaTvqTZcu/R9JdStMtr5Q0vZB3tNJU58WbrqYW8vfO7/ecpIclfaKQd5ykW3O91km6uDDmH6U7wIvrbZH08wrt+2TefqdVyBukdFd2xTtmKy2rNEX7ytzex5SmhB5YttznJa3K7XpArbN+ttmmXOaY/Hk+pzRF9Yk11qumbd7W59Hwenvcqx+tD9KUvZvJ45NJN7asJo1bLqYFaY6grnzv+eT7D6rkd3j8eC9/lp8hjRUfAQwnjauvOOMnaVqJ/fLzwaRx7k2F/LNIM7TuRJoEbxPwtzlv57zNPkMaL/83pHHoh+b8oyncy1Hhva8i3fi1O2nSu83kGUFJd/pOJN3UtRdpbPsPq6xHpCmVP1mWvhfwIOmO2O3udyDdeHZLpTpWW5Y06d2e+fnepPtIvljIP4005n5srtcbgb1raVNe5klgEulO3qGUzQjaRr3a3ebtfR6N/uj1CvhR2BjpzuG/Am/Lr08k3Zx2c1lac2GZilNJ57z5FHbypJusStNEn8a2N3DNBy4k3TD2DLCk9I+YdxhBuqnmWeDjFepecbpr2rkZizQz6O+AC0g3NK0kTVl8KunmrieBqZ34LGueMrlsucGkm4aWt1GmCfhSfr5vbl/x5q07gJPy86OpEhCA3UjTaR9YSLsM+GaV8h8F7quS96683XYrS/8h6fc3XvnMC3mjSFOfT6pUx7aWLZQZSprO5aL8eqe83SbUuJ22aRNpdtlvtLNMxXrVss1raVMjP9xl1IdExIukHfE7c9I7SXPZ31qWdgu0PZV0+bqVpon+ImlemdGkHVW5KaSj4b1IP8YzJ9er9N6HRppW4OoKy1ac7rpGR5COKIfmtiwkHWmPBv4e+L7SNBDdNmWypAPy8s+T7rI9r0q5V+W6LQOIiCdIR/mfUpry4O2kuYxuLSz2GklP5C6UC9Q6D9aBQEuk6SZqqec7qT4n0VTg2kgzvpbqOp70gy4/rLLMf5Bm9Hy+QjvbXFZpqu6nScH/UNJdvZC2/QjgEElrcpvPUvWpPsrbdGRe/32SHpd0udIUGrXUq81tXsPn0fAcEPqem2nd+b+DFBB+W5Z2c37ekamkS9NEL4uIv1J5muifRMTtkebduYLqU1tXUm2661qsym3YSuo+2Z80/8yWiPhv0lH0aOi2KZOJiEfy8vuQ5pB6sEpdf0ja0RTv9L2KNF3FFtK2+mpElGYMfZD0Ob4OeA/wNlrnztmdNEVGUcWpqiW9l7TTP6NC3q6k2U7nF9IGABcBMyPP41O2zEdI3ZA/qZDX5rLwylTdryYFtR/SOnlfaf6q9wH/i/S7ECdRYQ6pKm0aQZpe42OkaUxe+cWzGupVdZvX0iZzQOiLbgGOykdFwyLiz6RT4b/NaYfkMtCxqaTLp4leU6HMjkzLXG2661oUZwIt/SZBeVqHpoimY1MmvyLSbwAsAH5W4ULpt0if/4ml9ShNLreQNE/PINIR6emSjsvrWxcRyyPNwrmK9Dl9rEodS/XcZqpqpYnUrgSOLzubKPkoqcvw5kLaPwH3RsRt5YXzGcp5tM7nX67qsuXy93MZaWcLrWcb50XEUxGxmnT2sM3Ej2206XnSgcufIv2exDmFZdurV1vbvOY2NbL+9BuyjeIPpMnzPk3qWycinpb0WE57LO9YoHUq6ffWsN7HaT16g22nON5hEbEu1w9JRwE3SrqF1iO2XWk9Gu7sbx8g6Sukbo5q9SgFjtKUyaXphzsyBfRAUhfcq0k7WiSdReprf1dEFI/qDwH+FK1zA62QdF0uW+m3r4PWA7E/kWZUHZN3rNvVU+lXypqAf4iIX1Wp71Tg0rJgN4H0Yy+lnenepF9ZOwy4mHRt57f5hGkQMETSOlKXTdVlI2JmhfcfSLpwDOk61otsOxX2NkG4nTbd28ay7dWrrW3e0TY1pt6+iOHH9g/SGcETwOcKaf+R064opJV+BvMU0miXnUn922/O+fNpnbl0EikovJm0c17A9heVixegj2bbmU7XAe9ro84nACPy84NJR3pvyK/Xko7QBpBmI32JbS8qF2cfHZ2+ltusey1wVAc/w8+SLpgOJ50dLaP6KKOPkmZg3QkYRppS+65C/mzSby6/tsKybyQdmb6H1hE1zeSLm6Quk9fnvP1JP9jyo8LyC0ldTrvROsqsNMrokLzNt7uIX1h+BGm67vKROHuSAm/p8XvSNaQhpB14Me+jpIEGr83bqOqyed2nAa/Jz8fmz/b8wntfSprmfI9cvweBabW0KX8/VpGm0d41b4vL2mtTe9u8vWX9SA93GfVNN5OOUIv98L/NaaXuIiL9JOD7SBeDHyPttM8ljZTZRkT8EvgeaYfUDJROnbfUWKczgQW5a2q7ceGkQLRE6YdNmoDPR8TKnPdp0k88biAFi9/X+J474j9JP/F5H2mI4XW0XvhEadx+6adCh5N+4vCZXP5l4COFdZ1D+qGYZrWO+f8KQEQ8RNqJfY90BnQz6TrOxXnZw0ntfS7/vY9tu2r+idRP/iQpMPxjRJSOar9EClCXFN63/CznFOAPuR6viNRds670IB21Px0RmyNdbyrmbQRezq+3trVsXv3fAfdJeo70g0qL2fasbSYpSD5GOuO9kjSleLttioh5pICyhHSws6X0edVQr6rbvIZlDc922rCUfpDmftLvLbT74y1mVv98htBAJH1E0mBJe5HOJH7uYGBmJQ4IjeUzpK6Jh4CtwD+2XdzMGom7jMzMDPAZgpmZZf3qPoR99tknRo4c2dvVMDPrN+68886/RMSwWsr2q4AwcuRIli5d2tvVMDPrNyQ9XGtZdxmZmRnggGBmZpkDgpmZAQ4IZmaWOSCYmRnggGBmZpkDgpmZAQ4IZmaWOSCYmRnQz+5UNrO+ZeSs1l8JXf3N43qxJtYVfIZgZmaAA4KZmWUOCGZmBjggmJlZ5oBgZmaAA4KZmWUOCGZmBjggmJlZ5oBgZmaAA4KZmWU1BQRJEyWtkNQsaVaF/MGSrs75SySNLOTNzukrJB2b0w6SdHfh8bSkL3RVo8zMrOPanctI0gDgQuC9wFrgDklNEbG8UGwasCkiRkuaApwLfFzSWGAKcDCwH3CjpAMjYgVwWGH9jwI/6cJ2mZlZB9VyhjAeaI6IlRHxIrAQmFxWZjKwID9fBEyQpJy+MCK2RMQqoDmvr2gC8FBEPNzZRpiZ2Y6rJSAMB9YUXq/NaRXLREQLsBkYWuOyU4Crqr25pOmSlkpaun79+hqqa2ZmndGrF5UlDQI+BPy4WpmImBsR4yJi3LBhw3qucmZmDaaWgPAosH/h9YicVrGMpIHAEGBDDctOAu6KiCc6Vm0zM+tqtQSEO4AxkkblI/opQFNZmSZgan5+PHBTREROn5JHIY0CxgC3F5Y7iTa6i8zMrOe0O8ooIlokzQRuAAYA8yJimaSzgaUR0QRcAlwmqRnYSAoa5HLXAMuBFmBGRGwFkLQbaeTSZ7qhXWZm1kE1/YRmRCwGFpelnVF4/gJwQpVl5wBzKqQ/R7rwbGZmfYDvVDYzM8ABwczMMgcEMzMDHBDMzCxzQDAzM8ABwczMMgcEMzMDHBDMzCxzQDAzM8ABwczMMgcEMzMDHBDMzCxzQDAzM8ABwaxNI2ddx8hZ1/V2Ncx6hAOCmZkBDghmZpY5IJiZGeCAYGZmWU0BQdJESSskNUuaVSF/sKSrc/4SSSMLebNz+gpJxxbS95S0SNKDkh6Q9PauaJCZmXVOuwFB0gDgQmASMBY4SdLYsmLTgE0RMRq4ADg3LzsWmAIcDEwELsrrA/gucH1EvAk4FHhgx5tjZmadVcsZwnigOSJWRsSLwEJgclmZycCC/HwRMEGScvrCiNgSEauAZmC8pCHAO4FLACLixYh4asebY2ZmnVVLQBgOrCm8XpvTKpaJiBZgMzC0jWVHAeuBH0n6o6SLJe3WqRaYmVmX6K2LygOBtwI/iIjDgeeA7a5NAEiaLmmppKXr16/vyTqamTWUWgLCo8D+hdcjclrFMpIGAkOADW0suxZYGxFLcvoiUoDYTkTMjYhxETFu2LBhNVTXzMw6o5aAcAcwRtIoSYNIF4mbyso0AVPz8+OBmyIicvqUPAppFDAGuD0i1gFrJB2Ul5kALN/BtpiZ2Q4Y2F6BiGiRNBO4ARgAzIuIZZLOBpZGRBPp4vBlkpqBjaSgQS53DWln3wLMiIitedX/G7giB5mVwKe6uG1mZtYB7QYEgIhYDCwuSzuj8PwF4IQqy84B5lRIvxsY15HKmplZ9/GdymZmBjggmJlZ5oBgZmaAA4KZmWUOCGZmBjggmJlZ5oDQRfzbu2bW3zkgmJkZ4IDQJ/jswsz6AgcEa1gOxGbbckAwMzPAAcHMzDIHBDMzAxwQzMwsc0AwMzPAAcHMzDIHBDMzAxwQzMwsq+knNM1qVbzRa/U3j+vFmphZR9V0hiBpoqQVkpolzaqQP1jS1Tl/iaSRhbzZOX2FpGML6asl3SfpbklLu6IxZmbWee2eIUgaAFwIvBdYC9whqSkilheKTQM2RcRoSVOAc4GPSxoLTAEOBvYDbpR0YERszcu9OyL+0oXtMTOzTqrlDGE80BwRKyPiRWAhMLmszGRgQX6+CJggSTl9YURsiYhVQHNen5mZ9TG1BIThwJrC67U5rWKZiGgBNgND21k2gP+WdKek6dXeXNJ0SUslLV2/fn0N1TUz6xn1NkFib44yOioi3gpMAmZIemelQhExNyLGRcS4YcOG9WwNzcwaSC0B4VFg/8LrETmtYhlJA4EhwIa2lo2I0t8ngZ/griQzs15Vy7DTO4AxkkaRduZTgE+UlWkCpgJ/AI4HboqIkNQEXCnpfNJF5THA7ZJ2A3aKiGfy8/cBZ3dJi2w79TwUtNS2emtXX9Mfv0P9sc69rd2AEBEtkmYCNwADgHkRsUzS2cDSiGgCLgEuk9QMbCQFDXK5a4DlQAswIyK2StoX+Em67sxA4MqIuL4b2tdp3tGY9Q7vyHtPTTemRcRiYHFZ2hmF5y8AJ1RZdg4wpyxtJXBoRytr1hkO7ma18dQVZmYGeOoK6wCfypvVN58hmPVB9Ta+3foHBwQzsx7S1wO9A0If09e/MGZWv3wNocH4OoCZVeOAYJ3iwGJWf9xlZGZmgAOCmZllDghmZgY4IJiZWeaAYGZmgAOCmZllDghmPaCWGw59U6L1NgcEMzMDHBDMzCxzQOggn9abWb1yQDAz62V95UDTAcHMzIAaA4KkiZJWSGqWNKtC/mBJV+f8JZJGFvJm5/QVko4tW26ApD9K+sWONsSsr+krR339Wekz9OfYM9oNCJIGABcCk4CxwEmSxpYVmwZsiojRwAXAuXnZscAU4GBgInBRXl/J54EHdrQRZma242o5QxgPNEfEyoh4EVgITC4rMxlYkJ8vAiZIUk5fGBFbImIV0JzXh6QRwHHAxTveDDMz21G1/B7CcGBN4fVa4IhqZSKiRdJmYGhOv61s2eH5+XeA04E92npzSdOB6QAHHHBADdW1Wvk3DcysqFcuKkv6APBkRNzZXtmImBsR4yJi3LBhw3qgdtYXuR/Z+qv+9N2t5QzhUWD/wusROa1SmbWSBgJDgA1tLPsh4EOS3g/sArxa0uUR8fedaoXtsL52ttDX6mPWCGo5Q7gDGCNplKRBpIvETWVlmoCp+fnxwE0RETl9Sh6FNAoYA9weEbMjYkREjMzru8nBwMysd7V7hpCvCcwEbgAGAPMiYpmks4GlEdEEXAJcJqkZ2EjayZPLXQMsB1qAGRGxtZvaYmadUDob85mY1dJlREQsBhaXpZ1ReP4CcEKVZecAc9pY92+A39RSDzMz6z6+U9nMzAAHBDOzdvWnkUI7wgHBzMyAGq8h1Jt6uojm4Zm9r56+T9bYfIZgZmZAg54hWNdqhL5Vs0bgMwQzMwMcELpFo4xIMLP64oBgZmaAA4KZmWUOCGZmBniUUZ/mewysHvh73H84INQpX9Q2s45yl5GZmQEOCGZmljkg7ADfb2Bm9cQBocA7eDNrZL6obH1GowRjz4664zo6cqnW8o2+bWo6Q5A0UdIKSc2SZlXIHyzp6py/RNLIQt7snL5C0rE5bRdJt0u6R9IySWd1VYPMrLGUzuwb5YCiO7UbECQNAC4EJgFjgZMkjS0rNg3YFBGjgQuAc/OyY4EpwMHAROCivL4twHsi4lDgMGCipCO7pklmZtYZtXQZjQeaI2IlgKSFwGRgeaHMZODM/HwR8H1JyukLI2ILsEpSMzA+Iv4APJvL75wfsYNtMTNrl2+Uq66WgDAcWFN4vRY4olqZiGiRtBkYmtNvK1t2OLxy5nEnMBq4MCKWVHpzSdOB6QAHHHBADdWtrNH7BntDtVN4b4P6VG872kbcZ/TaKKOI2BoRhwEjgPGSDqlSbm5EjIuIccOGDevZSpqZNZBaAsKjwP6F1yNyWsUykgYCQ4ANtSwbEU8BvyZdYzAzs6ynL5bXEhDuAMZIGiVpEOkicVNZmSZgan5+PHBTREROn5JHIY0CxgC3SxomaU8ASa8C3gs8uOPNMbMij76xjmj3GkK+JjATuAEYAMyLiGWSzgaWRkQTcAlwWb5ovJEUNMjlriFdgG4BZkTEVkmvAxbk6wg7AddExC+6o4HtacR+wt5Wb33NZvWiphvTImIxsLgs7YzC8xeAE6osOweYU5Z2L3B4Rytr1lfU64GEg3Vj89QVZmZdoB665xwQrN+ph388s77IAcHMrIv114MWT25nvao//tOYdYW+eB3KZwhmZn1Ib55d+AzBtuORJtYT/D3rexwQzKxhOShty11GZvTfi4BmXclnCGbWL/SVgN0XLwZ3FZ8hmJkZ4IBg1pDcRWaVuMuojvgfvPfVc3eC1T8HhH7CoyHMrLu5y6ib+dTczPoLBwSzXuQDBusVFcDZAAAJLUlEQVRLHBDMauSdt9U7BwSrS955m3WcA4KZmQEOCGZmltU07FTSROC7wADg4oj4Zln+YOBS4G3ABuDjEbE6580GpgFbgc9FxA2S9s/l9wUCmBsR3+2SFjUAd4VU5nsAzHZMu2cIkgYAFwKTgLHASZLGlhWbBmyKiNHABcC5edmxwBTgYGAicFFeXwvwpYgYCxwJzKiwTjMz60G1dBmNB5ojYmVEvAgsBCaXlZkMLMjPFwETJCmnL4yILRGxCmgGxkfE4xFxF0BEPAM8AAzf8eaYmVln1RIQhgNrCq/Xsv3O+5UyEdECbAaG1rKspJHA4cCSSm8uabqkpZKWrl+/vobqdj2PWDGzRtCrU1dI2h24FvhCRDxdqUxEzAXmAowbNy56sHrdyv3dZq18wNU31HKG8Ciwf+H1iJxWsYykgcAQ0sXlqstK2pkUDK6IiP/qTOXNzKzr1BIQ7gDGSBolaRDpInFTWZkmYGp+fjxwU0RETp8iabCkUcAY4PZ8feES4IGIOL8rGmJmibs4rbPa7TKKiBZJM4EbSMNO50XEMklnA0sjoom0c79MUjOwkRQ0yOWuAZaTRhbNiIitko4CTgHuk3R3fquvRMTirm6gWZG76syqq+kaQt5RLy5LO6Pw/AXghCrLzgHmlKXdCqijlTVrRA5i1lN8p7KZmQEOCD3KfbvWXfzdsq7gX0wzs4ocYBqPA4K1yTsFs8bhgGDWT/XWxea+fJDQl+vWHzggmPUj/X3EkXfYfZsvKpuZGeCAYGZmmbuMzKzLuWuof/IZgpmZAQ4IZmaWOSCYmRnggGBmZpkDgpmZAQ4IZmaWOSCYNQjPiGrtcUAwMzPAAcFsOz6StkZVU0CQNFHSCknNkmZVyB8s6eqcv0TSyELe7Jy+QtKxhfR5kp6UdH9XNMTMzHZMuwFB0gDgQmASMBY4SdLYsmLTgE0RMRq4ADg3LzsWmAIcDEwELsrrA5if08zMrA+o5QxhPNAcESsj4kVgITC5rMxkYEF+vgiYIEk5fWFEbImIVUBzXh8RcQuwsQvaYGZmXaCWgDAcWFN4vTanVSwTES3AZmBojcu2SdJ0SUslLV2/fn1HFjUzsw7o8xeVI2JuRIyLiHHDhg3r7eqYmdWtWgLCo8D+hdcjclrFMpIGAkOADTUua2ZmfUAtAeEOYIykUZIGkS4SN5WVaQKm5ufHAzdFROT0KXkU0ihgDHB711TdzMy6UrsBIV8TmAncADwAXBMRyySdLelDudglwFBJzcAXgVl52WXANcBy4HpgRkRsBZB0FfAH4CBJayVN69qmmZlZR9T0i2kRsRhYXJZ2RuH5C8AJVZadA8ypkH5Sh2pqZmbdqs9fVDYzs57hgGBmZoADgpmZZQ4IZmYGOCCYmVnmgGBmZoADgpmZZQ4IZmYGOCCYmVnmgGBmZoADgpmZZQ4IZmYGOCCYmVnmgGBmZoADgpmZZQ4IZmYGOCCYmVnmgGBmZoADgpmZZTUFBEkTJa2Q1CxpVoX8wZKuzvlLJI0s5M3O6SskHVvrOs3MrGe1GxAkDQAuBCYBY4GTJI0tKzYN2BQRo4ELgHPzsmOBKcDBwETgIkkDalynmZn1oFrOEMYDzRGxMiJeBBYCk8vKTAYW5OeLgAmSlNMXRsSWiFgFNOf11bJOMzPrQYqItgtIxwMTI+K0/PoU4IiImFkoc38usza/fgg4AjgTuC0iLs/plwC/zIu1uc7CuqcD0/PLg4AVHWzjPsBfOrhMf9Zo7YXGa3OjtRcar81d2d7XR8SwWgoO7KI37DYRMReY29nlJS2NiHFdWKU+rdHaC43X5kZrLzRem3urvbV0GT0K7F94PSKnVSwjaSAwBNjQxrK1rNPMzHpQLQHhDmCMpFGSBpEuEjeVlWkCpubnxwM3ReqLagKm5FFIo4AxwO01rtPMzHpQu11GEdEiaSZwAzAAmBcRyySdDSyNiCbgEuAySc3ARtIOnlzuGmA50ALMiIitAJXW2fXNA3agu6mfarT2QuO1udHaC43X5l5pb7sXlc3MrDH4TmUzMwMcEMzMLKvbgNAIU2NI2l/SryUtl7RM0udz+t6S/kfSn/PfvXq7rl0p3+3+R0m/yK9H5SlTmvMUKoN6u45dSdKekhZJelDSA5LeXs/bWNI/5+/z/ZKukrRLvW1jSfMkPZnv4SqlVdymSr6X236vpLd2V73qMiA00NQYLcCXImIscCQwI7dzFvCriBgD/Cq/riefBx4ovD4XuCBPnbKJNJVKPfkucH1EvAk4lNT2utzGkoYDnwPGRcQhpEEnU6i/bTyfNJ1PUbVtOok0QnMM6SbdH3RXpeoyINAgU2NExOMRcVd+/gxpRzGcbacSWQB8uHdq2PUkjQCOAy7OrwW8hzRlCtRfe4cA7ySN5CMiXoyIp6jjbUwa/fiqfE/TrsDj1Nk2johbSCMyi6pt08nApZHcBuwp6XXdUa96DQjDgTWF12tzWt3KM8weDiwB9o2Ix3PWOmDfXqpWd/gOcDrwcn49FHgqIlry63rb1qOA9cCPcjfZxZJ2o063cUQ8CnwbeIQUCDYDd1Lf27ik2jbtsf1ZvQaEhiJpd+Ba4AsR8XQxL98gWBdjiyV9AHgyIu7s7br0oIHAW4EfRMThwHOUdQ/V2Tbei3REPArYD9iN7btW6l5vbdN6DQgNMzWGpJ1JweCKiPivnPxE6ZQy/32yt+rXxf4O+JCk1aRuwPeQ+tf3zN0LUH/bei2wNiKW5NeLSAGiXrfxMcCqiFgfES8B/0Xa7vW8jUuqbdMe25/Va0BoiKkxcv/5JcADEXF+Ias4lchU4Gc9XbfuEBGzI2JERIwkbdObIuJk4NekKVOgjtoLEBHrgDWSDspJE0h3/tflNiZ1FR0padf8/S61t263cUG1bdoEfDKPNjoS2FzoWupaEVGXD+D9wJ+Ah4Cv9nZ9uqmNR5FOK+8F7s6P95P61X8F/Bm4Edi7t+vaDW0/GvhFfv4G0hxZzcCPgcG9Xb8ubuthwNK8nX8K7FXP2xg4C3gQuB+4DBhcb9sYuIp0jeQl0lngtGrbFBBp1ORDwH2kEVjdUi9PXWFmZkD9dhmZmVkHOSCYmRnggGBmZpkDgpmZAQ4IZmaWOSCYmRnggGBmZtn/B4tcuhKw0tyxAAAAAElFTkSuQmCC\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "tvt = [\"train\", \"valid\", \"test\"][0]\n",
    "duration = 50\n",
    "datadir = \"/data/t-miyagawa/UCF101-{}-240-320/{}0{}\".format(duration, tvt, splitnum)\n",
    "classdirs = sorted(glob(datadir + \"/*\"))\n",
    "classnames = sorted([i[i.rfind(\"/{}0{}\".format(tvt, splitnum)) + len(\"/{}0{}\".format(tvt, splitnum)) + 1 : ] for i in classdirs])\n",
    "classwise_sample_sizes = []\n",
    "for label, classdir in enumerate(classdirs):\n",
    "    classwise_sample_sizes.append(len(glob(classdir + \"/*.npy\")))\n",
    "\n",
    "beta = 1 - 1e-6 # from 1e-2 to 1e-5 or 1e-7\n",
    "weights = cost_weight_generator(classwise_sample_sizes, beta)\n",
    "\n",
    "plt.title(\"UCF101 {} set, duration={}, beta={}\\nWeight sum={}\".format(tvt, duration, beta, tf.reduce_sum(weights).numpy()))\n",
    "plt.bar([i + 1 for i in range(101)], weights.numpy())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<BarContainer object of 101 artists>"
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "tvt = [\"train\", \"valid\", \"test\"][0]\n",
    "duration = 50\n",
    "datadir = \"/data/t-miyagawa/UCF101-{}-240-320/{}0{}\".format(duration, tvt, splitnum)\n",
    "classdirs = sorted(glob(datadir + \"/*\"))\n",
    "classnames = sorted([i[i.rfind(\"/{}0{}\".format(tvt, splitnum)) + len(\"/{}0{}\".format(tvt, splitnum)) + 1 : ] for i in classdirs])\n",
    "classwise_sample_sizes = []\n",
    "for label, classdir in enumerate(classdirs):\n",
    "    classwise_sample_sizes.append(len(glob(classdir + \"/*.npy\")))\n",
    "\n",
    "beta = 1 - 1e-7 # from 1e-2 to 1e-5 or 1e-7\n",
    "weights = cost_weight_generator(classwise_sample_sizes, beta)\n",
    "\n",
    "plt.title(\"UCF101 {} set, duration={}, beta={}\\nWeight sum={}\".format(tvt, duration, beta, tf.reduce_sum(weights).numpy()))\n",
    "plt.bar([i + 1 for i in range(101)], weights.numpy())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "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.5.2"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
