{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "'''\n",
    "Detailed analysis of the predictions\n",
    "1. Runtime bracket\n",
    "2. Probability change\n",
    "3. Top 2 with runtime within 5% as correct\n",
    "'''\n",
    "%matplotlib inline\n",
    "\n",
    "import os\n",
    "import torch\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "from sklearn.metrics import matthews_corrcoef as mcc_fn\n",
    "from sklearn.metrics import accuracy_score as acc_fn\n",
    "import torch.nn.functional as F\n",
    "\n",
    "# exp_dir = os.path.abspath(\"\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "exp_name: 0604_satzilla_mlp\n",
      "[            percentage     rt_base      rt_min      exp_rt     rt_top1  \\\n",
      "(0, 100)      0.157945  111.767591   70.149176   97.239790   88.070768   \n",
      "(100, 200)    0.211419  208.000601  146.851307  189.620106  166.634425   \n",
      "(200, 300)    0.215928  364.793824  250.580882  331.508892  296.295882   \n",
      "(300, 400)    0.166900  472.210426  345.279680  461.328270  422.538052   \n",
      "(400, 500)    0.108472  582.570258  446.531616  608.839764  549.467799   \n",
      "(500, inf)    0.139337  754.623063  637.096171  826.129954  735.632179   \n",
      "\n",
      "               rt_top2       mcc       acc  equ_top1_acc  equ_top2_acc  \\\n",
      "(0, 100)     75.298752  0.257055  0.507439      0.601126      0.833936   \n",
      "(100, 200)  151.601685  0.270363  0.603785      0.681886      0.908081   \n",
      "(200, 300)  266.874695  0.175300  0.538824      0.599706      0.814706   \n",
      "(300, 400)  376.873657  0.109937  0.393075      0.463470      0.695967   \n",
      "(400, 500)  489.075531  0.126917  0.375878      0.435012      0.687354   \n",
      "(500, inf)  677.062439  0.179474  0.431176      0.506381      0.732908   \n",
      "\n",
      "            improvement_top1  \n",
      "(0, 100)            0.068098  \n",
      "(100, 200)          0.101114  \n",
      "(200, 300)          0.107004  \n",
      "(300, 400)          0.046389  \n",
      "(400, 500)          0.015404  \n",
      "(500, inf)          0.002577  ,             percentage     rt_base      rt_min      exp_rt     rt_top1  \\\n",
      "(0, 100)      0.160041  112.284524   69.803571   99.445880   86.517460   \n",
      "(100, 200)    0.206910  210.066298  147.214856  192.356638  165.007366   \n",
      "(200, 300)    0.217897  365.101428  250.366948  333.346098  291.355290   \n",
      "(300, 400)    0.169059  474.092787  346.340721  464.357024  419.160030   \n",
      "(400, 500)    0.105932  590.125899  446.913669  612.559897  548.203237   \n",
      "(500, inf)    0.139972  752.798094  637.850272  835.915774  731.852541   \n",
      "\n",
      "               rt_top2       mcc       acc  equ_top1_acc  equ_top2_acc  \\\n",
      "(0, 100)     75.411903  0.257424  0.501587      0.591270      0.834921   \n",
      "(100, 200)  151.913757  0.294277  0.610190      0.688459      0.911295   \n",
      "(200, 300)  266.387054  0.195485  0.536578      0.597202      0.811717   \n",
      "(300, 400)  377.663788  0.139993  0.400451      0.468445      0.688580   \n",
      "(400, 500)  490.085144  0.145415  0.383094      0.443645      0.667866   \n",
      "(500, inf)  676.874756  0.193256  0.443739      0.525408      0.745916   \n",
      "\n",
      "            improvement_top1  \n",
      "(0, 100)            0.086978  \n",
      "(100, 200)          0.103132  \n",
      "(200, 300)          0.112160  \n",
      "(300, 400)          0.056363  \n",
      "(400, 500)          0.028509  \n",
      "(500, inf)          0.009354  ,             percentage     rt_base      rt_min      exp_rt     rt_top1  \\\n",
      "(0, 100)      0.158453  112.254910   70.779559   98.532714   87.906613   \n",
      "(100, 200)    0.210657  209.874585  146.999096  190.985393  163.634610   \n",
      "(200, 300)    0.221898  366.468231  251.574986  334.116824  294.682599   \n",
      "(300, 400)    0.167217  470.169389  345.789594  464.599866  419.022408   \n",
      "(400, 500)    0.107265  581.332741  446.160450  610.689139  540.731202   \n",
      "(500, inf)    0.134510  757.210104  638.303588  838.700806  730.521719   \n",
      "\n",
      "               rt_top2       mcc       acc  equ_top1_acc  equ_top2_acc  \\\n",
      "(0, 100)     76.566734  0.264923  0.497796      0.579559      0.833267   \n",
      "(100, 200)  150.864639  0.290972  0.606572      0.682544      0.913476   \n",
      "(200, 300)  267.789917  0.171795  0.525186      0.588724      0.818832   \n",
      "(300, 400)  375.849609  0.131755  0.401063      0.477022      0.709077   \n",
      "(400, 500)  486.142090  0.148662  0.386027      0.452931      0.687389   \n",
      "(500, inf)  677.454651  0.216605  0.458451      0.540132      0.743626   \n",
      "\n",
      "            improvement_top1  \n",
      "(0, 100)            0.032420  \n",
      "(100, 200)          0.104695  \n",
      "(200, 300)          0.109658  \n",
      "(300, 400)          0.051069  \n",
      "(400, 500)          0.029659  \n",
      "(500, inf)          0.014640  ,             percentage     rt_base      rt_min      exp_rt     rt_top1  \\\n",
      "(0, 100)      0.156992  111.452265   69.690129   97.970523   88.680825   \n",
      "(100, 200)    0.210466  208.920036  146.502112  190.533054  164.495775   \n",
      "(200, 300)    0.223485  361.362887  250.125604  333.820584  292.916454   \n",
      "(300, 400)    0.169503  473.638816  345.953541  463.770713  421.897340   \n",
      "(400, 500)    0.102248  585.525466  446.460870  614.297794  552.047826   \n",
      "(500, inf)    0.137305  760.072155  639.341351  837.636680  734.285384   \n",
      "\n",
      "               rt_top2       mcc       acc  equ_top1_acc  equ_top2_acc  \\\n",
      "(0, 100)     75.713997  0.280907  0.513754      0.592638      0.831715   \n",
      "(100, 200)  151.572723  0.295379  0.604406      0.687990      0.908871   \n",
      "(200, 300)  266.922424  0.196745  0.533674      0.594203      0.812163   \n",
      "(300, 400)  375.937805  0.146731  0.412139      0.484076      0.714500   \n",
      "(400, 500)  492.044098  0.135442  0.382609      0.442236      0.676398   \n",
      "(500, inf)  677.487976  0.176846  0.439870      0.526827      0.750694   \n",
      "\n",
      "            improvement_top1  \n",
      "(0, 100)            0.053071  \n",
      "(100, 200)          0.093311  \n",
      "(200, 300)          0.106090  \n",
      "(300, 400)          0.052541  \n",
      "(400, 500)          0.023903  \n",
      "(500, inf)          0.012242  ,             percentage     rt_base      rt_min      exp_rt     rt_top1  \\\n",
      "(0, 100)      0.157564  110.539299   70.833938   97.156535   88.332527   \n",
      "(100, 200)    0.209387  206.602366  147.070367  188.997249  163.493782   \n",
      "(200, 300)    0.216690  364.342907  250.191970  331.045026  292.221571   \n",
      "(300, 400)    0.172361  469.025792  345.956522  458.328488  420.714444   \n",
      "(400, 500)    0.103836  587.389602  444.732722  605.739533  548.320489   \n",
      "(500, inf)    0.140099  761.500907  636.866274  822.580348  734.567996   \n",
      "\n",
      "               rt_top2       mcc       acc  equ_top1_acc  equ_top2_acc  \\\n",
      "(0, 100)     75.870216  0.264410  0.501008      0.584442      0.839984   \n",
      "(100, 200)  151.883224  0.315871  0.620867      0.693358      0.909918   \n",
      "(200, 300)  265.782227  0.198867  0.539273      0.604924      0.821805   \n",
      "(300, 400)  376.126740  0.129929  0.403095      0.468681      0.704864   \n",
      "(400, 500)  489.851379  0.149539  0.379817      0.443425      0.681957   \n",
      "(500, inf)  678.129211  0.159612  0.422031      0.509520      0.743427   \n",
      "\n",
      "            improvement_top1  \n",
      "(0, 100)            0.039947  \n",
      "(100, 200)          0.102157  \n",
      "(200, 300)          0.109403  \n",
      "(300, 400)          0.048263  \n",
      "(400, 500)          0.035300  \n",
      "(500, inf)          0.012815  ]\n",
      "             percentage        rt_base         rt_min         exp_rt  \\\n",
      "(0, 100)    0.158±0.001   111.66±0.641   70.251±0.478   98.069±0.853   \n",
      "(100, 200)   0.21±0.002  208.693±1.279  146.928±0.243  190.498±1.159   \n",
      "(200, 300)  0.219±0.003  364.414±1.682  250.568±0.528   332.767±1.25   \n",
      "(300, 400)  0.169±0.002  471.827±1.957  345.864±0.344  462.477±2.377   \n",
      "(400, 500)  0.106±0.002  585.389±3.189   446.16±0.753   610.425±2.97   \n",
      "(500, inf)  0.138±0.002  757.241±3.248   637.892±0.89  832.193±6.558   \n",
      "\n",
      "                  rt_top1        rt_top2          mcc          acc  \\\n",
      "(0, 100)      87.902±0.74   75.772±0.447  0.265±0.009  0.504±0.006   \n",
      "(100, 200)  164.653±1.136  151.567±0.378  0.293±0.014  0.609±0.006   \n",
      "(200, 300)  293.494±1.777  266.751±0.663  0.188±0.012  0.535±0.005   \n",
      "(300, 400)  420.666±1.414   376.49±0.689  0.132±0.012  0.402±0.006   \n",
      "(400, 500)  547.754±3.774   489.44±1.917  0.141±0.009  0.381±0.003   \n",
      "(500, inf)  733.372±1.887  677.402±0.432  0.185±0.019  0.439±0.012   \n",
      "\n",
      "           equ_top1_acc equ_top2_acc improvement_top1  \n",
      "(0, 100)     0.59±0.007  0.835±0.003       0.056±0.02  \n",
      "(100, 200)  0.687±0.004   0.91±0.002      0.101±0.004  \n",
      "(200, 300)  0.597±0.005  0.816±0.004      0.109±0.002  \n",
      "(300, 400)  0.472±0.007  0.703±0.009      0.051±0.003  \n",
      "(400, 500)  0.443±0.006   0.68±0.007      0.027±0.007  \n",
      "(500, inf)  0.522±0.012  0.743±0.006       0.01±0.004  \n",
      "exp_name: 0608_solv-none\n",
      "[            percentage     rt_base      rt_min      exp_rt     rt_top1  \\\n",
      "(0, 100)      0.157945  111.767591   70.149176  115.679970   91.275030   \n",
      "(100, 200)    0.211419  208.000601  146.851307  227.538134  167.749775   \n",
      "(200, 300)    0.215928  364.793824  250.580882  372.895379  296.570000   \n",
      "(300, 400)    0.166900  472.210426  345.279680  502.631904  426.082953   \n",
      "(400, 500)    0.108472  582.570258  446.531616  665.736266  553.045667   \n",
      "(500, inf)    0.139337  754.623063  637.096171  910.873608  745.418414   \n",
      "\n",
      "               rt_top2       mcc       acc  equ_top1_acc  equ_top2_acc  \\\n",
      "(0, 100)     77.739845  0.171549  0.442300      0.531966      0.772014   \n",
      "(100, 200)  152.754578  0.164243  0.546110      0.629018      0.874437   \n",
      "(200, 300)  267.977936  0.123379  0.517353      0.580588      0.797941   \n",
      "(300, 400)  377.262939  0.080188  0.379756      0.444444      0.692161   \n",
      "(400, 500)  489.118256  0.106232  0.360656      0.422717      0.679157   \n",
      "(500, inf)  677.498657  0.162897  0.410210      0.486782      0.735643   \n",
      "\n",
      "            improvement_top1  \n",
      "(0, 100)            0.025329  \n",
      "(100, 200)          0.076339  \n",
      "(200, 300)          0.094056  \n",
      "(300, 400)          0.030079  \n",
      "(400, 500)          0.003112  \n",
      "(500, inf)         -0.013268  ,             percentage     rt_base      rt_min      exp_rt     rt_top1  \\\n",
      "(0, 100)      0.160041  112.284524   69.803571  116.230136   91.873016   \n",
      "(100, 200)    0.206910  210.066298  147.214856  227.517336  167.754451   \n",
      "(200, 300)    0.217897  365.101428  250.366948  370.520901  294.733314   \n",
      "(300, 400)    0.169059  474.092787  346.340721  502.723836  426.246807   \n",
      "(400, 500)    0.105932  590.125899  446.913669  665.014555  556.477818   \n",
      "(500, inf)    0.139972  752.798094  637.850272  913.681442  742.764065   \n",
      "\n",
      "               rt_top2       mcc       acc  equ_top1_acc  equ_top2_acc  \\\n",
      "(0, 100)     77.505157  0.175189  0.438492      0.521825      0.741667   \n",
      "(100, 200)  154.265808  0.192502  0.550031      0.628913      0.839472   \n",
      "(200, 300)  268.632172  0.140155  0.518216      0.580880      0.787525   \n",
      "(300, 400)  379.260345  0.095134  0.388054      0.449286      0.679940   \n",
      "(400, 500)  489.079132  0.090915  0.359113      0.413669      0.676858   \n",
      "(500, inf)  679.875671  0.157395  0.411071      0.490018      0.725045   \n",
      "\n",
      "            improvement_top1  \n",
      "(0, 100)            0.008977  \n",
      "(100, 200)          0.078202  \n",
      "(200, 300)          0.102047  \n",
      "(300, 400)          0.038860  \n",
      "(400, 500)          0.011441  \n",
      "(500, inf)         -0.008682  ,             percentage     rt_base      rt_min      exp_rt     rt_top1  \\\n",
      "(0, 100)      0.158453  112.254910   70.779559  116.067327   93.010421   \n",
      "(100, 200)    0.210657  209.874585  146.999096  228.000867  166.918903   \n",
      "(200, 300)    0.221898  366.468231  251.574986  370.682983  296.276188   \n",
      "(300, 400)    0.167217  470.169389  345.789594  505.397657  422.333080   \n",
      "(400, 500)    0.107265  581.332741  446.160450  661.451359  547.748372   \n",
      "(500, inf)    0.134510  757.210104  638.303588  910.166272  739.397545   \n",
      "\n",
      "               rt_top2       mcc       acc  equ_top1_acc  equ_top2_acc  \\\n",
      "(0, 100)     79.081764  0.200736  0.454108      0.534269      0.735872   \n",
      "(100, 200)  154.870056  0.162149  0.547784      0.627977      0.825143   \n",
      "(200, 300)  271.831421  0.122895  0.512593      0.576131      0.758443   \n",
      "(300, 400)  376.795288  0.085414  0.382074      0.455374      0.684390   \n",
      "(400, 500)  486.555359  0.118781  0.362345      0.426288      0.679692   \n",
      "(500, inf)  677.808777  0.203689  0.435316      0.517469      0.738905   \n",
      "\n",
      "            improvement_top1  \n",
      "(0, 100)           -0.002984  \n",
      "(100, 200)          0.080161  \n",
      "(200, 300)          0.095284  \n",
      "(300, 400)          0.031458  \n",
      "(400, 500)          0.007419  \n",
      "(500, inf)         -0.001828  ,             percentage     rt_base      rt_min      exp_rt     rt_top1  \\\n",
      "(0, 100)      0.156992  111.452265   69.690129  115.598013   92.169094   \n",
      "(100, 200)    0.210466  208.920036  146.502112  226.929991  167.666868   \n",
      "(200, 300)    0.223485  361.362887  250.125604  373.018434  295.848537   \n",
      "(300, 400)    0.169503  473.638816  345.953541  505.231308  424.689397   \n",
      "(400, 500)    0.102248  585.525466  446.460870  672.075689  557.589441   \n",
      "(500, inf)    0.137305  760.072155  639.341351  917.669233  738.703053   \n",
      "\n",
      "               rt_top2       mcc       acc  equ_top1_acc  equ_top2_acc  \\\n",
      "(0, 100)     77.261330  0.186936  0.449029      0.524676      0.750000   \n",
      "(100, 200)  154.195541  0.199473  0.549487      0.629451      0.842788   \n",
      "(200, 300)  269.141815  0.152046  0.514635      0.574027      0.774936   \n",
      "(300, 400)  378.865875  0.102085  0.390408      0.459348      0.684901   \n",
      "(400, 500)  493.996887  0.089735  0.357764      0.420497      0.663354   \n",
      "(500, inf)  677.309448  0.167135  0.427845      0.514339      0.742368   \n",
      "\n",
      "            improvement_top1  \n",
      "(0, 100)            0.014460  \n",
      "(100, 200)          0.075818  \n",
      "(200, 300)          0.092569  \n",
      "(300, 400)          0.040340  \n",
      "(400, 500)          0.004865  \n",
      "(500, inf)          0.006042  ,             percentage     rt_base      rt_min      exp_rt     rt_top1  \\\n",
      "(0, 100)      0.157564  110.539299   70.833938  116.820999   94.414752   \n",
      "(100, 200)    0.209387  206.602366  147.070367  226.966770  169.684865   \n",
      "(200, 300)    0.216690  364.342907  250.191970  371.595838  295.927902   \n",
      "(300, 400)    0.172361  469.025792  345.956522  501.244000  422.983788   \n",
      "(400, 500)    0.103836  587.389602  444.732722  667.095187  558.201835   \n",
      "(500, inf)    0.140099  761.500907  636.866274  910.187732  738.446510   \n",
      "\n",
      "               rt_top2       mcc       acc  equ_top1_acc  equ_top2_acc  \\\n",
      "(0, 100)     80.721886  0.120504  0.407094      0.484079      0.722289   \n",
      "(100, 200)  154.756149  0.153094  0.532605      0.608735      0.829542   \n",
      "(200, 300)  268.602570  0.133099  0.513189      0.580891      0.778722   \n",
      "(300, 400)  376.811707  0.106927  0.396463      0.461312      0.687914   \n",
      "(400, 500)  488.089905  0.098543  0.360245      0.425688      0.674618   \n",
      "(500, inf)  677.199463  0.168600  0.414325      0.500453      0.741614   \n",
      "\n",
      "            improvement_top1  \n",
      "(0, 100)           -0.000873  \n",
      "(100, 200)          0.068588  \n",
      "(200, 300)          0.096679  \n",
      "(300, 400)          0.035542  \n",
      "(400, 500)          0.007183  \n",
      "(500, inf)          0.004257  ]\n",
      "             percentage        rt_base         rt_min         exp_rt  \\\n",
      "(0, 100)    0.158±0.001   111.66±0.641   70.251±0.478  116.079±0.439   \n",
      "(100, 200)   0.21±0.002  208.693±1.279  146.928±0.243  227.391±0.401   \n",
      "(200, 300)  0.219±0.003  364.414±1.682  250.568±0.528  371.743±1.058   \n",
      "(300, 400)  0.169±0.002  471.827±1.957  345.864±0.344  503.446±1.614   \n",
      "(400, 500)  0.106±0.002  585.389±3.189   446.16±0.753  666.275±3.449   \n",
      "(500, inf)  0.138±0.002  757.241±3.248   637.892±0.89  912.516±2.883   \n",
      "\n",
      "                  rt_top1        rt_top2          mcc          acc  \\\n",
      "(0, 100)     92.548±1.088   78.462±1.294  0.171±0.027  0.438±0.016   \n",
      "(100, 200)   167.955±0.92  154.168±0.755  0.174±0.018  0.545±0.006   \n",
      "(200, 300)  295.871±0.625  269.237±1.349  0.134±0.011  0.515±0.002   \n",
      "(300, 400)  424.467±1.586  377.799±1.053   0.094±0.01  0.387±0.006   \n",
      "(400, 500)  554.613±3.868  489.368±2.495  0.101±0.011   0.36±0.002   \n",
      "(500, inf)   740.946±2.72   677.938±0.99  0.172±0.016    0.42±0.01   \n",
      "\n",
      "           equ_top1_acc equ_top2_acc improvement_top1  \n",
      "(0, 100)    0.519±0.018  0.744±0.017       0.009±0.01  \n",
      "(100, 200)  0.625±0.008  0.842±0.017      0.076±0.004  \n",
      "(200, 300)  0.579±0.003   0.78±0.013      0.096±0.003  \n",
      "(300, 400)  0.454±0.006  0.686±0.004      0.035±0.004  \n",
      "(400, 500)  0.422±0.005  0.675±0.006      0.007±0.003  \n",
      "(500, inf)  0.502±0.012  0.737±0.006     -0.003±0.007  \n",
      "exp_name: 0802_hetero_logits\n",
      "[            percentage     rt_base      rt_min      exp_rt     rt_top1  \\\n",
      "(0, 100)      0.157945  111.767591   70.149176  100.634692   89.672698   \n",
      "(100, 200)    0.211419  208.000601  146.851307  191.022298  167.277861   \n",
      "(200, 300)    0.215928  364.793824  250.580882  332.294642  297.122353   \n",
      "(300, 400)    0.166900  472.210426  345.279680  464.756760  427.634703   \n",
      "(400, 500)    0.108472  582.570258  446.531616  614.606729  555.546253   \n",
      "(500, inf)    0.139337  754.623063  637.096171  830.425115  742.061531   \n",
      "\n",
      "               rt_top2       mcc       acc  equ_top1_acc  equ_top2_acc  \\\n",
      "(0, 100)     76.977081  0.206144  0.476880      0.566948      0.813028   \n",
      "(100, 200)  152.732651  0.208530  0.574347      0.658456      0.900571   \n",
      "(200, 300)  268.644104  0.146879  0.526176      0.589706      0.815588   \n",
      "(300, 400)  378.570770  0.086196  0.381659      0.449772      0.691020   \n",
      "(400, 500)  491.248840  0.087272  0.351874      0.416276      0.680328   \n",
      "(500, inf)  677.499084  0.175732  0.425251      0.499088      0.734275   \n",
      "\n",
      "            improvement_top1  \n",
      "(0, 100)            0.048805  \n",
      "(100, 200)          0.093009  \n",
      "(200, 300)          0.100474  \n",
      "(300, 400)          0.035055  \n",
      "(400, 500)          0.001376  \n",
      "(500, inf)         -0.007813  ,             percentage     rt_base      rt_min      exp_rt     rt_top1  \\\n",
      "(0, 100)      0.160041  112.284524   69.803571  102.185035   89.728968   \n",
      "(100, 200)    0.206910  210.066298  147.214856  198.422304  168.046654   \n",
      "(200, 300)    0.217897  365.101428  250.366948  340.051884  298.639464   \n",
      "(300, 400)    0.169059  474.092787  346.340721  470.835736  428.340346   \n",
      "(400, 500)    0.105932  590.125899  446.913669  618.432071  556.893885   \n",
      "(500, inf)    0.139972  752.798094  637.850272  847.401192  741.894737   \n",
      "\n",
      "               rt_top2       mcc       acc  equ_top1_acc  equ_top2_acc  \\\n",
      "(0, 100)     77.664284  0.198693  0.471429      0.557540      0.814683   \n",
      "(100, 200)  152.319824  0.213396  0.577962      0.656845      0.907919   \n",
      "(200, 300)  267.980774  0.125962  0.517050      0.578840      0.809968   \n",
      "(300, 400)  379.603302  0.067176  0.377160      0.443276      0.688580   \n",
      "(400, 500)  490.756592  0.092447  0.363309      0.419664      0.676259   \n",
      "(500, inf)  679.135193  0.168948  0.418784      0.495917      0.739111   \n",
      "\n",
      "            improvement_top1  \n",
      "(0, 100)            0.048049  \n",
      "(100, 200)          0.090790  \n",
      "(200, 300)          0.096521  \n",
      "(300, 400)          0.035152  \n",
      "(400, 500)          0.010511  \n",
      "(500, inf)         -0.007956  ,             percentage     rt_base      rt_min      exp_rt     rt_top1  \\\n",
      "(0, 100)      0.158453  112.254910   70.779559  100.492208   91.721844   \n",
      "(100, 200)    0.210657  209.874585  146.999096  193.204980  165.667471   \n",
      "(200, 300)    0.221898  366.468231  251.574986  336.847492  296.493131   \n",
      "(300, 400)    0.167217  470.169389  345.789594  467.618328  424.150019   \n",
      "(400, 500)    0.107265  581.332741  446.160450  612.927792  549.444642   \n",
      "(500, inf)    0.134510  757.210104  638.303588  839.026875  739.422568   \n",
      "\n",
      "               rt_top2       mcc       acc  equ_top1_acc  equ_top2_acc  \\\n",
      "(0, 100)     77.673347  0.199074  0.467335      0.547094      0.814830   \n",
      "(100, 200)  152.303589  0.231419  0.580645      0.657522      0.902623   \n",
      "(200, 300)  268.774750  0.143714  0.516314      0.582999      0.810819   \n",
      "(300, 400)  376.366119  0.095788  0.386631      0.462210      0.704899   \n",
      "(400, 500)  488.742462  0.119279  0.367081      0.435169      0.673771   \n",
      "(500, inf)  678.279480  0.190462  0.432483      0.511331      0.745987   \n",
      "\n",
      "            improvement_top1  \n",
      "(0, 100)            0.022280  \n",
      "(100, 200)          0.095909  \n",
      "(200, 300)          0.103812  \n",
      "(300, 400)          0.035653  \n",
      "(400, 500)          0.009714  \n",
      "(500, inf)         -0.000877  ,             percentage     rt_base      rt_min      exp_rt     rt_top1  \\\n",
      "(0, 100)      0.156992  111.452265   69.690129  100.603552   90.866909   \n",
      "(100, 200)    0.210466  208.920036  146.502112  192.718728  166.957755   \n",
      "(200, 300)    0.223485  361.362887  250.125604  335.948010  298.988349   \n",
      "(300, 400)    0.169503  473.638816  345.953541  465.440129  426.708880   \n",
      "(400, 500)    0.102248  585.525466  446.460870  614.591092  558.309938   \n",
      "(500, inf)    0.137305  760.072155  639.341351  836.509870  743.381591   \n",
      "\n",
      "               rt_top2       mcc       acc  equ_top1_acc  equ_top2_acc  \\\n",
      "(0, 100)     77.189728  0.204967  0.470874      0.548544      0.807039   \n",
      "(100, 200)  151.878693  0.230390  0.571515      0.653289      0.899517   \n",
      "(200, 300)  267.534241  0.143687  0.512930      0.573174      0.810173   \n",
      "(300, 400)  378.443237  0.107334  0.394904      0.464593      0.702885   \n",
      "(400, 500)  492.940979  0.110712  0.370807      0.432298      0.676398   \n",
      "(500, inf)  679.052734  0.163783  0.418594      0.502313      0.747919   \n",
      "\n",
      "            improvement_top1  \n",
      "(0, 100)            0.022338  \n",
      "(100, 200)          0.084128  \n",
      "(200, 300)          0.086998  \n",
      "(300, 400)          0.036836  \n",
      "(400, 500)          0.001094  \n",
      "(500, inf)         -0.004242  ,             percentage     rt_base      rt_min      exp_rt     rt_top1  \\\n",
      "(0, 100)      0.157564  110.539299   70.833938  100.458813   90.595324   \n",
      "(100, 200)    0.209387  206.602366  147.070367  191.205060  167.336366   \n",
      "(200, 300)    0.216690  364.342907  250.191970  333.216628  297.254103   \n",
      "(300, 400)    0.172361  469.025792  345.956522  461.155525  424.968312   \n",
      "(400, 500)    0.103836  587.389602  444.732722  611.860909  559.653211   \n",
      "(500, inf)    0.140099  761.500907  636.866274  827.323166  741.333636   \n",
      "\n",
      "               rt_top2       mcc       acc  equ_top1_acc  equ_top2_acc  \\\n",
      "(0, 100)     76.786377  0.197894  0.478033      0.558646      0.823055   \n",
      "(100, 200)  152.604492  0.210769  0.579315      0.663937      0.907188   \n",
      "(200, 300)  267.099945  0.137250  0.518464      0.582649      0.816823   \n",
      "(300, 400)  376.202271  0.100225  0.394989      0.457996      0.704864   \n",
      "(400, 500)  492.803070  0.099125  0.361468      0.422018      0.674618   \n",
      "(500, inf)  679.284668  0.161799  0.408885      0.492294      0.738441   \n",
      "\n",
      "            improvement_top1  \n",
      "(0, 100)            0.028468  \n",
      "(100, 200)          0.088338  \n",
      "(200, 300)          0.096219  \n",
      "(300, 400)          0.032614  \n",
      "(400, 500)          0.008254  \n",
      "(500, inf)         -0.000934  ]\n",
      "             percentage        rt_base         rt_min         exp_rt  \\\n",
      "(0, 100)    0.158±0.001   111.66±0.641   70.251±0.478  100.875±0.658   \n",
      "(100, 200)   0.21±0.002  208.693±1.279  146.928±0.243  193.315±2.689   \n",
      "(200, 300)  0.219±0.003  364.414±1.682  250.568±0.528   335.672±2.76   \n",
      "(300, 400)  0.169±0.002  471.827±1.957  345.864±0.344  465.961±3.204   \n",
      "(400, 500)  0.106±0.002  585.389±3.189   446.16±0.753  614.484±2.232   \n",
      "(500, inf)  0.138±0.002  757.241±3.248   637.892±0.89   836.137±7.01   \n",
      "\n",
      "                  rt_top1        rt_top2          mcc          acc  \\\n",
      "(0, 100)     90.517±0.763   77.258±0.359  0.201±0.003  0.473±0.004   \n",
      "(100, 200)  167.057±0.781  152.368±0.295   0.219±0.01  0.577±0.003   \n",
      "(200, 300)  297.699±0.952  268.007±0.639  0.139±0.007  0.518±0.004   \n",
      "(300, 400)    426.36±1.58  377.837±1.331  0.091±0.014  0.387±0.007   \n",
      "(400, 500)    555.97±3.54  491.298±1.536  0.102±0.012  0.363±0.006   \n",
      "(500, inf)  741.619±1.287   678.65±0.673   0.172±0.01  0.421±0.008   \n",
      "\n",
      "           equ_top1_acc equ_top2_acc improvement_top1  \n",
      "(0, 100)    0.556±0.007  0.815±0.005      0.034±0.012  \n",
      "(100, 200)  0.658±0.003  0.904±0.003       0.09±0.004  \n",
      "(200, 300)  0.581±0.005  0.813±0.003      0.097±0.006  \n",
      "(300, 400)  0.456±0.008  0.698±0.007      0.035±0.001  \n",
      "(400, 500)  0.425±0.007  0.676±0.002      0.006±0.004  \n",
      "(500, inf)    0.5±0.006  0.741±0.005     -0.004±0.003  \n",
      "exp_name: 0808_hetero_satzilla_feat\n",
      "[            percentage     rt_base      rt_min      exp_rt     rt_top1  \\\n",
      "(0, 100)      0.157945  111.767591   70.149176   96.526714   88.206273   \n",
      "(100, 200)    0.211419  208.000601  146.851307  185.224938  163.339441   \n",
      "(200, 300)    0.215928  364.793824  250.580882  333.314628  290.877647   \n",
      "(300, 400)    0.166900  472.210426  345.279680  463.884385  414.375951   \n",
      "(400, 500)    0.108472  582.570258  446.531616  613.450701  545.850117   \n",
      "(500, inf)    0.139337  754.623063  637.096171  829.501667  732.625342   \n",
      "\n",
      "               rt_top2       mcc       acc  equ_top1_acc  equ_top2_acc  \\\n",
      "(0, 100)     75.805794  0.267575  0.502614      0.593486      0.840772   \n",
      "(100, 200)  150.934814  0.311856  0.614299      0.687293      0.912586   \n",
      "(200, 300)  266.322937  0.205135  0.545882      0.609118      0.817059   \n",
      "(300, 400)  373.461945  0.163304  0.414764      0.483638      0.710807   \n",
      "(400, 500)  490.053864  0.157234  0.385831      0.454918      0.676815   \n",
      "(500, inf)  677.482239  0.191290  0.439380      0.518232      0.735643   \n",
      "\n",
      "            improvement_top1  \n",
      "(0, 100)            0.070289  \n",
      "(100, 200)          0.105796  \n",
      "(200, 300)          0.118071  \n",
      "(300, 400)          0.062303  \n",
      "(400, 500)          0.021786  \n",
      "(500, inf)          0.007212  ,             percentage     rt_base      rt_min      exp_rt     rt_top1  \\\n",
      "(0, 100)      0.160041  112.284524   69.803571   96.826233   85.439286   \n",
      "(100, 200)    0.206910  210.066298  147.214856  187.243881  164.332106   \n",
      "(200, 300)    0.217897  365.101428  250.366948  332.026782  290.436316   \n",
      "(300, 400)    0.169059  474.092787  346.340721  461.526682  418.089031   \n",
      "(400, 500)    0.105932  590.125899  446.913669  607.476789  546.490408   \n",
      "(500, inf)    0.139972  752.798094  637.850272  824.491766  732.921960   \n",
      "\n",
      "               rt_top2       mcc       acc  equ_top1_acc  equ_top2_acc  \\\n",
      "(0, 100)     74.796028  0.261281  0.503175      0.592460      0.837698   \n",
      "(100, 200)  151.427567  0.305601  0.615408      0.690608      0.913137   \n",
      "(200, 300)  265.462250  0.188203  0.538910      0.599825      0.818712   \n",
      "(300, 400)  377.282501  0.139630  0.407213      0.469572      0.695718   \n",
      "(400, 500)  489.510803  0.153171  0.393285      0.452638      0.679257   \n",
      "(500, inf)  677.772705  0.190867  0.441924      0.524955      0.746824   \n",
      "\n",
      "            improvement_top1  \n",
      "(0, 100)            0.078098  \n",
      "(100, 200)          0.101375  \n",
      "(200, 300)          0.116683  \n",
      "(300, 400)          0.059084  \n",
      "(400, 500)          0.032481  \n",
      "(500, inf)          0.007145  ,             percentage     rt_base      rt_min      exp_rt     rt_top1  \\\n",
      "(0, 100)      0.158453  112.254910   70.779559   96.204264   86.999599   \n",
      "(100, 200)    0.210657  209.874585  146.999096  185.611500  162.743744   \n",
      "(200, 300)    0.221898  366.468231  251.574986  335.155845  291.864625   \n",
      "(300, 400)    0.167217  470.169389  345.789594  464.353124  415.748576   \n",
      "(400, 500)    0.107265  581.332741  446.160450  607.220281  538.357016   \n",
      "(500, inf)    0.134510  757.210104  638.303588  829.218363  729.646837   \n",
      "\n",
      "               rt_top2       mcc       acc  equ_top1_acc  equ_top2_acc  \\\n",
      "(0, 100)     76.149101  0.263052  0.496192      0.575551      0.831263   \n",
      "(100, 200)  150.396439  0.309281  0.612903      0.687368      0.914380   \n",
      "(200, 300)  266.871490  0.202911  0.538924      0.604751      0.819691   \n",
      "(300, 400)  373.349426  0.141014  0.401823      0.477782      0.714774   \n",
      "(400, 500)  486.962097  0.169552  0.395500      0.460036      0.680284   \n",
      "(500, inf)  676.280457  0.213952  0.458451      0.539188      0.751180   \n",
      "\n",
      "            improvement_top1  \n",
      "(0, 100)            0.065723  \n",
      "(100, 200)          0.112456  \n",
      "(200, 300)          0.118957  \n",
      "(300, 400)          0.059358  \n",
      "(400, 500)          0.034594  \n",
      "(500, inf)          0.016344  ,             percentage     rt_base      rt_min      exp_rt     rt_top1  \\\n",
      "(0, 100)      0.156992  111.452265   69.690129   96.648005   86.462783   \n",
      "(100, 200)    0.210466  208.920036  146.502112  185.987127  163.926373   \n",
      "(200, 300)    0.223485  361.362887  250.125604  334.681516  291.639102   \n",
      "(300, 400)    0.169503  473.638816  345.953541  463.685219  415.333833   \n",
      "(400, 500)    0.102248  585.525466  446.460870  612.002109  543.767081   \n",
      "(500, inf)    0.137305  760.072155  639.341351  828.012445  731.223867   \n",
      "\n",
      "               rt_top2       mcc       acc  equ_top1_acc  equ_top2_acc  \\\n",
      "(0, 100)     74.565536  0.284865  0.514563      0.593851      0.836570   \n",
      "(100, 200)  150.869644  0.321158  0.616777      0.690706      0.916415   \n",
      "(200, 300)  265.487640  0.207021  0.538505      0.599318      0.818983   \n",
      "(300, 400)  373.008240  0.164144  0.420382      0.488947      0.719371   \n",
      "(400, 500)  489.284485  0.164664  0.397516      0.462733      0.686957   \n",
      "(500, inf)  676.098999  0.201317  0.450509      0.534690      0.754394   \n",
      "\n",
      "            improvement_top1  \n",
      "(0, 100)            0.098613  \n",
      "(100, 200)          0.104796  \n",
      "(200, 300)          0.108747  \n",
      "(300, 400)          0.060731  \n",
      "(400, 500)          0.032477  \n",
      "(500, inf)          0.016196  ,             percentage     rt_base      rt_min      exp_rt     rt_top1  \\\n",
      "(0, 100)      0.157564  110.539299   70.833938   98.226818   89.328900   \n",
      "(100, 200)    0.209387  206.602366  147.070367  185.385470  163.846527   \n",
      "(200, 300)    0.216690  364.342907  250.191970  332.460350  291.118113   \n",
      "(300, 400)    0.172361  469.025792  345.956522  460.314353  416.056374   \n",
      "(400, 500)    0.103836  587.389602  444.732722  609.377168  545.053823   \n",
      "(500, inf)    0.140099  761.500907  636.866274  826.926939  733.951043   \n",
      "\n",
      "               rt_top2       mcc       acc  equ_top1_acc  equ_top2_acc  \\\n",
      "(0, 100)     75.604195  0.271829  0.515921      0.597743      0.839178   \n",
      "(100, 200)  151.207458  0.300419  0.615408      0.686685      0.916894   \n",
      "(200, 300)  264.974213  0.186145  0.533411      0.601407      0.825322   \n",
      "(300, 400)  375.214447  0.165317  0.422623      0.489315      0.705969   \n",
      "(400, 500)  488.163910  0.157195  0.388991      0.455046      0.680122   \n",
      "(500, inf)  677.361267  0.186174  0.428830      0.516772      0.741614   \n",
      "\n",
      "            improvement_top1  \n",
      "(0, 100)            0.070282  \n",
      "(100, 200)          0.104254  \n",
      "(200, 300)          0.114696  \n",
      "(300, 400)          0.052921  \n",
      "(400, 500)          0.032162  \n",
      "(500, inf)          0.011290  ]\n",
      "             percentage        rt_base         rt_min         exp_rt  \\\n",
      "(0, 100)    0.158±0.001   111.66±0.641   70.251±0.478     96.886±0.7   \n",
      "(100, 200)   0.21±0.002  208.693±1.279  146.928±0.243  185.891±0.723   \n",
      "(200, 300)  0.219±0.003  364.414±1.682  250.568±0.528  333.528±1.218   \n",
      "(300, 400)  0.169±0.002  471.827±1.957  345.864±0.344   462.753±1.56   \n",
      "(400, 500)  0.106±0.002  585.389±3.189   446.16±0.753  609.905±2.464   \n",
      "(500, inf)  0.138±0.002  757.241±3.248   637.892±0.89   827.63±1.817   \n",
      "\n",
      "                  rt_top1        rt_top2          mcc          acc  \\\n",
      "(0, 100)     87.287±1.356   75.384±0.605   0.27±0.008  0.506±0.008   \n",
      "(100, 200)  163.638±0.547  150.967±0.348   0.31±0.007  0.615±0.001   \n",
      "(200, 300)  291.187±0.515   265.824±0.68  0.198±0.009  0.539±0.004   \n",
      "(300, 400)  415.921±1.223  374.463±1.605  0.155±0.012  0.413±0.008   \n",
      "(400, 500)  543.904±2.918  488.795±1.104   0.16±0.006  0.392±0.004   \n",
      "(500, inf)  732.074±1.494  676.999±0.677   0.197±0.01   0.444±0.01   \n",
      "\n",
      "           equ_top1_acc equ_top2_acc improvement_top1  \n",
      "(0, 100)    0.591±0.008  0.837±0.003      0.077±0.012  \n",
      "(100, 200)  0.689±0.002  0.915±0.002      0.106±0.004  \n",
      "(200, 300)  0.603±0.004   0.82±0.003      0.115±0.004  \n",
      "(300, 400)  0.482±0.007  0.709±0.008      0.059±0.003  \n",
      "(400, 500)  0.457±0.004  0.681±0.003      0.031±0.005  \n",
      "(500, inf)  0.527±0.009  0.746±0.007      0.012±0.004  \n"
     ]
    }
   ],
   "source": [
    "# Process the metric from multiple runs and save the mean+std results\n",
    "\n",
    "def compute_metrics(preds, labels, thres):\n",
    "    # Compute runtime (rt) and halt rate (hr) based on different halt rate thresholds.\n",
    "    if labels.shape[1] > 7:\n",
    "        runtime = labels[:, 2:-1]\n",
    "    else:\n",
    "        runtime = labels\n",
    "    base_time = runtime[:, 0]\n",
    "    min_time, _ = runtime.min(dim=1) \n",
    "\n",
    "    len_data = preds.shape[0]\n",
    "\n",
    "    pred_top1 = preds.argmax(dim=1) # Predicted solver\n",
    "    pred_time_top1 = runtime[torch.arange(len_data), pred_top1] \n",
    "\n",
    "    # Compute the better time among predicted top2 solvers\n",
    "    _, pred_idx_top2 = torch.topk(preds, 2, dim=1)\n",
    "    tmp = torch.zeros((len_data, 2))\n",
    "    tmp[:, 0] = runtime[torch.arange(len_data), pred_idx_top2[:, 0]]\n",
    "    tmp[:, 1] = runtime[torch.arange(len_data), pred_idx_top2[:, 1]]\n",
    "    pred_time_top2, _ = tmp.min(dim=1)\n",
    "\n",
    "    # Analyze the results based on bracket of min runtime\n",
    "    mask = (min_time > thres[0]) & (min_time <= thres[1])\n",
    "    percentage = mask.sum().float() / len_data\n",
    "\n",
    "    # rt_top1 = pred_time_top1[top1_mask].mean()\n",
    "    rt_top1 = pred_time_top1[mask].mean()\n",
    "    rt_top2 = pred_time_top2[mask].mean()\n",
    "\n",
    "    improvement_top1 = ((base_time - pred_time_top1) / base_time)[mask].mean()\n",
    "\n",
    "    rt_min = min_time[mask].mean()\n",
    "    rt_base = base_time[mask].mean()\n",
    "\n",
    "    tgt_idx = runtime.argmin(dim=1)\n",
    "    \n",
    "    mcc = mcc_fn(tgt_idx[mask], pred_top1[mask])\n",
    "    acc = acc_fn(tgt_idx[mask], pred_top1[mask])\n",
    "    \n",
    "    # Calculate equivalent accuracy. Prediction is correct if the runtime difference is < 5%\n",
    "    equ_top1_corr = ((pred_time_top1-min_time) / min_time <= 0.05)\n",
    "    equ_top1_acc = equ_top1_corr[mask].sum() / mask.sum()\n",
    "\n",
    "    equ_top2_corr = ((pred_time_top2-min_time) / min_time <= 0.05)\n",
    "    equ_top2_acc = equ_top2_corr[mask].sum() / mask.sum()\n",
    "\n",
    "    # Expected runtime\n",
    "    probs = F.softmax(preds, dim=-1)\n",
    "    exp_rt_all = (runtime * probs).sum(dim=1)\n",
    "    exp_rt = exp_rt_all[mask].mean()\n",
    "    return {'percentage': percentage, 'rt_base': rt_base, 'rt_min': rt_min, 'exp_rt': exp_rt, 'rt_top1': rt_top1, 'rt_top2': rt_top2,\n",
    "            'mcc': mcc, 'acc': acc, 'equ_top1_acc': equ_top1_acc, 'equ_top2_acc': equ_top2_acc, 'improvement_top1': improvement_top1}\n",
    "\n",
    "def process_metrics(exp_dir):\n",
    "    # hr_options = [100, 200, 300, 400, 500]\n",
    "    exp_name = exp_dir.split('/')[-1]\n",
    "    print(f\"exp_name: {exp_name}\")\n",
    "    hr_options = [(0, 100), (100, 200), (200, 300), (300, 400), (400, 500), (500, np.inf)]\n",
    "    data = []\n",
    "    for split_idx in range(5):\n",
    "        run_dir = os.path.join(exp_dir, 'seed_604_split_'+str(split_idx))\n",
    "        test_label_file = os.path.join(run_dir, 'test_labels.csv')\n",
    "        test_pred_file = os.path.join(run_dir, 'test_pred_probs.csv')\n",
    "\n",
    "        if not os.path.isfile(test_pred_file):\n",
    "            continue\n",
    "\n",
    "        labels = pd.read_csv(test_label_file).to_numpy()\n",
    "        preds = pd.read_csv(test_pred_file).to_numpy()\n",
    "\n",
    "        labels = torch.tensor(labels)\n",
    "        preds = torch.tensor(preds)\n",
    "\n",
    "        test_metrics_list = []\n",
    "        \n",
    "        for hr_threshold in hr_options:\n",
    "            metrics = compute_metrics(preds, labels, hr_threshold)\n",
    "            test_metrics_list.append(metrics)\n",
    "\n",
    "        row_index = [str(rt_range) for rt_range in hr_options]\n",
    "        # print(row_index)\n",
    "        test_metrics = pd.DataFrame.from_records(test_metrics_list, index=row_index).astype(float)\n",
    "        save_path = os.path.join(run_dir, 'test_metrics_v3.csv')\n",
    "        test_metrics.to_csv(save_path)\n",
    "\n",
    "        data.append(test_metrics)\n",
    "\n",
    "    print(data)\n",
    "    data_arr = np.dstack([d.to_numpy() for d in data])\n",
    "\n",
    "    avg = data_arr.mean(axis=2).round(3)\n",
    "    std = data_arr.std(axis=2).round(3)\n",
    "\n",
    "    new_df = pd.DataFrame(index=data[0].index, columns=data[0].columns)\n",
    "    \n",
    "    for j, col in enumerate(new_df.columns):\n",
    "        dat = []\n",
    "        for i in range(avg.shape[0]):\n",
    "            avg_std = str(avg[i, j]) + str(u\"\\u00B1\") + str(std[i, j])\n",
    "            dat.append(avg_std)\n",
    "        new_df[col] = dat\n",
    "    \n",
    "    save_path = os.path.join(exp_dir, exp_name+'_min_rt_range.csv')\n",
    "    new_df.to_csv(save_path, encoding='utf-8-sig')\n",
    "    print(new_df)\n",
    "\n",
    "dirs = {\n",
    "    'SATzilla': \"/home/XXXX-2/sat/sat_selection_light/lightning_logs/0604_satzilla_mlp\",   # Raw logs in baselines/ directory\n",
    "    'GCN-LPE': \"/home/XXXX-2/sat/sat_selection_light/lightning_logs/0608_solv-none\",\n",
    "    'Hetero-LPE': \"/home/XXXX-2/sat/sat_selection_light/lightning_logs/0802_hetero_logits\",\n",
    "    'Hetero-Nodezilla': \"/home/XXXX-2/sat/sat_selection_light/lightning_logs/0808_hetero_satzilla_feat\"\n",
    "}\n",
    "\n",
    "for _, exp_dir in dirs.items():\n",
    "    process_metrics(exp_dir)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1200x400 with 6 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Total test data: 15746\n",
      "Ratio of diff in total: 0.280\n",
      "Avg. Runtime of diff pred: 16.542\n",
      "Median runtime of diff pred: 7.000\n",
      "Ratio of better in diff: 0.433\n",
      "Avg. Runtime of better pred: -88.627\n",
      "Median runtime of better pred: -46.000\n",
      "Ratio of worse in diff: 0.567\n",
      "Avg. Runtime of worse pred: 97.007\n",
      "Median runtime of worse pred: 47.000\n",
      "\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "import torch.nn.functional as F\n",
    "import numpy as np\n",
    "import torch\n",
    "import pandas as pd\n",
    "import seaborn as sbn\n",
    "import matplotlib.pyplot as plt\n",
    "# import plotly.express as px\n",
    "\n",
    "log_dir = \"/home/XXXX-2/sat/sat_selection_light/lightning_logs/\"\n",
    "\n",
    "def compare_model_predictions(exp_1, exp_2):\n",
    "    # hr_options = [100, 200, 300, 400, 500]\n",
    "\n",
    "    exp_dir_1 = os.path.join(log_dir, exp_1)\n",
    "    exp_dir_2 = os.path.join(log_dir, exp_2)\n",
    "\n",
    "    results = []\n",
    "    total_data_len = 0\n",
    "    \n",
    "    for split_idx in range(5):\n",
    "        split_dir_1 = os.path.join(exp_dir_1, 'seed_604_split_'+str(split_idx))\n",
    "        label_file_1 = os.path.join(split_dir_1, 'test_labels.csv')\n",
    "        pred_file_1 = os.path.join(split_dir_1, 'test_pred_probs.csv')\n",
    "\n",
    "        split_dir_2 = os.path.join(exp_dir_2, 'seed_604_split_'+str(split_idx))\n",
    "        label_file_2 = os.path.join(split_dir_2, 'test_labels.csv')\n",
    "        pred_file_2 = os.path.join(split_dir_2, 'test_pred_probs.csv')\n",
    "\n",
    "        if not (os.path.isfile(pred_file_1) and os.path.isfile(pred_file_2)):\n",
    "            continue\n",
    "\n",
    "        labels_1 = pd.read_csv(label_file_1).to_numpy()\n",
    "        if labels_1.shape[1] == 10:\n",
    "            runtimes_1 = labels_1[:, 2:-1]\n",
    "        else:\n",
    "            runtimes_1 = labels_1\n",
    "        preds_1 = F.softmax(torch.tensor(pd.read_csv(pred_file_1).to_numpy()), dim=-1).numpy()\n",
    "        preds_1_top1 = np.argmax(preds_1, -1)\n",
    "        index_arr = np.arange(preds_1.shape[0])\n",
    "        rt_1_top1 = runtimes_1[index_arr, preds_1_top1]\n",
    "\n",
    "        total_data_len += preds_1.shape[0]\n",
    "\n",
    "        labels_2 = pd.read_csv(label_file_2).to_numpy()\n",
    "        if labels_2.shape[1] == 10:\n",
    "            runtimes_2 = labels_2[:, 2:-1]\n",
    "        else:\n",
    "            runtimes_2 = labels_2\n",
    "        preds_2 = F.softmax(torch.tensor(pd.read_csv(pred_file_2).to_numpy()), dim=-1).numpy()\n",
    "        preds_2_top1 = np.argmax(preds_2, -1)\n",
    "        rt_2_top1 = runtimes_2[index_arr, preds_2_top1]\n",
    "\n",
    "        # nodezilla_labels = pd.read_csv(nodezilla_test_label_file).to_numpy()\n",
    "        # nodezilla_runtimes = nodezilla_labels[:, 2:-1]\n",
    "        # nodezilla_preds = F.softmax(torch.tensor(pd.read_csv(nodezilla_test_pred_file).to_numpy()), dim=-1).numpy()\n",
    "        # nodezilla_preds_top1 = np.argmax(nodezilla_preds, -1)\n",
    "        # nodezilla_rt_top1 = nodezilla_runtimes[index_arr, nodezilla_preds_top1]\n",
    "\n",
    "        diff_mask = rt_2_top1 != rt_1_top1\n",
    "        better_mask = rt_2_top1[diff_mask] < rt_1_top1[diff_mask]\n",
    "        worse_mask = rt_2_top1[diff_mask] > rt_1_top1[diff_mask]\n",
    "\n",
    "        num_lit = labels_2[:, 0][diff_mask]\n",
    "        num_clause = labels_2[:, 1][diff_mask]\n",
    "\n",
    "        diff_pred_1 = preds_1_top1[diff_mask]\n",
    "        diff_pred_2 = preds_2_top1[diff_mask]\n",
    "        diff_rt_1 = rt_1_top1[diff_mask]\n",
    "        diff_rt_2 = rt_2_top1[diff_mask]\n",
    "        diff_rt = diff_rt_2 - diff_rt_1\n",
    "\n",
    "        # impr_rt = base_rt_top1[diff_mask] - nodezilla_rt_top1[diff_mask]\n",
    "        # impr_base_pred = base_preds_top1[diff_mask]\n",
    "        # impr_base_prob = base_preds[index_arr, base_preds_top1][diff_mask]\n",
    "        # impr_nz_pred = nodezilla_preds_top1[diff_mask]\n",
    "        # impr_nz_prob = nodezilla_preds[index_arr, nodezilla_preds_top1][diff_mask] \n",
    "        # impr_base_pred_prob_change = (nodezilla_preds[index_arr, base_preds_top1] - base_preds[index_arr, base_preds_top1])[diff_mask]\n",
    "        # impr_nz_pred_prob_change = (nodezilla_preds[index_arr, nodezilla_preds_top1] - base_preds[index_arr, nodezilla_preds_top1])[diff_mask]\n",
    "\n",
    "        diff_data = np.stack([num_lit, num_clause, better_mask, worse_mask, diff_pred_1, diff_rt_1, diff_pred_2, diff_rt_2, diff_rt], axis=-1)\n",
    "        results.append(diff_data)\n",
    "        \n",
    "        # preds = np.stack([base_preds_top1, nodezilla_preds_top1], axis=-1)\n",
    "\n",
    "        # df_preds = pd.DataFrame(preds, columns=['base', 'nodezilla'])\n",
    "        # fig = px.density_heatmap(df_preds, nbinsx=7, nbinsy=7, x=\"base\", y=\"nodezilla\", range_x=[-0.5, 6.5], range_y=[-0.5, 6.5], marginal_x=\"histogram\", marginal_y=\"histogram\")\n",
    "        # fig.write_image(os.path.join(nodezilla_run_dir, 'label_change_'+str(split_idx)+'.png'))\n",
    "    \n",
    "    all_results = np.concatenate(results, axis=0)\n",
    "    df_res = pd.DataFrame(all_results, columns=['num_lit', 'num_clause', 'is_better', 'is_worse', 'pred_1', 'rt_1', 'pred_2', 'rt_2', 'diff_rt'])\n",
    "\n",
    "    def get_label_change_matrix(df_res, key=None):\n",
    "        if key != None:\n",
    "            data = df_res[df_res[key]==1.0]\n",
    "        else:\n",
    "            data = df_res\n",
    "        label_change = data.groupby(['pred_1', 'pred_2'], as_index=False)['num_lit'].count()\n",
    "        label_matrix = np.zeros((7, 7))\n",
    "        for _, row in label_change.iterrows():\n",
    "            idx_1 = int(row['pred_1'])\n",
    "            idx_2 = int(row['pred_2'])\n",
    "            label_matrix[idx_1, idx_2] = row['num_lit']\n",
    "        # print(label_matrix)\n",
    "        df_matrix = pd.DataFrame(label_matrix)\n",
    "        return df_matrix\n",
    "\n",
    "    fig, axes = plt.subplots(1, 3, figsize=(12, 4))\n",
    "    diff_rt_mean = df_res['diff_rt'].mean()\n",
    "    diff_rt_median = df_res['diff_rt'].median()\n",
    "    diff_label_matrix = get_label_change_matrix(df_res) \n",
    "    diff_savepath = os.path.join(exp_dir_2, f'vs_{exp_1}_diff_label.csv')\n",
    "    diff_label_matrix.to_csv(diff_savepath)\n",
    "\n",
    "    sbn.heatmap(diff_label_matrix, vmax=2e3, cmap='Reds', annot=True, annot_kws={'fontsize':8}, ax=axes[0])\n",
    "    axes[0].set(xlabel=exp_2+'(exp_2)', ylabel=exp_1+'(exp_1)', title='all_diff')\n",
    "    axes[0].xaxis.tick_top()\n",
    "    # plt.savefig(''.join(diff_savepath.split('.')[:-1])+'.png')\n",
    "    # plt.show()\n",
    "    # plt.close()\n",
    "\n",
    "    better_cnt = df_res['is_better'].sum() \n",
    "    better_ratio = better_cnt / df_res.shape[0]\n",
    "    better_rt_mean = df_res[df_res['is_better']==1.0]['diff_rt'].mean()\n",
    "    better_rt_median = df_res[df_res['is_better']==1.0]['diff_rt'].median()\n",
    "    better_label_matrix = get_label_change_matrix(df_res, 'is_better') \n",
    "    better_savepath = os.path.join(exp_dir_2, f'vs_{exp_1}_better_label.csv')\n",
    "    better_label_matrix.to_csv(better_savepath)\n",
    "\n",
    "    # print(better_label_matrix.iloc[0, 3])\n",
    "    sbn.heatmap(better_label_matrix, vmax=2e3, cmap='Reds', annot=True, annot_kws={'fontsize':8}, ax=axes[1])\n",
    "    axes[1].set(xlabel=exp_2+'(exp_2)', ylabel=exp_1+'(exp_1)', title='exp_2 is better than exp_1')\n",
    "    axes[1].xaxis.tick_top()\n",
    "    # plt.savefig(''.join(better_savepath.split('.')[:-1])+'.png')\n",
    "    # plt.close()\n",
    "\n",
    "    worse_cnt = df_res['is_worse'].sum() \n",
    "    worse_ratio = worse_cnt / df_res.shape[0]\n",
    "    worse_rt_mean = df_res[df_res['is_worse']==1.0]['diff_rt'].mean()\n",
    "    worse_rt_median = df_res[df_res['is_worse']==1.0]['diff_rt'].median()\n",
    "    worse_label_matrix = get_label_change_matrix(df_res, 'is_worse') \n",
    "    worse_savepath = os.path.join(exp_dir_2, f'vs_{exp_1}_worse_label.csv')\n",
    "    worse_label_matrix.to_csv(worse_savepath)\n",
    "\n",
    "    sbn.heatmap(worse_label_matrix, vmax=2e3, cmap='Reds', annot=True, annot_kws={'fontsize':8}, ax=axes[2])\n",
    "    axes[2].set(xlabel=exp_2+'(exp_2)', ylabel=exp_1+'(exp_1)', title='exp_2 is worse than exp_1')\n",
    "    axes[2].xaxis.tick_top()\n",
    "\n",
    "    fig_savepath = os.path.join(exp_dir_2, f'vs_{exp_1}_preds.png')\n",
    "    plt.tight_layout()\n",
    "    plt.savefig(fig_savepath)\n",
    "    plt.show()\n",
    "    plt.close()\n",
    "\n",
    "\n",
    "    # diff_rt_mean_neq_05 = df_res[(df_res['pred_2'] != 0) & (df_res['pred_2'] != 5)]['diff_rt'].mean()\n",
    "    # print(diff_rt_mean_neq_05)\n",
    "    # tmp2 = df_res[df_res['pred_2'] == 0]['diff_rt'].mean()\n",
    "    # print(tmp2)\n",
    "    # tmp3 = df_res[df_res['pred_2'] == 5]['diff_rt'].mean()\n",
    "    # print(tmp3)\n",
    "\n",
    "    diff_ratio = df_res.shape[0] / total_data_len\n",
    "    str2save = f\"Total test data: {total_data_len}\\n\" + \\\n",
    "               f\"Ratio of diff in total: {diff_ratio:.3f}\\n\" + \\\n",
    "               f\"Avg. Runtime of diff pred: {diff_rt_mean:.3f}\\n\" + \\\n",
    "               f\"Median runtime of diff pred: {diff_rt_median:.3f}\\n\" + \\\n",
    "               f\"Ratio of better in diff: {better_ratio:.3f}\\n\" + \\\n",
    "               f\"Avg. Runtime of better pred: {better_rt_mean:.3f}\\n\" + \\\n",
    "               f\"Median runtime of better pred: {better_rt_median:.3f}\\n\" + \\\n",
    "               f\"Ratio of worse in diff: {worse_ratio:.3f}\\n\" + \\\n",
    "               f\"Avg. Runtime of worse pred: {worse_rt_mean:.3f}\\n\" + \\\n",
    "               f\"Median runtime of worse pred: {worse_rt_median:.3f}\\n\"\n",
    "\n",
    "    print(str2save)\n",
    "    with open(os.path.join(exp_dir_2, f'vs_{exp_1}_summary.txt'), 'w') as f:\n",
    "        f.writelines(str2save)\n",
    "\n",
    "    save_path = os.path.join(exp_dir_2, f'vs_{exp_1}_res.csv')\n",
    "    df_res.to_csv(save_path)\n",
    "\n",
    "# dirs = {\n",
    "#     'SATzilla': \"/home/XXXX-2/sat/sat_selection_light/lightning_logs/0604_satzilla_mlp\",   # Raw logs in baselines/ directory\n",
    "#     'GCN-LPE': \"/home/XXXX-2/sat/sat_selection_light/lightning_logs/0608_solv-none\",\n",
    "#     'Hetero-LPE': \"/home/XXXX-2/sat/sat_selection_light/lightning_logs/0802_hetero_logits\",\n",
    "#     'Hetero-Nodezilla': \"/home/XXXX-2/sat/sat_selection_light/lightning_logs/0808_hetero_satzilla_feat\"\n",
    "# }\n",
    "# exp_1 = '0604_satzilla_mlp'\n",
    "exp_1 = '0808_hetero_satzilla_feat'\n",
    "exp_2 = '0914_nodezilla_exp_rt'\n",
    "# exp_2 = '0810_hetero_satzilla_feat_pe'\n",
    "\n",
    "compare_model_predictions(exp_1, exp_2)"
   ]
  }
 ],
 "metadata": {
  "interpreter": {
   "hash": "a78e89a48c699a6ba54266b96068dd7b0b69dfec9a3e27db3a261c177d599c1b"
  },
  "kernelspec": {
   "display_name": "Python 3.8.2 64-bit ('sat': conda)",
   "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.2"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
