{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "cbe2aa68-7c7b-4869-b3c5-0451d23d3614",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "09fb8375-697a-4846-b277-83f21fd4ac13",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Matplotlib is building the font cache; this may take a moment.\n",
      "2024-03-25 14:38:59.942258: I tensorflow/core/platform/cpu_feature_guard.cc:182] This TensorFlow binary is optimized to use available CPU instructions in performance-critical operations.\n",
      "To enable the following instructions: AVX2 FMA, in other operations, rebuild TensorFlow with the appropriate compiler flags.\n",
      "2024-03-25 14:39:14.016392: W tensorflow/compiler/tf2tensorrt/utils/py_utils.cc:38] TF-TRT Warning: Could not find TensorRT\n"
     ]
    }
   ],
   "source": [
    "import argparse\n",
    "import numpy as np\n",
    "import os\n",
    "import pandas as pd\n",
    "import scipy as sp\n",
    "import sys\n",
    "import torch\n",
    "import torch.nn.functional as F\n",
    "import warnings\n",
    "import random\n",
    "import collections\n",
    "\n",
    "# CD-T Imports\n",
    "import os\n",
    "import tqdm\n",
    "import seaborn as sns\n",
    "import matplotlib.pyplot as plt\n",
    "import itertools\n",
    "\n",
    "from torch import nn\n",
    "\n",
    "warnings.filterwarnings(\"ignore\")\n",
    "\n",
    "base_dir = os.path.split(os.getcwd())[0]\n",
    "sys.path.append(base_dir)\n",
    "\n",
    "from argparse import Namespace\n",
    "from methods.bag_of_ngrams.processing import cleanReports, cleanSplit, stripChars\n",
    "from pyfunctions.general import extractListFromDic, readJson\n",
    "from pyfunctions.pathology import extract_synoptic, fixLabelProstateGleason, fixProstateLabels, fixLabel, exclude_labels\n",
    "from pyfunctions.cd import *\n",
    "from sklearn import preprocessing\n",
    "from sklearn.model_selection import train_test_split\n",
    "from torch.utils.data import DataLoader, RandomSampler, SequentialSampler, TensorDataset\n",
    "from transformers import AutoTokenizer, AutoModel\n",
    "from transformers import BertTokenizer, BertForSequenceClassification"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "76f59a54-c233-47d9-ac6a-85e322f65811",
   "metadata": {
    "user_expressions": []
   },
   "source": [
    "## load in model and data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "d88fcd35-6261-4487-87fa-f6973c565fff",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<torch.autograd.grad_mode.set_grad_enabled at 0x7f143a888210>"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "torch.autograd.set_grad_enabled(False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "b521f795-8f77-4940-b82c-8472c12706ac",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "args = {\n",
    "    'model_type': 'bert', # bert, medical_bert, pubmed_bert, biobert, clinical_biobert\n",
    "    'task': 'path',\n",
    "    'field': 'PrimaryGleason'\n",
    "}\n",
    "\n",
    "device = 'cuda:0'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "4f154c09-1db4-47af-9ab2-f57a9665ff40",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "if args['model_type'] == 'bert':\n",
    "    bert_path = 'bert-base-uncased'\n",
    "    tokenizer = BertTokenizer.from_pretrained('bert-base-uncased')\n",
    "elif args['model_type'] == 'medical_bert':\n",
    "    bert_path = f\"{base_dir}/models/pretrained/bert_pretrain_output_all_notes_150000/\"\n",
    "    tokenizer = BertTokenizer.from_pretrained(bert_path, local_files_only=True)\n",
    "elif args['model_type'] == 'pubmed_bert':\n",
    "    bert_path = \"microsoft/BiomedNLP-PubMedBERT-base-uncased-abstract\"\n",
    "    tokenizer = AutoTokenizer.from_pretrained(\"microsoft/BiomedNLP-PubMedBERT-base-uncased-abstract\")\n",
    "elif args['model_type'] == 'pubmed_bert_full':\n",
    "    bert_path = \"microsoft/BiomedNLP-PubMedBERT-base-uncased-abstract-fulltext\"\n",
    "    tokenizer = AutoTokenizer.from_pretrained(\"microsoft/BiomedNLP-PubMedBERT-base-uncased-abstract-fulltext\")\n",
    "elif args['model_type'] == 'biobert':\n",
    "    bert_path = \"dmis-lab/biobert-v1.1\"\n",
    "    tokenizer = AutoTokenizer.from_pretrained(\"dmis-lab/biobert-v1.1\")\n",
    "elif args['model_type'] == 'clinical_biobert':\n",
    "    bert_path = \"emilyalsentzer/Bio_ClinicalBERT\"\n",
    "    tokenizer = AutoTokenizer.from_pretrained(\"emilyalsentzer/Bio_ClinicalBERT\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "33cfa45d-2353-413d-978d-4a8d6c84c6b5",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Token indices sequence length is longer than the specified maximum sequence length for this model (1345 > 512). Running this sequence through the model will result in indexing errors\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2066 517 324\n"
     ]
    }
   ],
   "source": [
    "# Read in data\n",
    "#field = 'PrimaryGleason' # out of PrimaryGleason, SecondaryGleason', 'MarginStatusNone', 'SeminalVesicleNone'\n",
    "path = f\"../data/prostate.json\"\n",
    "data = readJson(path)\n",
    "\n",
    "# Clean reports\n",
    "data = cleanSplit(data, stripChars)\n",
    "data['dev_test'] = cleanReports(data['dev_test'], stripChars)\n",
    "data = fixLabel(data)\n",
    "\n",
    "train_documents = [extract_synoptic(patient['document'].lower(), tokenizer) for patient in data['train']]\n",
    "val_documents = [extract_synoptic(patient['document'].lower(), tokenizer) for patient in data['val']]\n",
    "test_documents = [extract_synoptic(patient['document'].lower(), tokenizer) for patient in data['test']]\n",
    "print(len(train_documents), len(val_documents),len(test_documents))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "381ca175-375d-4fe1-a9c3-c5da8f4207eb",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "# Create datasets\n",
    "train_labels = [patient['labels'][args['field']] for patient in data['train']]\n",
    "val_labels = [patient['labels'][args['field']] for patient in data['val']]\n",
    "test_labels = [patient['labels'][args['field']] for patient in data['test']]\n",
    "\n",
    "train_documents, train_labels = exclude_labels(train_documents, train_labels)\n",
    "val_documents, val_labels = exclude_labels(val_documents, val_labels)\n",
    "test_documents, test_labels = exclude_labels(test_documents, test_labels)\n",
    "\n",
    "le = preprocessing.LabelEncoder()\n",
    "le.fit(train_labels)\n",
    "\n",
    "# Map raw label to processed label\n",
    "le_dict = dict(zip(le.classes_, le.transform(le.classes_)))\n",
    "le_dict = {str(key):le_dict[key] for key in le_dict}\n",
    "\n",
    "for label in val_labels + test_labels:\n",
    "    if str(label) not in le_dict:\n",
    "        le_dict[str(label)] = len(le_dict)\n",
    "\n",
    "# Map processed label back to raw label\n",
    "inv_le_dict = {v: k for k, v in le_dict.items()}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "8694004b-6fc2-4069-a7da-20c21877dc6e",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "documents_full = train_documents + val_documents + test_documents\n",
    "labels_full = train_labels + val_labels + test_labels"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "96a621fa-78ea-4f35-8a43-4b42b00a9f24",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "BertForSequenceClassification(\n",
       "  (bert): BertModel(\n",
       "    (embeddings): BertEmbeddings(\n",
       "      (word_embeddings): Embedding(30522, 768, padding_idx=0)\n",
       "      (position_embeddings): Embedding(512, 768)\n",
       "      (token_type_embeddings): Embedding(2, 768)\n",
       "      (LayerNorm): LayerNorm((768,), eps=1e-12, elementwise_affine=True)\n",
       "      (dropout): Dropout(p=0.1, inplace=False)\n",
       "    )\n",
       "    (encoder): BertEncoder(\n",
       "      (layer): ModuleList(\n",
       "        (0-11): 12 x BertLayer(\n",
       "          (attention): BertAttention(\n",
       "            (self): BertSelfAttention(\n",
       "              (query): Linear(in_features=768, out_features=768, bias=True)\n",
       "              (key): Linear(in_features=768, out_features=768, bias=True)\n",
       "              (value): Linear(in_features=768, out_features=768, bias=True)\n",
       "              (dropout): Dropout(p=0.1, inplace=False)\n",
       "            )\n",
       "            (output): BertSelfOutput(\n",
       "              (dense): Linear(in_features=768, out_features=768, bias=True)\n",
       "              (LayerNorm): LayerNorm((768,), eps=1e-12, elementwise_affine=True)\n",
       "              (dropout): Dropout(p=0.1, inplace=False)\n",
       "            )\n",
       "          )\n",
       "          (intermediate): BertIntermediate(\n",
       "            (dense): Linear(in_features=768, out_features=3072, bias=True)\n",
       "            (intermediate_act_fn): GELUActivation()\n",
       "          )\n",
       "          (output): BertOutput(\n",
       "            (dense): Linear(in_features=3072, out_features=768, bias=True)\n",
       "            (LayerNorm): LayerNorm((768,), eps=1e-12, elementwise_affine=True)\n",
       "            (dropout): Dropout(p=0.1, inplace=False)\n",
       "          )\n",
       "        )\n",
       "      )\n",
       "    )\n",
       "    (pooler): BertPooler(\n",
       "      (dense): Linear(in_features=768, out_features=768, bias=True)\n",
       "      (activation): Tanh()\n",
       "    )\n",
       "  )\n",
       "  (dropout): Dropout(p=0.1, inplace=False)\n",
       "  (classifier): Linear(in_features=768, out_features=3, bias=True)\n",
       ")"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "#load finetuned model\n",
    "model_path = f\"{base_dir}/models/{args['task']}/{args['model_type']}_{args['field']}\"\n",
    "checkpoint_file = f\"{model_path}/save_output\"\n",
    "config_file = f\"{model_path}/save_output/config.json\"\n",
    "\n",
    "model = BertForSequenceClassification.from_pretrained(checkpoint_file, num_labels=len(le_dict), output_hidden_states=True)\n",
    "\n",
    "model = model.eval()\n",
    "model.to(device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "da2ebf5b-acae-44ac-923c-24756f3b9e69",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "def reshape_separate_attention_heads(context_layer, sa_module):\n",
    "    new_shape = context_layer.size()[:-1] + (sa_module.num_attention_heads, sa_module.attention_head_size)\n",
    "    context_layer = context_layer.view(new_shape)\n",
    "    return context_layer\n",
    "\n",
    "def reshape_concatenate_attention_heads(context_layer, sa_module):\n",
    "    new_shape = context_layer.size()[:-2] + (sa_module.all_head_size,)\n",
    "    context_layer = context_layer.view(*new_shape)\n",
    "    return context_layer\n",
    "\n",
    "def prop_self_attention_patched(rel, irrel, attention_mask, \n",
    "                                head_mask, patched_entries, layer_patched_values,\n",
    "                                sa_module, att_probs = None):\n",
    "    \n",
    "    if att_probs is not None:\n",
    "        att_probs = att_probs\n",
    "    else:\n",
    "        att_probs = get_attention_probs(rel + irrel, attention_mask, head_mask, sa_module)\n",
    "    \n",
    "    rel_value, irrel_value = prop_linear(rel, irrel, sa_module.value)\n",
    "    \n",
    "    rel_context = mul_att(att_probs, rel_value, sa_module)\n",
    "    irrel_context = mul_att(att_probs, irrel_value, sa_module)\n",
    "        \n",
    "    return rel_context, irrel_context\n",
    "    \n",
    "def patch_context_eval(rel, irrel, patched_entries, layer_patched_values, sa_module):\n",
    "    rel = reshape_separate_attention_heads(rel, sa_module)\n",
    "    irrel = reshape_separate_attention_heads(irrel, sa_module)\n",
    "\n",
    "    for i, entry in enumerate(patched_entries):\n",
    "        pos = entry[1]\n",
    "        att_head = entry[2]\n",
    "        \n",
    "        rel[:, pos, att_head, :] = rel[:, pos, att_head, :] + irrel[:, pos, att_head, :]\n",
    "        irrel[:, pos, att_head, :] = 0\n",
    "        \n",
    "    rel = reshape_concatenate_attention_heads(rel, sa_module)\n",
    "    irrel = reshape_concatenate_attention_heads(irrel, sa_module)\n",
    "    return rel, irrel\n",
    "\n",
    "def prop_attention_patched_baseline(rel, irrel, attention_mask, \n",
    "                           head_mask, patched_entries, layer_patched_values, a_module, \n",
    "                           att_probs = None):\n",
    "\n",
    "    \n",
    "    rel_context, irrel_context = prop_self_attention_patched(rel, irrel, \n",
    "                                                             attention_mask, \n",
    "                                                             head_mask, \n",
    "                                                             patched_entries,\n",
    "                                                             layer_patched_values,\n",
    "                                                             a_module.self, att_probs)\n",
    "\n",
    "    output_module = a_module.output\n",
    "    \n",
    "    rel_dense, irrel_dense = prop_linear(rel_context, irrel_context, output_module.dense)\n",
    "    rel_tot = rel_dense + rel\n",
    "    irrel_tot = irrel_dense + irrel\n",
    "        \n",
    "    rel_tot, irrel_tot = patch_context_eval(rel_tot, irrel_tot, patched_entries, layer_patched_values, a_module.self)\n",
    "    \n",
    "    rel_out, irrel_out = prop_layer_norm(rel_tot, irrel_tot, output_module.LayerNorm)\n",
    "    \n",
    "    return rel_out, irrel_out\n",
    "\n",
    "def prop_layer_patched(rel, irrel, attention_mask, head_mask, patched_entries, layer_patched_values, layer_module, att_probs = None):\n",
    "    \n",
    "    rel_a, irrel_a = prop_attention_patched_baseline(rel, irrel, attention_mask, head_mask,\n",
    "                                                     patched_entries, layer_patched_values,\n",
    "                                                     layer_module.attention, att_probs)\n",
    "    \n",
    "    i_module = layer_module.intermediate\n",
    "    rel_id, irrel_id = prop_linear(rel_a, irrel_a, i_module.dense)\n",
    "    rel_iact, irrel_iact = prop_act(rel_id, irrel_id, i_module.intermediate_act_fn)\n",
    "    \n",
    "    o_module = layer_module.output\n",
    "    rel_od, irrel_od = prop_linear(rel_iact, irrel_iact, o_module.dense)\n",
    "    \n",
    "    rel_tot = rel_od + rel_a\n",
    "    irrel_tot = irrel_od + irrel_a\n",
    "    \n",
    "    rel_out, irrel_out = prop_layer_norm(rel_tot, irrel_tot, o_module.LayerNorm)\n",
    "    \n",
    "    # import pdb; pdb.set_trace()\n",
    "    \n",
    "    return rel_out, irrel_out"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "0eaccdee-2832-4146-beae-85c9f3850fbe",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "def ablate_target_nodes(encoding, model, patched_entries, patched_values=None, att_list = None):\n",
    "    \n",
    "    embedding_output = get_embeddings_bert(encoding, model.bert)\n",
    "    input_shape = encoding['input_ids'].size()\n",
    "    extended_attention_mask = get_extended_attention_mask(attention_mask = encoding['attention_mask'], \n",
    "                                                          input_shape = input_shape, \n",
    "                                                          bert_model = model.bert,\n",
    "                                                          device = device)\n",
    "    \n",
    "    head_mask = [None] * model.bert.config.num_hidden_layers\n",
    "    encoder_module = model.bert.encoder\n",
    "    \n",
    "    sh = list(embedding_output.shape)\n",
    "    \n",
    "    rel = torch.zeros(sh, dtype = embedding_output.dtype, device = device)\n",
    "    irrel = torch.zeros(sh, dtype = embedding_output.dtype, device = device)\n",
    "    \n",
    "    irrel[:] = embedding_output[:]\n",
    "\n",
    "    for i, layer_module in enumerate(encoder_module.layer):\n",
    "        layer_patched_entries = [p_entry for p_entry in patched_entries if p_entry[0] == i]\n",
    "        layer_head_mask = head_mask[i]\n",
    "        att_probs = None\n",
    "        \n",
    "        if patched_values is not None:\n",
    "            layer_patched_values = patched_values[i]\n",
    "        else:\n",
    "            layer_patched_values = None\n",
    "        \n",
    "        rel_n, irrel_n = prop_layer_patched(rel, irrel, extended_attention_mask,\n",
    "                                            layer_head_mask, layer_patched_entries,\n",
    "                                            layer_patched_values,\n",
    "                                            layer_module, att_probs)\n",
    "        normalize_rel_irrel(rel_n, irrel_n)\n",
    "        rel, irrel = rel_n, irrel_n\n",
    "    \n",
    "    rel_pool, irrel_pool = prop_pooler(rel, irrel, model.bert.pooler)\n",
    "    rel_out, irrel_out = prop_linear(rel_pool, irrel_pool, model.classifier)\n",
    "    \n",
    "    return rel_out, irrel_out"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a09ec026-86d2-4457-8acc-8f01e9541589",
   "metadata": {
    "user_expressions": []
   },
   "source": [
    "## Faithfulness"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "e7fd5ec7-1b5d-4f9a-a9eb-f9e8d05cc942",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "# the identified attn heads using CD-T\n",
    "CD_C = [(11, 0, 8), (11, 0, 0), (11, 0, 1), (11, 0, 4), (11, 0, 3), (11, 0, 7),\n",
    "        (10, 82, 0), (10, 61, 8), (10, 82, 7), (10, 176, 2), (10, 467, 1), (10, 91, 7),\n",
    "        (7, 82, 11), (7, 82, 0), (7, 82, 6), (9, 82, 0), (9, 91, 7), (8, 82, 0),\n",
    "        (6, 82, 4), (5, 82, 4), (3, 82, 0), (4, 82, 0), (5, 82, 0), (6, 82, 0),\n",
    "        (0, 82, 9), (0, 82, 1), (0, 82, 7), (1, 82, 6), (0, 82, 6), (2, 82, 0)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "c70f979c-8ce7-4654-8b1c-0c48d26c4dc8",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "# the identified attn heads using CD-T\n",
    "CD_C_15 = [(11, 0, 8), (11, 0, 0), (11, 0, 1), (11, 0, 4), (11, 0, 3),# (11, 0, 7),\n",
    "        #(10, 82, 0), (10, 61, 8), (10, 82, 7), (10, 176, 2), (10, 467, 1), (10, 91, 7),\n",
    "        #(7, 82, 11), (7, 82, 0), (7, 82, 6), (9, 82, 0), (9, 91, 7), (8, 82, 0),\n",
    "        (6, 82, 4), (5, 82, 4), (3, 82, 0), (4, 82, 0), (5, 82, 0),# (6, 82, 0),\n",
    "        (0, 82, 9), (0, 82, 1), (0, 82, 7), (1, 82, 6), (0, 82, 6)]#, (2, 82, 0)]\n",
    "\n",
    "# the identified attn heads using path patching(baseline)\n",
    "NLD_C_15 = [(11, 0, 1), (11, 0, 7), (11, 0, 5), (11, 0, 3), (11, 0, 0),# (11, 0, 8),\n",
    "        (8, 132, 1), (8, 275, 0), (6, 397, 1), (8, 66, 6), (8, 380, 8),# (1, 195, 0),\n",
    "        (1, 169, 2), (2, 169, 2), (2, 169, 3), (4, 169, 8), (1, 411, 3)]#, (2, 169, 1)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "id": "25a3eb91-36dc-4489-bb21-54dd757cb7ca",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "# the identified attn heads using path patching(baseline)\n",
    "NLD_C = [(11, 0, 1), (11, 0, 7), (11, 0, 5), (11, 0, 3), (11, 0, 0), (11, 0, 8),\n",
    "        (8, 132, 1), (8, 275, 0), (6, 397, 1), (8, 66, 6), (8, 380, 8), (1, 195, 0),\n",
    "        (1, 169, 2), (2, 169, 2), (2, 169, 3), (4, 169, 8), (1, 411, 3), (2, 169, 1)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "abc71f25-4e4f-4473-bda1-2def9c2216ed",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "NUM_SAMPLES = 200\n",
    "index_lst = random.sample(range(len(test_documents)), NUM_SAMPLES)\n",
    "docs = [test_documents[i] for i in index_lst]\n",
    "labels = [test_labels[i] for i in index_lst]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "62baab70-fc0a-452a-bd15-fa0bb8982d84",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "200it [00:15, 12.65it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "avg log p:  tensor(0.0634, device='cuda:0')\n",
      "acc:  0.9\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "200it [00:15, 12.62it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "avg log p:  tensor(0.0682, device='cuda:0')\n",
      "acc:  0.905\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "200it [00:15, 12.60it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "avg log p:  tensor(0.0680, device='cuda:0')\n",
      "acc:  0.905\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "200it [00:15, 12.58it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "avg log p:  tensor(0.0716, device='cuda:0')\n",
      "acc:  0.91\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "200it [00:15, 12.59it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "avg log p:  tensor(0.0688, device='cuda:0')\n",
      "acc:  0.91\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "200it [00:15, 12.58it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "avg log p:  tensor(0.0642, device='cuda:0')\n",
      "acc:  0.895\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "200it [00:15, 12.53it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "avg log p:  tensor(0.0664, device='cuda:0')\n",
      "acc:  0.915\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "200it [00:15, 12.57it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "avg log p:  tensor(0.0536, device='cuda:0')\n",
      "acc:  0.915\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "200it [00:15, 12.60it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "avg log p:  tensor(0.0693, device='cuda:0')\n",
      "acc:  0.91\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "200it [00:15, 12.54it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "avg log p:  tensor(0.0673, device='cuda:0')\n",
      "acc:  0.915\n",
      "global avg log p:  tensor(0.0067, device='cuda:0')\n",
      "global acc:  0.0915\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "pos_specific_hs = [\n",
    "            [i for i in range(12)],\n",
    "            [i for i in range(512)],\n",
    "            [i for i in range(12)]\n",
    "        ]\n",
    "all_heads = list(itertools.product(*pos_specific_hs))\n",
    "    \n",
    "for i in range(10):\n",
    "    g_acc = 0\n",
    "    g_logp = 0\n",
    "    #random heads\n",
    "    random_heads = random.sample(all_heads, 15)\n",
    "\n",
    "    with torch.no_grad():\n",
    "        logp = 0\n",
    "        acc = 0\n",
    "\n",
    "        for doc, label in tqdm.tqdm(zip(docs, labels)):\n",
    "            encoding = get_encoding(doc, tokenizer, device)\n",
    "            label_idx = le_dict[label]\n",
    "            circuit_out, rest_out = ablate_target_nodes(encoding, model, random_heads)\n",
    "\n",
    "            logp += circuit_out[0][label_idx]\n",
    "\n",
    "            pred = torch.argmax(circuit_out)\n",
    "            if pred == label_idx:\n",
    "                acc += 1\n",
    "            \n",
    "    print('avg log p: ', logp / NUM_SAMPLES)\n",
    "    print('acc: ', acc / NUM_SAMPLES)\n",
    "    \n",
    "    g_acc += acc / NUM_SAMPLES\n",
    "    g_logp += logp / NUM_SAMPLES\n",
    "\n",
    "print('global avg log p: ', g_logp / 10)\n",
    "print('global acc: ', g_acc / 10)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "4afa7fea-f1ac-4c92-a1e7-c77cb0c1c586",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "200it [00:15, 12.58it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "avg log p:  tensor(2.1517, device='cuda:0')\n",
      "acc:  0.995\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "#CD_C\n",
    "with torch.no_grad():\n",
    "    logp = 0\n",
    "    acc = 0\n",
    "    \n",
    "    for doc, label in tqdm.tqdm(zip(docs, labels)):\n",
    "        encoding = get_encoding(doc, tokenizer, device)\n",
    "        label_idx = le_dict[label]\n",
    "        circuit_out, rest_out = ablate_target_nodes(encoding, model, CD_C_15)\n",
    "        \n",
    "        logp += circuit_out[0][label_idx]\n",
    "        \n",
    "        pred = torch.argmax(circuit_out)\n",
    "        if pred == label_idx:\n",
    "            acc += 1\n",
    "            \n",
    "print('avg log p: ', logp / NUM_SAMPLES)\n",
    "print('acc: ', acc / NUM_SAMPLES)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "605f90aa-eae3-4b6b-b86a-0c5c8f8bd940",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "200it [00:15, 12.61it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "avg log p:  tensor(1.9635, device='cuda:0')\n",
      "acc:  0.995\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "#NLD_C\n",
    "with torch.no_grad():\n",
    "    logp = 0\n",
    "    acc = 0\n",
    "    \n",
    "    for doc, label in tqdm.tqdm(zip(docs, labels)):\n",
    "        encoding = get_encoding(doc, tokenizer, device)\n",
    "        label_idx = le_dict[label]\n",
    "        circuit_out, rest_out = ablate_target_nodes(encoding, model, NLD_C_15)\n",
    "        \n",
    "        logp += circuit_out[0][label_idx]\n",
    "        \n",
    "        pred = torch.argmax(circuit_out)\n",
    "        if pred == label_idx:\n",
    "            acc += 1\n",
    "            \n",
    "print('avg log p: ', logp / NUM_SAMPLES)\n",
    "print('acc: ', acc / NUM_SAMPLES)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 110,
   "id": "8d804002-526d-4f8d-911d-b9d268343311",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "200it [00:16, 12.48it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "avg log p:  tensor(6.0313, device='cuda:0')\n",
      "acc:  0.995\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "# full circuit\n",
    "with torch.no_grad():\n",
    "    logp = 0\n",
    "    acc = 0\n",
    "    \n",
    "    for doc, label in tqdm.tqdm(zip(docs, labels)):\n",
    "        encoding = get_encoding(doc, tokenizer, device)\n",
    "        label_idx = le_dict[label]\n",
    "        _, out = ablate_target_nodes(encoding, model, [])\n",
    "        \n",
    "        logp += out[0][label_idx]\n",
    "        \n",
    "        pred = torch.argmax(out)\n",
    "        if pred == label_idx:\n",
    "            acc += 1\n",
    "            \n",
    "print('avg log p: ', logp / NUM_SAMPLES)\n",
    "print('acc: ', acc / NUM_SAMPLES)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "7f5d9989-f182-4098-8f49-dbdacec57d32",
   "metadata": {
    "user_expressions": []
   },
   "source": [
    "## Minimality"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 111,
   "id": "f76a6bef-5a49-4488-a5e5-027a3555ba66",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "NUM_SAMPLES = 50\n",
    "index_lst = random.sample(range(len(test_documents)), NUM_SAMPLES)\n",
    "docs = [test_documents[i] for i in index_lst]\n",
    "labels = [test_labels[i] for i in index_lst]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 112,
   "id": "f6c31929-3c22-4df0-acf9-1da67c565991",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "50it [00:04, 12.32it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "avg log p:  tensor(6.0814, device='cuda:0')\n",
      "acc:  1.0\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "# full circuit\n",
    "with torch.no_grad():\n",
    "    logp = 0\n",
    "    acc = 0\n",
    "    \n",
    "    for doc, label in tqdm.tqdm(zip(docs, labels)):\n",
    "        encoding = get_encoding(doc, tokenizer, device)\n",
    "        label_idx = le_dict[label]\n",
    "        _, out = ablate_target_nodes(encoding, model, [])\n",
    "        \n",
    "        logp += out[0][label_idx]\n",
    "        \n",
    "        pred = torch.argmax(out)\n",
    "        if pred == label_idx:\n",
    "            acc += 1\n",
    "            \n",
    "print('avg log p: ', logp / NUM_SAMPLES)\n",
    "print('acc: ', acc / NUM_SAMPLES)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 115,
   "id": "eaa2e2db-a203-4949-b4d3-6b6d99c01532",
   "metadata": {
    "tags": []
   },
   "outputs": [],
   "source": [
    "FULL_LOGP = 6.0814"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 96,
   "id": "14af3780-ec4b-4735-a39e-29070bbbf9b1",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "50it [00:18,  2.69it/s]\n",
      "50it [00:20,  2.40it/s]\n",
      "50it [00:19,  2.57it/s]\n",
      "50it [00:19,  2.53it/s]\n",
      "50it [00:20,  2.45it/s]\n",
      "50it [00:19,  2.63it/s]\n",
      "50it [00:21,  2.36it/s]\n",
      "50it [00:18,  2.76it/s]\n",
      "50it [00:22,  2.23it/s]\n",
      "50it [00:17,  2.87it/s]\n",
      "50it [00:22,  2.19it/s]\n",
      "50it [00:16,  3.03it/s]\n",
      "50it [00:23,  2.09it/s]\n",
      "50it [00:16,  3.01it/s]\n",
      "50it [00:23,  2.10it/s]\n",
      "50it [00:16,  3.05it/s]\n",
      "50it [00:23,  2.10it/s]\n",
      "50it [00:16,  3.05it/s]\n",
      "50it [00:23,  2.10it/s]\n",
      "50it [00:16,  3.04it/s]\n",
      "50it [00:23,  2.16it/s]\n",
      "50it [00:17,  2.94it/s]\n",
      "50it [00:22,  2.19it/s]\n",
      "50it [00:17,  2.86it/s]\n",
      "50it [00:22,  2.27it/s]\n",
      "50it [00:18,  2.75it/s]\n",
      "50it [00:21,  2.34it/s]\n",
      "50it [00:18,  2.63it/s]\n",
      "50it [00:20,  2.45it/s]\n",
      "50it [00:19,  2.54it/s]\n"
     ]
    }
   ],
   "source": [
    "# CD_C\n",
    "with torch.no_grad():\n",
    "    v_lst = []\n",
    "    min_score_lst = []\n",
    "    for i in range(5):\n",
    "        K = CD_C[i*6:(i+1)*6]\n",
    "        score = 0\n",
    "        for v in K:\n",
    "            K_minus_v = [h for h in K if h != v]\n",
    "            for doc, label in tqdm.tqdm(zip(docs, labels)):\n",
    "                encoding = get_encoding(doc, tokenizer, device)\n",
    "                label_idx = le_dict[label]\n",
    "                out1, _ = ablate_target_nodes(encoding, model, [v for v in CD_C if v not in K])\n",
    "                out2, _ = ablate_target_nodes(encoding, model, [v for v in CD_C if v not in K_minus_v])\n",
    "\n",
    "                score += abs(out1[0][label_idx] - out2[0][label_idx])\n",
    "            v_lst.append(v)\n",
    "            min_score_lst.append(score.cpu() / NUM_SAMPLES)                "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 97,
   "id": "3736a117-889c-44f2-862d-e3171431cdd7",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, 'Change in logit (%)')"
      ]
     },
     "execution_count": 97,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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PXrgypUr8PT0RPXq1bF+/Xo0b94cADB8+HBkZGSgX79+uH37NurWrYvff/8d7u7udq6ciIiIiguNiIi9i7C1tLQ0eHp6IjU1FR4eHvYu56lW/r21Fm2fNKWVjSohIqLizpK/38XyHBoiIiIiS7ChISIiItVjQ0NERESqx4aGiIiIVI8NDREREakeGxoiIiJSPTY0REREpHpsaIiIiEj12NAQERGR6rGhISIiItVjQ0NERESqx4aGiIiIVM/u37ZN6sMvmCQiouKGR2iIiIhI9djQEBERkeqxoSEiIiLVY0NDREREqseGhoiIiFSPDQ0RERGpHhsaIiIiUj02NERERKR6bGiIiIhI9djQEBERkeqxoSEiIiLVY0NDREREqseGhoiIiFSPDQ0RERGpHhsaIiIiUj02NERERKR6bGiIiIhI9djQEBERkeqxoSEiIiLVY0NDREREqseGhoiIiFSPDQ0RERGpHhsaIiIiUj02NERERKR6bGiIiIhI9djQEBERkeqxoSEiIiLVY0NDREREqmf3hmby5MmoU6cO3N3d4evri/bt2+PkyZMG2/Tu3Rsajcbg8txzz9mpYiIiIipu7N7QbN26Ff3798euXbuwceNGZGdno0WLFrh3757BdrGxsbhy5Yr+sm7dOjtVTERERMWNo70LWL9+vcH1uXPnwtfXF/v370fDhg31t+t0Ovj7+xd1eURERKQCdj9C81+pqakAAC8vL4Pbt2zZAl9fX4SFhaFv3764du2ayX1kZmYiLS3N4EJERERPrkIdoUlISMDff/+NS5cuISMjAz4+PggPD0fDhg3h4eFR6GJEBEOHDsXzzz+PiIgI/e1xcXHo0qULQkJCkJiYiNGjR6NJkybYv38/dDpdnv1MnjwZ48aNK3QdREREpC5mNzS3b9/G119/jW+++QbJyckQkbw7c3TECy+8gLfffhtNmjSxuJgBAwbg8OHD2L59u8HtL730kv7fERERqF27NkJCQrB27Vp07Ngxz35GjhyJoUOH6q+npaUhODjY4nqIiIhIHcx6y+nzzz9HhQoVMG3aNMTFxWHp0qU4ffo0UlNTkZmZiStXruDvv//GlClTcPv2bTRv3hyxsbE4c+aM2YUMHDgQv/zyCzZv3oygoKB8tw0ICEBISAhOnz5tdFyn08HDw8PgQkRERE8us47QfP755/j000/RrVs3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\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "x = range(30)\n",
    "y = [n/FULL_LOGP*100 for n in min_score_lst]\n",
    "plt.bar(x, y)\n",
    "x_labels = [str(v) for v in v_lst]\n",
    "plt.xticks(x, x_labels, rotation='vertical')\n",
    "plt.xlabel('Attention head', fontsize=12)\n",
    "plt.ylabel('Change in logit (%)', fontsize=12)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 127,
   "id": "a844b0a1-d222-47cd-9aeb-785b640b1aa6",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "50it [00:07,  6.26it/s]\n",
      "50it [00:07,  6.30it/s]\n",
      "50it [00:07,  6.29it/s]\n",
      "50it [00:07,  6.28it/s]\n",
      "50it [00:07,  6.29it/s]\n",
      "50it [00:07,  6.26it/s]\n"
     ]
    }
   ],
   "source": [
    "# NLD_C\n",
    "with torch.no_grad():\n",
    "    nld_v_lst = []\n",
    "    nld_min_score_lst = []\n",
    "    for i in range(3):\n",
    "        K = NLD_C[i*6:(i+1)*6]\n",
    "        score = 0\n",
    "        for v in K:\n",
    "            K_minus_v = [h for h in K if h != v]\n",
    "            for doc, label in tqdm.tqdm(zip(docs, labels)):\n",
    "                encoding = get_encoding(doc, tokenizer, device)\n",
    "                label_idx = le_dict[label]\n",
    "                out1, _ = ablate_target_nodes(encoding, model, [v for v in NLD_C if v not in K])\n",
    "                out2, _ = ablate_target_nodes(encoding, model, [v for v in NLD_C if v not in K_minus_v])\n",
    "\n",
    "                score += abs(out1[0][label_idx] - out2[0][label_idx])\n",
    "            nld_v_lst.append(v)\n",
    "            nld_min_score_lst.append(score.cpu() / NUM_SAMPLES)   "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 128,
   "id": "1279edef-4c56-47d3-8d61-7c69088dd48f",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "50it [00:07,  6.28it/s]\n",
      "50it [00:07,  6.27it/s]\n",
      "50it [00:07,  6.28it/s]\n",
      "50it [00:08,  6.24it/s]\n",
      "50it [00:08,  6.24it/s]\n",
      "50it [00:08,  6.21it/s]\n",
      "50it [00:08,  6.23it/s]\n",
      "50it [00:08,  6.20it/s]\n",
      "50it [00:08,  6.18it/s]\n",
      "50it [00:08,  6.17it/s]\n",
      "50it [00:08,  6.17it/s]\n",
      "50it [00:08,  6.19it/s]\n",
      "50it [00:08,  6.07it/s]\n",
      "50it [00:08,  6.05it/s]\n",
      "50it [00:08,  6.10it/s]\n",
      "50it [00:08,  6.16it/s]\n",
      "50it [00:08,  6.15it/s]\n",
      "50it [00:08,  6.13it/s]\n"
     ]
    }
   ],
   "source": [
    "# NLD_C\n",
    "with torch.no_grad():\n",
    "    nld_v_lst = []\n",
    "    nld_min_score_lst = []\n",
    "    K = NLD_C[:6]\n",
    "    for v in NLD_C:\n",
    "        K_minus_v = [h for h in K if h != v]\n",
    "        score = 0\n",
    "        for doc, label in tqdm.tqdm(zip(docs, labels)):\n",
    "            encoding = get_encoding(doc, tokenizer, device)\n",
    "            label_idx = le_dict[label]\n",
    "            out1, _ = ablate_target_nodes(encoding, model, [v for v in NLD_C if v not in K])\n",
    "            out2, _ = ablate_target_nodes(encoding, model, [v for v in NLD_C if v not in K_minus_v])\n",
    "\n",
    "            score += abs(out1[0][label_idx] - out2[0][label_idx])\n",
    "        nld_v_lst.append(v)\n",
    "        nld_min_score_lst.append(score.cpu() / NUM_SAMPLES)  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 99,
   "id": "6aa30f7f-8cf6-44f4-bdeb-489d8bd71462",
   "metadata": {
    "tags": []
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, 'Change in logit (%)')"
      ]
     },
     "execution_count": 99,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjQAAAHsCAYAAADFDjfcAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjYuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8o6BhiAAAACXBIWXMAAA9hAAAPYQGoP6dpAABRPUlEQVR4nO3deXwM9/8H8Nfm2oREkDsSkZaIiDuqoo7QIEXdLVql1XzbUmdVi1/raIUqqkrTqhatu45qnXXfR2hdcZcQcjhzkIgc798fHvZhJSGb3cxm1uv5eMyDnc/svN8zQ7zMzs5oRERAREREpGJW5m6AiIiIyFgMNERERKR6DDRERESkegw0REREpHoMNERERKR6DDRERESkegw0REREpHo25m5ACXl5eUhISICTkxM0Go252yEiIqIiEBGkp6fD29sbVlZPPgfzTASahIQE+Pr6mrsNIiIiKob4+Hj4+Pg8cZlnItA4OTkBeLBDypUrZ+ZuiIiIqCjS0tLg6+ur+3f8SZ6JQPPwY6Zy5cox0BAREalMUS4X4UXBREREpHoMNERERKR6DDRERESkegw0REREpHoMNERERKR6DDRERESkegw0REREpHoMNERERKR6DDRERESkegw0REREpHoMNERERKR6DDRERESkegw0REREpHoMNERERKR6DDRERESkejbmboBIrap8utak64ub1M6k6yMiepbwDA0RERGpHgMNERERqR4DDREREakeAw0RERGpHgMNERERqR4DDREREakeAw0RERGpHgMNERERqR4DDREREakeAw0RERGpHgMNERERqR4DDREREame2QNNdHQ0ateujXLlyqFcuXJo3Lgx1q9frxsXEYwdOxbe3t5wcHBAixYtEBsba8aOiYiIqLQxe6Dx8fHBpEmTcOjQIRw6dAgtW7ZEx44ddaFl8uTJmDZtGmbOnImYmBh4enoiPDwc6enpZu6ciIiISguzB5oOHTrglVdeQUBAAAICAjBhwgQ4Ojpi//79EBFMnz4do0ePRpcuXRAcHIz58+cjIyMDixYtMnfrREREVEqYPdA8Kjc3F0uWLMHdu3fRuHFjXLx4EUlJSWjdurVuGa1Wi+bNm2Pv3r2FricrKwtpaWl6ExEREVmuUhFojh8/DkdHR2i1Wrz//vtYtWoVgoKCkJSUBADw8PDQW97Dw0M3VpCJEyfC2dlZN/n6+pZo/0RERGRepSLQVK9eHUeOHMH+/fvxwQcfoE+fPjh58qRuXKPR6C0vIvnmPWrkyJFITU3VTfHx8SXWOxEREZmfjbkbAAA7OztUrVoVABASEoKYmBh8++23+OSTTwAASUlJ8PLy0i1/7dq1fGdtHqXVaqHVaku2aSIiIio1SsUZmseJCLKysuDv7w9PT09s2rRJN3b//n3s2LEDoaGhZuyQiIiIShOzn6EZNWoUIiIi4Ovri/T0dCxZsgTbt2/Hhg0boNFoMGTIEERFRaFatWqoVq0aoqKiUKZMGfTq1cvcrRMREVEpYfZAk5ycjN69eyMxMRHOzs6oXbs2NmzYgPDwcADAiBEjkJmZif79++P27dto1KgR/v77bzg5OZm5cyIiIiotNCIi5m6ipKWlpcHZ2RmpqakoV66cudshC1Hl07UmXV/cpHYmXR8RkdoZ8u93qbyGhoiIiMgQDDRERESkegw0REREpHoMNERERKR6DDRERESkegw0REREpHoMNERERKR6DDRERESkegw0REREpHoMNERERKR6DDRERESkegw0REREpHoMNERERKR6DDRERESkegw0REREpHoMNERERKR6DDRERESkegw0REREpHoMNERERKR6DDRERESkegw0REREpHoMNERERKR6DDRERESkegw0REREpHoMNERERKR6DDRERESkegw0REREpHoMNERERKR6DDRERESkegw0REREpHoMNERERKR6DDRERESkegw0REREpHoMNERERKR6DDRERESkegw0REREpHoMNERERKR6DDRERESkegw0REREpHo25m6AqCRU+XStSdcXN6mdSddHRESmxTM0REREpHoMNERERKR6DDRERESkegw0REREpHoMNERERKR6Zg80EydORMOGDeHk5AR3d3d06tQJZ86c0Vumb9++0Gg0etOLL75opo6JiIiotDF7oNmxYwcGDBiA/fv3Y9OmTcjJyUHr1q1x9+5dveXatm2LxMRE3bRu3TozdUxERESljdnvQ7Nhwwa913PnzoW7uzsOHz6MZs2a6eZrtVp4enoq3R4RERGpgNnP0DwuNTUVAFCxYkW9+du3b4e7uzsCAgIQGRmJa9euFbqOrKwspKWl6U1ERERkuUpVoBERDBs2DC+99BKCg4N18yMiIrBw4UJs3boVU6dORUxMDFq2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pkaNGrob6xERERGVBgYHmqioKEyaNAlXr14tiX6IiIiIDFaka2heffVVvdepqakICAhA3bp18z3qQKPRYPXq1abrkAAAVT5d+/SFDBA3qZ1J10dERGRORQo0x44d0z1dGwCsra3h7u6OhIQEJCQk6C376HJERERESihSoImLiyuxBnbu3Imvv/4ahw8fRmJiIlatWoVOnTrpxkUE48aNw+zZs3H79m00atQIs2bNQs2aNUusJyIiIlIXs98p+O7du6hTpw5mzpxZ4PjkyZMxbdo0zJw5EzExMfD09ER4eDjS09MV7pSIiIhKqyIFmtu3b6Nr165Ys2ZNocusWbMGXbt2xc2bNw1qICIiAl9++SW6dOmSb0xEMH36dIwePRpdunRBcHAw5s+fj4yMDCxatMigOkRERGS5ihRo5syZg6NHj6Jt27aFLtO2bVscP34cs2bNMllzFy9eRFJSElq3bq2bp9Vq0bx5c+zdu7fQ92VlZSEtLU1vIiIiIstVpECzZMkSREZGwsam8EtubGxsEBkZiT///NNkzSUlJQEAPDw89OZ7eHjoxgoyceJEODs76yZfX1+T9URERESlT5ECzdmzZxESEvLU5erXr4+zZ88a3dTjHv/mlIg88dtUI0eORGpqqm6Kj483eU9ERERUehTpW045OTmwtbV96nK2trbIzs42uqmHPD09ATw4U+Pl5aWbf+3atXxnbR6l1Wr5aAYiIqJnSJHO0Hh5eeHkyZNPXS42NlYXQkzB398fnp6e2LRpk27e/fv3sWPHDoSGhpqsDhEREalbkQJN8+bN8f333z/x7Et2djaio6MRFhZmUAN37tzBkSNHcOTIEQAPLgQ+cuQILl++DI1GgyFDhiAqKgqrVq3CiRMn0LdvX5QpUwa9evUyqA4RERFZriJ95DR06FCEhISgc+fOmD17Nry9vfXGExISEBkZiTNnzmDhwoUGNXDo0CG9EDRs2DAAQJ8+fTBv3jyMGDECmZmZ6N+/v+7Gen///TecnJwMqkNERESWq0iBpnbt2pg1axb69+8Pf39/NGjQAP7+/gAenFE5fPgw8vLyEB0djVq1ahnUQIsWLSAihY5rNBqMHTsWY8eONWi9RERE9OwoUqABgMjISAQHByMqKgrbtm3D/v37AQBlypRB27ZtMXLkSLz44osl1igRERFRYYocaACgcePG+Ouvv5CXl4cbN24AAFxdXWFlZfYnKBAREdEzzKBA85CVlRXc3d1N3QsRERFRsfDUChEREakeAw0RERGpHgMNERERqR4DDREREakeAw0RERGpHgMNERERqR4DDREREakeAw0RERGpHgMNERERqR4DDREREakeAw0RERGpHgMNERERqR4DDREREakeAw0RERGpHgMNERERqR4DDREREakeAw0RERGpHgMNERERqR4DDREREakeAw0RERGpHgMNERERqR4DDREREakeAw0RERGpHgMNERERqR4DDREREakeAw0RERGpHgMNERERqR4DDREREakeAw0RERGpHgMNERERqR4DDREREakeAw0RERGpHgMNERERqR4DDREREakeAw0RERGpHgMNERERqR4DDREREakeAw0RERGpHgMNERERqR4DDREREakeAw0RERGpHgMNERERqV6pDzRjx46FRqPRmzw9Pc3dFhEREZUiNuZuoChq1qyJzZs3615bW1ubsZv8qny61qTri5vUzqTrIyIisnSqCDQ2NjY8K0NERESFKvUfOQHAuXPn4O3tDX9/f/To0QMXLlx44vJZWVlIS0vTm4iIiMhylfpA06hRI/z666/YuHEjfvrpJyQlJSE0NBQ3b94s9D0TJ06Es7OzbvL19VWwYyIiIlJaqQ80ERER6Nq1K2rVqoWXX34Za9c+uF5l/vz5hb5n5MiRSE1N1U3x8fFKtUtERERmoIpraB5VtmxZ1KpVC+fOnSt0Ga1WC61Wq2BXREREZE6l/gzN47KysnDq1Cl4eXmZuxUiIiIqJUp9oBk+fDh27NiBixcv4sCBA+jWrRvS0tLQp08fc7dGREREpUSp/8jpypUr6NmzJ27cuAE3Nze8+OKL2L9/P/z8/MzdGhEREZUSpT7QLFmyxNwtEBERUSlX6j9yIiIiInoaBhoiIiJSPQYaIiIiUj0GGiIiIlI9BhoiIiJSPQYaIiIiUj0GGiIiIlI9BhoiIiJSPQYaIiIiUj0GGiIiIlI9BhoiIiJSPQYaIiIiUj0GGiIiIlI9BhoiIiJSPQYaIiIiUj0GGiIiIlI9BhoiIiJSPQYaIiIiUj0GGiIiIlI9BhoiIiJSPQYaIiIiUj0GGiIiIlI9BhoiIiJSPQYaIiIiUj0GGiIiIlI9BhoiIiJSPQYaIiIiUj0GGiIiIlI9BhoiIiJSPQYaIiIiUj0GGiIiIlI9BhoiIiJSPQYaIiIiUj0GGiIiIlI9BhoiIiJSPQYaIiIiUj0GGiIiIlI9BhoiIiJSPQYaIiIiUj0GGiIiIlI9BhoiIiJSPQYaIiIiUj0GGiIiIlI9BhoiIiJSPQYaIiIiUj3VBJrvv/8e/v7+sLe3R4MGDbBr1y5zt0RERESlhCoCzdKlSzFkyBCMHj0a//77L5o2bYqIiAhcvnzZ3K0RERFRKWBj7gaKYtq0aejXrx/effddAMD06dOxceNGREdHY+LEiWbujoiIyHSqfLrWpOuLm9TOLDWUVuoDzf3793H48GF8+umnevNbt26NvXv3FvierKwsZGVl6V6npqYCANLS0kqkx7ysDJOur6A+1VhDqTqWXINKp+AxG026vhPj2pilhlJ1LKWGUnX48yv/ekXk6QtLKXf16lUBIHv27NGbP2HCBAkICCjwPWPGjBEAnDhx4sSJEycLmOLj45+aF0r9GZqHNBqN3msRyTfvoZEjR2LYsGG613l5ebh16xZcXFwKfU9JS0tLg6+vL+Lj41GuXDnWKAV1LKWGUnUspYZSdSylhlJ1LKWGUnUspcbTiAjS09Ph7e391GVLfaBxdXWFtbU1kpKS9OZfu3YNHh4eBb5Hq9VCq9XqzStfvnxJtWiQcuXKlfgfDEupoVQdS6mhVB1LqaFUHUupoVQdS6mhVB1LqfEkzs7ORVqu1H/Lyc7ODg0aNMCmTZv05m/atAmhoaFm6oqIiIhKk1J/hgYAhg0bht69eyMkJASNGzfG7NmzcfnyZbz//vvmbo2IiIhKAVUEmtdffx03b97E+PHjkZiYiODgYKxbtw5+fn7mbq3ItFotxowZk++jMNYwXx1LqaFUHUupoVQdS6mhVB1LqaFUHUupYUoakaJ8F4qIiIio9Cr119AQERERPQ0DDREREakeAw0RERGpHgMNERERqR4DDREREameKr62rTYigh07dmDXrl2Ii4tDRkYG3NzcUK9ePbz88svw9fVlDYXrWEqNh+Li4gqs07hxY9jb27PGI5Q6Lpayv5SqYyk1lKpjKTVKVPEfG0mPy8jIkAkTJkilSpXE3t5eGjVqJF26dJE33nhDIiIixNfXV6ytrSUiIkL27dv3TNewpG1Ran+JiCxcuFAaNWokGo1GPDw8pH79+tKkSROpUaOG2NnZSbly5eSDDz6QuLi4Z76GUsfFUvaXJW0L91fpq6EEBhoT8vHxka5du8pff/0l9+/fL3CZuLg4iYqKksqVK8vs2bOf2RpK1bGUGiIi9erVkwYNGsh3330nly5dyjd+79492bZtm7z33nvi6uoqy5Yte2ZriChzXCxpf1nKtnB/lb4aSmGgMaHjx48XedmsrCw5e/bsM1tDqTqWUkNEZM2aNUVe9vr163Lw4MFntoaIMsfFkvaXpWwL91fpq6EU3imYiIiIVI8XBSvs7t27OHz4MJo1a1bsdRw+fBgNGjQwYVdFc/v2bZw/fx5eXl7w8fEx6bpzc3NhbW2te33gwAFkZWWhcePGsLW1NUmNc+fOYe/evUhKSoJGo4GHhwdCQ0NRrVo1k6z/2rVriI2NRYMGDVCuXDkkJydj/vz5yMvLQ7t27VCrVi2T1HmSnJwcJCQkoHLlykav686dOzh8+LDe/mrQoAEcHR1N0OmTmXI7HpWSkoLff/8dly9fhp+fH7p37w5nZ2ej15ubm6tbp5WVFbKysrB69Wrk5eUhLCwMHh4eJujevMfEEiQnJyMrK8ukf66UOvaPK4ltKUxJ/X00OXOfInrWHDlyRKysrIxah0ajkeeee04mTJggV65cMVFn+kaOHCl3794VEZH79+9LZGSkWFlZiUajESsrK+ncubNkZmYaXSchIUGaNGki1tbW0qxZM7l165a0a9dONBqNaDQaCQgIkISEBKNqpKSkyKuvvioajUbKly8vAQEBUq1aNSlfvrxYWVlJx44dJTU11aga27Ztk7Jly4pGoxEvLy85evSo+Pj4SLVq1aR69eqi1Wpl48aNRtUoClP8+crOzpZBgwaJg4ODaDQa0Wq1YmdnJxqNRhwcHGTw4MGFXpNiKqbYDhGRrl27yooVK0REJDY2VlxdXcXNzU0aNWokHh4e4unpKSdPnjS6V09PT7GyspLatWtLfHy8BAcHS9myZcXR0VEqVKhg9Gl6JY/JrFmzpFWrVtK9e3fZsmWL3tj169fF39+/1NdIS0uTN954QypXrixvvfWWZGVlSf/+/XU/v5o1a2b033kRZY69UtvyJKb6+1jSGGgUZqpAExkZKR4eHmJjYyPt2rWTVatWSU5Ojom6FLGyspLk5GQREZkwYYK4ubnJihUr5OrVq/LXX39JpUqVZPz48UbX6d27t4SGhsqff/4pr7/+uoSGhkrTpk3lypUrcvnyZWnatKkMGDDA6Bq1atWS/fv35xvbv3+/1K5dW9566y2jajRp0kQGDBgg6enp8vXXX4uPj49e38OHD5fQ0FCjahSFKf58DRo0SCpVqiRLliyR27dv6+bfvn1blixZIr6+vjJ48GDjGn0KU/0AdXV11V0bExERIb169ZKsrCwReRDU+/XrJ61btzaqRuvWraVbt25y/PhxGTx4sAQFBUn37t3l/v37kp2dLW+++aa8/PLLRtVQ6ph8++23UqZMGRkwYIC8+eabotVqJSoqSjeelJRk9HFRosaHH34ogYGBMmPGDGnRooV07NhRgoODZffu3bJz504JDg6WUaNGGVVDRJljr9S2PAkDzTOqQoUKT5zKlStnkkCTnJws2dnZsnz5cnnllVfE2tpaPDw8ZMSIEXL69Gmjt+NhDRGRunXrys8//6w3vnTpUqlRo4bRdby8vHRfmb1586ZoNBrZvHmzbnzr1q3y3HPPGVXD2dm5wDDz0L59+8TZ2dmoGuXKlZPz58+LyIP/TdvY2Mi///6rGz979qzRNUQefCPhSVNgYKDRf75cXV3z/a/5UZs3bxZXV1ejaiixHSIiDg4OuuPi5eUl//zzj974mTNnjD4uFSpU0J3lycjIEGtrazlw4IBu/MSJE+Li4mJUDSWOiYhIUFCQLFy4UPd679694u7uLp999pmImCZsKFHD19dXtm7dKiIiV69eFY1GI3/++adufO3atVK9enWjaogoc+yV2Bal/j6WNF5DY2JZWVn44IMPCr1e4tKlSxg3bpxJatnY2KBr167o2rUrrl69il9++QXz5s3DlClT0KRJE+zcudOo9Ws0GgBAfHw8XnjhBb2xF154AZcuXTJq/cCD63IqVaoEAKhYsSLKlCkDPz8/3fjzzz+PxMREo+s83BZDx4rKzs4O9+7dAwDcv38feXl5utcAkJmZaZJrgU6ePIkePXrA39+/wPHExEScPXvWqBqZmZlwdXUtdNzFxQWZmZlG1VBiOwCgdu3a2Lp1K55//nl4enri0qVLqFevnm780qVLcHBwMKqGiMDG5sGP0sd/BQBra2vk5eUZVUOJYwIAFy9eRGhoqO5148aNsXXrVrRq1QrZ2dkYMmSIKmpcu3YNVatWBQB4e3vDwcEB1atX143XrFkT8fHxRtdR4tgrsS1K/X0sceZOVJYmNDRUpk+fXui4KU7dPfpxUEE2b94svXr1MqqGRqORCRMmyLfffive3t6yc+dOvfEjR45IhQoVjKohIlK5cmW9/9F88skncvPmTb06xv7P880335TatWtLTExMvrGYmBipW7eu9O7d26gaHTt2lPbt28vu3bvlf//7n4SEhEi7du3kzp07cvfuXenWrZu0bdvWqBoiIg0aNJDvv/++0PF///3X6D9f7du3l1atWklSUlK+saSkJAkPD5cOHToYVUOJ7RB58JXUihUryty5c2Xu3LlSpUoVmTNnjuzZs0d++eUX8fX1lY8//tioGq1atZJ+/frJlStXZNy4cVK1alV5++23deP9+/eXpk2bGlVDiWMi8uBswON/10UeXH/k4eEhvXv3NsnZk5Ku4e3tLYcPH9a97tmzp97PzBMnTpjk55cSx16JbVHq72NJY6AxsQkTJsjYsWMLHb98+bL07dvXqBqPfhxUUvz8/KRKlSq66fGQ9s0338iLL75odJ1XX331iQFw5syZ0rJlS6Nq3L59W9q2bSsajUYqVKgg1atXl8DAQKlQoYJYWVlJRESE3nUJxXH27FmpWrWqaDQaqVmzply9elVeffVVsbGxERsbG3Fzc9P7oVRcgwcPfuK1EufPn5cWLVoYVePy5csSHBwsNjY2UrduXWnTpo20bdtW6tatKzY2NrqLH42hxHY8tHz5cvHx8dFd1P5wsre3lyFDhhh97dnBgwelYsWKYmVlJe7u7hIbGyuNGjUST09P8fb2FgcHB72PUYtDiWMi8uAfy8KOy4kTJ8TNzc3of9iUqNG2bVv54YcfCh2fO3euSa5pU+LYK7EtSv59LEm8D40K7dixA02aNNE7tam0/fv3Q6vV6p2+LwkxMTFwcHBAcHCw0es6ffo09u3bh6SkJACAp6cnGjdujMDAQKPX/dDNmzfh4uKie71lyxZkZmaicePGevNLu7y8PGzcuBH79+/Pt79at24NKyt1Pdc2NzcX//zzDy5cuIC8vDx4eXmhQYMGcHJyMsn679y5gzNnzqB69epwdHTEvXv3sHDhQmRmZiI8PFzvI4LiUuKYHDt2DIcPH8bbb79d4HhsbCyWL1+OMWPGlOoat27dgpWVFcqXL1/g+Pr16+Hg4IAWLVoUu8ZDJX3sldwWtWOgISIiItVT13+ziIiIiArAQENERESqx0BDRERE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\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "x = range(18)\n",
    "y = [n/FULL_LOGP*100 for n in nld_min_score_lst]\n",
    "plt.bar(x, y)\n",
    "x_labels = [str(v) for v in nld_v_lst]\n",
    "plt.xticks(x, x_labels, rotation='vertical')\n",
    "plt.xlabel('Attention head', fontsize=12)\n",
    "plt.ylabel('Change in logit (%)', fontsize=12)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "08ffeb11-8e4c-4c5e-815e-924f5c52cd54",
   "metadata": {
    "user_expressions": []
   },
   "source": [
    "# Completeness"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b61b4432-713d-4f7a-ab5e-6aff37f74777",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.11.0"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
