{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "f6e4867c",
   "metadata": {},
   "outputs": [],
   "source": [
    "import sys; sys.path.append(\"../\") # For relative imports\n",
    "\n",
    "from utils.experiment_utils import *\n",
    "\n",
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "323738a7",
   "metadata": {},
   "source": [
    "In this notebook, we investigate the class-conditional coverage properties of standard conformal on ImageNet. \n",
    "\n",
    "**Note**: Before running this notebook, run `sh run_experiment.sh` (or just a single experiment using standard conformal). \n",
    "\n",
    "Mapping from ImageNet labels to names: https://gist.github.com/yrevar/942d3a0ac09ec9e5eb3a"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "34949a8e",
   "metadata": {},
   "outputs": [],
   "source": [
    "dataset = 'imagenet'\n",
    "pth = f'/home/ANONYMIZED/code/class-conditional-conformal/.cache/paper/varying_n/{dataset}/random_calset/n_totalcal=20/score=softmax/seed=0_allresults.pkl'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "f2a22c8d",
   "metadata": {},
   "outputs": [],
   "source": [
    "with open(pth, 'rb') as f:\n",
    "    results = pickle.load(f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "47be7b22",
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "data": {
      "image/png": "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LwCNi4uDtbW11gskIiIi+hAah5158+bh5MmTGDp0KCZMmIBKlSoBADZu3Ij69etrvUAiIiKiD6HxNTs1atTA2bNnM7XPmjWLFwUTERFRkaPxzM7Nmzdx69YtafnEiRMYMWIEVq5cCaVSqdXiiIiIiD6UxmGne/fu2LdvHwAgISEBPj4+OHHiBL777jtMnTpV6wUSERERfQiNw865c+dQp04dAMAff/yB6tWr48iRI1i7di2Cg4O1XR8RERHRB9E47KSmpkKlUgF4c+t5u3btAABVqlRBfHy8dqsjIiIi+kAahx0XFxf8+uuvOHjwIMLCwtCqVSsAwJ07d3L13VVEREREBUnjsDNjxgz89ttvaNKkCbp16wY3NzcAwN9//y2d3iIiIiIqKjS+9bxJkya4f/8+kpKSUKpUKal94MCBMDQ01GpxRERERB9K47ADALq6umpBBwAcHR21UQ8RERGRVuUp7GzcuBF//PEHbty4gZSUFLV1J0+e1EphRERERNqg8TU7CxYsQJ8+fWBlZYVTp06hTp06sLCwwNWrV+Hr65sfNRIRERHlmcZhZ/HixVi6dCl++eUX6OnpYdy4cQgLC8OwYcPw5MmT/KiRiIiIKM80Djs3btyQvvDTwMAAT58+BQD07NkT69at0251RERERB9I47BjY2ODBw8eAAAcHBxw7NgxAEBcXByEENqtjoiIiOgDaRx2mjZtim3btgEA+vXrh5EjR8LHxwddunTBZ599pvUCiYiIiD6ExndjLV26FOnp6QCAQYMGwdzcHIcOHULbtm0xaNAgrRdIRERE9CE0Djs6OjrQ0flvQqhz587o3LmzVosiIiIi0pZchZ0zZ87keoM1atTIczFERERE2parsFOzZk0oFIr3XoCsUCiQlpamlcKIiIiItCFXYScuLi6/6yAiIiLKF7kKOw4ODvldBxEREVG+0PgC5YCAAFhbW6Nv375q7YGBgbh37x6+/fZbrRVHREQfF8fxIYVdAsmQxs/Z+e2331ClSpVM7S4uLvj111+1UhQRERGRtmgcdhISEmBra5upvXTp0oiPj9dKUURERETaonHYsbe3x+HDhzO1Hz58GHZ2dlopioiIiEhbNL5mp3///hgxYgRSU1PRtGlTAMCePXswbtw4jB49WusFEhEREX0IjcPOuHHj8PDhQwwePBgpKSkAAH19fXz77bfw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\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "bins = np.linspace(0.5, 1, 20)\n",
    "plt.hist(results['standard'][2]['raw_class_coverages'], bins=bins)\n",
    "plt.xlabel('Class-conditional coverage')\n",
    "plt.ylabel('Number of classes')\n",
    "\n",
    "ymin, ymax = plt.ylim()\n",
    "plt.vlines(x=0.9, ymin=ymin, ymax=ymax, label='Desired coverage (0.9)', color='limegreen')\n",
    "plt.ylim(ymin, ymax)\n",
    "\n",
    "plt.title('Standard conformal on ImageNet')\n",
    "plt.legend(loc='upper left')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "e6700b77",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Class-conditional coverages:\n",
      "[0.95848057 0.98090278 0.94117647 0.90685859 0.92560554 0.88640275\n",
      " 0.94952951 0.96210164 0.92355556 0.98613518 0.96681223 0.98515284\n",
      " 0.98526863 0.98339161 0.98594025 0.97535211 0.99136442 0.97554585\n",
      " 0.9554413  0.99035933 0.95175439 0.95934256 0.98415493 0.96167247\n",
      " 0.9877836  0.95192308 0.88       0.92699491 0.9470538  0.96327925\n",
      " 0.96709957 0.96007098 0.90933333 0.90517241 0.89063867 0.88763066\n",
      " 0.8558952  0.95742832 0.92650919 0.93825043 0.95829713 0.90932868\n",
      " 0.94596988 0.91758794 0.92643285 0.96832192 0.836966   0.96575342\n",
      " 0.98615917 0.93787748 0.95438596 0.98931434 0.83333333 0.92788879\n",
      " 0.8194325  0.86215979 0.95750217 0.96440972 0.90740741 0.91989437\n",
      " 0.74558304 0.93410508 0.84479167 0.95081967 0.92957746 0.90339426\n",
      " 0.79020979 0.88636364 0.85008666 0.9675491  0.96462468 0.96575342\n",
      " 0.98167539 0.77873812 0.78497409 0.97243755 0.96140351 0.94323144\n",
      " 0.94220665 0.95368782 0.90964379 0.97048611 0.91804708 0.92857143\n",
      " 0.97829861 0.95462478 0.7677643  0.98792062 0.9792567  0.97826087\n",
      " 0.98685364 0.97635727 0.97723292 0.97695035 0.98502203 0.97891037\n",
      " 0.9806338  0.96847636 0.96616915 0.92248062 0.98607485 0.90079017\n",
      " 0.99026549 0.96108597 0.97416021 0.99120493 0.96309315 0.96818573\n",
      " 0.91373239 0.97053726 0.94371152 0.94283276 0.87413194 0.94395797\n",
      " 0.92121212 0.95833333 0.95909487 0.96925705 0.8462867  0.90972222\n",
      " 0.93474427 0.88742304 0.9291958  0.92491468 0.85989492 0.95644599\n",
      " 0.91441048 0.95617879 0.92400691 0.98320071 0.99050086 0.95017483\n",
      " 0.95431034 0.96788194 0.90791738 0.98183391 0.9720524  0.98101812\n",
      " 0.97222222 0.97666379 0.97224631 0.97767857 0.97865073 0.97219809\n",
      " 0.96844873 0.98792062 0.98242531 0.95172414 0.98006932 0.97797357\n",
      " 0.9200695  0.84729494 0.84750733 0.94185022 0.94194107 0.90394511\n",
      " 0.94545455 0.93593074 0.7243173  0.92962641 0.94323144 0.92700088\n",
      " 0.84364261 0.85204526 0.92629482 0.7136294  0.83628319 0.79429429\n",
      " 0.8600175  0.94425087 0.80948276 0.87971905 0.91356958 0.90854185\n",
      " 0.9293617  0.82126348 0.90751945 0.95478261 0.95774648 0.84114583\n",
      " 0.76977153 0.94336283 0.89023336 0.93171608 0.81701031 0.79406632\n",
      " 0.8633218  0.93386243 0.84907834 0.85311699 0.92694611 0.91777188\n",
      " 0.85677308 0.85551664 0.91707799 0.94478528 0.89785408 0.91418564\n",
      " 0.88770999 0.89759036 0.83958152 0.81849913 0.87336245 0.93413174\n",
      " 0.81730769 0.941331   0.90432383 0.89098712 0.8469657  0.8969697\n",
      " 0.95196507 0.91695804 0.88888889 0.94234079 0.91465517 0.92678725\n",
      " 0.92254134 0.93593074 0.94044444 0.8961039  0.86194996 0.91860465\n",
      " 0.93554007 0.91725979 0.93017241 0.89991372 0.8558952  0.81659389\n",
      " 0.90877797 0.95263158 0.87735849 0.85221239 0.92354474 0.93085566\n",
      " 0.91659501 0.91790393 0.9200695  0.90901137 0.83217993 0.92974848\n",
      " 0.81778929 0.87348354 0.85901926 0.93868739 0.88811189 0.8858885\n",
      " 0.84330986 0.95829713 0.77413793 0.89035088 0.7890223  0.96980155\n",
      " 0.92343934 0.90139616 0.93874029 0.95993031 0.91659574 0.86701209\n",
      " 0.94587629 0.94791667 0.97212544 0.96748682 0.91382979 0.92676548\n",
      " 0.86548673 0.81746725 0.8784965  0.90496949 0.93558282 0.90250216\n",
      " 0.9083045  0.87734242 0.883821   0.88675958 0.92017167 0.94449263\n",
      " 0.97339056 0.93904594 0.85143354 0.95536481 0.88675958 0.91361257\n",
      " 0.70959378 0.97112861 0.9826087  0.88687392 0.96200345 0.91703057\n",
      " 0.87274291 0.99059829 0.95087719 0.98686515 0.98789974 0.97998259\n",
      " 0.97366111 0.96807593 0.97864769 0.96234676 0.85327511 0.98277347\n",
      " 0.92771084 0.97827976 0.93421053 0.89423904 0.86683849 0.92682927\n",
      " 0.94649123 0.94031142 0.93545535 0.94763948 0.90933333 0.91737649\n",
      " 0.9206626  0.92173913 0.89741379 0.98006932 0.95296167 0.95913043\n",
      " 0.9644714  0.95411255 0.95716783 0.99567848 0.96701389 0.99557913\n",
      " 0.97579948 0.95599655 0.96732588 0.9534687  0.95482189 0.94570928\n",
      " 0.93950178 0.9231441  0.96620451 0.97998259 0.96052632 0.96660482\n",
      " 0.96239316 0.91529818 0.96031061 0.99654875 0.99040976 0.88927944\n",
      " 0.9090106  0.9737303  0.97975352 0.8921484  0.96822595 0.98631309\n",
      " 0.94829097 0.92268041 0.97320657 0.97236615 0.92248062 0.92977778\n",
      " 0.98774081 0.97584124 0.78508772 0.90666667 0.8712522  0.94449339\n",
      " 0.9226087  0.97120419 0.94468832 0.96296296 0.98106713 0.96200345\n",
      " 0.97212544 0.92105263 0.91515152 0.95096322 0.88024476 0.8221831\n",
      " 0.96092362 0.90431034 0.92116538 0.95996519 0.98607485 0.93971631\n",
      " 0.92125984 0.92173913 0.78097731 0.78987993 0.95733333 0.96187175\n",
      " 0.94199134 0.94148021 0.94661922 0.99120493 0.99465717 0.89965695\n",
      " 0.92138063 0.92959002 0.970726   0.9745167  0.95855379 0.94303243\n",
      " 0.97610619 0.98421053 0.90529974 0.91225022 0.92795139 0.90917186\n",
      " 0.92602263 0.96660959 0.95789474 0.95986038 0.89947552 0.91116974\n",
      " 0.88917526 0.84622068 0.9506383  0.90627687 0.71378092 0.85539001\n",
      " 0.84939759 0.73093777 0.9372313  0.92524186 0.82268227 0.78050922\n",
      " 0.92857143 0.82661996 0.87554777 0.907585   0.9122807  0.93674177\n",
      " 0.88425047 0.83666377 0.86026201 0.90297203 0.9537925  0.9250646\n",
      " 0.85914261 0.85248714 0.85863874 0.84155844 0.79861711 0.91034483\n",
      " 0.8845815  0.94637817 0.83496007 0.88626422 0.90522586 0.91428571\n",
      " 0.93981083 0.86262799 0.81315789 0.84219554 0.92838654 0.91002571\n",
      " 0.97569444 0.89767842 0.86869565 0.93333333 0.84499557 0.88601036\n",
      " 0.89382071 0.80299033 0.91896552 0.87640449 0.82854656 0.82563208\n",
      " 0.82623805 0.71043478 0.80856643 0.90267176 0.97152718 0.93419913\n",
      " 0.83461211 0.85038693 0.79930495 0.91838488 0.91543156 0.80895009\n",
      " 0.91507799 0.95316565 0.9720035  0.85862966 0.81880932 0.79531657\n",
      " 0.90853659 0.85466795 0.71699741 0.93151888 0.91371872 0.8115688\n",
      " 0.87920621 0.75218914 0.77413793 0.87435009 0.91184097 0.88530806\n",
      " 0.87783595 0.92724046 0.74336283 0.90017212 0.93033135 0.85021645\n",
      " 0.88501742 0.76659751 0.97764402 0.73856209 0.80363322 0.85575049\n",
      " 0.82493369 0.84142114 0.85047537 0.82653061 0.8415493  0.87314086\n",
      " 0.95070423 0.96097138 0.86113537 0.82619863 0.84843206 0.79487179\n",
      " 0.84117125 0.9083045  0.84347826 0.82136602 0.90123457 0.85605338\n",
      " 0.90414508 0.79126638 0.81989708 0.94479074 0.83433995 0.75234842\n",
      " 0.88792354 0.86451049 0.82882096 0.87516088 0.90043668 0.98146514\n",
      " 0.87392055 0.95175439 0.81708449 0.9797891  0.85065502 0.82033304\n",
      " 0.95126197 0.84594835 0.7211704  0.87347295 0.86089907 0.90220264\n",
      " 0.93367786 0.92413793 0.91513561 0.88908297 0.88534397 0.85980392\n",
      " 0.93859649 0.81717687 0.9614711  0.93263342 0.87291849 0.87105038\n",
      " 0.82560137 0.83000867 0.95070423 0.93280977 0.9256993  0.94347826\n",
      " 0.9717564  0.94015611 0.93989547 0.81668194 0.94655172 0.94641314\n",
      " 0.85201401 0.90463918 0.85764192 0.96587927 0.9505737  0.94325021\n",
      " 0.98945518 0.92559787 0.8830156  0.91202091 0.88179465 0.87359307\n",
      " 0.78761823 0.92638037 0.81433506 0.63914027 0.9135274  0.74070796\n",
      " 0.84092863 0.81184669 0.85869565 0.86879433 0.90980736 0.84020619\n",
      " 0.96983141 0.86188811 0.76100629 0.94759825 0.93398751 0.92107546\n",
      " 0.61149826 0.8948291  0.92467532 0.97442681 0.95851721 0.89137931\n",
      " 0.84201236 0.97525597 0.85664639 0.93556929 0.90239574 0.93613298\n",
      " 0.97001764 0.83840139 0.95902354 0.82214473 0.87929515 0.86558219\n",
      " 0.69913043 0.78119658 0.76943005 0.90854185 0.87065972 0.82730455\n",
      " 0.79177603 0.92367067 0.76876618 0.9469496  0.94736842 0.87817704\n",
      " 0.9244713  0.743521   0.75131349 0.77641921 0.90932868 0.88484252\n",
      " 0.79444926 0.8684669  0.80137575 0.75720524 0.96017699 0.82414698\n",
      " 0.95907928 0.83727034 0.84118674 0.98366294 0.89896373 0.83678756\n",
      " 0.88533333 0.95611015 0.76909871 0.90138408 0.86230637 0.90322581\n",
      " 0.88504754 0.84816754 0.85516045 0.80642361 0.93345009 0.80378657\n",
      " 0.91386736 0.97110333 0.80254154 0.76167315 0.7486911  0.89554795\n",
      " 0.86631944 0.90600522 0.93782837 0.94086957 0.92407248 0.93968531\n",
      " 0.96542783 0.73485514 0.8788143  0.89566929 0.84142716 0.84432718\n",
      " 0.78173077 0.93183779 0.8359375  0.78947368 0.94189072 0.86171132\n",
      " 0.90941073 0.96413322 0.90744467 0.95633188 0.89519651 0.88044693\n",
      " 0.93139842 0.85788562 0.77300613 0.82692308 0.95742832 0.87305699\n",
      " 0.72679965 0.92449517 0.87202118 0.93073593 0.76835664 0.91229579\n",
      " 0.88898601 0.90622261 0.89170306 0.86147186 0.91006843 0.8962766\n",
      " 0.87561214 0.86816999 0.81818182 0.82585752 0.90700344 0.92052402\n",
      " 0.83912612 0.95611015 0.8399654  0.88810573 0.80489939 0.94618056\n",
      " 0.84750219 0.87057808 0.83612335 0.92089249 0.94306418 0.80158033\n",
      " 0.93362069 0.92748433 0.84501062 0.88602151 0.91368788 0.55039439\n",
      " 0.94050744 0.65104167 0.90079017 0.89700704 0.95171203 0.84494774\n",
      " 0.87085515 0.96937883 0.83227446 0.89496157 0.80839895 0.85065502\n",
      " 0.81164384 0.84215168 0.90305677 0.8956044  0.7037037  0.88859878\n",
      " 0.88378144 0.93712317 0.92774309 0.86133333 0.70454545 0.96066434\n",
      " 0.8501292  0.90940767 0.85137457 0.94185022 0.87894737 0.85864794\n",
      " 0.80772532 0.87826087 0.76855124 0.91035683 0.92024014 0.78571429\n",
      " 0.92869875 0.84426947 0.93133047 0.8373102  0.80444444 0.84688581\n",
      " 0.90450928 0.87598253 0.90933099 0.88888889 0.81298036 0.94516971\n",
      " 0.92595819 0.96768559 0.73209549 0.83013937 0.6897747  0.93642612\n",
      " 0.91035683 0.82276281 0.79861111 0.87647593 0.85211268 0.90388007\n",
      " 0.80574913 0.89193825 0.87401575 0.91803279 0.87640449 0.83661249\n",
      " 0.9344894  0.78165939 0.96754386 0.92857143 0.97558849 0.93179805\n",
      " 0.80749129 0.92447917 0.90113736 0.89544236 0.89044698 0.79268293\n",
      " 0.82589771 0.7258248  0.95711679 0.62195122 0.96915167 0.95021834\n",
      " 0.93368237 0.87673611 0.76274165 0.90564374 0.98962835 0.95445545\n",
      " 0.94596913 0.86086957 0.73426573 0.95225694 0.8487395  0.8407699\n",
      " 0.77244987 0.94759825 0.86026201 0.90425532 0.96474635 0.94334764\n",
      " 0.86257563 0.89354276 0.6537133  0.80229479 0.74211503 0.93379791\n",
      " 0.79529617 0.75837321 0.86615516 0.94493783 0.86758383 0.77065026\n",
      " 0.87826087 0.95172414 0.7840708  0.85886403 0.92348285 0.82414698\n",
      " 0.76255319 0.96779661 0.91273375 0.88418323 0.8826087  0.91103203\n",
      " 0.90534619 0.86543536 0.84111311 0.85839161 0.8781331  0.971078\n",
      " 0.89938217 0.87190813 0.90971625 0.91884817 0.71221178 0.87982833\n",
      " 0.9288225  0.93203883 0.85867446 0.93920705 0.94987035 0.90529974\n",
      " 0.80440529 0.9206626  0.90592334 0.86339755 0.90034662 0.91383812\n",
      " 0.82450043 0.81500873 0.85082394 0.70042194 0.95438898 0.94667832\n",
      " 0.96512642 0.90748899 0.9619469  0.91716567 0.84475282 0.82413793\n",
      " 0.89382071 0.95462329 0.88184188 0.90743945 0.69223986 0.49956635\n",
      " 0.971113   0.85074627 0.78218695 0.82909728 0.84750219 0.78916173\n",
      " 0.89229341 0.81358885 0.87456446 0.8125     0.78829604 0.66839378\n",
      " 0.82704126 0.88120567 0.9213691  0.96223176 0.93648069 0.90635739\n",
      " 0.93744493 0.93187773 0.91494845 0.83101392 0.91782007 0.78664354\n",
      " 0.89264069 0.85595568 0.9404878  0.92489083 0.83840139 0.80960699\n",
      " 0.90751945 0.90652557 0.91463415 0.96187175 0.92175408 0.91093474\n",
      " 0.92974848 0.93652174 0.91398784 0.90393013 0.86996337 0.93684211\n",
      " 0.89708405 0.89102005 0.93858131 0.93934142 0.95495495 0.76186368\n",
      " 0.89670139 0.93362445 0.90158172 0.891748   0.93787748 0.9237435\n",
      " 0.90901213 0.97222222 0.97398092 0.95395308 0.94031142 0.96296296\n",
      " 0.8600175  0.8772688  0.89168111 0.94385965 0.9283247  0.94658494\n",
      " 0.79391304 0.88860104 0.71538462 0.81506196 0.91179039 0.91559001\n",
      " 0.90713672 0.84027778 0.98699046 0.79570815 0.83333333 0.79965157\n",
      " 0.83520276 0.8685567  0.9453125  0.941331   0.90853659 0.94230769\n",
      " 0.95804196 0.98091934 0.98846495 0.77729636 0.94390027 0.9622807\n",
      " 0.95724258 0.94107452 0.94622723 0.96143734 0.96214789 0.87640449\n",
      " 0.85639687 0.95888014 0.81081081 0.70593293]\n"
     ]
    }
   ],
   "source": [
    "print('Class-conditional coverages:')\n",
    "print(results['standard'][2]['raw_class_coverages'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "1d2d0a40",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "==== Most undercovered class under standard ====\n",
      "Class: 899\n",
      "Coverage under standard : 0.49956634865568084\n",
      "Coverage under clustered: 0.7337380745880312\n",
      "Coverage under classwise: 0.8924544666088465\n"
     ]
    }
   ],
   "source": [
    "print('==== Most undercovered class under standard ====')\n",
    "most_undercov = results['standard'][2]['raw_class_coverages'].argmin()\n",
    "print('Class:', most_undercov)\n",
    "print('Coverage under standard :', results['standard'][2]['raw_class_coverages'][most_undercov])\n",
    "print('Coverage under clustered:', results['cluster_proportional'][2]['raw_class_coverages'][most_undercov])\n",
    "print('Coverage under classwise:', results['classwise'][2]['raw_class_coverages'][most_undercov])"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "9f10a372",
   "metadata": {},
   "source": [
    "Class 889 corresponds to water jug"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "1d69e4d2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "==== Most overcovered class under standard ====\n",
      "Class: 339\n",
      "Coverage under standard : 0.996548748921484\n",
      "Coverage under clustered: 0.9818809318377912\n",
      "Coverage under classwise: 0.9378774805867127\n"
     ]
    }
   ],
   "source": [
    "print('==== Most overcovered class under standard ====')\n",
    "most_overcov = results['standard'][2]['raw_class_coverages'].argmax()\n",
    "print('Class:', most_overcov)\n",
    "print('Coverage under standard :', results['standard'][2]['raw_class_coverages'][most_overcov])\n",
    "print('Coverage under clustered:', results['cluster_proportional'][2]['raw_class_coverages'][most_overcov])\n",
    "print('Coverage under classwise:', results['classwise'][2]['raw_class_coverages'][most_overcov])"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a4e975e4",
   "metadata": {},
   "source": [
    "Class 339 corresponds to \"sorrel,\" which is not a very common thing. Let's find another overcovered class that is more familiar"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "98c5416d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Classes with coverage above 99%:\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "(array([ 16,  19, 102, 105, 130, 289, 321, 323, 339, 340, 387, 388]),)"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "print('Classes with coverage above 99%:')\n",
    "np.where(results['standard'][2]['raw_class_coverages'] > .99)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f52fc18a",
   "metadata": {},
   "source": [
    "Some classes that correspond to common things:\n",
    "* 102 = koala\n",
    "* 105 = flamingo\n",
    "* 289 = leopard"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "8eafc8bc",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Class-conditional coverage of Class 105:\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "0.9912049252418645"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "cls = 105\n",
    "\n",
    "print(f'Class-conditional coverage of Class {cls}:')\n",
    "results['standard'][2]['raw_class_coverages'][cls]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f0340541",
   "metadata": {},
   "source": [
    "## Some addititional code for comparing against other conformal methods"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "ff8ed2e3",
   "metadata": {},
   "outputs": [],
   "source": [
    "# # For comparison\n",
    "# print('==== Most undercovered class under clustered ====')\n",
    "# method = 'cluster_proportional'\n",
    "# most_undercov = results[method][2]['raw_class_coverages'].argmin()\n",
    "# print('Class:', most_undercov)\n",
    "# print('Coverage:', results[method][2]['raw_class_coverages'][most_undercov])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "bb378d48",
   "metadata": {},
   "outputs": [],
   "source": [
    "# n_totalcal = 20\n",
    "# score = 'softmax'\n",
    "# folder = f'/home/ANONYMIZED/code/class-conditional-conformal/.cache/paper/varying_n/{dataset}/random_calset/n_totalcal={n_totalcal}/score={score}'\n",
    "# plot_class_coverage_histogram(folder, desired_cov=0.9, vmin=.5, vmax=1, nbins=30, \n",
    "#                               methods = ['standard', 'classwise', 'cluster_random'],\n",
    "#                               title=f'ImageNet, n={n_totalcal}, {score}')"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "py3.9",
   "language": "python",
   "name": "py3.9"
  },
  "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.9.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
