{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "27de1fef",
   "metadata": {},
   "source": [
    "# What i want to do\n",
    "\n",
    "if the score differences are there for smaller and bigger accuracy differences over a certain threshold\n",
    "\n",
    "ie. does score differs enough when the accuracy also differs enough or it difers slightly like models when they have smaller differences in accuray"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0d4fadcc",
   "metadata": {},
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "0993483f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'resnet152': 0.5101921487526754,\n",
       " 'resnet101': 0.4965302703273255,\n",
       " 'resnet50': 0.41490007875060986,\n",
       " 'densenet201': 0.40710704181563495,\n",
       " 'densenet169': 0.3888939385792787,\n",
       " 'inception_v3': 0.3507810593634498,\n",
       " 'resnet34': 0.3411951186875728,\n",
       " 'densenet121': 0.33682993098582215,\n",
       " 'googlenet': 0.32660615321912817,\n",
       " 'mnasnet1_0': 0.31662695070208585,\n",
       " 'mobilenet_v2': 0.2923328258133188}"
      ]
     },
     "execution_count": 1,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from rank_correlation import load_score\n",
    "import pandas as pd\n",
    "from scipy.stats import pearsonr\n",
    "import itertools\n",
    "from collections import defaultdict\n",
    "metric = 'logme'\n",
    "dataset = 'cifar10'\n",
    "score_path = f'./results_metrics/group1/{metric}/{dataset}_metrics.json'\n",
    "score, _ = load_score(score_path)\n",
    "\n",
    "score"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "3a63579d",
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "acc_dict = {\n",
    "        'aircraft': {'resnet34': 84.06, 'resnet50': 84.64, 'resnet101': 85.53, 'resnet152': 86.29, 'densenet121': 84.66, \n",
    "                    'densenet169': 84.19, 'densenet201': 85.38, 'mnasnet1_0': 66.48, 'mobilenet_v2': 79.68, \n",
    "                    'googlenet': 80.32, 'inception_v3': 80.15}, \n",
    "        'caltech101': {'resnet34': 91.15, 'resnet50': 91.98, 'resnet101': 92.38, 'resnet152': 93.1, 'densenet121': 91.5, \n",
    "                    'densenet169': 92.51, 'densenet201': 93.14, 'mnasnet1_0': 89.34, 'mobilenet_v2': 88.64, \n",
    "                    'googlenet': 90.85, 'inception_v3': 92.75}, \n",
    "        'cars': {'resnet34': 88.63, 'resnet50': 89.09, 'resnet101': 89.47, 'resnet152': 89.88, 'densenet121': 89.34, \n",
    "                    'densenet169': 89.02, 'densenet201': 89.44, 'mnasnet1_0': 72.58, 'mobilenet_v2': 86.44, \n",
    "                    'googlenet': 87.76, 'inception_v3': 87.74}, \n",
    "        'cifar10': {'resnet34': 96.12, 'resnet50': 96.28, 'resnet101': 97.39, 'resnet152': 97.53, 'densenet121': 96.45, \n",
    "                    'densenet169': 96.77, 'densenet201': 97.02, 'mnasnet1_0': 92.59, 'mobilenet_v2': 94.74, \n",
    "                    'googlenet': 95.54, \n",
    "                    'inception_v3': 96.18}, \n",
    "        'cifar100': {'resnet34': 81.94, 'resnet50': 82.8, 'resnet101': 84.88, 'resnet152': 85.66, 'densenet121': 82.75, \n",
    "                    'densenet169': 84.26, 'densenet201': 84.88, 'mnasnet1_0': 72.04, 'mobilenet_v2': 78.11, \n",
    "                    'googlenet': 79.84, \n",
    "                    'inception_v3': 81.49}, \n",
    "        'dtd': {'resnet34': 72.96, 'resnet50': 74.72, 'resnet101': 74.8, 'resnet152': 76.44, 'densenet121': 74.18, \n",
    "                    'densenet169': 74.72, 'densenet201': 76.04, 'mnasnet1_0': 70.12, 'mobilenet_v2': 71.72, \n",
    "                    'googlenet': 72.53, \n",
    "                    'inception_v3': 72.85}, \n",
    "        'flowers': {'resnet34': 95.2, 'resnet50': 96.26, 'resnet101': 96.53, 'resnet152': 96.86, 'densenet121': 97.02, \n",
    "                    'densenet169': 97.32, 'densenet201': 97.1, 'mnasnet1_0': 95.39, 'mobilenet_v2': 96.2, \n",
    "                    'googlenet': 95.76, \n",
    "                    'inception_v3': 95.73},\n",
    "        'food': {'resnet34': 81.99, 'resnet50': 84.45, 'resnet101': 85.58, 'resnet152': 86.28, 'densenet121': 84.99, \n",
    "                    'densenet169': 85.84, 'densenet201': 86.71, 'mnasnet1_0': 71.35, 'mobilenet_v2': 81.12, \n",
    "                    'googlenet': 79.3, \n",
    "                    'inception_v3': 81.76}, \n",
    "        'pets': {'resnet34': 93.5, 'resnet50': 93.88, 'resnet101': 93.92, 'resnet152': 94.42, 'densenet121': 93.07, \n",
    "                    'densenet169': 93.62, 'densenet201': 94.03, 'mnasnet1_0': 91.08, 'mobilenet_v2': 91.28, \n",
    "                    'googlenet': 91.38, \n",
    "                    'inception_v3': 92.14},\n",
    "        'sun397': {'resnet34': 61.02, 'resnet50': 63.54, 'resnet101': 63.76, 'resnet152': 64.82, 'densenet121': 63.26, \n",
    "                    'densenet169': 64.1, 'densenet201': 64.57, 'mnasnet1_0': 56.56, 'mobilenet_v2': 60.29, \n",
    "                    'googlenet': 59.89, \n",
    "                    'inception_v3': 59.98}, \n",
    "        'voc2007': {'resnet34': 84.6, 'resnet50': 85.8, 'resnet101': 85.68, 'resnet152': 86.32, 'densenet121': 85.28, \n",
    "                    'densenet169': 85.77, 'densenet201': 85.67, 'mnasnet1_0': 81.06, 'mobilenet_v2': 82.8, \n",
    "                    'googlenet': 82.58, \n",
    "                    'inception_v3': 83.84}\n",
    "        }"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "6b3e80fd",
   "metadata": {},
   "outputs": [],
   "source": [
    "def count_order_violations_detailed(df, acc_col='acc_diff', score_col='score_diff'):\n",
    "    \"\"\"\n",
    "    Enhanced version that captures violation details including magnitudes\n",
    "    \"\"\"\n",
    "    df = df.copy()\n",
    "    df['abs_acc_diff'] = df[acc_col].abs()\n",
    "    df['abs_score_diff'] = df[score_col].abs()\n",
    "    \n",
    "    rows = list(df.itertuples(index=False))\n",
    "    violations = []\n",
    "    total = 0\n",
    "    \n",
    "    for r1, r2 in itertools.combinations(rows, 2):\n",
    "        total += 1\n",
    "        \n",
    "        # Check for violations and capture details\n",
    "        if (r1.abs_acc_diff > r2.abs_acc_diff and r1.abs_score_diff < r2.abs_score_diff):\n",
    "            violations.append({\n",
    "                'pair1_models': (r1.model_a, r1.model_b),\n",
    "                'pair2_models': (r2.model_a, r2.model_b),\n",
    "                'acc_diff_1': r1.abs_acc_diff,\n",
    "                'acc_diff_2': r2.abs_acc_diff,\n",
    "                'score_diff_1': r1.abs_score_diff,\n",
    "                'score_diff_2': r2.abs_score_diff,\n",
    "                'acc_violation_magnitude': r1.abs_acc_diff - r2.abs_acc_diff,  # How much larger acc diff is\n",
    "                'score_violation_magnitude': r2.abs_score_diff - r1.abs_score_diff,  # How much larger score diff should be\n",
    "                'violation_severity': (r1.abs_acc_diff - r2.abs_acc_diff) / (r2.abs_score_diff - r1.abs_score_diff + 1e-8)\n",
    "            })\n",
    "            \n",
    "        elif (r2.abs_acc_diff > r1.abs_acc_diff and r2.abs_score_diff < r1.abs_score_diff):\n",
    "            violations.append({\n",
    "                'pair1_models': (r2.model_a, r2.model_b),\n",
    "                'pair2_models': (r1.model_a, r1.model_b),\n",
    "                'acc_diff_1': r2.abs_acc_diff,\n",
    "                'acc_diff_2': r1.abs_acc_diff,\n",
    "                'score_diff_1': r2.abs_score_diff,\n",
    "                'score_diff_2': r1.abs_score_diff,\n",
    "                'acc_violation_magnitude': r2.abs_acc_diff - r1.abs_acc_diff,\n",
    "                'score_violation_magnitude': r1.abs_score_diff - r2.abs_score_diff,\n",
    "                'violation_severity': (r2.abs_acc_diff - r1.abs_acc_diff) / (r1.abs_score_diff - r2.abs_score_diff + 1e-8)\n",
    "            })\n",
    "    \n",
    "    violations_df = pd.DataFrame(violations)\n",
    "    return len(violations), total, len(violations)/total if total else 0, violations_df\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "a7fb56a1",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Ordering violations (|Δacc| larger but |score| smaller): 797 of 1485 pair-of-pairs (53.670%)\n",
      "Metric logme Dataset: aircraft, Pairs: 55, Pearson corr(|Δacc|, |Δscore|) = -0.080\n",
      "Ordering violations (|Δacc| larger but |score| smaller): 523 of 1485 pair-of-pairs (35.219%)\n",
      "Metric logme Dataset: cifar10, Pairs: 55, Pearson corr(|Δacc|, |Δscore|) = 0.328\n",
      "Ordering violations (|Δacc| larger but |score| smaller): 748 of 1485 pair-of-pairs (50.370%)\n",
      "Metric logme Dataset: cifar100, Pairs: 55, Pearson corr(|Δacc|, |Δscore|) = 0.012\n",
      "Ordering violations (|Δacc| larger but |score| smaller): 697 of 1485 pair-of-pairs (46.936%)\n",
      "Metric logme Dataset: dtd, Pairs: 55, Pearson corr(|Δacc|, |Δscore|) = 0.031\n",
      "Ordering violations (|Δacc| larger but |score| smaller): 783 of 1485 pair-of-pairs (52.727%)\n",
      "Metric logme Dataset: food, Pairs: 55, Pearson corr(|Δacc|, |Δscore|) = -0.111\n",
      "Ordering violations (|Δacc| larger but |score| smaller): 640 of 1485 pair-of-pairs (43.098%)\n",
      "Metric logme Dataset: pets, Pairs: 55, Pearson corr(|Δacc|, |Δscore|) = 0.102\n",
      "Ordering violations (|Δacc| larger but |score| smaller): 825 of 1485 pair-of-pairs (55.556%)\n",
      "Metric transrate Dataset: aircraft, Pairs: 55, Pearson corr(|Δacc|, |Δscore|) = -0.172\n",
      "Ordering violations (|Δacc| larger but |score| smaller): 785 of 1485 pair-of-pairs (52.862%)\n",
      "Metric transrate Dataset: cifar10, Pairs: 55, Pearson corr(|Δacc|, |Δscore|) = -0.089\n",
      "Ordering violations (|Δacc| larger but |score| smaller): 826 of 1485 pair-of-pairs (55.623%)\n",
      "Metric transrate Dataset: cifar100, Pairs: 55, Pearson corr(|Δacc|, |Δscore|) = -0.225\n",
      "Ordering violations (|Δacc| larger but |score| smaller): 835 of 1485 pair-of-pairs (56.229%)\n",
      "Metric transrate Dataset: dtd, Pairs: 55, Pearson corr(|Δacc|, |Δscore|) = -0.246\n",
      "Ordering violations (|Δacc| larger but |score| smaller): 849 of 1485 pair-of-pairs (57.172%)\n",
      "Metric transrate Dataset: food, Pairs: 55, Pearson corr(|Δacc|, |Δscore|) = -0.217\n",
      "Ordering violations (|Δacc| larger but |score| smaller): 790 of 1485 pair-of-pairs (53.199%)\n",
      "Metric transrate Dataset: pets, Pairs: 55, Pearson corr(|Δacc|, |Δscore|) = -0.121\n",
      "Ordering violations (|Δacc| larger but |score| smaller): 776 of 1485 pair-of-pairs (52.256%)\n",
      "Metric hscore Dataset: aircraft, Pairs: 55, Pearson corr(|Δacc|, |Δscore|) = -0.084\n",
      "Ordering violations (|Δacc| larger but |score| smaller): 480 of 1485 pair-of-pairs (32.323%)\n",
      "Metric hscore Dataset: cifar10, Pairs: 55, Pearson corr(|Δacc|, |Δscore|) = 0.394\n",
      "Ordering violations (|Δacc| larger but |score| smaller): 603 of 1485 pair-of-pairs (40.606%)\n",
      "Metric hscore Dataset: cifar100, Pairs: 55, Pearson corr(|Δacc|, |Δscore|) = 0.202\n",
      "Ordering violations (|Δacc| larger but |score| smaller): 786 of 1485 pair-of-pairs (52.929%)\n",
      "Metric hscore Dataset: dtd, Pairs: 55, Pearson corr(|Δacc|, |Δscore|) = -0.104\n",
      "Ordering violations (|Δacc| larger but |score| smaller): 616 of 1485 pair-of-pairs (41.481%)\n",
      "Metric hscore Dataset: food, Pairs: 55, Pearson corr(|Δacc|, |Δscore|) = 0.086\n",
      "Ordering violations (|Δacc| larger but |score| smaller): 620 of 1485 pair-of-pairs (41.751%)\n",
      "Metric hscore Dataset: pets, Pairs: 55, Pearson corr(|Δacc|, |Δscore|) = 0.110\n",
      "Ordering violations (|Δacc| larger but |score| smaller): 743 of 1485 pair-of-pairs (50.034%)\n",
      "Metric sfda Dataset: aircraft, Pairs: 55, Pearson corr(|Δacc|, |Δscore|) = -0.068\n",
      "Ordering violations (|Δacc| larger but |score| smaller): 336 of 1485 pair-of-pairs (22.626%)\n",
      "Metric sfda Dataset: cifar10, Pairs: 55, Pearson corr(|Δacc|, |Δscore|) = 0.658\n",
      "Ordering violations (|Δacc| larger but |score| smaller): 324 of 1485 pair-of-pairs (21.818%)\n",
      "Metric sfda Dataset: cifar100, Pairs: 55, Pearson corr(|Δacc|, |Δscore|) = 0.682\n",
      "Ordering violations (|Δacc| larger but |score| smaller): 490 of 1485 pair-of-pairs (32.997%)\n",
      "Metric sfda Dataset: dtd, Pairs: 55, Pearson corr(|Δacc|, |Δscore|) = 0.479\n",
      "Ordering violations (|Δacc| larger but |score| smaller): 464 of 1485 pair-of-pairs (31.246%)\n",
      "Metric sfda Dataset: food, Pairs: 55, Pearson corr(|Δacc|, |Δscore|) = 0.514\n",
      "Ordering violations (|Δacc| larger but |score| smaller): 531 of 1485 pair-of-pairs (35.758%)\n",
      "Metric sfda Dataset: pets, Pairs: 55, Pearson corr(|Δacc|, |Δscore|) = 0.313\n",
      "Ordering violations (|Δacc| larger but |score| smaller): 573 of 1485 pair-of-pairs (38.586%)\n",
      "Metric nleep Dataset: aircraft, Pairs: 55, Pearson corr(|Δacc|, |Δscore|) = 0.374\n",
      "Ordering violations (|Δacc| larger but |score| smaller): 564 of 1485 pair-of-pairs (37.980%)\n",
      "Metric nleep Dataset: cifar10, Pairs: 55, Pearson corr(|Δacc|, |Δscore|) = 0.319\n",
      "Ordering violations (|Δacc| larger but |score| smaller): 525 of 1485 pair-of-pairs (35.354%)\n",
      "Metric nleep Dataset: cifar100, Pairs: 55, Pearson corr(|Δacc|, |Δscore|) = 0.326\n",
      "Ordering violations (|Δacc| larger but |score| smaller): 664 of 1485 pair-of-pairs (44.714%)\n",
      "Metric nleep Dataset: dtd, Pairs: 55, Pearson corr(|Δacc|, |Δscore|) = 0.063\n",
      "Ordering violations (|Δacc| larger but |score| smaller): 621 of 1485 pair-of-pairs (41.818%)\n",
      "Metric nleep Dataset: food, Pairs: 55, Pearson corr(|Δacc|, |Δscore|) = 0.009\n",
      "Ordering violations (|Δacc| larger but |score| smaller): 369 of 1485 pair-of-pairs (24.848%)\n",
      "Metric nleep Dataset: pets, Pairs: 55, Pearson corr(|Δacc|, |Δscore|) = 0.702\n",
      "Ordering violations (|Δacc| larger but |score| smaller): 748 of 1485 pair-of-pairs (50.370%)\n",
      "Metric gbc Dataset: aircraft, Pairs: 55, Pearson corr(|Δacc|, |Δscore|) = -0.144\n",
      "Ordering violations (|Δacc| larger but |score| smaller): 723 of 1485 pair-of-pairs (48.687%)\n",
      "Metric gbc Dataset: cifar10, Pairs: 55, Pearson corr(|Δacc|, |Δscore|) = -0.173\n",
      "Ordering violations (|Δacc| larger but |score| smaller): 660 of 1485 pair-of-pairs (44.444%)\n",
      "Metric gbc Dataset: cifar100, Pairs: 55, Pearson corr(|Δacc|, |Δscore|) = -0.140\n",
      "Ordering violations (|Δacc| larger but |score| smaller): 748 of 1485 pair-of-pairs (50.370%)\n",
      "Metric gbc Dataset: dtd, Pairs: 55, Pearson corr(|Δacc|, |Δscore|) = -0.142\n",
      "Ordering violations (|Δacc| larger but |score| smaller): 686 of 1485 pair-of-pairs (46.195%)\n",
      "Metric gbc Dataset: food, Pairs: 55, Pearson corr(|Δacc|, |Δscore|) = -0.116\n",
      "Ordering violations (|Δacc| larger but |score| smaller): 716 of 1485 pair-of-pairs (48.215%)\n",
      "Metric gbc Dataset: pets, Pairs: 55, Pearson corr(|Δacc|, |Δscore|) = -0.165\n",
      "\n",
      "Summary correlation dataframe (|Δaccuracy| vs |Δscore|):\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>metric</th>\n",
       "      <th>dataset</th>\n",
       "      <th>pearson_abs_diff_corr</th>\n",
       "      <th>violations</th>\n",
       "      <th>total_pairs</th>\n",
       "      <th>violation_ratio</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>gbc</td>\n",
       "      <td>aircraft</td>\n",
       "      <td>-0.143536</td>\n",
       "      <td>748</td>\n",
       "      <td>1485</td>\n",
       "      <td>0.503704</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>gbc</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>-0.173458</td>\n",
       "      <td>723</td>\n",
       "      <td>1485</td>\n",
       "      <td>0.486869</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>gbc</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>-0.140497</td>\n",
       "      <td>660</td>\n",
       "      <td>1485</td>\n",
       "      <td>0.444444</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>gbc</td>\n",
       "      <td>dtd</td>\n",
       "      <td>-0.142359</td>\n",
       "      <td>748</td>\n",
       "      <td>1485</td>\n",
       "      <td>0.503704</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>gbc</td>\n",
       "      <td>food</td>\n",
       "      <td>-0.116158</td>\n",
       "      <td>686</td>\n",
       "      <td>1485</td>\n",
       "      <td>0.461953</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>gbc</td>\n",
       "      <td>pets</td>\n",
       "      <td>-0.164588</td>\n",
       "      <td>716</td>\n",
       "      <td>1485</td>\n",
       "      <td>0.482155</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>hscore</td>\n",
       "      <td>aircraft</td>\n",
       "      <td>-0.083613</td>\n",
       "      <td>776</td>\n",
       "      <td>1485</td>\n",
       "      <td>0.522559</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>hscore</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>0.394432</td>\n",
       "      <td>480</td>\n",
       "      <td>1485</td>\n",
       "      <td>0.323232</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>hscore</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>0.202448</td>\n",
       "      <td>603</td>\n",
       "      <td>1485</td>\n",
       "      <td>0.406061</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>hscore</td>\n",
       "      <td>dtd</td>\n",
       "      <td>-0.103969</td>\n",
       "      <td>786</td>\n",
       "      <td>1485</td>\n",
       "      <td>0.529293</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>hscore</td>\n",
       "      <td>food</td>\n",
       "      <td>0.086428</td>\n",
       "      <td>616</td>\n",
       "      <td>1485</td>\n",
       "      <td>0.414815</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>hscore</td>\n",
       "      <td>pets</td>\n",
       "      <td>0.110061</td>\n",
       "      <td>620</td>\n",
       "      <td>1485</td>\n",
       "      <td>0.417508</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>logme</td>\n",
       "      <td>aircraft</td>\n",
       "      <td>-0.079518</td>\n",
       "      <td>797</td>\n",
       "      <td>1485</td>\n",
       "      <td>0.536700</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>logme</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>0.328392</td>\n",
       "      <td>523</td>\n",
       "      <td>1485</td>\n",
       "      <td>0.352189</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>logme</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>0.012355</td>\n",
       "      <td>748</td>\n",
       "      <td>1485</td>\n",
       "      <td>0.503704</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>logme</td>\n",
       "      <td>dtd</td>\n",
       "      <td>0.030673</td>\n",
       "      <td>697</td>\n",
       "      <td>1485</td>\n",
       "      <td>0.469360</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>logme</td>\n",
       "      <td>food</td>\n",
       "      <td>-0.110512</td>\n",
       "      <td>783</td>\n",
       "      <td>1485</td>\n",
       "      <td>0.527273</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>logme</td>\n",
       "      <td>pets</td>\n",
       "      <td>0.102090</td>\n",
       "      <td>640</td>\n",
       "      <td>1485</td>\n",
       "      <td>0.430976</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>18</th>\n",
       "      <td>nleep</td>\n",
       "      <td>aircraft</td>\n",
       "      <td>0.373813</td>\n",
       "      <td>573</td>\n",
       "      <td>1485</td>\n",
       "      <td>0.385859</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>19</th>\n",
       "      <td>nleep</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>0.318529</td>\n",
       "      <td>564</td>\n",
       "      <td>1485</td>\n",
       "      <td>0.379798</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>20</th>\n",
       "      <td>nleep</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>0.325821</td>\n",
       "      <td>525</td>\n",
       "      <td>1485</td>\n",
       "      <td>0.353535</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>21</th>\n",
       "      <td>nleep</td>\n",
       "      <td>dtd</td>\n",
       "      <td>0.062746</td>\n",
       "      <td>664</td>\n",
       "      <td>1485</td>\n",
       "      <td>0.447138</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22</th>\n",
       "      <td>nleep</td>\n",
       "      <td>food</td>\n",
       "      <td>0.008551</td>\n",
       "      <td>621</td>\n",
       "      <td>1485</td>\n",
       "      <td>0.418182</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>23</th>\n",
       "      <td>nleep</td>\n",
       "      <td>pets</td>\n",
       "      <td>0.702045</td>\n",
       "      <td>369</td>\n",
       "      <td>1485</td>\n",
       "      <td>0.248485</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>24</th>\n",
       "      <td>sfda</td>\n",
       "      <td>aircraft</td>\n",
       "      <td>-0.068009</td>\n",
       "      <td>743</td>\n",
       "      <td>1485</td>\n",
       "      <td>0.500337</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>25</th>\n",
       "      <td>sfda</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>0.658157</td>\n",
       "      <td>336</td>\n",
       "      <td>1485</td>\n",
       "      <td>0.226263</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>26</th>\n",
       "      <td>sfda</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>0.681581</td>\n",
       "      <td>324</td>\n",
       "      <td>1485</td>\n",
       "      <td>0.218182</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>27</th>\n",
       "      <td>sfda</td>\n",
       "      <td>dtd</td>\n",
       "      <td>0.478873</td>\n",
       "      <td>490</td>\n",
       "      <td>1485</td>\n",
       "      <td>0.329966</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>28</th>\n",
       "      <td>sfda</td>\n",
       "      <td>food</td>\n",
       "      <td>0.513844</td>\n",
       "      <td>464</td>\n",
       "      <td>1485</td>\n",
       "      <td>0.312458</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>29</th>\n",
       "      <td>sfda</td>\n",
       "      <td>pets</td>\n",
       "      <td>0.313404</td>\n",
       "      <td>531</td>\n",
       "      <td>1485</td>\n",
       "      <td>0.357576</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>30</th>\n",
       "      <td>transrate</td>\n",
       "      <td>aircraft</td>\n",
       "      <td>-0.171748</td>\n",
       "      <td>825</td>\n",
       "      <td>1485</td>\n",
       "      <td>0.555556</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>31</th>\n",
       "      <td>transrate</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>-0.089483</td>\n",
       "      <td>785</td>\n",
       "      <td>1485</td>\n",
       "      <td>0.528620</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>32</th>\n",
       "      <td>transrate</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>-0.224603</td>\n",
       "      <td>826</td>\n",
       "      <td>1485</td>\n",
       "      <td>0.556229</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>33</th>\n",
       "      <td>transrate</td>\n",
       "      <td>dtd</td>\n",
       "      <td>-0.246197</td>\n",
       "      <td>835</td>\n",
       "      <td>1485</td>\n",
       "      <td>0.562290</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>34</th>\n",
       "      <td>transrate</td>\n",
       "      <td>food</td>\n",
       "      <td>-0.217040</td>\n",
       "      <td>849</td>\n",
       "      <td>1485</td>\n",
       "      <td>0.571717</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>35</th>\n",
       "      <td>transrate</td>\n",
       "      <td>pets</td>\n",
       "      <td>-0.121228</td>\n",
       "      <td>790</td>\n",
       "      <td>1485</td>\n",
       "      <td>0.531987</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "       metric   dataset  pearson_abs_diff_corr  violations  total_pairs  \\\n",
       "0         gbc  aircraft              -0.143536         748         1485   \n",
       "1         gbc   cifar10              -0.173458         723         1485   \n",
       "2         gbc  cifar100              -0.140497         660         1485   \n",
       "3         gbc       dtd              -0.142359         748         1485   \n",
       "4         gbc      food              -0.116158         686         1485   \n",
       "5         gbc      pets              -0.164588         716         1485   \n",
       "6      hscore  aircraft              -0.083613         776         1485   \n",
       "7      hscore   cifar10               0.394432         480         1485   \n",
       "8      hscore  cifar100               0.202448         603         1485   \n",
       "9      hscore       dtd              -0.103969         786         1485   \n",
       "10     hscore      food               0.086428         616         1485   \n",
       "11     hscore      pets               0.110061         620         1485   \n",
       "12      logme  aircraft              -0.079518         797         1485   \n",
       "13      logme   cifar10               0.328392         523         1485   \n",
       "14      logme  cifar100               0.012355         748         1485   \n",
       "15      logme       dtd               0.030673         697         1485   \n",
       "16      logme      food              -0.110512         783         1485   \n",
       "17      logme      pets               0.102090         640         1485   \n",
       "18      nleep  aircraft               0.373813         573         1485   \n",
       "19      nleep   cifar10               0.318529         564         1485   \n",
       "20      nleep  cifar100               0.325821         525         1485   \n",
       "21      nleep       dtd               0.062746         664         1485   \n",
       "22      nleep      food               0.008551         621         1485   \n",
       "23      nleep      pets               0.702045         369         1485   \n",
       "24       sfda  aircraft              -0.068009         743         1485   \n",
       "25       sfda   cifar10               0.658157         336         1485   \n",
       "26       sfda  cifar100               0.681581         324         1485   \n",
       "27       sfda       dtd               0.478873         490         1485   \n",
       "28       sfda      food               0.513844         464         1485   \n",
       "29       sfda      pets               0.313404         531         1485   \n",
       "30  transrate  aircraft              -0.171748         825         1485   \n",
       "31  transrate   cifar10              -0.089483         785         1485   \n",
       "32  transrate  cifar100              -0.224603         826         1485   \n",
       "33  transrate       dtd              -0.246197         835         1485   \n",
       "34  transrate      food              -0.217040         849         1485   \n",
       "35  transrate      pets              -0.121228         790         1485   \n",
       "\n",
       "    violation_ratio  \n",
       "0          0.503704  \n",
       "1          0.486869  \n",
       "2          0.444444  \n",
       "3          0.503704  \n",
       "4          0.461953  \n",
       "5          0.482155  \n",
       "6          0.522559  \n",
       "7          0.323232  \n",
       "8          0.406061  \n",
       "9          0.529293  \n",
       "10         0.414815  \n",
       "11         0.417508  \n",
       "12         0.536700  \n",
       "13         0.352189  \n",
       "14         0.503704  \n",
       "15         0.469360  \n",
       "16         0.527273  \n",
       "17         0.430976  \n",
       "18         0.385859  \n",
       "19         0.379798  \n",
       "20         0.353535  \n",
       "21         0.447138  \n",
       "22         0.418182  \n",
       "23         0.248485  \n",
       "24         0.500337  \n",
       "25         0.226263  \n",
       "26         0.218182  \n",
       "27         0.329966  \n",
       "28         0.312458  \n",
       "29         0.357576  \n",
       "30         0.555556  \n",
       "31         0.528620  \n",
       "32         0.556229  \n",
       "33         0.562290  \n",
       "34         0.571717  \n",
       "35         0.531987  "
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Score threshold: 1 %\n",
    "# is this score good if i only want to capture differences more than 1% \n",
    "import pandas as pd\n",
    "import itertools\n",
    "from scipy.stats import pearsonr\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "# Collect (metric, dataset, pearson_corr) over iterations\n",
    "results = []  # will hold dicts: {'metric': ..., 'dataset': ..., 'pearson_abs_diff_corr': ...}\n",
    "\n",
    "for metric in ['logme', 'transrate', 'hscore', 'sfda', 'nleep', 'gbc']:\n",
    "    for dataset in acc_dict.keys():\n",
    "        if dataset not in ['cifar10', 'cifar100', 'aircraft', 'pets', 'dtd', 'food']:\n",
    "            continue\n",
    "        accuracies = acc_dict[dataset]\n",
    "        score_path = f'./results_metrics/group1/{metric}/{dataset}_metrics.json'\n",
    "        score, _ = load_score(score_path)\n",
    "\n",
    "        models = list(accuracies.keys())\n",
    "        \n",
    "        rows = []\n",
    "        for (m1, a1), (m2, a2) in itertools.combinations(accuracies.items(), 2):\n",
    "            acc_diff = abs(a1 - a2)\n",
    "            score_diff = abs(score[m1] - score[m2])\n",
    "            rows.append({\n",
    "                'model_a': m1,\n",
    "                'model_b': m2,\n",
    "                'acc_a': a1,\n",
    "                'acc_b': a2,\n",
    "                'acc_diff': acc_diff,\n",
    "                'score_a': score[m1],\n",
    "                'score_b': score[m2],\n",
    "                'score_diff': score_diff\n",
    "            })\n",
    "\n",
    "        df = pd.DataFrame(rows)\n",
    "        # df = df[df['acc_diff'] > 1.0]\n",
    "        df = df.sort_values(by='acc_diff', ascending=False)\n",
    "        df.reset_index(drop=True, inplace=True)\n",
    "        df = df.sort_values(by='acc_diff', ascending=False).reset_index(drop=True)\n",
    "        violations, total_pairs, ratio, _ = count_order_violations_detailed(df)\n",
    "        print(f\"Ordering violations (|Δacc| larger but |score| smaller): {violations} of {total_pairs} pair-of-pairs ({ratio:.3%})\")\n",
    "        pearson_corr, _ = pearsonr(df['acc_diff'], df['score_diff'])\n",
    "        print(f\"Metric {metric} Dataset: {dataset}, Pairs: {len(df)}, Pearson corr(|Δacc|, |Δscore|) = {pearson_corr:.3f}\")\n",
    "        # store result for summary dataframe\n",
    "        results.append({'metric': metric, 'dataset': dataset, 'pearson_abs_diff_corr': pearson_corr, 'violations': violations, 'total_pairs': total_pairs, 'violation_ratio': ratio})\n",
    "        # make a dataframe with metric dataset pearson_corr\n",
    "\n",
    "# Build summary dataframe after loops\n",
    "corr_df = pd.DataFrame(results)\n",
    "# Sort for readability\n",
    "corr_df = corr_df.sort_values(['metric', 'dataset']).reset_index(drop=True)\n",
    "print(\"\\nSummary correlation dataframe (|Δaccuracy| vs |Δscore|):\")\n",
    "corr_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f1d1df8d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAwEAAAJNCAYAAABp8nm2AAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjEsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvc2/+5QAAAAlwSFlzAAAPYQAAD2EBqD+naQAAsn5JREFUeJzs3XV4U2cbBvA7qXsqVKkrUgoUKzLcfQwbLsMGY8AY7gwYwweMDXcZ7jIchgwtDoUWirSlbVL35Puj+wJZBShtTtrcv+s610XOec+b5+SQJk9eEykUCgWIiIiIiEhriIUOgIiIiIiI1ItJABERERGRlmESQERERESkZZgEEBERERFpGSYBRERERERahkkAEREREZGWYRJARERERKRlmAQQEREREWkZJgFERERERFqGSQARERERkZZhEkBEREREWu3cuXNo3bo1HB0dIRKJsHfv3g+ec+bMGVSuXBkGBgbw8vLCunXrijzOwsQkgIiIiIi0WlJSEgICArBs2bKPKh8aGoqWLVuifv36uHXrFr7//nv0798fx44dK+JIC49IoVAohA6CiIiIiEgTiEQi7NmzB+3atcuzzJgxY3Do0CHcvXtXua9Lly6QyWQ4evSoGqL8fGwJICIiIqISJy0tDfHx8SpbWlpaodR96dIlNGrUSGVf06ZNcenSpUKpXx10hQ6AiIiIiLTHIT1ftTzPPxO6Ytq0aSr7pkyZgqlTp3523REREbCzs1PZZ2dnh/j4eKSkpMDIyOizn6Ooldgk4OrDOKFD0GrV/CxwJyRS6DC0mr+XHe+BwPy97JC6/+P6l1LRMGzzLe6FvBE6DK1WzssBfz9IEDoMrVazjJnQIQhi3LhxGDlypMo+AwMDgaLRPCU2CSAiIiIizSPSE6nleQwMDIrsS7+9vT0iI1V/aIuMjIS5uXmxaAUAOCaAiIiIiOiTBAUF4eTJkyr7Tpw4gaCgIIEi+nRsCSAiIiIitRHrqqcl4FMkJiYiJCRE+Tg0NBS3bt2ClZUVXFxcMG7cOLx69QobNmwAAAwaNAhLly7Fjz/+iL59++LUqVPYsWMHDh06JNQlfDK2BBARERGRVrt27RoqVaqESpUqAQBGjhyJSpUqYfLkyQCAN2/e4MWLF8ry7u7uOHToEE6cOIGAgADMnz8fq1atQtOmTQWJvyDYEkBEREREaiPS07zfoOvVq4f8ls7KbTXgevXq4ebNm0UYVdHSvLtARERERERFii0BRERERKQ2mjgmQBuxJYCIiIiISMuwJYCIiIiI1EZd6wRQ/tgSQERERESkZdgSQERERERqwzEBmoEtAUREREREWoYtAURERESkNhwToBnYEkBEREREpGXYEkBEREREasMxAZqBLQFERERERFqGLQFEREREpDYiHbYEaAK2BBARERERaRnBk4AGDRpAJpPl2B8fH48GDRqoPyAiIiIiKjJiHZFaNsqf4EnAmTNnkJ6enmN/amoqzp8/L0BEREREREQlm2BjAoKDg5X/vn//PiIiIpSPs7KycPToUTg5OQkRGhEREREVEZGYv9JrAsGSgIoVK0IkEkEkEuXa7cfIyAi//vqrAJEREREREZVsgiQB8fHxePbsGQDAw8MDV69eRalSpZTH9fX1YWtrCx0dHSHCIyIiIqIiItIRvDc6QaAkwNLSEm/evIGtrS3q1q0LLy8vSCQSIUIhIiIiItI6giQBpqamiImJga2tLc6dO4eMjAwhwiAiIiIiNePMPZpBkCSgUaNGqF+/PsqUKQOFQoH27dtDX18/17KnTp1Sc3RERERERCWbIEnApk2bsH79ejx9+hRnz55FuXLlYGxsLEQoRERERKRGnB1IMwiSBBgZGWHQoEEAgGvXruHnn3/mmAAiIiIiIjURbIrQ/zt9+rTQIRARERGRmnBMgGYQPAkAgJcvX2L//v148eJFjtWDFyxYIFBUREREREQlk+BJwMmTJ9GmTRt4eHjg4cOHKF++PMLCwqBQKFC5cmWhwyMiIiKiQiRiS4BGEHy1hnHjxuGHH37AnTt3YGhoiF27diE8PBx169ZFx44dhQ6PiIiIiKjEETwJePDgAXr27AkA0NXVRUpKCkxNTTF9+nT8/PPPAkdHRERERIVJJBarZaP8Cf4KmZiYKMcBODg44OnTp8pj0dHRQoVFRERERFRiCT4moEaNGrhw4QLKlCmDFi1aYNSoUbhz5w52796NGjVqCB0eERERERUirhOgGQRPAhYsWIDExEQAwLRp05CYmIjt27fD29ubMwMRERERERUBQZOArKwsvHz5EhUqVACQ3TVoxYoVQoZUZBQKBXZv+QOnT+xFclIifPwqoPfgMbB3dMnznIf3buDQnk0IC3kImTQaw8fNRZUa9fIsv3b5bJw6tgfd+o1A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RFKgQIiIiIiIKKelS5ciNTUVADBhwgTo6enh77//RocOHTBx4sQC1VmgJKBPnz64ffs26tati7Fjx6J169ZYunQpMjIyCrRsMRERERFph5L2K706WFlZKf8tFosxduzYz66zQEnAiBEjlP9u1KgRHj58iOvXr8PLywsVKlT47KCIiIiIiOidp0+fYu3atXj69CkWL14MW1tbHDlyBC4uLihXrtwn1/fJYwLkcjnWrFmDVq1aoXz58vD398ewYcOQmJgIf3//Tw6AiIiIiLQHxwR8urNnz8Lf3x9XrlzB7t27kZiYCAC4ffs2pkyZUqA6PykJUCgUaNOmDfr3749Xr17B398f5cqVw/Pnz9G7d2+0b9++QEEQEREREVHuxo4di5kzZ+LEiRPQ19dX7m/QoAEuX75coDo/qTvQunXrcO7cOZw8eRL169dXOXbq1Cm0a9cOGzZsQM+ePQsUDBERERERqbpz5w62bNmSY7+trS2io6MLVOcntQRs3boV48ePz5EAANmZyNixY7lOABERERHliYuFfTqJRII3b97k2H/z5k04OTkVqM5PSgKCg4PRrFmzPI83b94ct2/fLlAgRERERESUU5cuXTBmzBhERERAJBJBLpfj4sWL+OGHHwrcA+eTkoDY2FjY2dnledzOzg5SqbRAgRARERFRySeHSC1bSTJr1iz4+fnB2dkZiYmJKFu2LL744gvUrFlTPesEZGVlQVc371N0dHSQmZlZoECIiIiIiCgnfX19rFy5EpMnT8adO3eQmJiISpUqwdvbu8B1flISoFAo0Lt3bxgYGOR6PC0trcCBEBEREVHJV9Km7yxKcrkcv/zyC/bv34/09HQ0bNgQU6ZMgZGR0WfX/UlJQK9evT5YhjMDERERERF9vp9++glTp05Fo0aNYGRkhMWLFyMqKgpr1qz57Lo/KQlYu3btZz8hEREREWmvkjZzT1HasGEDli9fjoEDBwIA/vrrL7Rs2RKrVq2CWPzJa/6q+LyziYiIiIioSLx48QItWrRQPm7UqBFEIhFev3792XV/UksAEREREdHn4JiAj5eZmQlDQ0OVfXp6esjIyPjsupkEEBERERFpoNwm5UlNTcWgQYNgYmKi3Ld79+5PrltjkgCFQoGYmBiIRCJYW1sLHQ4RERERFQGOCfh4uU3K071790KpW/AkICIiAj/++CP279+P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sbCzs8vzuJ2dHaRSqRojIiIiIqKiJOfsQBpB0JaArKws6OrmnYfo6OggMzNTjREREREREZV8gq8T0Lt3bxgYGOR6PC0tTc0REREREVFR4sw9mkHQJKBXr14fLMOZgYiIiIiICpegScDatWuFfHoiIiIiUjPO3KMZBB0TQERERERE6idoSwARERERaRcFZwfSCGwJICIiIiLSMmwJICIiIiK1kXNMgEZgSwARERERkZZhSwARERERqQ3XCdAMbAkgIiIiItIybAkgIiIiIrXhOgGagS0BRERERERahi0BRERERKQ2cq4ToBHYEkBEREREpGXYEkBEREREasMxAZqBLQFERERERFqGLQFEREREpDZcJ0AzsCWAiIiIiEjLsCWAiIiIiNRGzjEBGoEtAUREREREWoZJABERERGRlmF3ICIiIiJSG04RqhnYEkBEREREpGXYEkBEREREaqMApwjVBGwJICIiIiLSMmwJICIiIiK14RShmoEtAUREREREWoYtAURERESkNpwdSDOIFAreCiIiIiJSjz8vy9XyPB1rsMNLfkpsS8CNxzFCh6DVKvtYI/LBdaHD0Gp2ZQL5PhBYZR9rhD4NEToMrebu6YXEFeOEDkOrmQ6ajdN3UoQOQ6vV9zcSOgQV/PlZMzBFIiIiIiLSMiW2JYCIiIiINI9cwXUCNAFbAoiIiIiItAxbAoiIiIhIbTgmQDOwJYCIiIiISMuwJYCIiIiI1IYtAZqBLQFERERERFqGLQFEREREpDZytgRoBLYEEBERERFpGbYEEBEREZHaKLhOgEZgSwARERERkZZhSwARERERqQ1nB9IMbAkgIiIiItIybAkgIiIiIrXh7ECaQaNbAiIjIzF9+nShwyAiIiIiKlE0OgmIiIjAtGnThA6DiIiIiAqJQqGejfInaHeg4ODgfI8/evRITZEQEREREWkPQZOAihUrQiQSQZFLuvb//SIR55IlIiIiKin4K71mEDQJsLKywty5c9GwYcNcj9+7dw+tW7dWc1RERERERCWboElAYGAgXr9+DVdX11yPy2SyXFsJiIiIiKh44uxAmkHQJGDQoEFISkrK87iLiwvWrl2rxoiIiIiIiEo+QZOA9u3b53vc0tISvXr1UlM0RERERFTU2MlDM2j0FKFERERERFT4BF8x+P79+1i6dCkuXbqEiIgIAIC9vT2CgoIw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4eGKdeHh4XBwcEDLli0V6+RyORYtWgRnZ2cYGBigRYsW2LZtGwDg5s2b6NKlCwDAwsJCKYLQuXNnjBs3DhMnToSVlRX8/PwAlL0d6M6dO3jnnXdgaWkJIyMjeHl54dSpU9VceyIi0hZ11F0AIiJNExQUhHXr1mHIkCEAgB9++AHvvfcejh49qkizaNEibNy4EWvWrIGbmxuOHTuGoUOHwtraGq+99hq2b9+OAQMGIC4uDqampjAwMFDsu379eowePRpRUVHlHj8rKwudOnVCgwYNEBkZCTs7O5w9exZyubxa601ERNqDnQAioicMHToUwcHBuHXrFgAgKioKW7ZsUXQC8vLysHDhQhw6dAje3t4AABcXF5w4cQLffPMNOnXqBEtLSwCAjY0NzM3NlfJ3c3PD0qVLKzz+5s2bkZycjDNnzijycXV1reJaEhGRNmMngIjoCdbW1ujduzfCwsIghEDv3r1hZWWl2H7t2jXk5OSge/fuSvvl5+cr3TJUkdatWz91e0xMDFq2bKnoABAREVU1dgKIiMoRFBSEcePGAQC+/vprpW1ZWVkAgN27d6NBgwZK2yozuNfIyOip20vfOkRERFQd2AkgIipHjx49kJ+fD4lEohi8W8LT0xMymQy3b99Gp06dyt1fT08PAFBUVPTcx27evDm+//57PHz4kNEAIiKqFpwdiIioHDo6OoiNjcWlS5ego6OjtM3ExASTJ0/Gxx9/jPXr1+P69es4e/YsvvrqK6xfvx4A4OjoCIlEgl27diE5OVkRPaiMd955B3Z2dnjrrbcQFRWFGzduYPv27YiOjq7SOhIRkfZiJ4CIqAKmpqYwNTUtd9v8+fMxa9YsLFq0CB4eHujRowd2794NZ2dnAECDBg0wd+5cTJ8+Hba2topbiypDT08PBw4cgI2NDXr16oVmzZph8eLFZTojREREL0oihBDqLgQREREREakOIwFERERERFqGnQAiIiIiIi3DTgARERERkZZhJ4CIiIiISMuwE0BEREREpGXYCSAiIiIi0jLsBBARERERaRl2AoiIiIiItAw7AUREREREWoadACIiIiIiLcNOABERERGRlvl/VgjndZWswDkAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 800x600 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "PRETTY_METRIC = {\n",
    "    \"logme\": \"LogME\",\n",
    "    \"gbc\": \"GBC\", \n",
    "    \"transrate\": \"TransRate\",\n",
    "    \"sfda\": \"SFDA\",\n",
    "    \"hscore\": \"H-Score\",\n",
    "    \"nleep\": \"NLEEP\"\n",
    "}\n",
    "\n",
    "PRETTY_DATASET = {\n",
    "    \"cifar10\": \"CIFAR-10\",\n",
    "    \"cifar100\": \"CIFAR-100\",\n",
    "    \"aircraft\": \"Aircraft\",\n",
    "    \"pets\": \"Pets\",\n",
    "    \"dtd\": \"DTD\", \n",
    "    \n",
    "    \"food\": \"Food-101\"\n",
    "}\n",
    "\n",
    "# Apply the pretty names to your correlation dataframe\n",
    "corr_df['metric_pretty'] = corr_df['metric'].map(PRETTY_METRIC)\n",
    "corr_df['dataset_pretty'] = corr_df['dataset'].map(PRETTY_DATASET)\n",
    "\n",
    "# Create pivot with pretty metric and dataset names\n",
    "pivot = corr_df.pivot(index='dataset_pretty', columns='metric_pretty', values='pearson_abs_diff_corr')\n",
    "\n",
    "plt.figure(figsize=(8,6))\n",
    "sns.heatmap(\n",
    "    pivot,\n",
    "    annot=True,\n",
    "    fmt='.2f',\n",
    "    cmap='coolwarm',\n",
    "    vmin=-1, vmax=1,  # force full correlation range\n",
    "    center=0,\n",
    "    linewidths=0.5,\n",
    "    cbar_kws={'label': 'Pearson r', 'ticks': [-1,-0.5,0,0.5,1]}\n",
    ")\n",
    "plt.ylabel('Dataset')\n",
    "plt.xlabel('Metric')\n",
    "plt.tight_layout()\n",
    "# plt.savefig('Figures/exp2/correlation_heatmap.pdf')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0a0daece",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Ordering violations (|Δacc| larger but |score| smaller): 355 of 666 pair-of-pairs (53.303%)\n",
      "Metric logme Dataset: aircraft, Pairs: 37, Pearson corr(Δacc, Δscore) = -0.298\n",
      "Ordering violations (|Δacc| larger but |score| smaller): 197 of 528 pair-of-pairs (37.311%)\n",
      "Metric logme Dataset: cifar10, Pairs: 33, Pearson corr(Δacc, Δscore) = 0.282\n",
      "Ordering violations (|Δacc| larger but |score| smaller): 275 of 561 pair-of-pairs (49.020%)\n",
      "Metric logme Dataset: cifar100, Pairs: 34, Pearson corr(Δacc, Δscore) = 0.013\n",
      "Ordering violations (|Δacc| larger but |score| smaller): 267 of 561 pair-of-pairs (47.594%)\n",
      "Metric logme Dataset: dtd, Pairs: 34, Pearson corr(Δacc, Δscore) = 0.207\n",
      "Ordering violations (|Δacc| larger but |score| smaller): 269 of 496 pair-of-pairs (54.234%)\n",
      "Metric logme Dataset: food, Pairs: 32, Pearson corr(Δacc, Δscore) = -0.175\n",
      "Ordering violations (|Δacc| larger but |score| smaller): 308 of 630 pair-of-pairs (48.889%)\n",
      "Metric logme Dataset: pets, Pairs: 36, Pearson corr(Δacc, Δscore) = 0.206\n",
      "\n",
      "Summary correlation dataframe (Δaccuracy vs Δscore):\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>metric</th>\n",
       "      <th>dataset</th>\n",
       "      <th>pearson_abs_diff_corr</th>\n",
       "      <th>violations</th>\n",
       "      <th>total_pairs</th>\n",
       "      <th>violation_ratio</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>logme</td>\n",
       "      <td>aircraft</td>\n",
       "      <td>-0.297601</td>\n",
       "      <td>355</td>\n",
       "      <td>666</td>\n",
       "      <td>0.533033</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>logme</td>\n",
       "      <td>cifar10</td>\n",
       "      <td>0.281930</td>\n",
       "      <td>197</td>\n",
       "      <td>528</td>\n",
       "      <td>0.373106</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>logme</td>\n",
       "      <td>cifar100</td>\n",
       "      <td>0.013342</td>\n",
       "      <td>275</td>\n",
       "      <td>561</td>\n",
       "      <td>0.490196</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>logme</td>\n",
       "      <td>dtd</td>\n",
       "      <td>0.206560</td>\n",
       "      <td>267</td>\n",
       "      <td>561</td>\n",
       "      <td>0.475936</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>logme</td>\n",
       "      <td>food</td>\n",
       "      <td>-0.174927</td>\n",
       "      <td>269</td>\n",
       "      <td>496</td>\n",
       "      <td>0.542339</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>logme</td>\n",
       "      <td>pets</td>\n",
       "      <td>0.206285</td>\n",
       "      <td>308</td>\n",
       "      <td>630</td>\n",
       "      <td>0.488889</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "  metric   dataset  pearson_abs_diff_corr  violations  total_pairs  \\\n",
       "0  logme  aircraft              -0.297601         355          666   \n",
       "1  logme   cifar10               0.281930         197          528   \n",
       "2  logme  cifar100               0.013342         275          561   \n",
       "3  logme       dtd               0.206560         267          561   \n",
       "4  logme      food              -0.174927         269          496   \n",
       "5  logme      pets               0.206285         308          630   \n",
       "\n",
       "   violation_ratio  \n",
       "0         0.533033  \n",
       "1         0.373106  \n",
       "2         0.490196  \n",
       "3         0.475936  \n",
       "4         0.542339  \n",
       "5         0.488889  "
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Score threshold: 1 %\n",
    "# is this score good if i only want to capture differences more than 1% \n",
    "import pandas as pd\n",
    "import itertools\n",
    "from scipy.stats import pearsonr\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "# Collect (metric, dataset, pearson_corr) over iterations\n",
    "results = []  # will hold dicts: {'metric': ..., 'dataset': ..., 'pearson_abs_diff_corr': ...}\n",
    "\n",
    "for metric in ['logme',]:\n",
    "    for dataset in acc_dict.keys():\n",
    "        if dataset not in ['cifar10', 'cifar100', 'aircraft', 'pets', 'dtd', 'food']:\n",
    "            continue\n",
    "        accuracies = acc_dict[dataset]\n",
    "        score_path = f'./results_metrics/group1/{metric}/{dataset}_metrics.json'\n",
    "        score, _ = load_score(score_path)\n",
    "\n",
    "        models = list(accuracies.keys())\n",
    "        \n",
    "        rows = []\n",
    "        for (m1, a1), (m2, a2) in itertools.combinations(accuracies.items(), 2):\n",
    "            # Only include pairs where model 1 has higher accuracy than model 2\n",
    "            if a1 > a2:\n",
    "                acc_diff = a1 - a2  # Delta accuracy (positive since a1 > a2)\n",
    "                score_diff = score[m1] - score[m2]  # Delta score (can be positive or negative)\n",
    "                rows.append({\n",
    "                    'model_a': m1,\n",
    "                    'model_b': m2,\n",
    "                    'acc_a': a1,\n",
    "                    'acc_b': a2,\n",
    "                    'acc_diff': acc_diff,\n",
    "                    'score_a': score[m1],\n",
    "                    'score_b': score[m2],\n",
    "                    'score_diff': score_diff,\n",
    "                    'dataset': dataset,\n",
    "                })\n",
    "\n",
    "        df = pd.DataFrame(rows)\n",
    "        df = df.sort_values(by='acc_diff', ascending=False)\n",
    "        df.reset_index(drop=True, inplace=True)\n",
    "        \n",
    "        violations, total_pairs, ratio, _ = count_order_violations_detailed(df)\n",
    "        print(f\"Ordering violations (|Δacc| larger but |score| smaller): {violations} of {total_pairs} pair-of-pairs ({ratio:.3%})\")\n",
    "        pearson_corr, _ = pearsonr(df['acc_diff'], df['score_diff'])\n",
    "        print(f\"Metric {metric} Dataset: {dataset}, Pairs: {len(df)}, Pearson corr(Δacc, Δscore) = {pearson_corr:.3f}\")\n",
    "        # store result for summary dataframe\n",
    "        results.append({'metric': metric, 'dataset': dataset, 'pearson_abs_diff_corr': pearson_corr, 'violations': violations, 'total_pairs': total_pairs, 'violation_ratio': ratio})\n",
    "\n",
    "# Build summary dataframe after loops\n",
    "corr_df = pd.DataFrame(results)\n",
    "# Sort for readability\n",
    "corr_df = corr_df.sort_values(['metric', 'dataset']).reset_index(drop=True)\n",
    "print(\"\\nSummary correlation dataframe (Δaccuracy vs Δscore):\")\n",
    "corr_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bf0f48d2",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "newmol",
   "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.12.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
