{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "389837f6",
   "metadata": {},
   "source": [
    "## Getting comparisons on MMLU data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 167,
   "id": "dc1ed5ee",
   "metadata": {},
   "outputs": [],
   "source": [
    "from itertools import combinations\n",
    "import re\n",
    "\n",
    "def get_pairs(n):\n",
    "    return list(combinations(range(n), 2))\n",
    "\n",
    "def extract_comparisons_mmlu(data, include_scenario=False):\n",
    "    comparisons = []\n",
    "    data_cleaned = []\n",
    "    for i, item in enumerate(data):\n",
    "        response = item['judge response']\n",
    "        eval1_response = item['eval1 response']\n",
    "        eval2_response = item['eval2 response']\n",
    "\n",
    "        if response == None or eval1_response == None:\n",
    "            continue\n",
    "\n",
    "        e = re.search(r\"Error in \\w+ API call\", response)\n",
    "        e1 = re.search(r\"Error in \\w+ API call\", eval1_response)\n",
    "        e2 = re.search(r\"Error in \\w+ API call\", eval2_response)\n",
    "        if e or e1 or e2:\n",
    "            print(f\"Error in {i}th API call\")\n",
    "            continue\n",
    "\n",
    "        m = re.search(f'<choice>(.)</choice>', response)\n",
    "\n",
    "        if m:\n",
    "            try:\n",
    "                score = int(m.group(1))\n",
    "\n",
    "                if score not in [0,1,2]:\n",
    "                    continue\n",
    "\n",
    "                if include_scenario:\n",
    "                    # comparisons.append([item['judge'], item['eval1'], item['eval2'], score])\n",
    "                    comparisons.append([item['subject'], item['scenario_index'], item['judge'], item['eval1'], item['eval2'], score])\n",
    "                else:\n",
    "                    comparisons.append([item['subject'], item['judge'], item['eval1'], item['eval2'], score])\n",
    "                data_cleaned.append(item)\n",
    "            except:\n",
    "                print(f\"No number found in the {i}th judge response\")\n",
    "                continue\n",
    "        else:\n",
    "            print(f\"No <choice>…</choice> match found in the {i}th judge response\")\n",
    "\n",
    "    return comparisons, data_cleaned"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 196,
   "id": "49fe5dec",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import json\n",
    "events = [name for name in os.listdir('transcript_mmlu/') if '2025' in name]\n",
    "data = []\n",
    "for name in events:\n",
    "    with open(f\"transcript_mmlu/{name}/evaluations.json\", 'r') as file:\n",
    "        data.extend(json.load(file))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 197,
   "id": "31ad9125",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "217420"
      ]
     },
     "execution_count": 197,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(data)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 198,
   "id": "43189b31",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "No <choice>…</choice> match found in the 54th judge response\n",
      "No number found in the 660th judge response\n",
      "No number found in the 665th judge response\n",
      "No number found in the 1111th judge response\n",
      "No number found in the 1209th judge response\n",
      "No <choice>…</choice> match found in the 1224th judge response\n",
      "No number found in the 2172th judge response\n",
      "No number found in the 2173th judge response\n",
      "No number found in the 2798th judge response\n",
      "No number found in the 2803th judge response\n",
      "No number found in the 6854th judge response\n",
      "No number found in the 7479th judge response\n",
      "No number found in the 7482th judge response\n",
      "No number found in the 8117th judge response\n",
      "No number found in the 8734th judge response\n",
      "No number found in the 9251th judge response\n",
      "No number found in the 10592th judge response\n",
      "No number found in the 12130th judge response\n",
      "No <choice>…</choice> match found in the 12138th judge response\n",
      "No <choice>…</choice> match found in the 12139th judge response\n",
      "No number found in the 13743th judge response\n",
      "No number found in the 13754th judge response\n",
      "No number found in the 13835th judge response\n",
      "No number found in the 13842th judge response\n",
      "No <choice>…</choice> match found in the 15799th judge response\n",
      "No number found in the 18155th judge response\n",
      "No number found in the 18163th judge response\n",
      "No number found in the 19334th judge response\n",
      "No number found in the 20654th judge response\n",
      "No <choice>…</choice> match found in the 20859th judge response\n",
      "No <choice>…</choice> match found in the 21650th judge response\n",
      "No number found in the 22543th judge response\n",
      "No number found in the 22544th judge response\n",
      "Error in 22682th API call\n",
      "Error in 22683th API call\n",
      "Error in 22684th API call\n",
      "Error in 22685th API call\n",
      "Error in 22686th API call\n",
      "Error in 22687th API call\n",
      "Error in 22688th API call\n",
      "Error in 22927th API call\n",
      "Error in 22930th API call\n",
      "Error in 22932th API call\n",
      "Error in 22934th API call\n",
      "No number found in the 23503th judge response\n",
      "No number found in the 24637th judge response\n",
      "No number found in the 24643th judge response\n",
      "No <choice>…</choice> match found in the 26723th judge response\n",
      "No number found in the 27088th judge response\n",
      "No number found in the 27431th judge response\n",
      "No number found in the 28593th judge response\n",
      "No number found in the 28600th judge response\n",
      "No number found in the 30101th judge response\n",
      "No number found in the 30103th judge response\n",
      "No number found in the 30993th judge response\n",
      "No number found in the 30998th judge response\n",
      "No <choice>…</choice> match found in the 31017th judge response\n",
      "No number found in the 31145th judge response\n",
      "No number found in the 31149th judge response\n",
      "No number found in the 31683th judge response\n",
      "No number found in the 32311th judge response\n",
      "No number found in the 32314th judge response\n",
      "No number found in the 32607th judge response\n",
      "No number found in the 33131th judge response\n",
      "No number found in the 33728th judge response\n",
      "No number found in the 33733th judge response\n",
      "No number found in the 34871th judge response\n",
      "No number found in the 36799th judge response\n",
      "No number found in the 37158th judge response\n",
      "No number found in the 37159th judge response\n",
      "No number found in the 37162th judge response\n",
      "No number found in the 37166th judge response\n",
      "No number found in the 37167th judge response\n",
      "No number found in the 37780th judge response\n",
      "No number found in the 38882th judge response\n",
      "No number found in the 38984th judge response\n",
      "No number found in the 39177th judge response\n",
      "Error in 40090th API call\n",
      "Error in 40092th API call\n",
      "Error in 40094th API call\n",
      "No number found in the 40113th judge response\n",
      "No number found in the 40132th judge response\n",
      "Error in 40250th API call\n",
      "Error in 40251th API call\n",
      "Error in 40256th API call\n",
      "Error in 40257th API call\n",
      "Error in 40258th API call\n",
      "Error in 40259th API call\n",
      "No number found in the 40272th judge response\n",
      "Error in 40411th API call\n",
      "Error in 40423th API call\n",
      "Error in 40424th API call\n",
      "No number found in the 40770th judge response\n",
      "No number found in the 40775th judge response\n",
      "No number found in the 40777th judge response\n",
      "No number found in the 40782th judge response\n",
      "No number found in the 41131th judge response\n",
      "No number found in the 42035th judge response\n",
      "No number found in the 42314th judge response\n",
      "No number found in the 43273th judge response\n",
      "No number found in the 43902th judge response\n",
      "No <choice>…</choice> match found in the 44848th judge response\n",
      "No number found in the 45025th judge response\n",
      "No number found in the 46421th judge response\n",
      "No number found in the 46422th judge response\n",
      "No number found in the 48043th judge response\n",
      "No number found in the 48361th judge response\n",
      "No number found in the 48554th judge response\n",
      "No number found in the 48558th judge response\n",
      "No number found in the 48562th judge response\n",
      "No number found in the 48567th judge response\n",
      "No number found in the 49443th judge response\n",
      "No number found in the 49454th judge response\n",
      "No number found in the 49542th judge response\n",
      "No number found in the 50344th judge response\n",
      "No number found in the 50583th judge response\n",
      "No number found in the 50585th judge response\n",
      "No number found in the 50594th judge response\n",
      "No number found in the 51977th judge response\n",
      "No number found in the 51986th judge response\n",
      "No number found in the 52323th judge response\n",
      "No number found in the 52331th judge response\n",
      "No number found in the 52332th judge response\n",
      "No number found in the 52334th judge response\n",
      "No number found in the 53313th judge response\n",
      "No number found in the 53315th judge response\n",
      "No number found in the 53319th judge response\n",
      "No number found in the 54222th judge response\n",
      "No number found in the 55265th judge response\n",
      "No number found in the 55540th judge response\n",
      "No number found in the 56344th judge response\n",
      "No number found in the 56940th judge response\n",
      "No number found in the 56946th judge response\n",
      "No number found in the 56949th judge response\n",
      "No number found in the 56952th judge response\n",
      "No number found in the 56954th judge response\n",
      "No number found in the 56956th judge response\n",
      "No number found in the 57221th judge response\n",
      "No number found in the 58718th judge response\n",
      "No number found in the 58722th judge response\n",
      "No number found in the 59799th judge response\n",
      "No number found in the 59802th judge response\n",
      "No number found in the 59803th judge response\n",
      "No number found in the 59805th judge response\n",
      "No number found in the 59806th judge response\n",
      "No number found in the 59808th judge response\n",
      "No number found in the 59809th judge response\n",
      "No number found in the 59818th judge response\n",
      "No number found in the 60874th judge response\n",
      "No number found in the 62012th judge response\n",
      "No number found in the 63634th judge response\n",
      "No number found in the 65494th judge response\n",
      "No number found in the 65498th judge response\n",
      "No number found in the 65501th judge response\n",
      "No number found in the 66487th judge response\n",
      "No <choice>…</choice> match found in the 66507th judge response\n",
      "No number found in the 67657th judge response\n",
      "No number found in the 69852th judge response\n",
      "No number found in the 70561th judge response\n",
      "No number found in the 70565th judge response\n",
      "No number found in the 70569th judge response\n",
      "No number found in the 70573th judge response\n",
      "No number found in the 70574th judge response\n",
      "No number found in the 71010th judge response\n",
      "No number found in the 71160th judge response\n",
      "No number found in the 71437th judge response\n",
      "No number found in the 71440th judge response\n",
      "No number found in the 71442th judge response\n",
      "No number found in the 71863th judge response\n",
      "No number found in the 72273th judge response\n",
      "No <choice>…</choice> match found in the 73986th judge response\n",
      "No number found in the 74314th judge response\n",
      "No <choice>…</choice> match found in the 75112th judge response\n",
      "No number found in the 75192th judge response\n",
      "No number found in the 76874th judge response\n",
      "No number found in the 77047th judge response\n",
      "No number found in the 77052th judge response\n",
      "No number found in the 77472th judge response\n",
      "No <choice>…</choice> match found in the 78028th judge response\n",
      "No <choice>…</choice> match found in the 78202th judge response\n",
      "No number found in the 79451th judge response\n",
      "No number found in the 79455th judge response\n",
      "No number found in the 79459th judge response\n",
      "No number found in the 80083th judge response\n",
      "No number found in the 80888th judge response\n",
      "No number found in the 81062th judge response\n",
      "No number found in the 81065th judge response\n",
      "No number found in the 81069th judge response\n",
      "No number found in the 81070th judge response\n",
      "No number found in the 81601th judge response\n",
      "Error in 81754th API call\n",
      "Error in 81758th API call\n",
      "Error in 81761th API call\n",
      "Error in 81763th API call\n",
      "Error in 81845th API call\n",
      "Error in 81848th API call\n",
      "Error in 81849th API call\n",
      "Error in 81850th API call\n",
      "No <choice>…</choice> match found in the 81977th judge response\n",
      "No number found in the 82212th judge response\n",
      "No number found in the 82390th judge response\n",
      "No number found in the 82392th judge response\n",
      "No number found in the 82405th judge response\n",
      "No number found in the 82662th judge response\n",
      "No number found in the 82663th judge response\n",
      "No number found in the 82759th judge response\n",
      "No number found in the 83467th judge response\n",
      "No number found in the 83470th judge response\n",
      "No number found in the 83472th judge response\n",
      "No <choice>…</choice> match found in the 83845th judge response\n",
      "No number found in the 84307th judge response\n",
      "No number found in the 84493th judge response\n",
      "No <choice>…</choice> match found in the 84499th judge response\n",
      "No number found in the 85027th judge response\n",
      "No number found in the 85034th judge response\n",
      "No number found in the 87520th judge response\n",
      "No <choice>…</choice> match found in the 88707th judge response\n",
      "No <choice>…</choice> match found in the 88709th judge response\n",
      "No number found in the 88958th judge response\n",
      "No number found in the 90391th judge response\n",
      "No number found in the 90393th judge response\n",
      "No number found in the 90405th judge response\n",
      "No number found in the 90406th judge response\n",
      "No number found in the 90407th judge response\n",
      "No number found in the 90408th judge response\n",
      "No number found in the 90415th judge response\n",
      "No number found in the 91210th judge response\n",
      "No number found in the 91214th judge response\n",
      "No <choice>…</choice> match found in the 91392th judge response\n",
      "No number found in the 91808th judge response\n",
      "No number found in the 91809th judge response\n",
      "No number found in the 91811th judge response\n",
      "No number found in the 92919th judge response\n",
      "No number found in the 92920th judge response\n",
      "No number found in the 93188th judge response\n",
      "No number found in the 93195th judge response\n",
      "No number found in the 93199th judge response\n",
      "No number found in the 95556th judge response\n",
      "No number found in the 95828th judge response\n",
      "No number found in the 95838th judge response\n",
      "No <choice>…</choice> match found in the 96388th judge response\n",
      "No <choice>…</choice> match found in the 96751th judge response\n",
      "No number found in the 97087th judge response\n",
      "No number found in the 97095th judge response\n",
      "No number found in the 97099th judge response\n",
      "No number found in the 97100th judge response\n",
      "No <choice>…</choice> match found in the 97195th judge response\n",
      "No number found in the 97276th judge response\n",
      "No number found in the 97278th judge response\n",
      "No number found in the 97293th judge response\n",
      "No number found in the 97810th judge response\n",
      "No number found in the 97814th judge response\n",
      "No number found in the 97993th judge response\n",
      "No number found in the 97997th judge response\n",
      "No number found in the 98258th judge response\n",
      "No number found in the 98263th judge response\n",
      "No <choice>…</choice> match found in the 98278th judge response\n",
      "No number found in the 99160th judge response\n",
      "No number found in the 99169th judge response\n",
      "No number found in the 99170th judge response\n",
      "No number found in the 99517th judge response\n",
      "No number found in the 99525th judge response\n",
      "No number found in the 99529th judge response\n",
      "No number found in the 99532th judge response\n",
      "No number found in the 99543th judge response\n",
      "No number found in the 99815th judge response\n",
      "No number found in the 100065th judge response\n",
      "No number found in the 100066th judge response\n",
      "No number found in the 100604th judge response\n",
      "No number found in the 100606th judge response\n",
      "No <choice>…</choice> match found in the 100712th judge response\n",
      "No number found in the 101180th judge response\n",
      "No <choice>…</choice> match found in the 101193th judge response\n",
      "No number found in the 102190th judge response\n",
      "No number found in the 102199th judge response\n",
      "No number found in the 102280th judge response\n",
      "No number found in the 104228th judge response\n",
      "No number found in the 104229th judge response\n",
      "No number found in the 104233th judge response\n",
      "No number found in the 104683th judge response\n",
      "No number found in the 104686th judge response\n",
      "No number found in the 104688th judge response\n",
      "No number found in the 105399th judge response\n",
      "No number found in the 105407th judge response\n",
      "No number found in the 105410th judge response\n",
      "No number found in the 105414th judge response\n",
      "No number found in the 105416th judge response\n",
      "No number found in the 105418th judge response\n",
      "No number found in the 105423th judge response\n",
      "No number found in the 105823th judge response\n",
      "No number found in the 107496th judge response\n",
      "No number found in the 107505th judge response\n",
      "No number found in the 107516th judge response\n",
      "No number found in the 107586th judge response\n",
      "No number found in the 107764th judge response\n",
      "No number found in the 107765th judge response\n",
      "No number found in the 107840th judge response\n",
      "No number found in the 109696th judge response\n",
      "No number found in the 109959th judge response\n",
      "No number found in the 109964th judge response\n",
      "No number found in the 109966th judge response\n",
      "No number found in the 109978th judge response\n",
      "No number found in the 109981th judge response\n",
      "No number found in the 110835th judge response\n",
      "No number found in the 110839th judge response\n",
      "No number found in the 110841th judge response\n",
      "No number found in the 110844th judge response\n",
      "No number found in the 110845th judge response\n",
      "No number found in the 110854th judge response\n",
      "No number found in the 111109th judge response\n",
      "No number found in the 112549th judge response\n",
      "No number found in the 117404th judge response\n",
      "No number found in the 117406th judge response\n",
      "No <choice>…</choice> match found in the 119854th judge response\n",
      "No number found in the 121156th judge response\n",
      "No number found in the 121165th judge response\n",
      "No number found in the 121689th judge response\n",
      "No number found in the 122955th judge response\n",
      "No number found in the 125382th judge response\n",
      "No <choice>…</choice> match found in the 126931th judge response\n",
      "No <choice>…</choice> match found in the 126932th judge response\n",
      "No number found in the 127190th judge response\n",
      "No <choice>…</choice> match found in the 129422th judge response\n",
      "No number found in the 129487th judge response\n",
      "No number found in the 129492th judge response\n",
      "No <choice>…</choice> match found in the 129511th judge response\n",
      "No number found in the 129770th judge response\n",
      "No <choice>…</choice> match found in the 130983th judge response\n",
      "No <choice>…</choice> match found in the 131875th judge response\n",
      "No number found in the 131949th judge response\n",
      "No number found in the 131971th judge response\n",
      "No <choice>…</choice> match found in the 132028th judge response\n",
      "No number found in the 132489th judge response\n",
      "Error in 135218th API call\n",
      "No <choice>…</choice> match found in the 140312th judge response\n",
      "No <choice>…</choice> match found in the 143342th judge response\n",
      "No number found in the 145215th judge response\n",
      "No number found in the 146368th judge response\n",
      "No <choice>…</choice> match found in the 147292th judge response\n",
      "No number found in the 149168th judge response\n",
      "No number found in the 151115th judge response\n",
      "No number found in the 151120th judge response\n",
      "No number found in the 151123th judge response\n",
      "No number found in the 151124th judge response\n",
      "No number found in the 151126th judge response\n",
      "No <choice>…</choice> match found in the 153991th judge response\n",
      "No <choice>…</choice> match found in the 158133th judge response\n",
      "No number found in the 160086th judge response\n",
      "No number found in the 160725th judge response\n",
      "No <choice>…</choice> match found in the 160912th judge response\n",
      "No number found in the 161447th judge response\n",
      "No number found in the 161714th judge response\n",
      "No number found in the 161889th judge response\n",
      "No number found in the 163745th judge response\n",
      "No number found in the 164464th judge response\n",
      "No number found in the 164470th judge response\n",
      "No <choice>…</choice> match found in the 166375th judge response\n",
      "No <choice>…</choice> match found in the 167723th judge response\n",
      "No <choice>…</choice> match found in the 167732th judge response\n",
      "Error in 168287th API call\n",
      "Error in 168534th API call\n",
      "Error in 168536th API call\n",
      "Error in 168537th API call\n",
      "No <choice>…</choice> match found in the 168565th judge response\n",
      "No number found in the 170235th judge response\n",
      "No number found in the 172308th judge response\n",
      "No <choice>…</choice> match found in the 172561th judge response\n",
      "No number found in the 172904th judge response\n",
      "No <choice>…</choice> match found in the 174718th judge response\n",
      "No number found in the 174796th judge response\n",
      "No number found in the 174797th judge response\n",
      "Error in 177128th API call\n",
      "Error in 177132th API call\n",
      "Error in 177135th API call\n",
      "Error in 177137th API call\n",
      "Error in 177138th API call\n",
      "Error in 177343th API call\n",
      "Error in 177344th API call\n",
      "Error in 177347th API call\n",
      "Error in 177348th API call\n",
      "Error in 177350th API call\n",
      "Error in 177351th API call\n",
      "Error in 177353th API call\n",
      "Error in 177564th API call\n",
      "No number found in the 177738th judge response\n",
      "No number found in the 178563th judge response\n",
      "No number found in the 178566th judge response\n",
      "No number found in the 179534th judge response\n",
      "No number found in the 179538th judge response\n",
      "No number found in the 179982th judge response\n",
      "No number found in the 180263th judge response\n",
      "No number found in the 180264th judge response\n",
      "No <choice>…</choice> match found in the 182673th judge response\n",
      "Error in 183430th API call\n",
      "Error in 183435th API call\n",
      "Error in 183436th API call\n",
      "Error in 183437th API call\n",
      "Error in 183438th API call\n",
      "Error in 183512th API call\n",
      "Error in 183514th API call\n",
      "Error in 183515th API call\n",
      "Error in 183517th API call\n",
      "Error in 183519th API call\n",
      "No <choice>…</choice> match found in the 183547th judge response\n",
      "No number found in the 185021th judge response\n",
      "No number found in the 185022th judge response\n",
      "No number found in the 185027th judge response\n",
      "No number found in the 185028th judge response\n",
      "No number found in the 185030th judge response\n",
      "No number found in the 185031th judge response\n",
      "No number found in the 185032th judge response\n",
      "No number found in the 185033th judge response\n",
      "No <choice>…</choice> match found in the 187901th judge response\n",
      "No <choice>…</choice> match found in the 188914th judge response\n",
      "No number found in the 192301th judge response\n",
      "No number found in the 197291th judge response\n",
      "No number found in the 197293th judge response\n",
      "No number found in the 197304th judge response\n",
      "No <choice>…</choice> match found in the 197311th judge response\n",
      "No number found in the 200632th judge response\n",
      "No number found in the 202363th judge response\n",
      "No number found in the 202369th judge response\n",
      "No number found in the 202371th judge response\n",
      "No number found in the 202374th judge response\n",
      "No number found in the 203902th judge response\n",
      "No number found in the 204532th judge response\n",
      "No number found in the 205064th judge response\n",
      "No number found in the 205424th judge response\n",
      "No <choice>…</choice> match found in the 205436th judge response\n",
      "No number found in the 207646th judge response\n",
      "No number found in the 207653th judge response\n",
      "No number found in the 208364th judge response\n",
      "No number found in the 208543th judge response\n",
      "No number found in the 208552th judge response\n",
      "No <choice>…</choice> match found in the 210015th judge response\n",
      "No number found in the 210024th judge response\n",
      "No <choice>…</choice> match found in the 210161th judge response\n",
      "No <choice>…</choice> match found in the 210163th judge response\n",
      "No <choice>…</choice> match found in the 210164th judge response\n",
      "No number found in the 211278th judge response\n",
      "Error in 212220th API call\n",
      "Error in 212223th API call\n",
      "Error in 212224th API call\n",
      "Error in 212225th API call\n",
      "Error in 212228th API call\n",
      "Error in 212229th API call\n",
      "Error in 212412th API call\n",
      "Error in 212414th API call\n",
      "Error in 212418th API call\n",
      "Error in 212421th API call\n",
      "Error in 212423th API call\n",
      "Error in 212424th API call\n",
      "No <choice>…</choice> match found in the 213174th judge response\n",
      "No <choice>…</choice> match found in the 213213th judge response\n",
      "No number found in the 215620th judge response\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "216960"
      ]
     },
     "execution_count": 198,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "comparisons,_ = extract_comparisons_mmlu(data, include_scenario = True)\n",
    "len(comparisons)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 199,
   "id": "29ad92a6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "36674"
      ]
     },
     "execution_count": 199,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len([i for i in comparisons if i[-1] != 0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 200,
   "id": "eb66c810",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "57"
      ]
     },
     "execution_count": 200,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "subjects = list(set([i[0] for i in comparisons]))\n",
    "len(subjects)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 201,
   "id": "43f53f06",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "professional law: 3858\n",
      "nutrition: 660\n",
      "high school us history: 598\n",
      "conceptual physics: 754\n",
      "logical fallacies: 617\n",
      "econometrics: 568\n",
      "moral disputes: 489\n",
      "jurisprudence: 407\n",
      "professional medicine: 456\n",
      "high school european history: 483\n",
      "high school macroeconomics: 584\n",
      "us foreign policy: 305\n",
      "elementary mathematics: 478\n",
      "business ethics: 545\n",
      "high school microeconomics: 448\n",
      "formal logic: 508\n",
      "high school statistics: 497\n",
      "security studies: 744\n",
      "medical genetics: 432\n",
      "global facts: 640\n",
      "high school world history: 584\n",
      "management: 429\n",
      "moral scenarios: 2506\n",
      "high school psychology: 573\n",
      "marketing: 513\n",
      "human aging: 522\n",
      "college physics: 551\n",
      "machine learning: 522\n",
      "high school government and politics: 409\n",
      "miscellaneous: 562\n",
      "college biology: 653\n",
      "world religions: 672\n",
      "professional accounting: 801\n",
      "sociology: 470\n",
      "college medicine: 523\n",
      "professional psychology: 622\n",
      "high school physics: 473\n",
      "international law: 525\n",
      "virology: 544\n",
      "astronomy: 604\n",
      "abstract algebra: 454\n",
      "prehistory: 449\n",
      "high school computer science: 534\n",
      "anatomy: 562\n",
      "college mathematics: 656\n",
      "high school geography: 576\n",
      "philosophy: 583\n",
      "human sexuality: 591\n",
      "college chemistry: 561\n",
      "computer security: 487\n",
      "college computer science: 515\n",
      "high school mathematics: 475\n",
      "electrical engineering: 754\n",
      "public relations: 622\n",
      "high school chemistry: 569\n",
      "clinical knowledge: 546\n",
      "high school biology: 611\n"
     ]
    }
   ],
   "source": [
    "for subject in subjects:\n",
    "    print(f'{subject}: {len([i for i in comparisons if i[0] == subject and i[-1] != 0])}' )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 174,
   "id": "321a69fb",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['jurisprudence', 'us foreign policy', 'management', 'high school government and politics']\n",
      "4\n"
     ]
    }
   ],
   "source": [
    "l=[]\n",
    "for subject in subjects:\n",
    "    if len([i for i in comparisons if i[0] == subject and i[-1] != 0]) <432:\n",
    "        l.append(subject)\n",
    "print(l)\n",
    "print(len(l))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "aabf641c",
   "metadata": {},
   "source": [
    "## Training BT models"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "id": "0f61ad02",
   "metadata": {},
   "outputs": [],
   "source": [
    "from BT_criteria import *\n",
    "from eigentrust import *\n",
    "import random"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 191,
   "id": "267b1410",
   "metadata": {},
   "outputs": [],
   "source": [
    "def train_vector_bt(model, dataloader, lr, weight_decay, max_epochs, device, save_path=None, normalize=False, use_btd=False):\n",
    "    model.to(device)\n",
    "    optimizer = torch.optim.Adam(model.parameters(), lr=lr, weight_decay=weight_decay)\n",
    "    \n",
    "    if use_btd:\n",
    "        loss_fn = nn.CrossEntropyLoss()\n",
    "    else:\n",
    "        loss_fn = nn.BCELoss()\n",
    "\n",
    "    loss_history = []\n",
    "\n",
    "    for epoch in range(1, max_epochs+1):\n",
    "        total_loss = 0.0\n",
    "        model.train()\n",
    "\n",
    "        for c_idx, i_idx, j_idx, k_idx, r in dataloader:\n",
    "            c_idx = c_idx.to(device)\n",
    "            i_idx = i_idx.to(device)\n",
    "            j_idx = j_idx.to(device)\n",
    "            k_idx = k_idx.to(device)\n",
    "            r = r.to(device)\n",
    "\n",
    "            if use_btd:\n",
    "                r = r.long()  # CrossEntropyLoss expects long tensor\n",
    "\n",
    "                logits = model(c_idx, i_idx, j_idx, k_idx)\n",
    "                loss = loss_fn(logits, r) # CE expects logits, unnormalized, as it has built in softmax\n",
    "            else:\n",
    "                p = model(i_idx, j_idx, k_idx)\n",
    "                loss = loss_fn(p, r)\n",
    "\n",
    "            optimizer.zero_grad()\n",
    "            loss.backward()\n",
    "            optimizer.step()\n",
    "\n",
    "            if normalize:\n",
    "                with torch.no_grad():\n",
    "                    model.v.weight.data = F.normalize(model.v.weight.data, p=2, dim=1)\n",
    "\n",
    "            total_loss += loss.item() * r.size(0)\n",
    "\n",
    "        avg_loss = total_loss / len(dataloader.dataset)\n",
    "        loss_history.append(avg_loss)\n",
    "\n",
    "        if epoch % 10 == 0:\n",
    "            print(f\"Epoch {epoch:>3d}, Loss = {avg_loss:.4f}\")\n",
    "\n",
    "        if len(loss_history) >= 10 and  np.average(np.abs(np.diff(loss_history[-10:]))) <= .0001:\n",
    "            print('loss converged, breaking')\n",
    "            break\n",
    "\n",
    "    plt.figure()\n",
    "    plt.plot(range(1, len(loss_history)+1), loss_history)\n",
    "    plt.xlabel('Epoch')\n",
    "    plt.ylabel('Average Loss')\n",
    "    plt.title('Training Loss over Epochs')\n",
    "    plt.tight_layout()\n",
    "\n",
    "    if save_path:\n",
    "        loss_path = save_path+\"training_loss.png\"\n",
    "        plt.savefig(loss_path)\n",
    "        print(f\"Loss plot saved to {loss_path}\")\n",
    "\n",
    "        model_path = save_path+\"model.pt\"\n",
    "        torch.save(model.state_dict(), model_path)\n",
    "        print(f\"Model saved to {model_path}\")\n",
    "\n",
    "    return loss_history"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 192,
   "id": "3b3b62fa",
   "metadata": {},
   "outputs": [],
   "source": [
    "def train_trust_matrix(comparisons,epochs):\n",
    "\n",
    "    num_models = len(set([i[1] for i in comparisons]))\n",
    "    num_criteria = 1\n",
    "\n",
    "    d = 6\n",
    "    NORMALIZE=False\n",
    "    USE_BTD=True\n",
    "\n",
    "    lr = 1e-3\n",
    "    weight_decay = 0\n",
    "    max_epochs = epochs\n",
    "\n",
    "    batch_size=32\n",
    "    dataloader = DataLoader(dataset = PairwiseDataset(comparisons), batch_size=batch_size, shuffle=True)\n",
    "\n",
    "    model = VectorBTD(num_criteria, num_models, d)\n",
    "    train_vector_bt(\n",
    "        model,\n",
    "        dataloader,\n",
    "        lr=lr,\n",
    "        weight_decay=weight_decay,\n",
    "        max_epochs=max_epochs,\n",
    "        device='cpu',\n",
    "        save_path=None,\n",
    "        normalize=NORMALIZE,\n",
    "        use_btd=USE_BTD\n",
    "    )\n",
    "\n",
    "    device = 'cpu'\n",
    "    T = compute_trust_matrix_ties(model, device)\n",
    "    t = eigentrust(T, alpha=0)\n",
    "\n",
    "    return T,t,model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8e12d377",
   "metadata": {},
   "outputs": [],
   "source": [
    "for subject in tqdm(subjects):\n",
    "    subject_list = [i[1:] for i in comparisons if i[0] == subject]\n",
    "\n",
    "    subject_list = [[0] + i[1:] for i in subject_list]  # remove scenario and criteria indices; make every datapoint associated with criterion 0\n",
    "\n",
    "    epochs = 1000\n",
    "    print(f'Now training subject {subject} with {len(subject_list)} comparisons for {epochs} epochs')\n",
    "\n",
    "    T,t,model = train_trust_matrix(subject_list, epochs=epochs)\n",
    "\n",
    "    trust_matrices = [T.cpu().numpy().tolist(),\n",
    "                           t.cpu().numpy().tolist()]\n",
    "\n",
    "    with open(f'transcript_MMLU/_scores/{subject} scores.json', \"w\") as file:\n",
    "        json.dump(trust_matrices, file, indent=4)\n",
    "    torch.save(model.state_dict(), f'transcript_MMLU/_models/{subject} model.pt')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 195,
   "id": "69dba5d2",
   "metadata": {},
   "outputs": [],
   "source": [
    "import json\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "\n",
    "data = []\n",
    "\n",
    "for subject in subjects:\n",
    "    with open(f'transcript_MMLU/_scores/{subject} scores.json', 'r') as file:\n",
    "        trust_scores = json.load(file)[1]\n",
    "        data.append(trust_scores)\n",
    "        \n",
    "# Convert to DataFrame where each vector is a column\n",
    "df = pd.DataFrame(data).T  # Transpose so vectors become columns\n",
    "df.columns = [i.replace(\" \", \"_\") for i in subjects]\n",
    "\n",
    "# Save to CSV\n",
    "df.to_csv('transcript_MMLU/_scores/data.csv', index=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ac04a9a0",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "26e334b5",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "id": "bb47b9c1",
   "metadata": {},
   "source": [
    "## Trying to group into bigger categories"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 203,
   "id": "276e22b1",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['professional law',\n",
       " 'nutrition',\n",
       " 'high school us history',\n",
       " 'conceptual physics',\n",
       " 'logical fallacies',\n",
       " 'econometrics',\n",
       " 'moral disputes',\n",
       " 'jurisprudence',\n",
       " 'professional medicine',\n",
       " 'high school european history',\n",
       " 'high school macroeconomics',\n",
       " 'us foreign policy',\n",
       " 'elementary mathematics',\n",
       " 'business ethics',\n",
       " 'high school microeconomics',\n",
       " 'formal logic',\n",
       " 'high school statistics',\n",
       " 'security studies',\n",
       " 'medical genetics',\n",
       " 'global facts',\n",
       " 'high school world history',\n",
       " 'management',\n",
       " 'moral scenarios',\n",
       " 'high school psychology',\n",
       " 'marketing',\n",
       " 'human aging',\n",
       " 'college physics',\n",
       " 'machine learning',\n",
       " 'high school government and politics',\n",
       " 'miscellaneous',\n",
       " 'college biology',\n",
       " 'world religions',\n",
       " 'professional accounting',\n",
       " 'sociology',\n",
       " 'college medicine',\n",
       " 'professional psychology',\n",
       " 'high school physics',\n",
       " 'international law',\n",
       " 'virology',\n",
       " 'astronomy',\n",
       " 'abstract algebra',\n",
       " 'prehistory',\n",
       " 'high school computer science',\n",
       " 'anatomy',\n",
       " 'college mathematics',\n",
       " 'high school geography',\n",
       " 'philosophy',\n",
       " 'human sexuality',\n",
       " 'college chemistry',\n",
       " 'computer security',\n",
       " 'college computer science',\n",
       " 'high school mathematics',\n",
       " 'electrical engineering',\n",
       " 'public relations',\n",
       " 'high school chemistry',\n",
       " 'clinical knowledge',\n",
       " 'high school biology']"
      ]
     },
     "execution_count": 203,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "subjects"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 216,
   "id": "1f5f36c5",
   "metadata": {},
   "outputs": [],
   "source": [
    "categories = {\n",
    "    \"math\": [\n",
    "        \"elementary mathematics\",\n",
    "        \"high school mathematics\", \n",
    "        \"college mathematics\",\n",
    "        \"high school statistics\",\n",
    "        \"abstract algebra\"\n",
    "    ],\n",
    "    \n",
    "    \"phy_science\": [\n",
    "        \"conceptual physics\",\n",
    "        \"high school physics\",\n",
    "        \"college physics\", \n",
    "        \"high school chemistry\",\n",
    "        \"college chemistry\",\n",
    "        \"astronomy\"\n",
    "    ],\n",
    "    \n",
    "    \"life_science\": [\n",
    "        \"high school biology\",\n",
    "        \"college biology\",\n",
    "        \"anatomy\",\n",
    "        \"medical genetics\",\n",
    "        \"virology\",\n",
    "        \"human aging\",\n",
    "        \"human sexuality\", \n",
    "        \"nutrition\"\n",
    "    ],\n",
    "    \n",
    "    \"cs\": [\n",
    "        \"high school computer science\",\n",
    "        \"college computer science\",\n",
    "        \"machine learning\",\n",
    "        \"computer security\",\n",
    "        \"electrical engineering\"\n",
    "    ],\n",
    "    \n",
    "    \"psych\": [\n",
    "        \"high school psychology\",\n",
    "        \"professional psychology\"\n",
    "    ],\n",
    "    \n",
    "    \"econ\": [\n",
    "        \"high school macroeconomics\",\n",
    "        \"high school microeconomics\",\n",
    "        \"econometrics\"\n",
    "    ],\n",
    "    \n",
    "    \"social\": [\n",
    "        \"sociology\",\n",
    "        \"high school geography\",\n",
    "        \"global facts\"\n",
    "    ],\n",
    "    \n",
    "    \"history\": [\n",
    "        \"high school us history\",\n",
    "        \"high school european history\", \n",
    "        \"high school world history\",\n",
    "        \"prehistory\"\n",
    "    ],\n",
    "    \n",
    "    \"phil\": [\n",
    "        \"philosophy\",\n",
    "        \"logical fallacies\",\n",
    "        \"formal logic\",\n",
    "        \"moral disputes\",\n",
    "        \"moral scenarios\"\n",
    "    ],\n",
    "    \n",
    "    \"religion\": [\n",
    "        \"world religions\"\n",
    "    ],\n",
    "    \n",
    "    \"medicine\": [\n",
    "        \"professional medicine\",\n",
    "        \"college medicine\",\n",
    "        \"clinical knowledge\"\n",
    "    ],\n",
    "    \n",
    "    \"law\": [\n",
    "        \"professional law\",\n",
    "        \"jurisprudence\",\n",
    "        \"international law\"\n",
    "    ],\n",
    "    \n",
    "    \"business\": [\n",
    "        \"professional accounting\",\n",
    "        \"management\",\n",
    "        \"marketing\",\n",
    "        \"public relations\",\n",
    "        \"business ethics\"\n",
    "    ],\n",
    "    \n",
    "    \"gov\": [\n",
    "        \"high school government and politics\",\n",
    "        \"us foreign policy\",\n",
    "        \"security studies\"\n",
    "    ],\n",
    "    \n",
    "    \"misc\": [\n",
    "        \"miscellaneous\"\n",
    "    ]\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 218,
   "id": "e974ad5c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "math 2560\n",
      "phy_science 3512\n",
      "life_science 4575\n",
      "cs 2812\n",
      "psych 1195\n",
      "econ 1600\n",
      "social 1686\n",
      "history 2114\n",
      "phil 4703\n",
      "religion 672\n",
      "medicine 1525\n",
      "law 4790\n",
      "business 2910\n",
      "gov 1458\n",
      "misc 562\n"
     ]
    }
   ],
   "source": [
    "for key, val in categories.items():\n",
    "    print(key, len([i for i in comparisons if i[0] in val and i[-1] != 0]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 220,
   "id": "0197d897",
   "metadata": {},
   "outputs": [],
   "source": [
    "from BT_criteria import *\n",
    "from eigentrust import *\n",
    "import random"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 221,
   "id": "d21d4d61",
   "metadata": {},
   "outputs": [],
   "source": [
    "def train_vector_bt(model, dataloader, lr, weight_decay, max_epochs, device, save_path=None, normalize=False, use_btd=False):\n",
    "    model.to(device)\n",
    "    optimizer = torch.optim.Adam(model.parameters(), lr=lr, weight_decay=weight_decay)\n",
    "    \n",
    "    if use_btd:\n",
    "        loss_fn = nn.CrossEntropyLoss()\n",
    "    else:\n",
    "        loss_fn = nn.BCELoss()\n",
    "\n",
    "    loss_history = []\n",
    "\n",
    "    for epoch in range(1, max_epochs+1):\n",
    "        total_loss = 0.0\n",
    "        model.train()\n",
    "\n",
    "        for c_idx, i_idx, j_idx, k_idx, r in dataloader:\n",
    "            c_idx = c_idx.to(device)\n",
    "            i_idx = i_idx.to(device)\n",
    "            j_idx = j_idx.to(device)\n",
    "            k_idx = k_idx.to(device)\n",
    "            r = r.to(device)\n",
    "\n",
    "            if use_btd:\n",
    "                r = r.long()  # CrossEntropyLoss expects long tensor\n",
    "\n",
    "                logits = model(c_idx, i_idx, j_idx, k_idx)\n",
    "                loss = loss_fn(logits, r) # CE expects logits, unnormalized, as it has built in softmax\n",
    "            else:\n",
    "                p = model(i_idx, j_idx, k_idx)\n",
    "                loss = loss_fn(p, r)\n",
    "\n",
    "            optimizer.zero_grad()\n",
    "            loss.backward()\n",
    "            optimizer.step()\n",
    "\n",
    "            if normalize:\n",
    "                with torch.no_grad():\n",
    "                    model.v.weight.data = F.normalize(model.v.weight.data, p=2, dim=1)\n",
    "\n",
    "            total_loss += loss.item() * r.size(0)\n",
    "\n",
    "        avg_loss = total_loss / len(dataloader.dataset)\n",
    "        loss_history.append(avg_loss)\n",
    "\n",
    "        if epoch % 10 == 0:\n",
    "            print(f\"Epoch {epoch:>3d}, Loss = {avg_loss:.4f}\")\n",
    "\n",
    "        if len(loss_history) >= 10 and  np.average(np.abs(np.diff(loss_history[-10:]))) <= .0001:\n",
    "            print('loss converged, breaking')\n",
    "            break\n",
    "\n",
    "    plt.figure()\n",
    "    plt.plot(range(1, len(loss_history)+1), loss_history)\n",
    "    plt.xlabel('Epoch')\n",
    "    plt.ylabel('Average Loss')\n",
    "    plt.title('Training Loss over Epochs')\n",
    "    plt.tight_layout()\n",
    "\n",
    "    if save_path:\n",
    "        loss_path = save_path+\"training_loss.png\"\n",
    "        plt.savefig(loss_path)\n",
    "        print(f\"Loss plot saved to {loss_path}\")\n",
    "\n",
    "        model_path = save_path+\"model.pt\"\n",
    "        torch.save(model.state_dict(), model_path)\n",
    "        print(f\"Model saved to {model_path}\")\n",
    "\n",
    "    return loss_history"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 222,
   "id": "ef4ea1f6",
   "metadata": {},
   "outputs": [],
   "source": [
    "def train_trust_matrix(comparisons,epochs):\n",
    "\n",
    "    num_models = len(set([i[1] for i in comparisons]))\n",
    "    num_criteria = 1\n",
    "\n",
    "    d = 6\n",
    "    NORMALIZE=False\n",
    "    USE_BTD=True\n",
    "\n",
    "    lr = 1e-3\n",
    "    weight_decay = 0\n",
    "    max_epochs = epochs\n",
    "\n",
    "    batch_size=32\n",
    "    dataloader = DataLoader(dataset = PairwiseDataset(comparisons), batch_size=batch_size, shuffle=True)\n",
    "\n",
    "    model = VectorBTD(num_criteria, num_models, d)\n",
    "    train_vector_bt(\n",
    "        model,\n",
    "        dataloader,\n",
    "        lr=lr,\n",
    "        weight_decay=weight_decay,\n",
    "        max_epochs=max_epochs,\n",
    "        device='cpu',\n",
    "        save_path=None,\n",
    "        normalize=NORMALIZE,\n",
    "        use_btd=USE_BTD\n",
    "    )\n",
    "\n",
    "    device = 'cpu'\n",
    "    T = compute_trust_matrix_ties(model, device)\n",
    "    t = eigentrust(T, alpha=0)\n",
    "\n",
    "    return T,t,model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f75af154",
   "metadata": {},
   "outputs": [],
   "source": [
    "for category, val in tqdm(categories.items()):\n",
    "    subject_list = [i[1:] for i in comparisons if i[0] in val]\n",
    "\n",
    "    subject_list = [[0] + i[1:] for i in subject_list]  # remove scenario and criteria indices; make every datapoint associated with criterion 0\n",
    "\n",
    "    epochs = 1000\n",
    "    print(f'Now training category {category} with {len(subject_list)} comparisons for {epochs} epochs')\n",
    "\n",
    "    T,t,model = train_trust_matrix(subject_list, epochs=epochs)\n",
    "\n",
    "    trust_matrices = [T.cpu().numpy().tolist(),\n",
    "                           t.cpu().numpy().tolist()]\n",
    "\n",
    "    with open(f'transcript_MMLU/_results/{category}_scores.json', \"w\") as file:\n",
    "        json.dump(trust_matrices, file, indent=4)\n",
    "    # torch.save(model.state_dict(), f'transcript_MMLU/_results/{subject}_model.pt')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 229,
   "id": "afed215d",
   "metadata": {},
   "outputs": [],
   "source": [
    "import json\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "\n",
    "data = []\n",
    "\n",
    "for category, val in categories.items():\n",
    "    with open(f'transcript_MMLU/_results/{category}_scores.json', 'r') as file:\n",
    "        trust_scores = json.load(file)[1]\n",
    "        data.append(trust_scores)\n",
    "        \n",
    "# Convert to DataFrame where each vector is a column\n",
    "df = pd.DataFrame(data).T  # Transpose so vectors become columns\n",
    "df.columns = [i.replace(\" \", \"_\") for i in categories.keys()]\n",
    "\n",
    "# Save to CSV\n",
    "df.to_csv('transcript_MMLU/_results/data.csv', index=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d8af9fe5",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6ff75fa8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "id": "88249513",
   "metadata": {},
   "source": [
    "## Running regression on categories"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 230,
   "id": "34a0b9e3",
   "metadata": {},
   "outputs": [
    {
     "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>math</th>\n",
       "      <th>phy_science</th>\n",
       "      <th>life_science</th>\n",
       "      <th>cs</th>\n",
       "      <th>psych</th>\n",
       "      <th>econ</th>\n",
       "      <th>social</th>\n",
       "      <th>history</th>\n",
       "      <th>phil</th>\n",
       "      <th>religion</th>\n",
       "      <th>medicine</th>\n",
       "      <th>law</th>\n",
       "      <th>business</th>\n",
       "      <th>gov</th>\n",
       "      <th>misc</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.209028</td>\n",
       "      <td>0.202485</td>\n",
       "      <td>0.183608</td>\n",
       "      <td>0.180141</td>\n",
       "      <td>0.207547</td>\n",
       "      <td>0.197284</td>\n",
       "      <td>0.176700</td>\n",
       "      <td>0.184639</td>\n",
       "      <td>0.172040</td>\n",
       "      <td>0.165305</td>\n",
       "      <td>0.199659</td>\n",
       "      <td>0.171647</td>\n",
       "      <td>0.183231</td>\n",
       "      <td>0.191123</td>\n",
       "      <td>0.199591</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.192021</td>\n",
       "      <td>0.193621</td>\n",
       "      <td>0.178919</td>\n",
       "      <td>0.190045</td>\n",
       "      <td>0.198641</td>\n",
       "      <td>0.193758</td>\n",
       "      <td>0.166415</td>\n",
       "      <td>0.177811</td>\n",
       "      <td>0.180702</td>\n",
       "      <td>0.166842</td>\n",
       "      <td>0.180499</td>\n",
       "      <td>0.172219</td>\n",
       "      <td>0.176939</td>\n",
       "      <td>0.184364</td>\n",
       "      <td>0.184541</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0.180226</td>\n",
       "      <td>0.192905</td>\n",
       "      <td>0.166264</td>\n",
       "      <td>0.180285</td>\n",
       "      <td>0.161874</td>\n",
       "      <td>0.183572</td>\n",
       "      <td>0.164380</td>\n",
       "      <td>0.172878</td>\n",
       "      <td>0.164446</td>\n",
       "      <td>0.200193</td>\n",
       "      <td>0.148293</td>\n",
       "      <td>0.160764</td>\n",
       "      <td>0.168339</td>\n",
       "      <td>0.164757</td>\n",
       "      <td>0.155247</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0.192407</td>\n",
       "      <td>0.177932</td>\n",
       "      <td>0.175787</td>\n",
       "      <td>0.162357</td>\n",
       "      <td>0.171325</td>\n",
       "      <td>0.168994</td>\n",
       "      <td>0.190161</td>\n",
       "      <td>0.141858</td>\n",
       "      <td>0.173553</td>\n",
       "      <td>0.191070</td>\n",
       "      <td>0.172079</td>\n",
       "      <td>0.175357</td>\n",
       "      <td>0.176464</td>\n",
       "      <td>0.192409</td>\n",
       "      <td>0.178936</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.117233</td>\n",
       "      <td>0.120476</td>\n",
       "      <td>0.153355</td>\n",
       "      <td>0.155933</td>\n",
       "      <td>0.133753</td>\n",
       "      <td>0.152347</td>\n",
       "      <td>0.147069</td>\n",
       "      <td>0.172413</td>\n",
       "      <td>0.159808</td>\n",
       "      <td>0.158878</td>\n",
       "      <td>0.165783</td>\n",
       "      <td>0.168094</td>\n",
       "      <td>0.146074</td>\n",
       "      <td>0.145701</td>\n",
       "      <td>0.149559</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>0.109085</td>\n",
       "      <td>0.112581</td>\n",
       "      <td>0.142066</td>\n",
       "      <td>0.131241</td>\n",
       "      <td>0.126860</td>\n",
       "      <td>0.104044</td>\n",
       "      <td>0.155275</td>\n",
       "      <td>0.150402</td>\n",
       "      <td>0.149451</td>\n",
       "      <td>0.117712</td>\n",
       "      <td>0.133687</td>\n",
       "      <td>0.151919</td>\n",
       "      <td>0.148954</td>\n",
       "      <td>0.121646</td>\n",
       "      <td>0.132126</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "       math  phy_science  life_science        cs     psych      econ  \\\n",
       "0  0.209028     0.202485      0.183608  0.180141  0.207547  0.197284   \n",
       "1  0.192021     0.193621      0.178919  0.190045  0.198641  0.193758   \n",
       "2  0.180226     0.192905      0.166264  0.180285  0.161874  0.183572   \n",
       "3  0.192407     0.177932      0.175787  0.162357  0.171325  0.168994   \n",
       "4  0.117233     0.120476      0.153355  0.155933  0.133753  0.152347   \n",
       "5  0.109085     0.112581      0.142066  0.131241  0.126860  0.104044   \n",
       "\n",
       "     social   history      phil  religion  medicine       law  business  \\\n",
       "0  0.176700  0.184639  0.172040  0.165305  0.199659  0.171647  0.183231   \n",
       "1  0.166415  0.177811  0.180702  0.166842  0.180499  0.172219  0.176939   \n",
       "2  0.164380  0.172878  0.164446  0.200193  0.148293  0.160764  0.168339   \n",
       "3  0.190161  0.141858  0.173553  0.191070  0.172079  0.175357  0.176464   \n",
       "4  0.147069  0.172413  0.159808  0.158878  0.165783  0.168094  0.146074   \n",
       "5  0.155275  0.150402  0.149451  0.117712  0.133687  0.151919  0.148954   \n",
       "\n",
       "        gov      misc  \n",
       "0  0.191123  0.199591  \n",
       "1  0.184364  0.184541  \n",
       "2  0.164757  0.155247  \n",
       "3  0.192409  0.178936  \n",
       "4  0.145701  0.149559  \n",
       "5  0.121646  0.132126  "
      ]
     },
     "execution_count": 230,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 282,
   "id": "319d6370",
   "metadata": {},
   "outputs": [],
   "source": [
    "df2 = pd.read_csv('data/mmlu/mmlu_6_models.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 283,
   "id": "c427bb35",
   "metadata": {},
   "outputs": [
    {
     "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>Model</th>\n",
       "      <th>abstract algebra</th>\n",
       "      <th>anatomy</th>\n",
       "      <th>college chemistry</th>\n",
       "      <th>computer security</th>\n",
       "      <th>econometrics</th>\n",
       "      <th>global facts</th>\n",
       "      <th>jurisprudence</th>\n",
       "      <th>philosophy</th>\n",
       "      <th>professional medicine</th>\n",
       "      <th>...</th>\n",
       "      <th>nutrition</th>\n",
       "      <th>prehistory</th>\n",
       "      <th>professional accounting</th>\n",
       "      <th>professional law</th>\n",
       "      <th>professional psychology</th>\n",
       "      <th>public relations</th>\n",
       "      <th>security studies</th>\n",
       "      <th>sociology</th>\n",
       "      <th>virology</th>\n",
       "      <th>world religions</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>DeepSeek v3</td>\n",
       "      <td>0.84</td>\n",
       "      <td>0.867</td>\n",
       "      <td>0.65</td>\n",
       "      <td>0.86</td>\n",
       "      <td>0.746</td>\n",
       "      <td>0.68</td>\n",
       "      <td>0.898</td>\n",
       "      <td>0.900</td>\n",
       "      <td>0.949</td>\n",
       "      <td>...</td>\n",
       "      <td>0.918</td>\n",
       "      <td>0.923</td>\n",
       "      <td>0.826</td>\n",
       "      <td>0.713</td>\n",
       "      <td>0.887</td>\n",
       "      <td>0.809</td>\n",
       "      <td>0.837</td>\n",
       "      <td>0.955</td>\n",
       "      <td>0.596</td>\n",
       "      <td>0.912</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>GPT-4o (2024-08-06)</td>\n",
       "      <td>0.58</td>\n",
       "      <td>0.911</td>\n",
       "      <td>0.60</td>\n",
       "      <td>0.85</td>\n",
       "      <td>0.711</td>\n",
       "      <td>0.69</td>\n",
       "      <td>0.907</td>\n",
       "      <td>0.894</td>\n",
       "      <td>0.960</td>\n",
       "      <td>...</td>\n",
       "      <td>0.905</td>\n",
       "      <td>0.935</td>\n",
       "      <td>0.801</td>\n",
       "      <td>0.742</td>\n",
       "      <td>0.899</td>\n",
       "      <td>0.782</td>\n",
       "      <td>0.833</td>\n",
       "      <td>0.945</td>\n",
       "      <td>0.578</td>\n",
       "      <td>0.883</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>Gemini 1.5 Flash (002)</td>\n",
       "      <td>0.63</td>\n",
       "      <td>0.793</td>\n",
       "      <td>0.56</td>\n",
       "      <td>0.72</td>\n",
       "      <td>0.675</td>\n",
       "      <td>0.47</td>\n",
       "      <td>0.852</td>\n",
       "      <td>0.797</td>\n",
       "      <td>0.647</td>\n",
       "      <td>...</td>\n",
       "      <td>0.588</td>\n",
       "      <td>0.762</td>\n",
       "      <td>0.621</td>\n",
       "      <td>0.603</td>\n",
       "      <td>0.806</td>\n",
       "      <td>0.700</td>\n",
       "      <td>0.547</td>\n",
       "      <td>0.851</td>\n",
       "      <td>0.524</td>\n",
       "      <td>0.865</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>GPT-4o mini (2024-07-18)</td>\n",
       "      <td>0.42</td>\n",
       "      <td>0.770</td>\n",
       "      <td>0.51</td>\n",
       "      <td>0.85</td>\n",
       "      <td>0.649</td>\n",
       "      <td>0.45</td>\n",
       "      <td>0.870</td>\n",
       "      <td>0.772</td>\n",
       "      <td>0.864</td>\n",
       "      <td>...</td>\n",
       "      <td>0.827</td>\n",
       "      <td>0.833</td>\n",
       "      <td>0.667</td>\n",
       "      <td>0.592</td>\n",
       "      <td>0.833</td>\n",
       "      <td>0.791</td>\n",
       "      <td>0.788</td>\n",
       "      <td>0.900</td>\n",
       "      <td>0.536</td>\n",
       "      <td>0.860</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>Claude 3 Haiku (20240307)</td>\n",
       "      <td>0.42</td>\n",
       "      <td>0.711</td>\n",
       "      <td>0.52</td>\n",
       "      <td>0.79</td>\n",
       "      <td>0.632</td>\n",
       "      <td>0.47</td>\n",
       "      <td>0.861</td>\n",
       "      <td>0.814</td>\n",
       "      <td>0.857</td>\n",
       "      <td>...</td>\n",
       "      <td>0.830</td>\n",
       "      <td>0.824</td>\n",
       "      <td>0.539</td>\n",
       "      <td>0.577</td>\n",
       "      <td>0.802</td>\n",
       "      <td>0.755</td>\n",
       "      <td>0.808</td>\n",
       "      <td>0.900</td>\n",
       "      <td>0.542</td>\n",
       "      <td>0.871</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>GPT-3.5 Turbo (0125)</td>\n",
       "      <td>0.31</td>\n",
       "      <td>0.696</td>\n",
       "      <td>0.49</td>\n",
       "      <td>0.78</td>\n",
       "      <td>0.474</td>\n",
       "      <td>0.39</td>\n",
       "      <td>0.806</td>\n",
       "      <td>0.746</td>\n",
       "      <td>0.772</td>\n",
       "      <td>...</td>\n",
       "      <td>0.748</td>\n",
       "      <td>0.735</td>\n",
       "      <td>0.493</td>\n",
       "      <td>0.487</td>\n",
       "      <td>0.722</td>\n",
       "      <td>0.727</td>\n",
       "      <td>0.751</td>\n",
       "      <td>0.861</td>\n",
       "      <td>0.536</td>\n",
       "      <td>0.842</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>6 rows × 58 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "                       Model  abstract algebra  anatomy  college chemistry  \\\n",
       "0                DeepSeek v3              0.84    0.867               0.65   \n",
       "1        GPT-4o (2024-08-06)              0.58    0.911               0.60   \n",
       "2     Gemini 1.5 Flash (002)              0.63    0.793               0.56   \n",
       "3   GPT-4o mini (2024-07-18)              0.42    0.770               0.51   \n",
       "4  Claude 3 Haiku (20240307)              0.42    0.711               0.52   \n",
       "5       GPT-3.5 Turbo (0125)              0.31    0.696               0.49   \n",
       "\n",
       "   computer security  econometrics  global facts  jurisprudence  philosophy  \\\n",
       "0               0.86         0.746          0.68          0.898       0.900   \n",
       "1               0.85         0.711          0.69          0.907       0.894   \n",
       "2               0.72         0.675          0.47          0.852       0.797   \n",
       "3               0.85         0.649          0.45          0.870       0.772   \n",
       "4               0.79         0.632          0.47          0.861       0.814   \n",
       "5               0.78         0.474          0.39          0.806       0.746   \n",
       "\n",
       "   professional medicine  ...  nutrition  prehistory  professional accounting  \\\n",
       "0                  0.949  ...      0.918       0.923                    0.826   \n",
       "1                  0.960  ...      0.905       0.935                    0.801   \n",
       "2                  0.647  ...      0.588       0.762                    0.621   \n",
       "3                  0.864  ...      0.827       0.833                    0.667   \n",
       "4                  0.857  ...      0.830       0.824                    0.539   \n",
       "5                  0.772  ...      0.748       0.735                    0.493   \n",
       "\n",
       "   professional law  professional psychology  public relations  \\\n",
       "0             0.713                    0.887             0.809   \n",
       "1             0.742                    0.899             0.782   \n",
       "2             0.603                    0.806             0.700   \n",
       "3             0.592                    0.833             0.791   \n",
       "4             0.577                    0.802             0.755   \n",
       "5             0.487                    0.722             0.727   \n",
       "\n",
       "   security studies  sociology  virology  world religions  \n",
       "0             0.837      0.955     0.596            0.912  \n",
       "1             0.833      0.945     0.578            0.883  \n",
       "2             0.547      0.851     0.524            0.865  \n",
       "3             0.788      0.900     0.536            0.860  \n",
       "4             0.808      0.900     0.542            0.871  \n",
       "5             0.751      0.861     0.536            0.842  \n",
       "\n",
       "[6 rows x 58 columns]"
      ]
     },
     "execution_count": 283,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 324,
   "id": "4c6714e6",
   "metadata": {},
   "outputs": [],
   "source": [
    "category_scores = {}\n",
    "for category, val in categories.items():\n",
    "    weights = []\n",
    "    l = []\n",
    "    for subject in val:\n",
    "        l.append(list(df2[subject]))\n",
    "        weights.append(len([i for i in comparisons if i[0] == subject]))\n",
    "    category_scores[category] = np.average(l,axis=0, weights=weights)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 325,
   "id": "759f387a",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'math': array([0.8662337 , 0.67975714, 0.64963825, 0.58517028, 0.53475398,\n",
       "        0.44768197]),\n",
       " 'phy_science': array([0.85618224, 0.8285217 , 0.76936331, 0.72019631, 0.68657695,\n",
       "        0.5992621 ]),\n",
       " 'life_science': array([0.89322664, 0.88700586, 0.73967723, 0.83155965, 0.79078903,\n",
       "        0.7379633 ]),\n",
       " 'cs': array([0.87168299, 0.84053486, 0.77010711, 0.78062943, 0.72415265,\n",
       "        0.66858184]),\n",
       " 'psych': array([0.93857939, 0.93786118, 0.8702976 , 0.90012386, 0.88254864,\n",
       "        0.82091938]),\n",
       " 'econ': array([0.90291646, 0.89662732, 0.83600319, 0.83324365, 0.76753409,\n",
       "        0.65832766]),\n",
       " 'social': array([0.91853368, 0.91435379, 0.81726805, 0.84951508, 0.83157508,\n",
       "        0.79949354]),\n",
       " 'history': array([0.91805625, 0.93347873, 0.84535108, 0.88681231, 0.85227564,\n",
       "        0.79757294]),\n",
       " 'phil': array([0.86046399, 0.84549674, 0.73030466, 0.69644309, 0.68828573,\n",
       "        0.60508691]),\n",
       " 'religion': array([0.912, 0.883, 0.865, 0.86 , 0.871, 0.842]),\n",
       " 'medicine': array([0.91403226, 0.90783128, 0.72952356, 0.83117727, 0.80233265,\n",
       "        0.7290348 ]),\n",
       " 'law': array([0.80991432, 0.82557512, 0.69068441, 0.73206445, 0.71575897,\n",
       "        0.63256462]),\n",
       " 'business': array([0.90048105, 0.89254914, 0.75437542, 0.84314392, 0.82067283,\n",
       "        0.80006029]),\n",
       " 'gov': array([0.94010227, 0.95150636, 0.85298784, 0.91896312, 0.92821922,\n",
       "        0.88720959]),\n",
       " 'misc': array([0.949, 0.958, 0.9  , 0.913, 0.893, 0.89 ])}"
      ]
     },
     "execution_count": 325,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "category_scores"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 322,
   "id": "5eddcd6d",
   "metadata": {},
   "outputs": [
    {
     "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>math</th>\n",
       "      <th>phy_science</th>\n",
       "      <th>life_science</th>\n",
       "      <th>cs</th>\n",
       "      <th>psych</th>\n",
       "      <th>econ</th>\n",
       "      <th>social</th>\n",
       "      <th>history</th>\n",
       "      <th>phil</th>\n",
       "      <th>religion</th>\n",
       "      <th>medicine</th>\n",
       "      <th>law</th>\n",
       "      <th>business</th>\n",
       "      <th>gov</th>\n",
       "      <th>misc</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.866234</td>\n",
       "      <td>0.856182</td>\n",
       "      <td>0.893227</td>\n",
       "      <td>0.871683</td>\n",
       "      <td>0.938579</td>\n",
       "      <td>0.902916</td>\n",
       "      <td>0.918534</td>\n",
       "      <td>0.918056</td>\n",
       "      <td>0.860464</td>\n",
       "      <td>0.912</td>\n",
       "      <td>0.914032</td>\n",
       "      <td>0.809914</td>\n",
       "      <td>0.900481</td>\n",
       "      <td>0.940102</td>\n",
       "      <td>0.949</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.679757</td>\n",
       "      <td>0.828522</td>\n",
       "      <td>0.887006</td>\n",
       "      <td>0.840535</td>\n",
       "      <td>0.937861</td>\n",
       "      <td>0.896627</td>\n",
       "      <td>0.914354</td>\n",
       "      <td>0.933479</td>\n",
       "      <td>0.845497</td>\n",
       "      <td>0.883</td>\n",
       "      <td>0.907831</td>\n",
       "      <td>0.825575</td>\n",
       "      <td>0.892549</td>\n",
       "      <td>0.951506</td>\n",
       "      <td>0.958</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0.649638</td>\n",
       "      <td>0.769363</td>\n",
       "      <td>0.739677</td>\n",
       "      <td>0.770107</td>\n",
       "      <td>0.870298</td>\n",
       "      <td>0.836003</td>\n",
       "      <td>0.817268</td>\n",
       "      <td>0.845351</td>\n",
       "      <td>0.730305</td>\n",
       "      <td>0.865</td>\n",
       "      <td>0.729524</td>\n",
       "      <td>0.690684</td>\n",
       "      <td>0.754375</td>\n",
       "      <td>0.852988</td>\n",
       "      <td>0.900</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0.585170</td>\n",
       "      <td>0.720196</td>\n",
       "      <td>0.831560</td>\n",
       "      <td>0.780629</td>\n",
       "      <td>0.900124</td>\n",
       "      <td>0.833244</td>\n",
       "      <td>0.849515</td>\n",
       "      <td>0.886812</td>\n",
       "      <td>0.696443</td>\n",
       "      <td>0.860</td>\n",
       "      <td>0.831177</td>\n",
       "      <td>0.732064</td>\n",
       "      <td>0.843144</td>\n",
       "      <td>0.918963</td>\n",
       "      <td>0.913</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.534754</td>\n",
       "      <td>0.686577</td>\n",
       "      <td>0.790789</td>\n",
       "      <td>0.724153</td>\n",
       "      <td>0.882549</td>\n",
       "      <td>0.767534</td>\n",
       "      <td>0.831575</td>\n",
       "      <td>0.852276</td>\n",
       "      <td>0.688286</td>\n",
       "      <td>0.871</td>\n",
       "      <td>0.802333</td>\n",
       "      <td>0.715759</td>\n",
       "      <td>0.820673</td>\n",
       "      <td>0.928219</td>\n",
       "      <td>0.893</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>0.447682</td>\n",
       "      <td>0.599262</td>\n",
       "      <td>0.737963</td>\n",
       "      <td>0.668582</td>\n",
       "      <td>0.820919</td>\n",
       "      <td>0.658328</td>\n",
       "      <td>0.799494</td>\n",
       "      <td>0.797573</td>\n",
       "      <td>0.605087</td>\n",
       "      <td>0.842</td>\n",
       "      <td>0.729035</td>\n",
       "      <td>0.632565</td>\n",
       "      <td>0.800060</td>\n",
       "      <td>0.887210</td>\n",
       "      <td>0.890</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "       math  phy_science  life_science        cs     psych      econ  \\\n",
       "0  0.866234     0.856182      0.893227  0.871683  0.938579  0.902916   \n",
       "1  0.679757     0.828522      0.887006  0.840535  0.937861  0.896627   \n",
       "2  0.649638     0.769363      0.739677  0.770107  0.870298  0.836003   \n",
       "3  0.585170     0.720196      0.831560  0.780629  0.900124  0.833244   \n",
       "4  0.534754     0.686577      0.790789  0.724153  0.882549  0.767534   \n",
       "5  0.447682     0.599262      0.737963  0.668582  0.820919  0.658328   \n",
       "\n",
       "     social   history      phil  religion  medicine       law  business  \\\n",
       "0  0.918534  0.918056  0.860464     0.912  0.914032  0.809914  0.900481   \n",
       "1  0.914354  0.933479  0.845497     0.883  0.907831  0.825575  0.892549   \n",
       "2  0.817268  0.845351  0.730305     0.865  0.729524  0.690684  0.754375   \n",
       "3  0.849515  0.886812  0.696443     0.860  0.831177  0.732064  0.843144   \n",
       "4  0.831575  0.852276  0.688286     0.871  0.802333  0.715759  0.820673   \n",
       "5  0.799494  0.797573  0.605087     0.842  0.729035  0.632565  0.800060   \n",
       "\n",
       "        gov   misc  \n",
       "0  0.940102  0.949  \n",
       "1  0.951506  0.958  \n",
       "2  0.852988  0.900  \n",
       "3  0.918963  0.913  \n",
       "4  0.928219  0.893  \n",
       "5  0.887210  0.890  "
      ]
     },
     "execution_count": 322,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df3 = pd.DataFrame(category_scores)\n",
    "df3"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 323,
   "id": "738bb867",
   "metadata": {},
   "outputs": [
    {
     "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>math</th>\n",
       "      <th>phy_science</th>\n",
       "      <th>life_science</th>\n",
       "      <th>cs</th>\n",
       "      <th>psych</th>\n",
       "      <th>econ</th>\n",
       "      <th>social</th>\n",
       "      <th>history</th>\n",
       "      <th>phil</th>\n",
       "      <th>religion</th>\n",
       "      <th>medicine</th>\n",
       "      <th>law</th>\n",
       "      <th>business</th>\n",
       "      <th>gov</th>\n",
       "      <th>misc</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>0.209028</td>\n",
       "      <td>0.202485</td>\n",
       "      <td>0.183608</td>\n",
       "      <td>0.180141</td>\n",
       "      <td>0.207547</td>\n",
       "      <td>0.197284</td>\n",
       "      <td>0.176700</td>\n",
       "      <td>0.184639</td>\n",
       "      <td>0.172040</td>\n",
       "      <td>0.165305</td>\n",
       "      <td>0.199659</td>\n",
       "      <td>0.171647</td>\n",
       "      <td>0.183231</td>\n",
       "      <td>0.191123</td>\n",
       "      <td>0.199591</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>0.192021</td>\n",
       "      <td>0.193621</td>\n",
       "      <td>0.178919</td>\n",
       "      <td>0.190045</td>\n",
       "      <td>0.198641</td>\n",
       "      <td>0.193758</td>\n",
       "      <td>0.166415</td>\n",
       "      <td>0.177811</td>\n",
       "      <td>0.180702</td>\n",
       "      <td>0.166842</td>\n",
       "      <td>0.180499</td>\n",
       "      <td>0.172219</td>\n",
       "      <td>0.176939</td>\n",
       "      <td>0.184364</td>\n",
       "      <td>0.184541</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>0.180226</td>\n",
       "      <td>0.192905</td>\n",
       "      <td>0.166264</td>\n",
       "      <td>0.180285</td>\n",
       "      <td>0.161874</td>\n",
       "      <td>0.183572</td>\n",
       "      <td>0.164380</td>\n",
       "      <td>0.172878</td>\n",
       "      <td>0.164446</td>\n",
       "      <td>0.200193</td>\n",
       "      <td>0.148293</td>\n",
       "      <td>0.160764</td>\n",
       "      <td>0.168339</td>\n",
       "      <td>0.164757</td>\n",
       "      <td>0.155247</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>0.192407</td>\n",
       "      <td>0.177932</td>\n",
       "      <td>0.175787</td>\n",
       "      <td>0.162357</td>\n",
       "      <td>0.171325</td>\n",
       "      <td>0.168994</td>\n",
       "      <td>0.190161</td>\n",
       "      <td>0.141858</td>\n",
       "      <td>0.173553</td>\n",
       "      <td>0.191070</td>\n",
       "      <td>0.172079</td>\n",
       "      <td>0.175357</td>\n",
       "      <td>0.176464</td>\n",
       "      <td>0.192409</td>\n",
       "      <td>0.178936</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>0.117233</td>\n",
       "      <td>0.120476</td>\n",
       "      <td>0.153355</td>\n",
       "      <td>0.155933</td>\n",
       "      <td>0.133753</td>\n",
       "      <td>0.152347</td>\n",
       "      <td>0.147069</td>\n",
       "      <td>0.172413</td>\n",
       "      <td>0.159808</td>\n",
       "      <td>0.158878</td>\n",
       "      <td>0.165783</td>\n",
       "      <td>0.168094</td>\n",
       "      <td>0.146074</td>\n",
       "      <td>0.145701</td>\n",
       "      <td>0.149559</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>0.109085</td>\n",
       "      <td>0.112581</td>\n",
       "      <td>0.142066</td>\n",
       "      <td>0.131241</td>\n",
       "      <td>0.126860</td>\n",
       "      <td>0.104044</td>\n",
       "      <td>0.155275</td>\n",
       "      <td>0.150402</td>\n",
       "      <td>0.149451</td>\n",
       "      <td>0.117712</td>\n",
       "      <td>0.133687</td>\n",
       "      <td>0.151919</td>\n",
       "      <td>0.148954</td>\n",
       "      <td>0.121646</td>\n",
       "      <td>0.132126</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "       math  phy_science  life_science        cs     psych      econ  \\\n",
       "0  0.209028     0.202485      0.183608  0.180141  0.207547  0.197284   \n",
       "1  0.192021     0.193621      0.178919  0.190045  0.198641  0.193758   \n",
       "2  0.180226     0.192905      0.166264  0.180285  0.161874  0.183572   \n",
       "3  0.192407     0.177932      0.175787  0.162357  0.171325  0.168994   \n",
       "4  0.117233     0.120476      0.153355  0.155933  0.133753  0.152347   \n",
       "5  0.109085     0.112581      0.142066  0.131241  0.126860  0.104044   \n",
       "\n",
       "     social   history      phil  religion  medicine       law  business  \\\n",
       "0  0.176700  0.184639  0.172040  0.165305  0.199659  0.171647  0.183231   \n",
       "1  0.166415  0.177811  0.180702  0.166842  0.180499  0.172219  0.176939   \n",
       "2  0.164380  0.172878  0.164446  0.200193  0.148293  0.160764  0.168339   \n",
       "3  0.190161  0.141858  0.173553  0.191070  0.172079  0.175357  0.176464   \n",
       "4  0.147069  0.172413  0.159808  0.158878  0.165783  0.168094  0.146074   \n",
       "5  0.155275  0.150402  0.149451  0.117712  0.133687  0.151919  0.148954   \n",
       "\n",
       "        gov      misc  \n",
       "0  0.191123  0.199591  \n",
       "1  0.184364  0.184541  \n",
       "2  0.164757  0.155247  \n",
       "3  0.192409  0.178936  \n",
       "4  0.145701  0.149559  \n",
       "5  0.121646  0.132126  "
      ]
     },
     "execution_count": 323,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 294,
   "id": "ab7b9c6e",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 326,
   "id": "d45272dd",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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XFEUgTl03dP89e31MjF/orouGS6//HLVH27FihVy22239eu2g0m/ou0IgjfM4UMfOcx3u/fee+Wmm25SFbqwbt061ebk3XfflbKyMpUiRUuW6667TrUrQeB28803y5VXXqkqXwHBKXrtoX8dKmlRDPKf//mfKtUc8cADD8g3vvENdf8RJP785z+X/fv3yw9+8IMBPx4i0g6mX6kLBHBoW1I6bojaMqCjeEHxA9qWYCQORRFtHW0SCAXUFvs4Pm/CvIT3q4vAnDoERgisMM8uWSwWiyrawBaja1dddZUK4BBwRbS1tamqVQRvESjemDBhgpx//vlqZO3ss8+WZ599Nno+NzdXtUvZt2+fGs370Y9+pNqzdG5ngipYBIYIEvE9UHGLKuCeRgiJSF9MIXxE1ji88OAFC9VavaU1iChxsPoCAgZUWA5mFYJYfepG541WAV0i+9RR6p5zIkpOHMT0KxElFQI3tC1J9ooSRERGx6COiJIOAVwi2pYQEaUzfjQmIiIiMgAGdUREREQGwKCOiIiIyAAY1BEREREZAIM6IiIiIgNgUEdERERkAAzqiIiIiAyAQR0RERGRATCoIyLDu/rqq8VkMqkvm82mlr1asmSJWgYr4qc//alceOGFMnnyZJk3b554vd6E3Z8DBw7IJZdcIi6XS4qKiuT2228Xv9/f622OHTsmCxYsUEsE5eXlybXXXistLS3R81gr9rzzzpPi4mK1pNfo0aPl3nvv7bJ+7NatW2Xu3LkycuRI9bt44oknEvYYiSj5uKIEESVdKBgU767dEmxyizknVxzjxorJnNjPmBdddJG8+OKLKsjZuHGjLF68WAU2jzzyiDp/1113id1uV/8/btw42bt3r1r4Pt4CgYAK6EpKSuTjjz+WmpoaWbRokQo2H3rooR5vh4AO165Zs0Y9hmuuuUauv/56WbVqlTqP2+P7nH766Sro+/zzz+W6666TYDAY/b5tbW0q2Lv88svllltuiftjI6LUYlBHREnVtukzOb5ypXj37pGQzycmu10co8fIkAULxHX6aQn7uQ6HQwVSUF5eLhdccIEKkCJBXSSgu+++++R73/teQgI6eOedd2Tbtm3yf//3f2pUrbKyUh588EG544475Cc/+Un0fnRWVVUlb731lqxfv15mzJihjv3yl7+Uiy++WJYvXy6lpaUqWMNXxIgRI+T9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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for i in range(6):\n",
    "    x_data = list(df.iloc[i])\n",
    "    y_data = list(df3.iloc[i])\n",
    "\n",
    "    # Fit and calculate R²\n",
    "    coeffs = np.polyfit(x_data, y_data, 1)\n",
    "    poly_func = np.poly1d(coeffs)\n",
    "    r_squared = np.corrcoef(x_data, y_data)[0, 1]**2\n",
    "    plt.scatter(x_data, y_data, alpha=0.7, label=f'R² = {r_squared:.3f}')\n",
    "    \n",
    "plt.legend()\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 304,
   "id": "f5ff3d1c",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\n",
    "from sklearn.linear_model import LinearRegression\n",
    "from sklearn.metrics import r2_score"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1851360b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 327,
   "id": "c3f12f1a",
   "metadata": {},
   "outputs": [],
   "source": [
    "true_scores = []\n",
    "for col in df3.columns:\n",
    "    true_scores.append(list(df3[col]))\n",
    "estimated_scores = []\n",
    "for col in df.columns:\n",
    "    estimated_scores.append(list(df[col]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 328,
   "id": "0e464036",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "from scipy.stats import kendalltau\n",
    "from itertools import combinations\n",
    "\n",
    "def scores_to_ranking(scores):\n",
    "    \"\"\"\n",
    "    Convert scores to ranking order (highest score gets rank 0).\n",
    "    Returns the order of indices sorted by score (descending).\n",
    "    \"\"\"\n",
    "    return np.argsort(-scores)  # Negative for descending order\n",
    "\n",
    "def kendall_tau_distance(rank1, rank2):\n",
    "    \"\"\"\n",
    "    Calculate Kendall tau distance between two rankings.\n",
    "    \"\"\"\n",
    "    n = len(rank1)\n",
    "    distance = 0\n",
    "    \n",
    "    for i, j in combinations(range(n), 2):\n",
    "        # Check if pair (i,j) is ordered differently in the two rankings\n",
    "        if (rank1[i] < rank1[j]) != (rank2[i] < rank2[j]):\n",
    "            distance += 1\n",
    "    \n",
    "    return distance\n",
    "\n",
    "# Your data\n",
    "true_scores = np.array(true_scores)\n",
    "\n",
    "estimated_scores = np.array(estimated_scores)\n",
    "\n",
    "# Calculate distances for all 15 pairs\n",
    "distances = []\n",
    "for i in range(15):\n",
    "    # Convert scores to rankings (order of items from best to worst)\n",
    "    true_ranking = scores_to_ranking(true_scores[i])\n",
    "    estimated_ranking = scores_to_ranking(estimated_scores[i])\n",
    "    \n",
    "    # Calculate Kendall tau distance\n",
    "    distance = kendall_tau_distance(true_ranking, estimated_ranking)\n",
    "    distances.append(distance)\n",
    "\n",
    "distances = np.array(distances)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 329,
   "id": "1e0fea7e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAhYAAAGdCAYAAABO2DpVAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8ekN5oAAAACXBIWXMAAA9hAAAPYQGoP6dpAAATW0lEQVR4nO3dbWxVhf3A8V+BUZ1CAaeTjieNCgMGm0+L021O1IUQonuxGcMy4sySGdxgxkT7ZtoXW3kzo9sMontgL0ZwW4I6DTq2CWTZugGGBDRz4iR2imOPLfDPOgP3n3MSGAWLLfza+9DPJzmh9+a295fDbfvtOeee01SpVCoBAJBgVMYXAQAoCAsAII2wAADSCAsAII2wAADSCAsAII2wAADSCAsAIM2YGGaHDx+ON998M8aNGxdNTU3D/fQAwCkozqe5f//+aG1tjVGjRtVOWBRRMXXq1OF+WgAgQVdXV0yZMqV2wqLYUnFksPHjxw/30wMAp6Cnp6fcMHDk93jNhMWR3R9FVAgLAKgv73YYg4M3AYA0wgIASCMsAIA0wgIASCMsAIA0wgIASCMsAIA0wgIASCMsAIA0wgIAqE5Y3H///eWpPI9dZs2alTcNAFDXBn2tkDlz5sQvf/nL/32BMcN+uREAoEYNugqKkDj//POHZhoAYGQdY/HKK69Ea2trXHjhhbFkyZJ4/fXXT/r43t7e8lKrxy4AQGNqqlQqlYE+eMOGDXHgwIGYOXNm7N27N9rb2+ONN96IXbt29Xt99uK4jOJxx+vu7nbZdGhAM+59JurNnpWLqj0C1Lxiw0BLS8u7/v4eVFgc79///ndMnz49Hnjggbj99tv73WJRLMcONnXqVGEBDUpYwMgOi9M68nLChAlxySWXxO7du/t9THNzc7kAAI3vtM5jUewWefXVV2Py5Ml5EwEAIyMs7r777ti8eXPs2bMnfvvb38ZnPvOZGD16dNx6661DNyEAUDcGtSvkL3/5SxkR//jHP+Lcc8+Na665Jjo7O8uPAQAGFRbr1q0bukkAgLrnWiEAQBphAQCkERYAQBphAQCkERYAQBphAQCkERYAQBphAQCkERYAQBphAQCkERYAQBphAQCkERYAQBphAQCkERYAQBphAQCkERYAQBphAQCkERYAQBphAQCkERYAQBphAQCkERYAQBphAQCkERYAQBphAQCkERYAQBphAQCkERYAQBphAQCkERYAQBphAQCkERYAQBphAQCkERYAQBphAQCkERYAQBphAQCkERYAQBphAQCkERYAQBphAQCkERYAQBphAQCkERYAQBphAQCkERYAQBphAQCkERYAQBphAQCkERYAQBphAQCkERYAQBphAQCkERYAQBphAQCkERYAQBphAQCkERYAQBphAQDURlisXLkympqaYsWKFXkTAQAjLyy2bt0aq1evjnnz5uVOBACMrLA4cOBALFmyJB577LGYOHFi/lQAwMgJi2XLlsWiRYvi+uuvf9fH9vb2Rk9PT58FAGhMYwb7CevWrYsXXnih3BUyEB0dHdHe3n4qswEAjbzFoqurK5YvXx4//vGP44wzzhjQ57S1tUV3d/fRpfgaAEBjGtQWi+3bt8e+ffvi0ksvPXrfoUOHYsuWLfHd73633O0xevToPp/T3NxcLgBA4xtUWCxYsCB27tzZ577bbrstZs2aFffcc88JUQEAjCyDCotx48bF3Llz+9x31llnxTnnnHPC/QDAyOPMmwBA9d4VcrxNmzblTAIA1D1bLACANMICAEgjLACANMICAEgjLACANMICAEgjLACANMICAEgjLACANMICAEgjLACANMICAEgjLACANMICAEgjLACANMICAEgjLACANMICAEgjLACANMICAEgjLACANMICAEgjLACANMICAEgjLACANMICAEgjLACANMICAEgjLACANMICAEgjLACANMICAEgjLACANMICAEgjLACANMICAEgjLACANMICAEgjLACANMICAEgjLACANMICAEgjLACANMICAEgjLACANMICAEgjLACANMICAEgjLACANMICAEgjLACANMICAEgjLACANMICAEgjLACANMICAEgjLACANMICAEgjLACA6oTFqlWrYt68eTF+/Phyueqqq2LDhg150wAAIycspkyZEitXrozt27fHtm3b4rrrroubbropXnzxxaGbEACoG2MG8+DFixf3uf2Nb3yj3IrR2dkZc+bMyZ4NAGjksDjWoUOH4qc//WkcPHiw3CXSn97e3nI5oqen51SfEgBotLDYuXNnGRL/+c9/4uyzz47169fH7Nmz+318R0dHtLe3x3CYce8zUW/2rFxU7REAoHrvCpk5c2bs2LEjfv/738cdd9wRS5cujZdeeqnfx7e1tUV3d/fR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6dOnx09+8pO4/fbbqzpbLf4BdPnll8c3v/nN8naxxaL4ufXII4+U34/Dqe63WJzKpdxhoO688854+umn4/nnny8PUqT/Kx9fdNFF5dWPi7/Ei4OEH3rooWqPVXOK3bbFQeWXXnppjBkzplyKAPv2t79dflxsfaV/EyZMiEsuuSR2795d7VFqzuTJk08I+Q9+8INV2XVU92HhUu4MheL41iIqik36v/71r+OCCy6o9kh1pfge7O3trfYYNWfBggXlbqNi686Rpfgrszh2oPi4+COJ/h04cCBeffXV8pcofRW7ao9/S/yf/vSncgvPcGuIXSEu5T7wb8pjS7/YX1n8MCsOSJw2bVpVZ6vF3R9r166NJ598sjyXxZHjdVpaWsr3h/M/bW1t5Sbr4jVU7Psu1tumTZvK/bz0VbyWjj9O56yzzirPO+D4nRPdfffd5bl3il+Ob775ZnlKgSK+br311mqPVnO+9rWvxcc+9rFyV8jnPve58lxOjz76aLkMu0qD+M53vlOZNm1aZezYseXbTzs7O6s9Us15/vnny7dMHr8sXbq02qPVnHdaT8Xywx/+sNqj1ZwvfvGLlenTp5ffe+eee25lwYIFlV/84hfVHqtueLtp/2655ZbK5MmTy9fWBz7wgfL27t27qz1Wzfr5z39emTt3bqW5ubkya9asyqOPPlqVOVw2HQBIU/fHWAAAtUNYAABphAUAkEZYAABphAUAkEZYAABphAUAkEZYAABphAUAkEZYAABphAUAkEZYAACR5f8BgyqAZfrRP7oAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist(distances)\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "tf-metal",
   "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.9.23"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
