{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import json\n",
    "\n",
    "import pandas as pd"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "df = pd.DataFrame(columns=[\"Domain\", \"Attribute\", \"Accuracy\", \"Score Type\", \"Method\", \"Inference Mode\"])\n",
    "root_path = \"./results/full_ravel_results\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "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>Domain</th>\n",
       "      <th>Attribute</th>\n",
       "      <th>Accuracy</th>\n",
       "      <th>Score Type</th>\n",
       "      <th>Method</th>\n",
       "      <th>Inference Mode</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>Physical Object</td>\n",
       "      <td>Category</td>\n",
       "      <td>0.816968</td>\n",
       "      <td>Causal</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>Physical Object</td>\n",
       "      <td>Category</td>\n",
       "      <td>0.963964</td>\n",
       "      <td>Isolate</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>Physical Object</td>\n",
       "      <td>Category</td>\n",
       "      <td>0.890466</td>\n",
       "      <td>Disentangle</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>City</td>\n",
       "      <td>Latitude</td>\n",
       "      <td>0.148048</td>\n",
       "      <td>Causal</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>City</td>\n",
       "      <td>Latitude</td>\n",
       "      <td>0.794996</td>\n",
       "      <td>Isolate</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>City</td>\n",
       "      <td>Latitude</td>\n",
       "      <td>0.471522</td>\n",
       "      <td>Disentangle</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>Physical Object</td>\n",
       "      <td>Size</td>\n",
       "      <td>0.847430</td>\n",
       "      <td>Causal</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>Physical Object</td>\n",
       "      <td>Size</td>\n",
       "      <td>0.992464</td>\n",
       "      <td>Isolate</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>Physical Object</td>\n",
       "      <td>Size</td>\n",
       "      <td>0.919947</td>\n",
       "      <td>Disentangle</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>Nobel Prize Winner</td>\n",
       "      <td>Gender</td>\n",
       "      <td>0.895833</td>\n",
       "      <td>Causal</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>Nobel Prize Winner</td>\n",
       "      <td>Gender</td>\n",
       "      <td>0.988208</td>\n",
       "      <td>Isolate</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>Nobel Prize Winner</td>\n",
       "      <td>Gender</td>\n",
       "      <td>0.942020</td>\n",
       "      <td>Disentangle</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>Verb</td>\n",
       "      <td>Singular</td>\n",
       "      <td>0.768641</td>\n",
       "      <td>Causal</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>Verb</td>\n",
       "      <td>Singular</td>\n",
       "      <td>0.811361</td>\n",
       "      <td>Isolate</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>Verb</td>\n",
       "      <td>Singular</td>\n",
       "      <td>0.790001</td>\n",
       "      <td>Disentangle</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>City</td>\n",
       "      <td>Language</td>\n",
       "      <td>0.799521</td>\n",
       "      <td>Causal</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>City</td>\n",
       "      <td>Language</td>\n",
       "      <td>0.767642</td>\n",
       "      <td>Isolate</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>City</td>\n",
       "      <td>Language</td>\n",
       "      <td>0.783581</td>\n",
       "      <td>Disentangle</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>18</th>\n",
       "      <td>Nobel Prize Winner</td>\n",
       "      <td>Award Year</td>\n",
       "      <td>0.155987</td>\n",
       "      <td>Causal</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>19</th>\n",
       "      <td>Nobel Prize Winner</td>\n",
       "      <td>Award Year</td>\n",
       "      <td>0.893092</td>\n",
       "      <td>Isolate</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>20</th>\n",
       "      <td>Nobel Prize Winner</td>\n",
       "      <td>Award Year</td>\n",
       "      <td>0.524540</td>\n",
       "      <td>Disentangle</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>21</th>\n",
       "      <td>Occupation</td>\n",
       "      <td>Industry</td>\n",
       "      <td>0.665298</td>\n",
       "      <td>Causal</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22</th>\n",
       "      <td>Occupation</td>\n",
       "      <td>Industry</td>\n",
       "      <td>0.880492</td>\n",
       "      <td>Isolate</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>23</th>\n",
       "      <td>Occupation</td>\n",
       "      <td>Industry</td>\n",
       "      <td>0.772895</td>\n",
       "      <td>Disentangle</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>24</th>\n",
       "      <td>Nobel Prize Winner</td>\n",
       "      <td>Country Of Birth</td>\n",
       "      <td>0.853982</td>\n",
       "      <td>Causal</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>25</th>\n",
       "      <td>Nobel Prize Winner</td>\n",
       "      <td>Country Of Birth</td>\n",
       "      <td>0.954714</td>\n",
       "      <td>Isolate</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>26</th>\n",
       "      <td>Nobel Prize Winner</td>\n",
       "      <td>Country Of Birth</td>\n",
       "      <td>0.904348</td>\n",
       "      <td>Disentangle</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>27</th>\n",
       "      <td>City</td>\n",
       "      <td>Country</td>\n",
       "      <td>0.808290</td>\n",
       "      <td>Causal</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>28</th>\n",
       "      <td>City</td>\n",
       "      <td>Country</td>\n",
       "      <td>0.665121</td>\n",
       "      <td>Isolate</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>29</th>\n",
       "      <td>City</td>\n",
       "      <td>Country</td>\n",
       "      <td>0.736705</td>\n",
       "      <td>Disentangle</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>30</th>\n",
       "      <td>City</td>\n",
       "      <td>Longitude</td>\n",
       "      <td>0.146667</td>\n",
       "      <td>Causal</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>31</th>\n",
       "      <td>City</td>\n",
       "      <td>Longitude</td>\n",
       "      <td>0.807074</td>\n",
       "      <td>Isolate</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>32</th>\n",
       "      <td>City</td>\n",
       "      <td>Longitude</td>\n",
       "      <td>0.476870</td>\n",
       "      <td>Disentangle</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>33</th>\n",
       "      <td>Physical Object</td>\n",
       "      <td>Color</td>\n",
       "      <td>0.880105</td>\n",
       "      <td>Causal</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>34</th>\n",
       "      <td>Physical Object</td>\n",
       "      <td>Color</td>\n",
       "      <td>0.979508</td>\n",
       "      <td>Isolate</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>35</th>\n",
       "      <td>Physical Object</td>\n",
       "      <td>Color</td>\n",
       "      <td>0.929807</td>\n",
       "      <td>Disentangle</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>36</th>\n",
       "      <td>Occupation</td>\n",
       "      <td>Work Location</td>\n",
       "      <td>0.633978</td>\n",
       "      <td>Causal</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>37</th>\n",
       "      <td>Occupation</td>\n",
       "      <td>Work Location</td>\n",
       "      <td>0.845070</td>\n",
       "      <td>Isolate</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>38</th>\n",
       "      <td>Occupation</td>\n",
       "      <td>Work Location</td>\n",
       "      <td>0.739524</td>\n",
       "      <td>Disentangle</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>39</th>\n",
       "      <td>Physical Object</td>\n",
       "      <td>Texture</td>\n",
       "      <td>0.853755</td>\n",
       "      <td>Causal</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>40</th>\n",
       "      <td>Physical Object</td>\n",
       "      <td>Texture</td>\n",
       "      <td>0.979148</td>\n",
       "      <td>Isolate</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>41</th>\n",
       "      <td>Physical Object</td>\n",
       "      <td>Texture</td>\n",
       "      <td>0.916451</td>\n",
       "      <td>Disentangle</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>42</th>\n",
       "      <td>Verb</td>\n",
       "      <td>Past Tense</td>\n",
       "      <td>0.717532</td>\n",
       "      <td>Causal</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>43</th>\n",
       "      <td>Verb</td>\n",
       "      <td>Past Tense</td>\n",
       "      <td>0.780602</td>\n",
       "      <td>Isolate</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>44</th>\n",
       "      <td>Verb</td>\n",
       "      <td>Past Tense</td>\n",
       "      <td>0.749067</td>\n",
       "      <td>Disentangle</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>45</th>\n",
       "      <td>Occupation</td>\n",
       "      <td>Duty</td>\n",
       "      <td>0.221024</td>\n",
       "      <td>Causal</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>46</th>\n",
       "      <td>Occupation</td>\n",
       "      <td>Duty</td>\n",
       "      <td>0.917742</td>\n",
       "      <td>Isolate</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>47</th>\n",
       "      <td>Occupation</td>\n",
       "      <td>Duty</td>\n",
       "      <td>0.569383</td>\n",
       "      <td>Disentangle</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>48</th>\n",
       "      <td>Nobel Prize Winner</td>\n",
       "      <td>Field</td>\n",
       "      <td>0.818999</td>\n",
       "      <td>Causal</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>49</th>\n",
       "      <td>Nobel Prize Winner</td>\n",
       "      <td>Field</td>\n",
       "      <td>0.931783</td>\n",
       "      <td>Isolate</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>50</th>\n",
       "      <td>Nobel Prize Winner</td>\n",
       "      <td>Field</td>\n",
       "      <td>0.875391</td>\n",
       "      <td>Disentangle</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>51</th>\n",
       "      <td>City</td>\n",
       "      <td>Timezone</td>\n",
       "      <td>0.625000</td>\n",
       "      <td>Causal</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>52</th>\n",
       "      <td>City</td>\n",
       "      <td>Timezone</td>\n",
       "      <td>0.791312</td>\n",
       "      <td>Isolate</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>53</th>\n",
       "      <td>City</td>\n",
       "      <td>Timezone</td>\n",
       "      <td>0.708156</td>\n",
       "      <td>Disentangle</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>54</th>\n",
       "      <td>Nobel Prize Winner</td>\n",
       "      <td>Birth Year</td>\n",
       "      <td>0.077174</td>\n",
       "      <td>Causal</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>55</th>\n",
       "      <td>Nobel Prize Winner</td>\n",
       "      <td>Birth Year</td>\n",
       "      <td>0.906667</td>\n",
       "      <td>Isolate</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>56</th>\n",
       "      <td>Nobel Prize Winner</td>\n",
       "      <td>Birth Year</td>\n",
       "      <td>0.491920</td>\n",
       "      <td>Disentangle</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>57</th>\n",
       "      <td>City</td>\n",
       "      <td>Continent</td>\n",
       "      <td>0.849819</td>\n",
       "      <td>Causal</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>58</th>\n",
       "      <td>City</td>\n",
       "      <td>Continent</td>\n",
       "      <td>0.849075</td>\n",
       "      <td>Isolate</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>59</th>\n",
       "      <td>City</td>\n",
       "      <td>Continent</td>\n",
       "      <td>0.849447</td>\n",
       "      <td>Disentangle</td>\n",
       "      <td>MDAS</td>\n",
       "      <td>N/A</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                Domain         Attribute  Accuracy   Score Type Method  \\\n",
       "0      Physical Object          Category  0.816968       Causal   MDAS   \n",
       "1      Physical Object          Category  0.963964      Isolate   MDAS   \n",
       "2      Physical Object          Category  0.890466  Disentangle   MDAS   \n",
       "3                 City          Latitude  0.148048       Causal   MDAS   \n",
       "4                 City          Latitude  0.794996      Isolate   MDAS   \n",
       "5                 City          Latitude  0.471522  Disentangle   MDAS   \n",
       "6      Physical Object              Size  0.847430       Causal   MDAS   \n",
       "7      Physical Object              Size  0.992464      Isolate   MDAS   \n",
       "8      Physical Object              Size  0.919947  Disentangle   MDAS   \n",
       "9   Nobel Prize Winner            Gender  0.895833       Causal   MDAS   \n",
       "10  Nobel Prize Winner            Gender  0.988208      Isolate   MDAS   \n",
       "11  Nobel Prize Winner            Gender  0.942020  Disentangle   MDAS   \n",
       "12                Verb          Singular  0.768641       Causal   MDAS   \n",
       "13                Verb          Singular  0.811361      Isolate   MDAS   \n",
       "14                Verb          Singular  0.790001  Disentangle   MDAS   \n",
       "15                City          Language  0.799521       Causal   MDAS   \n",
       "16                City          Language  0.767642      Isolate   MDAS   \n",
       "17                City          Language  0.783581  Disentangle   MDAS   \n",
       "18  Nobel Prize Winner        Award Year  0.155987       Causal   MDAS   \n",
       "19  Nobel Prize Winner        Award Year  0.893092      Isolate   MDAS   \n",
       "20  Nobel Prize Winner        Award Year  0.524540  Disentangle   MDAS   \n",
       "21          Occupation          Industry  0.665298       Causal   MDAS   \n",
       "22          Occupation          Industry  0.880492      Isolate   MDAS   \n",
       "23          Occupation          Industry  0.772895  Disentangle   MDAS   \n",
       "24  Nobel Prize Winner  Country Of Birth  0.853982       Causal   MDAS   \n",
       "25  Nobel Prize Winner  Country Of Birth  0.954714      Isolate   MDAS   \n",
       "26  Nobel Prize Winner  Country Of Birth  0.904348  Disentangle   MDAS   \n",
       "27                City           Country  0.808290       Causal   MDAS   \n",
       "28                City           Country  0.665121      Isolate   MDAS   \n",
       "29                City           Country  0.736705  Disentangle   MDAS   \n",
       "30                City         Longitude  0.146667       Causal   MDAS   \n",
       "31                City         Longitude  0.807074      Isolate   MDAS   \n",
       "32                City         Longitude  0.476870  Disentangle   MDAS   \n",
       "33     Physical Object             Color  0.880105       Causal   MDAS   \n",
       "34     Physical Object             Color  0.979508      Isolate   MDAS   \n",
       "35     Physical Object             Color  0.929807  Disentangle   MDAS   \n",
       "36          Occupation     Work Location  0.633978       Causal   MDAS   \n",
       "37          Occupation     Work Location  0.845070      Isolate   MDAS   \n",
       "38          Occupation     Work Location  0.739524  Disentangle   MDAS   \n",
       "39     Physical Object           Texture  0.853755       Causal   MDAS   \n",
       "40     Physical Object           Texture  0.979148      Isolate   MDAS   \n",
       "41     Physical Object           Texture  0.916451  Disentangle   MDAS   \n",
       "42                Verb        Past Tense  0.717532       Causal   MDAS   \n",
       "43                Verb        Past Tense  0.780602      Isolate   MDAS   \n",
       "44                Verb        Past Tense  0.749067  Disentangle   MDAS   \n",
       "45          Occupation              Duty  0.221024       Causal   MDAS   \n",
       "46          Occupation              Duty  0.917742      Isolate   MDAS   \n",
       "47          Occupation              Duty  0.569383  Disentangle   MDAS   \n",
       "48  Nobel Prize Winner             Field  0.818999       Causal   MDAS   \n",
       "49  Nobel Prize Winner             Field  0.931783      Isolate   MDAS   \n",
       "50  Nobel Prize Winner             Field  0.875391  Disentangle   MDAS   \n",
       "51                City          Timezone  0.625000       Causal   MDAS   \n",
       "52                City          Timezone  0.791312      Isolate   MDAS   \n",
       "53                City          Timezone  0.708156  Disentangle   MDAS   \n",
       "54  Nobel Prize Winner        Birth Year  0.077174       Causal   MDAS   \n",
       "55  Nobel Prize Winner        Birth Year  0.906667      Isolate   MDAS   \n",
       "56  Nobel Prize Winner        Birth Year  0.491920  Disentangle   MDAS   \n",
       "57                City         Continent  0.849819       Causal   MDAS   \n",
       "58                City         Continent  0.849075      Isolate   MDAS   \n",
       "59                City         Continent  0.849447  Disentangle   MDAS   \n",
       "\n",
       "   Inference Mode  \n",
       "0             N/A  \n",
       "1             N/A  \n",
       "2             N/A  \n",
       "3             N/A  \n",
       "4             N/A  \n",
       "5             N/A  \n",
       "6             N/A  \n",
       "7             N/A  \n",
       "8             N/A  \n",
       "9             N/A  \n",
       "10            N/A  \n",
       "11            N/A  \n",
       "12            N/A  \n",
       "13            N/A  \n",
       "14            N/A  \n",
       "15            N/A  \n",
       "16            N/A  \n",
       "17            N/A  \n",
       "18            N/A  \n",
       "19            N/A  \n",
       "20            N/A  \n",
       "21            N/A  \n",
       "22            N/A  \n",
       "23            N/A  \n",
       "24            N/A  \n",
       "25            N/A  \n",
       "26            N/A  \n",
       "27            N/A  \n",
       "28            N/A  \n",
       "29            N/A  \n",
       "30            N/A  \n",
       "31            N/A  \n",
       "32            N/A  \n",
       "33            N/A  \n",
       "34            N/A  \n",
       "35            N/A  \n",
       "36            N/A  \n",
       "37            N/A  \n",
       "38            N/A  \n",
       "39            N/A  \n",
       "40            N/A  \n",
       "41            N/A  \n",
       "42            N/A  \n",
       "43            N/A  \n",
       "44            N/A  \n",
       "45            N/A  \n",
       "46            N/A  \n",
       "47            N/A  \n",
       "48            N/A  \n",
       "49            N/A  \n",
       "50            N/A  \n",
       "51            N/A  \n",
       "52            N/A  \n",
       "53            N/A  \n",
       "54            N/A  \n",
       "55            N/A  \n",
       "56            N/A  \n",
       "57            N/A  \n",
       "58            N/A  \n",
       "59            N/A  "
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# MDAS results\n",
    "\n",
    "for file in os.listdir(root_path):\n",
    "    if file.startswith(\"mdas\") and file.endswith(\".json\"):\n",
    "        with open(os.path.join(root_path, file), \"r\") as f:\n",
    "            results = json.load(f)\n",
    "            \n",
    "            strings = file.replace(\".json\", \"\").split(\"_\")\n",
    "            if \"physical_object\" in file:\n",
    "                domain = \"Physical Object\"\n",
    "                attribute = \" \".join(strings[3:]).title()\n",
    "            elif \"nobel_prize_winner\" in file:\n",
    "                domain = \"Nobel Prize Winner\"\n",
    "                attribute = \" \".join(strings[4:]).title()\n",
    "            else:\n",
    "                domain = strings[1].title()\n",
    "                attribute = \" \".join(strings[2:]).title()\n",
    "            \n",
    "            df.loc[len(df)] = [domain, attribute, results[\"causal\"], \"Causal\", \"MDAS\", \"N/A\"]\n",
    "            df.loc[len(df)] = [domain, attribute, results[\"isolate\"], \"Isolate\", \"MDAS\", \"N/A\"]\n",
    "            df.loc[len(df)] = [domain, attribute, results[\"disentangle\"], \"Disentangle\", \"MDAS\", \"N/A\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "# HyperDAS results\n",
    "for file in os.listdir(root_path):\n",
    "    if file.startswith(\"reflect_hyperdas\") and file.endswith(\".json\"):\n",
    "        with open(os.path.join(root_path, file), \"r\") as f:\n",
    "            results = json.load(f)\n",
    "            \n",
    "            strings = file.replace(\".json\", \"\").split(\"_\")\n",
    "            if \"physical_object\" in file:\n",
    "                domain = \"Physical Object\"\n",
    "                attribute = \" \".join(strings[4:]).title()\n",
    "            elif \"nobel_prize_winner\" in file:\n",
    "                domain = \"Nobel Prize Winner\"\n",
    "                attribute = \" \".join(strings[5:]).title()\n",
    "            else:\n",
    "                domain = strings[2].title()\n",
    "                attribute = \" \".join(strings[3:]).title()\n",
    "            \n",
    "            df.loc[len(df)] = [domain, attribute, results[\"column_argmax\"][\"accs\"][\"causal\"], \"Causal\", \"HyperDAS\", \"One-to-Many\"]\n",
    "            df.loc[len(df)] = [domain, attribute, results[\"column_argmax\"][\"accs\"][\"isolate\"], \"Isolate\", \"HyperDAS\", \"One-to-Many\"]\n",
    "            df.loc[len(df)] = [domain, attribute, results[\"column_argmax\"][\"accs\"][\"disentangle\"], \"Disentangle\", \"HyperDAS\", \"One-to-Many\"]\n",
    "            \n",
    "            df.loc[len(df)] = [domain, attribute, results[\"bidding_argmax\"][\"accs\"][\"causal\"], \"Causal\", \"HyperDAS\", \"One-to-One\"]\n",
    "            df.loc[len(df)] = [domain, attribute, results[\"bidding_argmax\"][\"accs\"][\"isolate\"], \"Isolate\", \"HyperDAS\", \"One-to-One\"]\n",
    "            df.loc[len(df)] = [domain, attribute, results[\"bidding_argmax\"][\"accs\"][\"disentangle\"], \"Disentangle\", \"HyperDAS\", \"One-to-One\"]\n",
    "            \n",
    "            df.loc[len(df)] = [domain, attribute, results[\"default\"][\"accs\"][\"causal\"], \"Causal\", \"HyperDAS\", \"Soft Intervention\"]\n",
    "            df.loc[len(df)] = [domain, attribute, results[\"default\"][\"accs\"][\"isolate\"], \"Isolate\", \"HyperDAS\", \"Soft Intervention\"]\n",
    "            df.loc[len(df)] = [domain, attribute, results[\"default\"][\"accs\"][\"disentangle\"], \"Disentangle\", \"HyperDAS\", \"Soft Intervention\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Nobel Prize Winner:\n",
      "Average Causal Score: 55.4\n",
      "Average Isolate Score: 95.1\n",
      "\n",
      "Occupation:\n",
      "Average Causal Score: 95.1\n",
      "Average Isolate Score: 94.9\n",
      "\n",
      "City:\n",
      "Average Causal Score: 71.1\n",
      "Average Isolate Score: 89.9\n",
      "\n",
      "Physical Object:\n",
      "Average Causal Score: 92.7\n",
      "Average Isolate Score: 97.2\n",
      "\n",
      "Verb:\n",
      "Average Causal Score: 93.0\n",
      "Average Isolate Score: 98.9\n",
      "\n",
      "Average Causal Score: 81.5\n",
      "Average Isolate Score: 95.2\n",
      "Average Disentangle Score: 88.35\n"
     ]
    }
   ],
   "source": [
    "def get_method_full_ravel_results(df, method, setting):\n",
    "    new_df = df[(df[\"Method\"] == method) & (df[\"Inference Mode\"] == setting)]\n",
    "    \n",
    "    all_domains_causal_score = []\n",
    "    all_domains_isolate_score = []\n",
    "    \n",
    "    for domain in new_df[\"Domain\"].unique():\n",
    "        domain_df = new_df[new_df[\"Domain\"] == domain]\n",
    "        \n",
    "        domain_average_causal_score = domain_df[domain_df[\"Score Type\"] == \"Causal\"][\"Accuracy\"].mean()\n",
    "        domain_average_causal_score = round(domain_average_causal_score * 100, 1)\n",
    "        domain_average_isolate_score = domain_df[domain_df[\"Score Type\"] == \"Isolate\"][\"Accuracy\"].mean()\n",
    "        domain_average_isolate_score = round(domain_average_isolate_score * 100, 1)\n",
    "        print(f\"{domain}:\")\n",
    "        print(f\"Average Causal Score: {domain_average_causal_score}\")\n",
    "        print(f\"Average Isolate Score: {domain_average_isolate_score}\")\n",
    "        print()\n",
    "        all_domains_causal_score.append(domain_average_causal_score)\n",
    "        all_domains_isolate_score.append(domain_average_isolate_score)\n",
    "    \n",
    "    all_causal = round(sum(all_domains_causal_score) / len(all_domains_causal_score), 1)\n",
    "    all_isolate = round(sum(all_domains_isolate_score) / len(all_domains_isolate_score), 1)\n",
    "    all_dientangle = 0.5 * (all_causal + all_isolate)\n",
    "    print(f\"Average Causal Score: {all_causal}\")\n",
    "    print(f\"Average Isolate Score: {all_isolate}\")\n",
    "    print(f\"Average Disentangle Score: {all_dientangle}\")\n",
    "        \n",
    "\n",
    "get_method_full_ravel_results(df, \"HyperDAS\", \"Soft Intervention\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "hypernet",
   "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.10.14"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
