{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "a84f4b0e",
   "metadata": {},
   "source": [
    "Example analysis code to retrieve the results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "9c13675b-2df7-481a-bf13-9483589dddac",
   "metadata": {},
   "outputs": [],
   "source": [
    "import scipy.stats\n",
    "import sklearn.metrics\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import jsonlines\n",
    "import json\n",
    "import math\n",
    "import rbo\n",
    "\n",
    "from context_attribution import tree"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "4cabf1ab-4a57-4a3d-aee8-bfb21dc29668",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Load results\n",
    "def load_results(path):\n",
    "    with jsonlines.open(path, \"r\") as f:\n",
    "        return list(f)\n",
    "\n",
    "def get_attribution_trees(results):\n",
    "    trees = []\n",
    "    for example_dict in results:\n",
    "        attribution_tree = tree.Tree.from_dict(example_dict[\"attributions\"])\n",
    "        trees.append(attribution_tree)\n",
    "    return trees"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "f092f64e-e405-422a-aca4-9c450819ea0a",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Implementation of ESD test statistic\n",
    "def grubbs_stat(y):\n",
    "    std_dev = np.std(y)\n",
    "    avg_y = np.mean(y)\n",
    "    abs_val_minus_avg = y - avg_y\n",
    "    max_of_deviations = max(abs_val_minus_avg)\n",
    "    max_ind = np.argmax(abs_val_minus_avg)\n",
    "    Gcal = max_of_deviations/ std_dev\n",
    "    return Gcal, max_ind\n",
    "\n",
    "def calculate_critical_value(size, alpha):\n",
    "    t_dist = scipy.stats.t.ppf(1 - alpha / (2 * size), size - 2)\n",
    "    numerator = (size - 1) * np.sqrt(np.square(t_dist))\n",
    "    denominator = np.sqrt(size) * np.sqrt(size - 2 + np.square(t_dist))\n",
    "    critical_value = numerator / denominator\n",
    "    return critical_value\n",
    "\n",
    "def esd_test(input_series, alpha, max_outliers):\n",
    "    outliers = []\n",
    "    for iterations in range(max_outliers):\n",
    "        Gcritical = calculate_critical_value(len(input_series), alpha)\n",
    "        Gstat, max_index = grubbs_stat(input_series)\n",
    "        if Gstat > Gcritical:\n",
    "            outliers.append(input_series[max_index])\n",
    "            input_series = np.delete(input_series, max_index)\n",
    "        else:\n",
    "            break\n",
    "    return outliers"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "127a1282-4fa5-4616-bac6-05333a728fb0",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Implementation RBO/Top-k Intersect\n",
    "def compute_rbo(reference_trees, test_trees, k=-1):\n",
    "    rbos = []\n",
    "    for reference_tree, test_tree in zip(reference_trees, test_trees):\n",
    "        source_indexes = {n.data.get(\"text\") + str(i): i for i, n in enumerate(tree.get_nodes_at_depth(reference_tree, 2))}\n",
    "        reference_scores = [(n.data.get(\"text\") + str(i), n.data.get(\"attribution_score\")) for i, n in enumerate(tree.get_nodes_at_depth(reference_tree, 2)) if n.data.get(\"attribution_score\") is not None]\n",
    "        test_scores = [(n.data.get(\"text\") + str(i), n.data.get(\"attribution_score\")) for i, n in enumerate(tree.get_nodes_at_depth(test_tree, 2)) if n.data.get(\"attribution_score\") is not None]\n",
    "        reference_sorted = [text for text, score in reversed(sorted(reference_scores, key=lambda e: e[1]))]\n",
    "        test_sorted = [text for text, score in reversed(sorted(test_scores, key=lambda e: e[1]))]\n",
    "        if k == \"adaptive\":\n",
    "            k_eff = max(len(esd_test([r[1] for r in reference_scores], 0.05, 50)), 1)\n",
    "        else:\n",
    "            k_eff = k\n",
    "        if k_eff > 0:\n",
    "            reference_sorted = reference_sorted[:k_eff]\n",
    "            test_sorted = test_sorted[:k_eff]\n",
    "\n",
    "        rbos.append(rbo.RankingSimilarity(reference_sorted, test_sorted).rbo())\n",
    "    return rbos\n",
    "\n",
    "def compute_topk_intersect(reference_trees, test_trees, k=5):\n",
    "    tkis = []\n",
    "    for reference_tree, test_tree in zip(reference_trees, test_trees):\n",
    "        source_indexes = {n.data.get(\"text\"): i for i, n in enumerate(tree.get_nodes_at_depth(reference_tree, 2))}\n",
    "        reference_scores = [(n.data.get(\"text\"), n.data.get(\"attribution_score\")) for n in tree.get_nodes_at_depth(reference_tree, 2) if n.data.get(\"attribution_score\") is not None]\n",
    "        test_scores = [(n.data.get(\"text\"), n.data.get(\"attribution_score\")) for n in tree.get_nodes_at_depth(test_tree, 2) if n.data.get(\"attribution_score\") is not None]\n",
    "        reference_sorted = [text for text, score in reversed(sorted(reference_scores, key=lambda e: e[1]))]\n",
    "        test_sorted = [text for text, score in reversed(sorted(test_scores, key=lambda e: e[1]))]\n",
    "        if k == \"adaptive\":\n",
    "            k_eff = max(len(esd_test([r[1] for r in reference_scores], 0.05, 50)), 1)\n",
    "        else:\n",
    "            k_eff = k\n",
    "        tki = len(set(reference_sorted[:k_eff]).intersection(test_sorted[:k_eff])) / k_eff\n",
    "        tkis.append(tki)\n",
    "    return tkis"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "d59c8ccf",
   "metadata": {},
   "outputs": [],
   "source": [
    "def visualize(path, i):\n",
    "    res = []\n",
    "    with open(path, 'r') as gnd_f:\n",
    "        for line in gnd_f:\n",
    "            res.append(json.loads(line))\n",
    "    example = res[i]\n",
    "    texts = []\n",
    "    attributions = []\n",
    "    for child in example['attributions']['children']: \n",
    "        for grandchild in child['children']:\n",
    "            try: attributions.append(grandchild['data']['attribution_score'])\n",
    "            except: continue\n",
    "            texts.append(grandchild['data']['text'])\n",
    "    df = pd.DataFrame(list(zip(texts, attributions)),\n",
    "                columns =['Sentence', 'Attribution Score'])\n",
    "    df = df.sort_values('Attribution Score', ascending=False)\n",
    "    return df"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "d72ff585-1ea9-41d0-b080-f20fa92ca426",
   "metadata": {},
   "source": [
    "# HotPot QA"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "f2761245-f800-4371-954c-94fd2e1d26bd",
   "metadata": {},
   "outputs": [],
   "source": [
    "reference_results = load_results(\"../data/attributions/HotpotQA/l70_nokv/attributions.jsonl\")\n",
    "\n",
    "kv_results = load_results(\"../data/attributions/HotpotQA/l70_kv/attributions.jsonl\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "5ef39f9d-8781-4bc4-8157-e30970363316",
   "metadata": {},
   "outputs": [],
   "source": [
    "reference_trees = get_attribution_trees(reference_results)\n",
    "\n",
    "kv_trees = get_attribution_trees(kv_results)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "466a1677-b7c0-4708-84bb-ec286a13a31c",
   "metadata": {},
   "outputs": [],
   "source": [
    "reference_times = [r[\"time\"] for r in reference_results]\n",
    "\n",
    "kv_times = [r[\"time\"] for r in kv_results]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "afa0805a-13f7-4011-b9e0-44586f61b95a",
   "metadata": {},
   "outputs": [],
   "source": [
    "plot_data_adaptive = [\n",
    "    {\n",
    "        \"time\": np.mean(reference_times),\n",
    "        \"top_k_intersect\": np.mean(compute_topk_intersect(reference_trees, reference_trees, k=\"adaptive\")),\n",
    "        \"top_k_rbo\": np.mean(compute_rbo(reference_trees, reference_trees, k=\"adaptive\")),\n",
    "        \"rbo\": np.mean(compute_rbo(reference_trees, reference_trees, k=-1)),\n",
    "        \"label\": \"l70\"\n",
    "    },\n",
    "    {\n",
    "        \"time\": np.mean(kv_times),\n",
    "        \"top_k_intersect\": np.mean(compute_topk_intersect(reference_trees, kv_trees, k=\"adaptive\")),\n",
    "        \"top_k_rbo\": np.mean(compute_rbo(reference_trees, kv_trees, k=\"adaptive\")),\n",
    "        \"rbo\": np.mean(compute_rbo(reference_trees, kv_trees, k=-1)),\n",
    "        \"label\": \"l70_kv\"\n",
    "    },\n",
    "]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "72191c5f-05d4-4dfe-9a6a-0f69e9209a66",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.legend.Legend at 0x7f9af8e44ca0>"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABrAAAAHYCAYAAAAF0qieAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8hTgPZAAAACXBIWXMAAA9hAAAPYQGoP6dpAAB7DElEQVR4nOzdd3gU1f7H8c8mkAIhCYFASAgtIqFoQJqASjcUkaYiwqWIclFAEZVy6baIKIKA5VroKBbEThVQlAtIUZEiIgIGCEVJKBJC9vz+4JeFJW03pEw279fzzCN79szMOWcnM1/3u3PGZowxAgAAAAAAAAAAACzCq6AbAAAAAAAAAAAAAFyJBBYAAAAAAAAAAAAshQQWAAAAAAAAAAAALIUEFgAAAAAAAAAAACyFBBYAAAAAAAAAAAAshQQWAAAAAAAAAAAALIUEFgAAAAAAAAAAACyFBBYAAAAAAAAAAAAshQQWAAAAAAAAAAAALIUEFgDLefjhh9W2bdtc3eaZM2f0wAMPKCwsTDabTcOGDcvV7SP/7Ny5U8WKFdOOHTsKuikAgCLqhRdeUHR0tOx2e65t8+LFixoxYoQiIyPl5eWlLl265Nq2kb9OnjypkiVL6ssvvyzopgAAkG/Wrl0rm82mtWvXOsr69eunKlWqFFibABR+JLBgCTabzaXlyotgXpk4caJsNptOnDjhVH7o0CFFRUUpJCREW7duzXT9OXPmyGaz6YcffnB73+fOndPEiRPzpZ/5YefOnZo4caL++OMPl9fZv3+/3nrrLf3nP/9xlP3xxx+y2Wx68cUXneoaY/Tvf/9bNptNEydOzHK7zz33nObMmaOHHnpI8+fP17/+9S93upLvsvo7GDRokFPdzz77TM2bN1e5cuVUokQJVatWTffcc4+WLVvmqJM2hmlL8eLFVbZsWTVt2lT/+c9/dPDgwWzb1K9fP5f+Tvv165crY7Bo0SJNmzYtXXmtWrXUsWNHjR8/Plf2AwCFmSfGUGlLsWLFFBERoX79+ik+Pj5d/RYtWjjV9/HxUdWqVTVw4EAdOnQow318/vnnateuncqUKSM/Pz9df/31euKJJ3Ty5EmX+5mUlKTJkydr5MiR8vK6/L9TNptNQ4YMSVf/ueeek81m0/33359lwuudd97RlClTdNddd2nu3Ll67LHHXG5TQahSpUqmx1u7du2c6q5fv17t27dXRESE/Pz8VKlSJXXq1EmLFi1yqnf15x8SEqL69evr0Ucf1c6dO7NtU9oxmN3SokWLXBmDL7/8MsMYtEyZMnrggQc0bty4XNkPAAB55er468pl1KhR+daOq+M6f39/3XjjjZo2bVq6+Onq7zdsNpsCAwNVt25dzZw5U6mpqem2f/bsWT399NO68cYbVaJECQUFBenWW2/VvHnzZIzJr24CyIFiBd0AQJLmz5/v9HrevHlauXJluvKaNWvmZ7Mc4uPj1bJlS/31119atWqVbrrppjzZz7lz5zRp0iRJyrX/sS5IO3fu1KRJk9SiRQuXf3Ezffp0Va1aVS1btsyynjFGDz/8sP773/9q3Lhx2Sawvv76a918882aMGGCi60veG3btlWfPn3SlV9//fWOf7/44ot68skn1bx5c40ePVolSpTQb7/9plWrVum9995L9wVSz5491aFDB9ntdv3999/avHmzpk2bpunTp+vtt9/Wvffem2l7/v3vf6tNmzaO1/v379f48eM1cOBA3XrrrY7yqKioa+m2w6JFi7Rjx44M75YbNGiQOnTooH379uXa/gCgMPLEGOqpp55S1apVdf78ef3vf//TnDlztH79eu3YsUN+fn5OdStWrKi4uDhJ0oULF7Rz5069/vrrWr58uXbt2qUSJUo46j7xxBN66aWXFBMTo5EjRzoSajNnztR7772n1atXq0aNGtm275133tHFixfVs2fPbOs+//zzGjNmjPr27au33nrLKeF1ta+//loRERF6+eWXs92uVdStW1ePP/54uvLw8HDHvz/44AP16NFDdevW1aOPPqrSpUtr//79+uabb/Tmm2/qvvvuc1o3Lf4xxigxMVE//vij5s6dq1dffVWTJ0/W8OHDM21Pt27ddN111zlenzlzRg899JC6du2qbt26OcrLly9/Ld12+PLLLzVr1qwM49BBgwbplVde0ddff61WrVrlyv4AAMgrafHXlerUqZOvbbgyrjtx4oQWLVqkxx57TMePH9ezzz6brn7a9xuSlJiYqC+//FJDhw7VgQMHNGXKFEe9hIQEtW7dWrt27dK9996rIUOG6Pz58/roo4/Ut29fffnll1q4cKG8vb3zp6MA3GMACxo8eLApqMNzwoQJRpI5fvy4McaY+Ph4U716dRMcHGw2b96c7fqzZ882klyqe7Xjx48bSWbChAlur5uVM2fO5Or2XPXBBx8YSWbNmjUu1b9w4YIpW7asGTt2rFP5/v37jSQzZcoUR1naMTJmzBiXtl21alXTsWPHbOv9888/JjU11aVt5iVJZvDgwVnWSUlJMYGBgaZt27YZvp+QkOD4d0ZjmOaPP/4w119/vfHx8THbt293uY2bN282kszs2bNdXscdHTt2NJUrV87wvQsXLpjSpUubcePG5cm+AaCw8sQYauTIkUaSWbx4sVN58+bNTe3atdNtZ+bMmUaSWbFihaNs0aJFRpLp0aOHuXjxolP9jRs3mhIlSpgbbrjBpKSkZNvOG2+80fTu3Ttd+dXX7hdeeMFIMn369HEptmjZsmWG/blaSkqKSU5OzrZeXqtcubJLsVWtWrVM7dq1M2zzlbGKMZnHPydOnDBNmjQxkswXX3zhchvzKrZOk93fW506dcy//vWvPNk3AAC54Vq+w7ramjVr0n0H1Ldv30z/v/5KGcV1//zzj6lcubIpVaqUU/yW2fcbdrvdNGzY0ISHhzuVx8bGGi8vL/PJJ5+k2+8TTzxhJJnnn3/ehR4CKAhMIYhC4+zZs3r88ccVGRkpX19f1ahRQy+++GK6W33Tpm9ZuHChatSoIT8/P9WvX1/ffPON2/s8cuSIWrZsqWPHjmnFihVq0KBBjtrer18/BQQEKD4+Xl26dFFAQIBCQ0P1xBNPOG5t/uOPPxQaGipJmjRpkuM26Ct/0bl7927dddddCgkJkZ+fnxo0aKBPP/3UaV9pt3+vW7dODz/8sMqVK6eKFStKkk6fPq1hw4apSpUq8vX1Vbly5dS2bdt00/ls3LhR7dq1U1BQkEqUKKHmzZvru+++S9ev+Ph4DRgwQOHh4fL19VXVqlX10EMP6cKFC5ozZ47uvvtuSVLLli1dmsJo/fr1OnHihNNdPhl59NFHNWvWLI0ePVrPPPNMlnXT5mDev3+/vvjiC0c7/vjjD8d77733nsaOHauIiAiVKFFCSUlJki79Yrh+/fry9/dX2bJl1bt373RTGKV9tgcPHtQdd9yhgIAARUREaNasWZKkn3/+Wa1atVLJkiVVuXLldFPlXIsTJ04oKSlJzZo1y/D9cuXKubSdypUra86cObpw4YJeeOGFa26XK8dPdsdiixYt9MUXX+jAgQOOz+zKu/iKFy+uFi1a6JNPPrnm9gKApyvMMZQkx12++/btc6l+WFiYJKlYscuTTUyaNEmlS5fWf//733S/rm3UqJFGjhypn3/+WR9++GGW296/f79++umnbGOVqVOnasSIEerdu7dmz56d5Z1XadPgrFmzRr/88otTzHTlNMrTpk1TVFSUfH19HdPpff3117r11ltVsmRJBQcHq3Pnztq1a5fT9tOm1fv111/Vu3dvBQUFKTQ0VOPGjZMxRocOHVLnzp0VGBiosLAwvfTSS1n2zV379u1Tw4YN5ePjk+49V2OVMmXK6L333lOxYsUy/AW2u1yJqVNSUjRp0iRVr15dfn5+KlOmjG655RatXLlS0qUYMC3eu3IKoyu1bdtWn332GVMTAQAKtcwe21ClSpVce4RARvz8/NSwYUOdPn1ax44dy7a+zWZT+fLlnWLA//3vf1q+fLn69eunO++8M906cXFxql69uiZPnqx//vknV9sPIHcwhSAKBWOM7rzzTq1Zs0YDBgxQ3bp1tXz5cj355JOKj49PN9XKunXrtHjxYj3yyCPy9fXVq6++qnbt2mnTpk0u3wKdkJCgu+66S0ePHtWKFSvUsGHDa+pDamqqYmNj1bhxY7344otatWqVXnrpJUVFRemhhx5SaGioXnvttXTTnNx4442SpF9++UXNmjVTRESERo0apZIlS+r9999Xly5d9NFHH6lr165O+3v44YcVGhqq8ePH6+zZs5IuTWXy4YcfasiQIapVq5ZOnjyp9evXa9euXY4pfb7++mu1b99e9evX14QJE+Tl5aXZs2erVatW+vbbb9WoUSNJ0uHDh9WoUSOdOnVKAwcOVHR0tOLj4/Xhhx/q3Llzuu222/TII4/olVde0X/+8x/H1EVZTWH0/fffy2azqV69epnWeeyxx/TKK69o5MiReu6557Id95o1a2r+/Pl67LHHVLFiRcc0N6GhoY5ncz399NPy8fHRE088oeTkZPn4+GjOnDnq37+/GjZsqLi4OCUkJGj69On67rvvtG3bNgUHBzt9tu3bt9dtt92mF154QQsXLtSQIUNUsmRJjRkzRr169VK3bt30+uuvq0+fPmrSpEm6W/Mzcv78+XTPEZGkwMBA+fj4qFy5cvL399dnn32moUOHKiQkJNttZqZJkyaKiopyfCmTU64eP9kdi2PGjFFiYqL+/PNPx993QECA077q16+vTz75RElJSQoMDLymdgOAp/KEGCrtel26dOl076WmpjqulSkpKdq1a5cmTJig6667zvEDj71792rPnj3q169fpteLPn36aMKECfr888+znE73+++/l6Qsp0KcPn26Hn/8cd13332aM2dOlskr6VJMMn/+fD377LM6c+aMY+qcmjVrOr5ImT17ts6fP6+BAwfK19dXISEhWrVqldq3b69q1app4sSJ+ueffzRjxgw1a9ZMW7duTTd9c48ePVSzZk09//zz+uKLL/TMM88oJCREb7zxhlq1aqXJkydr4cKFeuKJJ9SwYUPddtttWbZbujTmGcUqJUuWlL+/v6RLP5RZvXq1/vzzT8ePqnKiUqVKat68udasWXNN135XY+qJEycqLi5ODzzwgBo1aqSkpCT98MMP2rp1q9q2bat///vfOnz4cIZTdqapX7++Xn75Zf3yyy/5Pg0TAADuSExMTHdNL1u2bAG15rK0H/Nc+R1MmnPnzjnanJSUpK+++krLli3T6NGjHXU+++wzScrw8QzSpR883XfffZo0aZK+++67bH+kBKAAFOTtX0Bmrp6OY+nSpUaSeeaZZ5zq3XXXXcZms5nffvvNUSbJSDI//PCDo+zAgQPGz8/PdO3aNdt9p01/U7lyZRMYGGg2bNjgVtszuv26b9++RpJ56qmnnOrWq1fP1K9f3/E6q2lOWrdubW644QZz/vx5R5ndbjdNmzY11atXT7f/W265Jd0UOUFBQVlOS2e320316tVNbGyssdvtjvJz586ZqlWrOk1V16dPH+Pl5ZXhbeZp67o7hWDv3r1NmTJl0pWn3R5euXJlI8k8+eSTLm3vShlNc5N2e3u1atXMuXPnHOUXLlww5cqVM3Xq1DH//POPo/zzzz83ksz48eMdZWmf7XPPPeco+/vvv42/v7+x2Wzmvffec5Tv3r3b5Wls0o7jjJZ3333XUW/8+PFGkilZsqRp3769efbZZ82WLVvSbS+rKQTTdO7c2UgyiYmJ2bbPmPRTCLpz/GR3LBqT9RSCxlyeDmrjxo0utRcAigJPiKFWrVpljh8/bg4dOmQ+/PBDExoaanx9fc2hQ4ec6jdv3jzD62TNmjXN77//nm4MXn755Sz3HxgYaG666aYs64wdO9ZIMqdPn0733pWxSs+ePdPFYdnJaOqctOt3YGCgOXbsmNN7devWNeXKlTMnT550lP3444/Gy8vL9OnTx1GW9rkMHDjQUXbx4kVTsWJFY7PZnKbMSYth+vbtm2170/qa0RIXF+eo9/bbbxtJxsfHx7Rs2dKMGzfOfPvttxlOq6hsplB+9NFHjSTz448/Zts+YzKOrV2NqWNiYrKdIjG7KQS///77DKe/BADAKtLir4yWNJl9j1G5cmWnmOFapxCMjo42x48fN8ePHze7d+82Tz75pJGU7nqcFh9ltDz00ENO30d06dLFSDJ///13pvtesmSJkWReeeWVbNsJIP8xhSAKhS+//FLe3t565JFHnMoff/xxGWP01VdfOZU3adJE9evXd7yuVKmSOnfurOXLlzum7MtOQkKCAgICVKFChWvvwP8bNGiQ0+tbb71Vv//+e7br/fXXX/r66691zz336PTp0zpx4oROnDihkydPKjY2Vnv37k03td2DDz6Yboqc4OBgbdy4UYcPH85wP9u3b9fevXt133336eTJk479nD17Vq1bt9Y333wju90uu92upUuXqlOnThlOCXT19CmuOnnyZIa/rk6TkJAgSbr++utztP3M9O3b1/ErYUn64YcfdOzYMT388MNOD4vv2LGjoqOj9cUXX6TbxgMPPOD4d3BwsGrUqKGSJUvqnnvucZTXqFFDwcHBLn3mktS5c2etXLky3dKyZUtHnUmTJmnRokWqV6+eli9frjFjxqh+/fq66aab0k0hlJ20O5xOnz7t1nppXD1+pOyPRVekHSsZ/fIbAHBJYYyh2rRpo9DQUEVGRuquu+5SyZIl9emnn2Z4906VKlUc18evvvpK06ZNU2Jiotq3b6/jx49LunxdK1WqVJb7LVWqlGMa4cycPHlSxYoVS3dXcJq0WKVq1aq5+iDw7t27O6aali5N0bh9+3b169fP6Q7sG2+8UW3bttWXX36ZbhtXxire3t5q0KCBjDEaMGCAozwthnE1VmncuHGGsUrPnj0dde6//34tW7ZMLVq00Pr16/X000/r1ltvVfXq1R13tLnqWmMVd2Lq4OBg/fLLL9q7d2+O9iURqwAACo9Zs2alu57nt927dys0NFShoaGKjo7WlClTdOedd2rOnDkZ1h84cKCjrR999JEGDx6sN954Q8OHD3fUcSUOTHsvuzgQQMFgCkEUCgcOHFB4eHi6C07adHQHDhxwKq9evXq6bVx//fU6d+6cjh8/rpCQEP31119O74eGhjp90bBgwQL17t1bbdu21fr1612eoz8zfn5+Tl88SJf+p/bvv//Odt3ffvtNxhiNGzdO48aNy7DOsWPHFBER4Xid0RR1L7zwgvr27avIyEjVr19fHTp0UJ8+fVStWjVJcvwPet++fTNtS2Jioi5cuKCkpKQ8mQrFZPGMgJEjR+rLL7/Uv//9bwUHB+uuu+7KlX1ePVZpx1ONGjXS1Y2Ojtb69eudyjL6bIOCglSxYsV0ybygoCCXPnNJqlixoku3r/fs2VM9e/ZUUlKSNm7cqDlz5mjRokXq1KmTduzY4ZSEy8qZM2ckZf8FX2ZcPX5Kly6d7bHoirRjJacJUwAoCgpjDDVr1ixdf/31SkxM1DvvvKNvvvlGvr6+GdYtWbKk07WyXbt2uuWWW9SgQQM9//zzeumllxx9zy7pcfr06WuO9/r27avDhw/rueeeU9myZfXYY49d0/bSuBOr1KxZU8uXL9fZs2dVsmRJR3mlSpWc6gUFBcnPzy/d9EBBQUE6efKkS+0qW7asS7FKbGysYmNjde7cOW3ZskWLFy/W66+/rjvuuEO7d+92edyvNVZxJ6Z+6qmn1LlzZ11//fWqU6eO2rVrp3/961+O6b1dQawCACgsGjVqdE3PLM0NVapU0Ztvvim73a59+/bp2Wef1fHjxzP9TqN69epOcUi3bt1ks9k0bdo03X///brhhhuc4sCMpiFMe0/KeXwBIG+RwEKR9P333zvdxSJdeij3lc8KaN68ud5//31169ZNsbGxWrt2rYKCgnK8z2v5FW7aXStPPPGEYmNjM6xz3XXXOb2+8o6iNPfcc49uvfVWffzxx1qxYoWmTJmiyZMna8mSJWrfvr1jP1OmTFHdunUz3E9AQEC6L65yS5kyZbJM7gQEBOirr77Sbbfdpl69eikwMFC33377Ne83o7FyR2afbWblWSXprkVgYKDatm2rtm3bqnjx4po7d642btyo5s2bu7T+jh07VK5cuRw/U8LV40fK/lh0RdqxYoV5uQGgqMiPGOrKL1C6dOmiW265Rffdd5/27NmT6Z1PV6pfv76CgoL0zTffSLqcrPvpp58yXefAgQNKSkpSrVq1stx2mTJldPHiRZ0+fTrDLzmKFSum999/X+3atdPjjz+u4OBg9e/fP9s2Z+daYxUp47gkv2OVEiVK6NZbb9Wtt96qsmXLatKkSfrqq6+y/PHLlXbs2CFvb2+XniWaEXdi6ttuu0379u3TJ598ohUrVuitt97Syy+/rNdff93pbrasEKsAADyZq3fnu+rqHyY1a9ZMN910k/7zn//olVdecWkbrVu31syZM/XNN9/ohhtuUM2aNbV06VL99NNPmT7fMy1GzC4OBFAwSGChUKhcubJWrVqV7suC3bt3O96/UkZTffz6668qUaKEQkND5evrm+526LCwsHTrdOrUSe+884769u2rO+64QytWrMiVLxAyk9mvM9PuSilevPg1P1CyQoUKevjhh/Xwww/r2LFjuummm/Tss8+qffv2ioqKknQpEZLVfkJDQxUYGKgdO3ZkuS93f20aHR2thQsXKjExMdMvusqUKaMVK1aoWbNm6tatm1auXKkmTZq4tZ/spB1Pe/bsUatWrZze27NnT7rjzYoaNGiguXPn6siRIy7V37Bhg/bt26fevXvneJ+uHj9psjoWpeyPn/3798vLyyvXp5QEAE9S2GMob29vxcXFqWXLlpo5c6ZGjRrl0nqpqamOu3Wuv/56XX/99Vq6dKmmT5+eYeJp3rx5kqQ77rgjy+1GR0dLunQNyuxOHD8/P3366adq2bKlHnzwQQUHB6tr164utdtVV8YqV9u9e7fKli3rdPeVFaUlKV2NVQ4ePKh169apSZMmOf6FtLsxdUhIiPr376/+/fvrzJkzuu222zRx4kRHAsuVWEW6nEQFAKAwKl26tE6dOuVUduHCBZev4Tl14403qnfv3nrjjTf0xBNPpLubPCMXL16UdPmu7TvuuENxcXGaN29ehgms1NRULVq0SKVLl1azZs1ytwMAcgXPwEKh0KFDB6WmpmrmzJlO5S+//LJsNlu6OzY2bNigrVu3Ol4fOnRIn3zyiW6//XZ5e3urdOnSatOmjdOS2S3J//rXvzRt2jStX79e3bt3V0pKSu538P+VKFFCktIFBuXKlVOLFi30xhtvZBggpD3jISupqalKTExMt93w8HAlJydLuvSL5aioKL344ouOi31G+/Hy8lKXLl302Wef6YcffkhXL+1Xu2lfnFzdn8w0adJExhht2bIly3oRERFauXKlSpYsqY4dO+rnn392afuuatCggcqVK6fXX3/dMTaS9NVXX2nXrl3q2LFjru4vp86dO6cNGzZk+F7aM00ymlroagcOHFC/fv3k4+OjJ598MsftcfX4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Renpp5+WMcZRp1+/frLZbE5Lu3btctJ8AAAAlxH3AACAooTYBwAAWEUxd1dYvHixhg8frtdff12NGzfWtGnTFBsbqz179qhcuXLp6o8dO1YLFizQm2++qejoaC1fvlxdu3bV999/r3r16kmSJk+erNdee01z585V7dq19cMPP6h///4KCgrSI4884thWu3btNHv2bMdrX1/fnPQZAADAJcQ9AACgKCH2AQAAVmIzV/7kxQWNGzdWw4YNNXPmTEmS3W5XZGSkhg4dqlGjRqWrHx4erjFjxmjw4MGOsu7du8vf318LFiyQJN1xxx0qX7683n777Uzr9OvXT6dOndLSpUtdamdycrKSk5Mdr5OSkhQZGanExEQFBga602UAAJADSUlJCgoKKtTX3sIS90jEPgAAFCRPiHukwhP7EPcAAFCw8iv2cWsKwQsXLmjLli1q06bN5Q14ealNmzbasGFDhuskJyfLz8/Pqczf31/r1693vG7atKlWr16tX3/9VZL0448/av369Wrfvr3TemvXrlW5cuVUo0YNPfTQQzp58mSmbY2Li1NQUJBjiYyMdKerAACgiCtMcY9E7AMAAK5NYYp9iHsAACga3EpgnThxQqmpqSpfvrxTefny5XX06NEM14mNjdXUqVO1d+9e2e12rVy5UkuWLNGRI0ccdUaNGqV7771X0dHRKl68uOrVq6dhw4apV69ejjrt2rXTvHnztHr1ak2ePFnr1q1T+/btlZqamuF+R48ercTERMdy6NAhd7oKAACKuMIU90jEPgAA4NoUptiHuAcAgKLB7WdguWv69Ol68MEHFR0dLZvNpqioKPXv31/vvPOOo87777+vhQsXatGiRapdu7a2b9+uYcOGKTw8XH379pUk3XvvvY76N9xwg2688UZFRUVp7dq1at26dbr9+vr6Ml8yAADIVwUV90jEPgAAIP/xnQ8AAMhLbt2BVbZsWXl7eyshIcGpPCEhQWFhYRmuExoaqqVLl+rs2bM6cOCAdu/erYCAAFWrVs1R58knn3T8IueGG27Qv/71Lz322GOKi4vLtC3VqlVT2bJl9dtvv7nTBQAAAJcQ9wAAgKKE2AcAAFiNWwksHx8f1a9fX6tXr3aU2e12rV69Wk2aNMlyXT8/P0VEROjixYv66KOP1LlzZ8d7586dk5eXc1O8vb1lt9sz3d6ff/6pkydP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meKo89dff6lXr14KDAxUcHCwBgwYoDNnzuRbGwEAAAAAAAAAALJTrKAb4FF2fiotGyklHb5cFhgutZss1bozz3d/5MgRp9dfffWVBgwYoO7duzvKevXqpSNHjmjlypVKSUlR//79NXDgQC1atCjP2wcAAAAAAAAAAOAK7sDKLTs/ld7v45y8kqSkI5fKd36a500ICwtzWj755BO1bNlS1apVkyTt2rVLy5Yt01tvvaXGjRvrlltu0YwZM/Tee+/p8OHD2Ww9vePHj6tBgwbq2rWrkpOTVbFiRb322mtOdbZt2yYvLy8dOHAgV/oIAAAAAACQ5wpwhh0AAHAJCazcYE+9dOeVTAZv/n/ZslH5GuwkJCToiy++0IABAxxlGzZsUHBwsBo0aOAoa9Omjby8vLRx40a3tn/o0CHdeuutqlOnjj788EP5+vqqZ8+e6e7kWrhwoZo1a6bKlStfW4cAAAAAAADyw85PpWl1pLl3SB8NuPTfaXXy5cfJAADgMhJYueHA9+nvvHJipKT4S/Xyydy5c1WqVCl169bNUXb06FGVK1fOqV6xYsUUEhKio0ePurztPXv2qFmzZoqNjdXs2bPl7e0t6dL0hN99950OHjwoSbLb7XrvvffUq1evXOgRAAAAAABAHrPADDsAAOASEli54UxC7tbLBe+884569eolPz+/XN3uP//8o1tvvVXdunXT9OnTZbPZHO/VrVtXNWvWdNyFtW7dOh07dkx33313rrYBAAAAAAAg11lwhh0AAIoyEli5IaB87ta7Rt9++6327NmjBx54wKk8LCxMx44dcyq7ePGi/vrrL4WFhbm0bV9fX7Vp00aff/654uPj073fq1cvRwJr0aJFateuncqUKZPDngAAAAAAAOQTC86wAwBAUUYCKzdUbioFhkuyZVLBJgVGXKqXD95++23Vr19fMTExTuVNmjTRqVOntGXLFkfZ119/LbvdrsaNG7u0bS8vL82fP1/169dXy5Ytdfiwc2B33333aceOHdqyZYs+/PBDpg8EAAAAAACFgwVn2AEAoCgjgZUbvLyldpP//8XVSaz/f93u+Uv18lhSUpI++OCDdHdfSVLNmjXVrl07Pfjgg9q0aZO+++47DRkyRPfee6/Cw8Nd3oe3t7cWLlyomJgYtWrVyun5WVWqVFHTpk01YMAApaam6s4778yVfgEAAAAA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",
      "text/plain": [
       "<Figure size 2100x500 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, axes = plt.subplots(nrows=1, ncols=3, figsize=(21,5), sharey=True)\n",
    "\n",
    "for d in plot_data_adaptive:\n",
    "    axes[0].scatter([d[\"time\"]], [d[\"top_k_intersect\"]], label=d[\"label\"])\n",
    "    axes[1].scatter([d[\"time\"]], [d[\"top_k_rbo\"]], label=d[\"label\"])\n",
    "    axes[2].scatter([d[\"time\"]], [d[\"rbo\"]], label=d[\"label\"])\n",
    "\n",
    "\n",
    "for ax in axes:\n",
    "    ax.set_xscale(\"log\")\n",
    "    ax.set_xlabel(\"Attribution Time (s)\")\n",
    "    ax.yaxis.set_tick_params(labelleft=True)\n",
    "axes[0].set_title(\"Top-K Intersect (K from ESD Test)\")\n",
    "axes[1].set_title(\"Top-K RBO (K from ESD Test)\")\n",
    "axes[2].set_title(\"Full RBO\")\n",
    "axes[0].legend()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "22c71e1c",
   "metadata": {},
   "outputs": [],
   "source": [
    "pd.set_option('display.width', 2000)\n",
    "pd.set_option('display.max_colwidth',3000)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "398b3e65",
   "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>Sentence</th>\n",
       "      <th>Attribution Score</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>Scott Derrickson (born July 16, 1966) is an American director, screenwriter and producer.</td>\n",
       "      <td>0.448263</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>Edward Davis Wood Jr. (October 10, 1924 – December 10, 1978) was an American filmmaker, actor, writer, producer, and director.</td>\n",
       "      <td>0.378248</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>Ed Wood is a 1994 American biographical period comedy-drama film directed and produced by Tim Burton, and starring Johnny Depp as cult filmmaker Ed Wood.</td>\n",
       "      <td>0.321689</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>27</th>\n",
       "      <td>Conrad Brooks (born Conrad Biedrzycki on January 3, 1931 in Baltimore, Maryland) is an American actor.</td>\n",
       "      <td>0.102728</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>Woodson is a census-designated place (CDP) in Pulaski County, Arkansas, in the United States.</td>\n",
       "      <td>0.054718</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>20</th>\n",
       "      <td>Adam Collis is an American filmmaker and actor.</td>\n",
       "      <td>0.054083</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>34</th>\n",
       "      <td>The film was directed by Scott Derrickson, who wrote it with Jon Spaihts and C. Robert Cargill, and stars Benedict Cumberbatch as Stephen Strange, along with Chiwetel Ejiofor, Rachel McAdams, Benedict Wong, Michael Stuhlbarg, Benjamin Bratt, Scott Adkins, Mads Mikkelsen, and Tilda Swinton.</td>\n",
       "      <td>0.046650</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>25</th>\n",
       "      <td>Sinister is a 2012 supernatural horror film directed by Scott Derrickson and written by Derrickson and C. Robert Cargill.</td>\n",
       "      <td>0.041127</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>The film concerns the period in Wood's life when he made his best-known films as well as his relationship with actor Bela Lugosi, played by Martin Landau.</td>\n",
       "      <td>0.039582</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>32</th>\n",
       "      <td>Doctor Strange is a 2016 American superhero film based on the Marvel Comics character of the same name, produced by Marvel Studios and distributed by Walt Disney Studios Motion Pictures.</td>\n",
       "      <td>0.037141</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>He is best known for directing horror films such as \"Sinister\", \"The Exorcism of Emily Rose\", and \"Deliver Us From Evil\", as well as the 2016 Marvel Cinematic Universe installment, \"Doctor Strange.\"</td>\n",
       "      <td>0.017013</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>He lives in Los Angeles, California.</td>\n",
       "      <td>0.015862</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>It is part of the Little Rock–North Little Rock–Conway Metropolitan Statistical Area.</td>\n",
       "      <td>0.009771</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>30</th>\n",
       "      <td>He took a break from acting during the 1960s and 1970s but due to the ongoing interest in the films of Ed Wood, he reemerged in the 1980s and has become a prolific actor.</td>\n",
       "      <td>0.008733</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>18</th>\n",
       "      <td>The film is officially based on a 2001 non-fiction book entitled \"Beware the Night\" by Ralph Sarchie and Lisa Collier Cool, and its marketing campaign highlighted that it was \"inspired by actual accounts\".</td>\n",
       "      <td>0.006467</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>Woodson and its accompanying Woodson Lake and Wood Hollow are the namesake for Ed Wood Sr., a prominent plantation owner, trader, and businessman at the turn of the 20th century.</td>\n",
       "      <td>0.006270</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22</th>\n",
       "      <td>He also studied cinema at the University of Southern California from 1991 to 1997.</td>\n",
       "      <td>0.004652</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>Its population was 403 at the 2010 census.</td>\n",
       "      <td>0.002968</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>28</th>\n",
       "      <td>He moved to Hollywood, California in 1948 to pursue a career in acting.</td>\n",
       "      <td>-0.001547</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>31</th>\n",
       "      <td>He also has since gone on to write, produce and direct several films.</td>\n",
       "      <td>-0.006183</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>33</th>\n",
       "      <td>It is the fourteenth film of the Marvel Cinematic Universe (MCU).</td>\n",
       "      <td>-0.006576</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>In addition, he is also the lead guitarist of the American rock band Marilyn Manson, and produced its albums \"The Pale Emperor\" and \"Heaven Upside Down\".</td>\n",
       "      <td>-0.011813</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>Sarah Jessica Parker, Patricia Arquette, Jeffrey Jones, Lisa Marie, and Bill Murray are among the supporting cast.</td>\n",
       "      <td>-0.013573</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>24</th>\n",
       "      <td>In 1998, he played \"Crankshaft\" in Eric Koyanagi's \"Hundred Percent\".</td>\n",
       "      <td>-0.014027</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>Deliver Us from Evil is a 2014 American supernatural horror film directed by Scott Derrickson and produced by Jerry Bruckheimer.</td>\n",
       "      <td>-0.014520</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>35</th>\n",
       "      <td>In \"Doctor Strange\", surgeon Strange learns the mystic arts after a career-ending car accident.</td>\n",
       "      <td>-0.025822</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>23</th>\n",
       "      <td>Collis first work was the assistant director for the Scott Derrickson's short \"Love in the Ruins\" (1995).</td>\n",
       "      <td>-0.028443</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>Tyler Bates (born June 5, 1965) is an American musician, music producer, and composer for films, television, and video games.</td>\n",
       "      <td>-0.028795</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>With Gunn, he has scored every one of the director's films; including \"Guardians of the Galaxy\", which became one of the highest grossing domestic movies of 2014, and its 2017 sequel.</td>\n",
       "      <td>-0.029335</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>Woodson is adjacent to the Wood Plantation, the largest of the plantations own by Ed Wood Sr.</td>\n",
       "      <td>-0.033199</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>19</th>\n",
       "      <td>The film stars Eric Bana, Édgar Ramírez, Sean Harris, Olivia Munn, and Joel McHale in the main roles and was released on July 2, 2014.</td>\n",
       "      <td>-0.036810</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>21</th>\n",
       "      <td>He attended the Duke University from 1986 to 1990 and the University of California, Los Angeles from 2007 to 2010.</td>\n",
       "      <td>-0.040623</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>26</th>\n",
       "      <td>It stars Ethan Hawke as fictional true-crime writer Ellison Oswalt who discovers a box of home movies in his attic that puts his family in danger.</td>\n",
       "      <td>-0.040703</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>Much of his work is in the action and horror film genres, with films like \"Dawn of the Dead, 300, Sucker Punch,\" and \"John Wick.\"</td>\n",
       "      <td>-0.042917</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>He has collaborated with directors like Zack Snyder, Rob Zombie, Neil Marshall, William Friedkin, Scott Derrickson, and James Gunn.</td>\n",
       "      <td>-0.056878</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>29</th>\n",
       "      <td>He got his start in movies appearing in Ed Wood films such as \"Plan 9 from Outer Space\", \"Glen or Glenda\", and \"Jail Bait.\"</td>\n",
       "      <td>-0.057127</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                                                                                                                                                                                                                                                                                               Sentence  Attribution Score\n",
       "3                                                                                                                                                                                                             Scott Derrickson (born July 16, 1966) is an American director, screenwriter and producer.           0.448263\n",
       "16                                                                                                                                                                       Edward Davis Wood Jr. (October 10, 1924 – December 10, 1978) was an American filmmaker, actor, writer, producer, and director.           0.378248\n",
       "0                                                                                                                                             Ed Wood is a 1994 American biographical period comedy-drama film directed and produced by Tim Burton, and starring Johnny Depp as cult filmmaker Ed Wood.           0.321689\n",
       "27                                                                                                                                                                                               Conrad Brooks (born Conrad Biedrzycki on January 3, 1931 in Baltimore, Maryland) is an American actor.           0.102728\n",
       "6                                                                                                                                                                                                         Woodson is a census-designated place (CDP) in Pulaski County, Arkansas, in the United States.           0.054718\n",
       "20                                                                                                                                                                                                                                                      Adam Collis is an American filmmaker and actor.           0.054083\n",
       "34   The film was directed by Scott Derrickson, who wrote it with Jon Spaihts and C. Robert Cargill, and stars Benedict Cumberbatch as Stephen Strange, along with Chiwetel Ejiofor, Rachel McAdams, Benedict Wong, Michael Stuhlbarg, Benjamin Bratt, Scott Adkins, Mads Mikkelsen, and Tilda Swinton.           0.046650\n",
       "25                                                                                                                                                                            Sinister is a 2012 supernatural horror film directed by Scott Derrickson and written by Derrickson and C. Robert Cargill.           0.041127\n",
       "1                                                                                                                                            The film concerns the period in Wood's life when he made his best-known films as well as his relationship with actor Bela Lugosi, played by Martin Landau.           0.039582\n",
       "32                                                                                                           Doctor Strange is a 2016 American superhero film based on the Marvel Comics character of the same name, produced by Marvel Studios and distributed by Walt Disney Studios Motion Pictures.           0.037141\n",
       "5                                                                                                He is best known for directing horror films such as \"Sinister\", \"The Exorcism of Emily Rose\", and \"Deliver Us From Evil\", as well as the 2016 Marvel Cinematic Universe installment, \"Doctor Strange.\"           0.017013\n",
       "4                                                                                                                                                                                                                                                                  He lives in Los Angeles, California.           0.015862\n",
       "8                                                                                                                                                                                                                 It is part of the Little Rock–North Little Rock–Conway Metropolitan Statistical Area.           0.009771\n",
       "30                                                                                                                           He took a break from acting during the 1960s and 1970s but due to the ongoing interest in the films of Ed Wood, he reemerged in the 1980s and has become a prolific actor.           0.008733\n",
       "18                                                                                        The film is officially based on a 2001 non-fiction book entitled \"Beware the Night\" by Ralph Sarchie and Lisa Collier Cool, and its marketing campaign highlighted that it was \"inspired by actual accounts\".           0.006467\n",
       "9                                                                                                                    Woodson and its accompanying Woodson Lake and Wood Hollow are the namesake for Ed Wood Sr., a prominent plantation owner, trader, and businessman at the turn of the 20th century.           0.006270\n",
       "22                                                                                                                                                                                                                   He also studied cinema at the University of Southern California from 1991 to 1997.           0.004652\n",
       "7                                                                                                                                                                                                                                                            Its population was 403 at the 2010 census.           0.002968\n",
       "28                                                                                                                                                                                                                              He moved to Hollywood, California in 1948 to pursue a career in acting.          -0.001547\n",
       "31                                                                                                                                                                                                                                He also has since gone on to write, produce and direct several films.          -0.006183\n",
       "33                                                                                                                                                                                                                                    It is the fourteenth film of the Marvel Cinematic Universe (MCU).          -0.006576\n",
       "15                                                                                                                                            In addition, he is also the lead guitarist of the American rock band Marilyn Manson, and produced its albums \"The Pale Emperor\" and \"Heaven Upside Down\".          -0.011813\n",
       "2                                                                                                                                                                                    Sarah Jessica Parker, Patricia Arquette, Jeffrey Jones, Lisa Marie, and Bill Murray are among the supporting cast.          -0.013573\n",
       "24                                                                                                                                                                                                                                In 1998, he played \"Crankshaft\" in Eric Koyanagi's \"Hundred Percent\".          -0.014027\n",
       "17                                                                                                                                                                     Deliver Us from Evil is a 2014 American supernatural horror film directed by Scott Derrickson and produced by Jerry Bruckheimer.          -0.014520\n",
       "35                                                                                                                                                                                                      In \"Doctor Strange\", surgeon Strange learns the mystic arts after a career-ending car accident.          -0.025822\n",
       "23                                                                                                                                                                                            Collis first work was the assistant director for the Scott Derrickson's short \"Love in the Ruins\" (1995).          -0.028443\n",
       "11                                                                                                                                                                        Tyler Bates (born June 5, 1965) is an American musician, music producer, and composer for films, television, and video games.          -0.028795\n",
       "14                                                                                                              With Gunn, he has scored every one of the director's films; including \"Guardians of the Galaxy\", which became one of the highest grossing domestic movies of 2014, and its 2017 sequel.          -0.029335\n",
       "10                                                                                                                                                                                                        Woodson is adjacent to the Wood Plantation, the largest of the plantations own by Ed Wood Sr.          -0.033199\n",
       "19                                                                                                                                                               The film stars Eric Bana, Édgar Ramírez, Sean Harris, Olivia Munn, and Joel McHale in the main roles and was released on July 2, 2014.          -0.036810\n",
       "21                                                                                                                                                                                   He attended the Duke University from 1986 to 1990 and the University of California, Los Angeles from 2007 to 2010.          -0.040623\n",
       "26                                                                                                                                                   It stars Ethan Hawke as fictional true-crime writer Ellison Oswalt who discovers a box of home movies in his attic that puts his family in danger.          -0.040703\n",
       "12                                                                                                                                                                    Much of his work is in the action and horror film genres, with films like \"Dawn of the Dead, 300, Sucker Punch,\" and \"John Wick.\"          -0.042917\n",
       "13                                                                                                                                                                  He has collaborated with directors like Zack Snyder, Rob Zombie, Neil Marshall, William Friedkin, Scott Derrickson, and James Gunn.          -0.056878\n",
       "29                                                                                                                                                                          He got his start in movies appearing in Ed Wood films such as \"Plan 9 from Outer Space\", \"Glen or Glenda\", and \"Jail Bait.\"          -0.057127"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "visualize(\"../data/attributions/HotpotQA/l70_nokv/attributions.jsonl\", 0)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
