{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Setup"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {
    "metadata": {}
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "4"
      ]
     },
     "execution_count": 1,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import os\n",
    "os.environ['CUDA_VISIBLE_DEVICES'] = '1,3,4,5' #'0,1,2,3'  \n",
    "import torch \n",
    "torch.cuda.device_count()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "metadata": {}
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/root/anaconda3/envs/nn/lib/python3.10/site-packages/tqdm/auto.py:21: TqdmWarning: IProgress not found. Please update jupyter and ipywidgets. See https://ipywidgets.readthedocs.io/en/stable/user_install.html\n",
      "  from .autonotebook import tqdm as notebook_tqdm\n",
      "install flash-attn for fast training!\n",
      "Loading checkpoint shards: 100%|██████████| 2/2 [00:01<00:00,  1.33it/s]\n"
     ]
    }
   ],
   "source": [
    "\n",
    "#os.environ['HF_HOME'] = \"/baichuan/huggingface_model\"\n",
    "import os\n",
    "import torch\n",
    "# assert torch.cuda.device_count() == 1\n",
    "from tqdm import tqdm\n",
    "import pandas as pd\n",
    "import torch\n",
    "import torch as t\n",
    "from easy_transformer.EasyTransformer_llama import (\n",
    "    EasyTransformer,\n",
    ")\n",
    "from time import ctime\n",
    "from functools import partial\n",
    "\n",
    "import numpy as np\n",
    "from tqdm import tqdm\n",
    "import pandas as pd\n",
    "\n",
    "from easy_transformer.experiments import (\n",
    "    ExperimentMetric,\n",
    "    AblationConfig,\n",
    "    EasyAblation,\n",
    "    EasyPatching,\n",
    "    PatchingConfig,\n",
    ")\n",
    "import plotly.express as px\n",
    "import plotly.io as pio\n",
    "import plotly.graph_objects as go\n",
    "import random\n",
    "import einops\n",
    "from IPython import get_ipython\n",
    "from copy import deepcopy\n",
    "from easy_transformer.fact_dataset_llama import (\n",
    "    FactDataset,\n",
    ")\n",
    "from easy_transformer.fact_utils import (\n",
    "    path_patching,\n",
    "    max_2d,\n",
    "    show_pp,\n",
    "    show_attention_patterns,\n",
    "    plot_path_patching,\n",
    "    plot_path_patching2,\n",
    "    scatter_attention_and_contribution,\n",
    ")\n",
    "from random import randint as ri\n",
    "from easy_transformer.fact_circuit_extraction import (\n",
    "    do_circuit_extraction,\n",
    "    get_heads_circuit,\n",
    "    get_mlps_circuit\n",
    ")\n",
    "from easy_transformer.fact_utils import logit_diff, probs\n",
    "# from easy_transformer.ioi_utils import get_top_tokens_and_probs as g\n",
    "\n",
    "ipython = get_ipython()\n",
    "if ipython is not None:\n",
    "    ipython.magic(\"load_ext autoreload\")\n",
    "    ipython.magic(\"autoreload 2\")\n",
    "    \n",
    "seed = 10024\n",
    "torch.manual_seed(seed)\n",
    "random.seed(seed)\n",
    "np.random.seed(seed)\n",
    "# Initialise model (use larger N or fewer templates for no warnings about in-template ablation)\n",
    "model = EasyTransformer.from_pretrained(\"llama2-7b-chat\").cuda()\n",
    "# model.set_use_headwise_qkv_input(True)\n",
    "# model.set_use_attn_result(True)\n",
    "\n",
    "figure_save_dir = f'output_figures/nation_fact/{model.cfg.model_name}'\n",
    "os.makedirs(figure_save_dir, exist_ok=True) \n",
    "\n",
    "tensor_save_dir = f'saved_tensors/nation_fact/{model.cfg.model_name}'\n",
    "os.makedirs(tensor_save_dir, exist_ok=True) "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# 把EasyTransformer的from_pretrained中的ori设为False，然后运行\n",
    "# ori_model = EasyTransformer.from_pretrained(\"milm-32k\").cuda()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# toks = torch.Tensor(model.tokenizer(\"You should know that England's capital is\", padding=True).input_ids).type(\n",
    "#             torch.int\n",
    "#         ).unsqueeze(0).cuda()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "# model.eval()\n",
    "# out = model.generate(toks, max_new_tokens=1, do_sample=False)\n",
    "# # out_ori = ori_model.generate(toks, max_new_tokens=10)\n",
    "# print(model.tokenizer.decode(out[0]))\n",
    "# # print(out)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# ori_model.eval()\n",
    "# out = ori_model.generate(toks, max_new_tokens=1, do_sample=False)\n",
    "# print(model.tokenizer.decode(out[0]))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# from easy_transformer.modeling_milm import VAR,PRE\n",
    "\n",
    "# from easy_transformer.EasyTransformer import var\n",
    "# # while var:\n",
    "# #     var.pop()\n",
    "# # while VAR:\n",
    "# #     VAR.pop()\n",
    "# # while PRE:\n",
    "# #     PRE.pop()\n",
    "# print(len(var))\n",
    "# print(len(VAR))\n",
    "# print(len(PRE))\n",
    "# # print(var[0].cuda().to(torch.float32).equal(VAR[0].cuda().to(torch.float32)))\n",
    "# # print()\n",
    "# for i in range(len(VAR)):\n",
    "#     a = VAR[i].cpu()\n",
    "#     b = var[i].cpu()\n",
    "#     # print(a.shape)\n",
    "#     if not a.equal(b) :\n",
    "#         print(i)\n",
    "#         for i in range(a.shape[1]):\n",
    "#             if not a[:, i].eq(b[:, i]).all():\n",
    "#                 print(a[:, i].eq(b[:, i]))\n",
    "#                 print(a[:,i])\n",
    "#                 print(b[:,i])\n",
    "#         # print(a[:,0].item())\n",
    "#         # print(b[:,0].item())\n",
    "#         print(a.dtype)\n",
    "#         print(b.dtype)\n",
    "        \n",
    "\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Path Patching: Heads Contributing to Final Logits"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Warning: There are only 225 unique data sample in dataset\n",
      "[\"<s>|Without|a|doubt|,|USA|'|s|capital|is|Washington|</s>|</s>|</s>|</s>|</s>|</s>|</s>|</s>\", \"<s>|In|case|you|didn|'|t|know|,|Th|ailand|'|s|capital|is|Bang|k|ok|</s>\"]\n",
      "Here are two of the prompts from the dataset: [\"Without a doubt, USA's capital is Washington\", \"In case you didn't know, Thailand's capital is Bangkok\"]\n",
      "tensor([[    1, 13932,   263,  7404, 29892,  8278, 29915, 29879,  7483,   338,\n",
      "          7660,     2,     2,     2,     2,     2,     2,     2,     2],\n",
      "        [    1,   512,  1206,   366,  3282, 29915, 29873,  1073, 29892,   498,\n",
      "         26517, 29915, 29879,  7483,   338, 14320, 29895,   554,     2]],\n",
      "       dtype=torch.int32)\n",
      "[\"<s>|Without|a|doubt|,|Portugal|'|s|capital|is|Washington|</s>|</s>|</s>|</s>|</s>|</s>|</s>\", \"<s>|In|case|you|didn|'|t|know|,|Australia|'|s|capital|is|Bang|k|ok|</s>\"]\n",
      "tensor([ 9, 14])\n",
      "tensor([[    1, 13932,   263,  7404, 29892, 12077, 29915, 29879,  7483,   338,\n",
      "          7660,     2,     2,     2,     2,     2,     2,     2],\n",
      "        [    1,   512,  1206,   366,  3282, 29915, 29873,  1073, 29892,  8314,\n",
      "         29915, 29879,  7483,   338, 14320, 29895,   554,     2]],\n",
      "       dtype=torch.int32)\n"
     ]
    }
   ],
   "source": [
    "\n",
    "f_dataset = FactDataset(\n",
    "    prompt_type=\"NCNC\",\n",
    "    N=1000,\n",
    "    tokenizer=model.tokenizer,\n",
    "    prepend_bos=False,\n",
    "    counterfact=False,\n",
    ")\n",
    "# f_dataset = f_dataset.add_a_shot().add_a_shot() # call add_a_shot() for one more shot\n",
    "print(f_dataset.tokenized_prompts[:2])\n",
    "print(f\"Here are two of the prompts from the dataset: {f_dataset.sentences[:2]}\")\n",
    "print(f_dataset.toks[:2])\n",
    "# model.reset_hooks()\n",
    "mean_dataset = (\n",
    "        f_dataset.gen_flipped_prompts((\"N\", \"RAND\"))\n",
    "    )\n",
    "print(mean_dataset.tokenized_prompts[:2])\n",
    "print(mean_dataset.word_idx['end'][:2])\n",
    "print(mean_dataset.toks[:2])\n",
    "# with torch.no_grad():\n",
    "#     plot_path_patching2(\n",
    "#         model,\n",
    "#         D_new=mean_dataset,\n",
    "#         D_orig=f_dataset,\n",
    "#         receiver_hooks=[(f\"blocks.{model.cfg.n_layers-1}.hook_resid_post\", None)],\n",
    "#         position=\"end\",\n",
    "#         figure_save_dir=figure_save_dir,\n",
    "#         layout='max+1',\n",
    "#         title='logits_llama',\n",
    "#         threshold=1,\n",
    "#         metric='iw',\n",
    "#     )\n",
    "# model.reset_hooks()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Projection of a Head's Outputs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Warning: There are only 225 unique data sample in dataset\n",
      "Pearson Correlation Coefficient: 0.6737990975379944\n"
     ]
    },
    {
     "data": {
      "application/vnd.plotly.v1+json": {
       "config": {
        "plotlyServerURL": "https://plot.ly"
       },
       "data": [
        {
         "customdata": [
          [
           "We confirm that USA's capital is Washington"
          ],
          [
           "We confirm that Spain's capital is Madrid"
          ],
          [
           "It's crucial to know that Italy's capital is Rome"
          ],
          [
           "In case you didn't know, Italy's capital is Rome"
          ],
          [
           "Just a reminder, Japan's capital is Tokyo"
          ],
          [
           "It's crucial to know that Australia's capital is Canberra"
          ],
          [
           "I am sure that China's capital is Beijing"
          ],
          [
           "Without a doubt, France's capital is Paris"
          ],
          [
           "In case you didn't know, Austria's capital is Vienna"
          ],
          [
           "Just a reminder, Spain's capital is Madrid"
          ],
          [
           "To emphasize, Russia's capital is Moscow"
          ],
          [
           "Bear in mind, China's capital is Beijing"
          ],
          [
           "Therefore, it's correct to state that USA's capital is Washington"
          ],
          [
           "It's crucial to know that Greece's capital is Athens"
          ],
          [
           "Bear in mind, Egypt's capital is Cairo"
          ],
          [
           "According to the textbook, USA's capital is Washington"
          ],
          [
           "I am sure that Portugal's capital is Lisbon"
          ],
          [
           "We confirm that Greece's capital is Athens"
          ],
          [
           "Just a reminder, Portugal's capital is Lisbon"
          ],
          [
           "Bear in mind, Austria's capital is Vienna"
          ],
          [
           "I am sure that Egypt's capital is Cairo"
          ],
          [
           "It's crucial to know that Japan's capital is Tokyo"
          ],
          [
           "When asked, always remember that China's capital is Beijing"
          ],
          [
           "In case you didn't know, China's capital is Beijing"
          ],
          [
           "You are right to say that Italy's capital is Rome"
          ],
          [
           "When asked, always remember that Australia's capital is Canberra"
          ],
          [
           "To emphasize, China's capital is Beijing"
          ],
          [
           "Just a reminder, Austria's capital is Vienna"
          ],
          [
           "Don't forget, Italy's capital is Rome"
          ],
          [
           "We confirm that China's capital is Beijing"
          ],
          [
           "According to the textbook, Canada's capital is Ottawa"
          ],
          [
           "Keep in mind, Canada's capital is Ottawa"
          ],
          [
           "You are right to say that Canada's capital is Ottawa"
          ],
          [
           "Therefore, it's correct to state that Egypt's capital is Cairo"
          ],
          [
           "We confirm that France's capital is Paris"
          ],
          [
           "Just a reminder, France's capital is Paris"
          ],
          [
           "Bear in mind, Spain's capital is Madrid"
          ],
          [
           "Keep in mind, Greece's capital is Athens"
          ],
          [
           "It's crucial to know that Spain's capital is Madrid"
          ],
          [
           "As we all know, France's capital is Paris"
          ],
          [
           "It's crucial to know that Portugal's capital is Lisbon"
          ],
          [
           "Just a reminder, Greece's capital is Athens"
          ],
          [
           "As we all know, Egypt's capital is Cairo"
          ],
          [
           "Therefore, it's correct to state that Greece's capital is Athens"
          ],
          [
           "According to the textbook, Australia's capital is Canberra"
          ],
          [
           "I am sure that Greece's capital is Athens"
          ],
          [
           "We confirm that Italy's capital is Rome"
          ],
          [
           "To emphasize, England's capital is London"
          ],
          [
           "Therefore, it's correct to state that Italy's capital is Rome"
          ],
          [
           "Therefore, it's correct to state that England's capital is London"
          ],
          [
           "Without a doubt, Austria's capital is Vienna"
          ],
          [
           "To emphasize, Austria's capital is Vienna"
          ],
          [
           "I am sure that Japan's capital is Tokyo"
          ],
          [
           "Don't forget, England's capital is London"
          ],
          [
           "It's crucial to know that Egypt's capital is Cairo"
          ],
          [
           "Bear in mind, France's capital is Paris"
          ],
          [
           "As we all know, China's capital is Beijing"
          ],
          [
           "Bear in mind, Russia's capital is Moscow"
          ],
          [
           "It's crucial to know that England's capital is London"
          ],
          [
           "When asked, always remember that Italy's capital is Rome"
          ],
          [
           "We confirm that Portugal's capital is Lisbon"
          ],
          [
           "As we all know, Russia's capital is Moscow"
          ],
          [
           "To emphasize, Canada's capital is Ottawa"
          ],
          [
           "Keep in mind, Spain's capital is Madrid"
          ],
          [
           "I am sure that France's capital is Paris"
          ],
          [
           "Keep in mind, France's capital is Paris"
          ],
          [
           "Don't forget, Canada's capital is Ottawa"
          ],
          [
           "According to the textbook, Italy's capital is Rome"
          ],
          [
           "Just a reminder, Italy's capital is Rome"
          ],
          [
           "I am sure that England's capital is London"
          ],
          [
           "Without a doubt, China's capital is Beijing"
          ],
          [
           "To emphasize, Greece's capital is Athens"
          ],
          [
           "Therefore, it's correct to state that China's capital is Beijing"
          ],
          [
           "When asked, always remember that Japan's capital is Tokyo"
          ],
          [
           "Keep in mind, Russia's capital is Moscow"
          ],
          [
           "According to the textbook, Spain's capital is Madrid"
          ],
          [
           "I am sure that Canada's capital is Ottawa"
          ],
          [
           "To emphasize, Japan's capital is Tokyo"
          ],
          [
           "Just a reminder, Australia's capital is Canberra"
          ],
          [
           "We confirm that Japan's capital is Tokyo"
          ],
          [
           "You are right to say that Spain's capital is Madrid"
          ],
          [
           "When asked, always remember that England's capital is London"
          ],
          [
           "Just a reminder, USA's capital is Washington"
          ],
          [
           "When asked, always remember that Spain's capital is Madrid"
          ],
          [
           "Keep in mind, Austria's capital is Vienna"
          ],
          [
           "When asked, always remember that Russia's capital is Moscow"
          ],
          [
           "I am sure that USA's capital is Washington"
          ],
          [
           "Without a doubt, Egypt's capital is Cairo"
          ],
          [
           "When asked, always remember that Greece's capital is Athens"
          ],
          [
           "I am sure that Italy's capital is Rome"
          ],
          [
           "As we all know, Portugal's capital is Lisbon"
          ],
          [
           "In case you didn't know, Portugal's capital is Lisbon"
          ],
          [
           "I am sure that Austria's capital is Vienna"
          ],
          [
           "According to the textbook, England's capital is London"
          ],
          [
           "It's crucial to know that France's capital is Paris"
          ],
          [
           "In case you didn't know, England's capital is London"
          ],
          [
           "In case you didn't know, Spain's capital is Madrid"
          ],
          [
           "In case you didn't know, Greece's capital is Athens"
          ],
          [
           "You are right to say that Australia's capital is Canberra"
          ],
          [
           "We confirm that Austria's capital is Vienna"
          ],
          [
           "Therefore, it's correct to state that Thailand's capital is Bangkok"
          ],
          [
           "According to the textbook, China's capital is Beijing"
          ],
          [
           "Bear in mind, Greece's capital is Athens"
          ],
          [
           "According to the textbook, Greece's capital is Athens"
          ],
          [
           "As we all know, USA's capital is Washington"
          ],
          [
           "Therefore, it's correct to state that Australia's capital is Canberra"
          ],
          [
           "It's crucial to know that Austria's capital is Vienna"
          ],
          [
           "As we all know, Thailand's capital is Bangkok"
          ],
          [
           "Bear in mind, Canada's capital is Ottawa"
          ],
          [
           "Just a reminder, Canada's capital is Ottawa"
          ],
          [
           "Without a doubt, Japan's capital is Tokyo"
          ],
          [
           "Without a doubt, Spain's capital is Madrid"
          ],
          [
           "Don't forget, Spain's capital is Madrid"
          ],
          [
           "To emphasize, Australia's capital is Canberra"
          ],
          [
           "When asked, always remember that Canada's capital is Ottawa"
          ],
          [
           "According to the textbook, France's capital is Paris"
          ],
          [
           "Bear in mind, Japan's capital is Tokyo"
          ],
          [
           "You are right to say that Egypt's capital is Cairo"
          ],
          [
           "You are right to say that England's capital is London"
          ],
          [
           "Just a reminder, Russia's capital is Moscow"
          ],
          [
           "As we all know, Greece's capital is Athens"
          ],
          [
           "Therefore, it's correct to state that Canada's capital is Ottawa"
          ],
          [
           "Therefore, it's correct to state that France's capital is Paris"
          ],
          [
           "Just a reminder, Egypt's capital is Cairo"
          ],
          [
           "Bear in mind, Portugal's capital is Lisbon"
          ],
          [
           "As we all know, England's capital is London"
          ],
          [
           "According to the textbook, Thailand's capital is Bangkok"
          ],
          [
           "Bear in mind, Australia's capital is Canberra"
          ],
          [
           "Don't forget, Thailand's capital is Bangkok"
          ],
          [
           "In case you didn't know, USA's capital is Washington"
          ],
          [
           "Without a doubt, Italy's capital is Rome"
          ],
          [
           "When asked, always remember that Egypt's capital is Cairo"
          ],
          [
           "As we all know, Italy's capital is Rome"
          ],
          [
           "Just a reminder, England's capital is London"
          ],
          [
           "In case you didn't know, Japan's capital is Tokyo"
          ],
          [
           "To emphasize, Italy's capital is Rome"
          ],
          [
           "Bear in mind, Thailand's capital is Bangkok"
          ],
          [
           "To emphasize, France's capital is Paris"
          ],
          [
           "Don't forget, Greece's capital is Athens"
          ],
          [
           "Therefore, it's correct to state that Spain's capital is Madrid"
          ],
          [
           "Don't forget, Russia's capital is Moscow"
          ],
          [
           "We confirm that Canada's capital is Ottawa"
          ],
          [
           "To emphasize, Spain's capital is Madrid"
          ],
          [
           "According to the textbook, Austria's capital is Vienna"
          ],
          [
           "You are right to say that China's capital is Beijing"
          ],
          [
           "In case you didn't know, France's capital is Paris"
          ],
          [
           "I am sure that Russia's capital is Moscow"
          ],
          [
           "Therefore, it's correct to state that Russia's capital is Moscow"
          ],
          [
           "Bear in mind, Italy's capital is Rome"
          ],
          [
           "Without a doubt, Russia's capital is Moscow"
          ],
          [
           "When asked, always remember that USA's capital is Washington"
          ],
          [
           "Without a doubt, Australia's capital is Canberra"
          ],
          [
           "Bear in mind, England's capital is London"
          ],
          [
           "Bear in mind, USA's capital is Washington"
          ],
          [
           "When asked, always remember that Portugal's capital is Lisbon"
          ],
          [
           "In case you didn't know, Russia's capital is Moscow"
          ],
          [
           "Keep in mind, Japan's capital is Tokyo"
          ],
          [
           "As we all know, Canada's capital is Ottawa"
          ],
          [
           "Without a doubt, Thailand's capital is Bangkok"
          ],
          [
           "Don't forget, France's capital is Paris"
          ],
          [
           "As we all know, Japan's capital is Tokyo"
          ],
          [
           "Without a doubt, Greece's capital is Athens"
          ],
          [
           "You are right to say that Portugal's capital is Lisbon"
          ],
          [
           "Just a reminder, China's capital is Beijing"
          ],
          [
           "You are right to say that France's capital is Paris"
          ],
          [
           "Therefore, it's correct to state that Austria's capital is Vienna"
          ],
          [
           "To emphasize, Thailand's capital is Bangkok"
          ],
          [
           "As we all know, Australia's capital is Canberra"
          ],
          [
           "It's crucial to know that USA's capital is Washington"
          ],
          [
           "Therefore, it's correct to state that Japan's capital is Tokyo"
          ],
          [
           "In case you didn't know, Canada's capital is Ottawa"
          ],
          [
           "To emphasize, USA's capital is Washington"
          ],
          [
           "You are right to say that Japan's capital is Tokyo"
          ],
          [
           "Keep in mind, USA's capital is Washington"
          ],
          [
           "Without a doubt, England's capital is London"
          ],
          [
           "In case you didn't know, Australia's capital is Canberra"
          ],
          [
           "It's crucial to know that Thailand's capital is Bangkok"
          ],
          [
           "Just a reminder, Thailand's capital is Bangkok"
          ],
          [
           "Without a doubt, USA's capital is Washington"
          ],
          [
           "According to the textbook, Portugal's capital is Lisbon"
          ],
          [
           "Keep in mind, England's capital is London"
          ],
          [
           "Don't forget, Japan's capital is Tokyo"
          ],
          [
           "In case you didn't know, Thailand's capital is Bangkok"
          ],
          [
           "As we all know, Austria's capital is Vienna"
          ],
          [
           "We confirm that Thailand's capital is Bangkok"
          ],
          [
           "Keep in mind, Egypt's capital is Cairo"
          ],
          [
           "Keep in mind, Thailand's capital is Bangkok"
          ],
          [
           "To emphasize, Portugal's capital is Lisbon"
          ],
          [
           "It's crucial to know that Russia's capital is Moscow"
          ],
          [
           "Keep in mind, Portugal's capital is Lisbon"
          ],
          [
           "I am sure that Spain's capital is Madrid"
          ],
          [
           "Therefore, it's correct to state that Portugal's capital is Lisbon"
          ],
          [
           "Without a doubt, Canada's capital is Ottawa"
          ],
          [
           "You are right to say that USA's capital is Washington"
          ],
          [
           "I am sure that Thailand's capital is Bangkok"
          ],
          [
           "When asked, always remember that France's capital is Paris"
          ],
          [
           "I am sure that Australia's capital is Canberra"
          ],
          [
           "Keep in mind, Italy's capital is Rome"
          ],
          [
           "According to the textbook, Egypt's capital is Cairo"
          ],
          [
           "You are right to say that Russia's capital is Moscow"
          ],
          [
           "According to the textbook, Russia's capital is Moscow"
          ],
          [
           "We confirm that Australia's capital is Canberra"
          ],
          [
           "You are right to say that Greece's capital is Athens"
          ],
          [
           "Don't forget, Portugal's capital is Lisbon"
          ],
          [
           "We confirm that Russia's capital is Moscow"
          ],
          [
           "Don't forget, Egypt's capital is Cairo"
          ],
          [
           "In case you didn't know, Egypt's capital is Cairo"
          ],
          [
           "When asked, always remember that Thailand's capital is Bangkok"
          ],
          [
           "To emphasize, Egypt's capital is Cairo"
          ],
          [
           "It's crucial to know that China's capital is Beijing"
          ],
          [
           "Without a doubt, Portugal's capital is Lisbon"
          ],
          [
           "Don't forget, Australia's capital is Canberra"
          ],
          [
           "You are right to say that Austria's capital is Vienna"
          ],
          [
           "According to the textbook, Japan's capital is Tokyo"
          ],
          [
           "It's crucial to know that Canada's capital is Ottawa"
          ],
          [
           "Keep in mind, China's capital is Beijing"
          ],
          [
           "Don't forget, Austria's capital is Vienna"
          ],
          [
           "When asked, always remember that Austria's capital is Vienna"
          ],
          [
           "As we all know, Spain's capital is Madrid"
          ],
          [
           "We confirm that Egypt's capital is Cairo"
          ],
          [
           "You are right to say that Thailand's capital is Bangkok"
          ],
          [
           "Don't forget, China's capital is Beijing"
          ],
          [
           "Keep in mind, Australia's capital is Canberra"
          ],
          [
           "Don't forget, USA's capital is Washington"
          ],
          [
           "We confirm that England's capital is London"
          ]
         ],
         "hovertemplate": "Name Type=N<br>Attn Prob on Name=%{x}<br>Dot w Name Embed=%{y}<br>text=%{customdata[0]}<extra></extra>",
         "legendgroup": "N",
         "marker": {
          "color": "rgb(201,165,247)",
          "symbol": "circle"
         },
         "mode": "markers",
         "name": "N",
         "orientation": "v",
         "showlegend": true,
         "type": "scatter",
         "x": [
          0.34745076298713684,
          0.42820027470588684,
          0.2936815023422241,
          0.31347042322158813,
          0.432434618473053,
          0.2375319004058838,
          0.42522740364074707,
          0.38873934745788574,
          0.7197966575622559,
          0.4484017789363861,
          0.48445209860801697,
          0.2722282111644745,
          0.4802234172821045,
          0.5318613052368164,
          0.3286314010620117,
          0.3917040228843689,
          0.4755116105079651,
          0.66773921251297,
          0.6381223201751709,
          0.6137135028839111,
          0.5847203135490417,
          0.3003503084182739,
          0.5281215906143188,
          0.36391380429267883,
          0.3495882451534271,
          0.27480584383010864,
          0.3402244448661804,
          0.7157672643661499,
          0.34460997581481934,
          0.3755418062210083,
          0.31750795245170593,
          0.2404409497976303,
          0.3708554804325104,
          0.6680185198783875,
          0.3316342830657959,
          0.2606102526187897,
          0.4402872323989868,
          0.6189605593681335,
          0.3736264705657959,
          0.3640702962875366,
          0.5525873899459839,
          0.6674913167953491,
          0.5373672246932983,
          0.6856222748756409,
          0.37781772017478943,
          0.7091772556304932,
          0.503950834274292,
          0.3561766445636749,
          0.5134380459785461,
          0.5730711221694946,
          0.5879976153373718,
          0.601539671421051,
          0.3523508608341217,
          0.29569029808044434,
          0.3940686583518982,
          0.26045602560043335,
          0.46905240416526794,
          0.5036541223526001,
          0.2489153891801834,
          0.3887014091014862,
          0.6317909955978394,
          0.6233552694320679,
          0.3088301420211792,
          0.46758732199668884,
          0.3519795835018158,
          0.2804211676120758,
          0.23662789165973663,
          0.5557158589363098,
          0.37336957454681396,
          0.24133755266666412,
          0.37355974316596985,
          0.5466379523277283,
          0.5286409854888916,
          0.45997023582458496,
          0.5784478187561035,
          0.625218391418457,
          0.3205670118331909,
          0.3760332465171814,
          0.23782622814178467,
          0.5663915872573853,
          0.3944265842437744,
          0.4438696801662445,
          0.278372198343277,
          0.5274816751480103,
          0.6331685781478882,
          0.571631669998169,
          0.3574516773223877,
          0.38775816559791565,
          0.6622782349586487,
          0.3557772934436798,
          0.5303683280944824,
          0.5472798347473145,
          0.4676080644130707,
          0.5574571490287781,
          0.2573126554489136,
          0.3080665171146393,
          0.42576050758361816,
          0.5978826284408569,
          0.3619488775730133,
          0.655238687992096,
          0.011176064610481262,
          0.40540221333503723,
          0.5430893301963806,
          0.7713394165039062,
          0.3229054808616638,
          0.3165380358695984,
          0.5392525792121887,
          0.01832951232790947,
          0.22329528629779816,
          0.2234455794095993,
          0.4234798848628998,
          0.3664326071739197,
          0.48566949367523193,
          0.27139610052108765,
          0.3121064007282257,
          0.46014878153800964,
          0.35715678334236145,
          0.4820980429649353,
          0.25581109523773193,
          0.4998376965522766,
          0.6996603012084961,
          0.48122045397758484,
          0.3563530445098877,
          0.6026270985603333,
          0.4856310486793518,
          0.3443905711174011,
          0.0036273777950555086,
          0.17171770334243774,
          0.006979987025260925,
          0.2346375435590744,
          0.35086295008659363,
          0.5715749263763428,
          0.36582642793655396,
          0.30313700437545776,
          0.3582017123699188,
          0.31690293550491333,
          0.011087908409535885,
          0.25845104455947876,
          0.5646870732307434,
          0.6950161457061768,
          0.4847581684589386,
          0.3657759130001068,
          0.40971362590789795,
          0.7340898513793945,
          0.39501723647117615,
          0.28668642044067383,
          0.6792128682136536,
          0.7052122354507446,
          0.3465271294116974,
          0.4825208783149719,
          0.4215407073497772,
          0.3309236168861389,
          0.37633392214775085,
          0.28300464153289795,
          0.5833210945129395,
          0.4781838357448578,
          0.4184950590133667,
          0.25169724225997925,
          0.003159430343657732,
          0.2564563751220703,
          0.41262003779411316,
          0.35350915789604187,
          0.5186822414398193,
          0.35487687587738037,
          0.2690088450908661,
          0.722389817237854,
          0.01986098475754261,
          0.2651248574256897,
          0.29389792680740356,
          0.5177954435348511,
          0.2468753159046173,
          0.29121482372283936,
          0.43382906913757324,
          0.31343579292297363,
          0.2921193242073059,
          0.21653041243553162,
          0.016188574954867363,
          0.006053120829164982,
          0.1908806711435318,
          0.7009863257408142,
          0.39502355456352234,
          0.4159775674343109,
          0.005194514524191618,
          0.7227115631103516,
          0.013898801989853382,
          0.4354477822780609,
          0.015185080468654633,
          0.4642567038536072,
          0.5108619928359985,
          0.5446844696998596,
          0.3382142186164856,
          0.6821557283401489,
          0.387888640165329,
          0.3023023307323456,
          0.015058201737701893,
          0.35621029138565063,
          0.48393160104751587,
          0.35414940118789673,
          0.629386305809021,
          0.589766800403595,
          0.5533853769302368,
          0.30603235960006714,
          0.6727169156074524,
          0.5692193508148193,
          0.6412740349769592,
          0.536480188369751,
          0.4730701148509979,
          0.010170924477279186,
          0.3976261615753174,
          0.3165673017501831,
          0.44195884466171265,
          0.2189764380455017,
          0.6045020818710327,
          0.4016343951225281,
          0.213541179895401,
          0.33307117223739624,
          0.6802750825881958,
          0.630858838558197,
          0.4285639226436615,
          0.6213722229003906,
          0.01144005823880434,
          0.3747044503688812,
          0.19974370300769806,
          0.32907596230506897,
          0.27751174569129944
         ],
         "xaxis": "x",
         "y": [
          1.2551472187042236,
          2.017150640487671,
          1.93413245677948,
          2.2383148670196533,
          2.1165430545806885,
          1.806028127670288,
          2.1107900142669678,
          2.0707993507385254,
          1.9728095531463623,
          2.0805158615112305,
          2.3587515354156494,
          1.5949172973632812,
          1.353987455368042,
          1.9054388999938965,
          0.9992531538009644,
          1.2041890621185303,
          1.701285481452942,
          2.537287950515747,
          2.2312865257263184,
          1.7540584802627563,
          1.6399484872817993,
          1.5922390222549438,
          2.700216054916382,
          2.159479856491089,
          2.2036190032958984,
          1.8630281686782837,
          1.989184021949768,
          1.9171462059020996,
          2.0043716430664062,
          2.320984363555908,
          2.061433792114258,
          1.9056750535964966,
          2.5528993606567383,
          1.8471252918243408,
          2.031529664993286,
          1.6256123781204224,
          2.1090214252471924,
          2.3314149379730225,
          1.7327886819839478,
          2.174449920654297,
          1.8010026216506958,
          2.501007080078125,
          1.641791582107544,
          2.597630739212036,
          2.2558772563934326,
          2.5984082221984863,
          2.7856032848358154,
          1.955216646194458,
          2.583505153656006,
          2.2298407554626465,
          1.684478521347046,
          1.7830466032028198,
          1.7085908651351929,
          1.5557173490524292,
          1.1121996641159058,
          1.682915449142456,
          2.493037700653076,
          2.4626128673553467,
          1.5005202293395996,
          2.1420648097991943,
          2.0593814849853516,
          2.973938465118408,
          2.3082275390625,
          2.127581834793091,
          1.8831422328948975,
          1.7777469158172607,
          1.954166293144226,
          2.806502342224121,
          2.184587001800537,
          1.1447099447250366,
          2.0500106811523438,
          2.1741323471069336,
          2.5759899616241455,
          2.183518409729004,
          2.6265478134155273,
          2.559183120727539,
          2.2548656463623047,
          1.950556755065918,
          1.8446834087371826,
          2.499849319458008,
          2.0015790462493896,
          2.145003318786621,
          1.0007812976837158,
          2.4230384826660156,
          1.7576245069503784,
          2.708780288696289,
          1.1244163513183594,
          1.1549853086471558,
          2.6012918949127197,
          1.9010087251663208,
          2.050159215927124,
          2.0421950817108154,
          1.381906270980835,
          2.6207587718963623,
          1.502358317375183,
          1.8719499111175537,
          2.012434720993042,
          2.443943500518799,
          2.308339834213257,
          1.8295607566833496,
          0.7235036492347717,
          2.0156359672546387,
          2.187072992324829,
          2.797858715057373,
          1.1508926153182983,
          1.844444990158081,
          1.5399572849273682,
          0.6792032718658447,
          1.9327490329742432,
          2.0580334663391113,
          1.9976054430007935,
          1.7192727327346802,
          2.235130548477173,
          2.014965772628784,
          2.2573180198669434,
          2.143587589263916,
          1.8143484592437744,
          1.4677695035934448,
          1.3407492637634277,
          2.429264783859253,
          2.9127509593963623,
          2.582345962524414,
          1.7831629514694214,
          1.7592337131500244,
          1.804045557975769,
          1.9993871450424194,
          0.71364426612854,
          1.3697967529296875,
          0.7070242762565613,
          0.9317309856414795,
          2.1669516563415527,
          1.5678648948669434,
          2.4686596393585205,
          1.643566608428955,
          1.7987293004989624,
          2.0228919982910156,
          0.5235559344291687,
          1.6905503273010254,
          2.1664717197418213,
          2.7638907432556152,
          2.4033613204956055,
          2.449946165084839,
          1.9531410932540894,
          2.011861801147461,
          2.156848430633545,
          1.7973748445510864,
          2.840200424194336,
          2.9208648204803467,
          2.126168966293335,
          2.34790301322937,
          1.2586231231689453,
          2.273928165435791,
          1.8723396062850952,
          0.9628999829292297,
          2.0804266929626465,
          2.3943395614624023,
          2.042677402496338,
          2.3372232913970947,
          0.5599502325057983,
          1.5218349695205688,
          2.0631399154663086,
          1.4728456735610962,
          1.961948037147522,
          2.0522937774658203,
          1.7819019556045532,
          1.9701566696166992,
          0.5455469489097595,
          2.150660753250122,
          0.9766523838043213,
          2.257201910018921,
          2.2641539573669434,
          1.0305532217025757,
          2.1752638816833496,
          0.980658769607544,
          1.6028634309768677,
          1.8413478136062622,
          0.5098368525505066,
          0.7043647766113281,
          0.8409672975540161,
          2.356609344482422,
          2.094879150390625,
          2.038724660873413,
          0.6414979696273804,
          2.0847036838531494,
          0.6806398034095764,
          1.2335383892059326,
          0.6205278038978577,
          1.8089313507080078,
          2.221510648727417,
          2.0026051998138428,
          1.5551875829696655,
          2.2438204288482666,
          2.638360023498535,
          1.0240015983581543,
          0.5241715908050537,
          1.920371651649475,
          2.789994239807129,
          2.130768060684204,
          1.6048779487609863,
          2.619584560394287,
          2.546656608581543,
          2.009530782699585,
          2.7143096923828125,
          2.0617287158966064,
          2.8912127017974854,
          1.5445789098739624,
          1.4410961866378784,
          0.6380906701087952,
          1.2341986894607544,
          1.6540107727050781,
          1.7435405254364014,
          1.5938323736190796,
          1.7831695079803467,
          1.9032901525497437,
          1.8928700685501099,
          1.872557282447815,
          1.8748869895935059,
          1.880104422569275,
          2.1258983612060547,
          1.723055124282837,
          0.6127315163612366,
          2.0649025440216064,
          1.5399030447006226,
          1.1033382415771484,
          1.4114186763763428
         ],
         "yaxis": "y"
        }
       ],
       "layout": {
        "legend": {
         "title": {
          "text": "Name Type"
         },
         "tracegroupgap": 0
        },
        "template": {
         "data": {
          "bar": [
           {
            "error_x": {
             "color": "#2a3f5f"
            },
            "error_y": {
             "color": "#2a3f5f"
            },
            "marker": {
             "line": {
              "color": "#E5ECF6",
              "width": 0.5
             },
             "pattern": {
              "fillmode": "overlay",
              "size": 10,
              "solidity": 0.2
             }
            },
            "type": "bar"
           }
          ],
          "barpolar": [
           {
            "marker": {
             "line": {
              "color": "#E5ECF6",
              "width": 0.5
             },
             "pattern": {
              "fillmode": "overlay",
              "size": 10,
              "solidity": 0.2
             }
            },
            "type": "barpolar"
           }
          ],
          "carpet": [
           {
            "aaxis": {
             "endlinecolor": "#2a3f5f",
             "gridcolor": "white",
             "linecolor": "white",
             "minorgridcolor": "white",
             "startlinecolor": "#2a3f5f"
            },
            "baxis": {
             "endlinecolor": "#2a3f5f",
             "gridcolor": "white",
             "linecolor": "white",
             "minorgridcolor": "white",
             "startlinecolor": "#2a3f5f"
            },
            "type": "carpet"
           }
          ],
          "choropleth": [
           {
            "colorbar": {
             "outlinewidth": 0,
             "ticks": ""
            },
            "type": "choropleth"
           }
          ],
          "contour": [
           {
            "colorbar": {
             "outlinewidth": 0,
             "ticks": ""
            },
            "colorscale": [
             [
              0,
              "#0d0887"
             ],
             [
              0.1111111111111111,
              "#46039f"
             ],
             [
              0.2222222222222222,
              "#7201a8"
             ],
             [
              0.3333333333333333,
              "#9c179e"
             ],
             [
              0.4444444444444444,
              "#bd3786"
             ],
             [
              0.5555555555555556,
              "#d8576b"
             ],
             [
              0.6666666666666666,
              "#ed7953"
             ],
             [
              0.7777777777777778,
              "#fb9f3a"
             ],
             [
              0.8888888888888888,
              "#fdca26"
             ],
             [
              1,
              "#f0f921"
             ]
            ],
            "type": "contour"
           }
          ],
          "contourcarpet": [
           {
            "colorbar": {
             "outlinewidth": 0,
             "ticks": ""
            },
            "type": "contourcarpet"
           }
          ],
          "heatmap": [
           {
            "colorbar": {
             "outlinewidth": 0,
             "ticks": ""
            },
            "colorscale": [
             [
              0,
              "#0d0887"
             ],
             [
              0.1111111111111111,
              "#46039f"
             ],
             [
              0.2222222222222222,
              "#7201a8"
             ],
             [
              0.3333333333333333,
              "#9c179e"
             ],
             [
              0.4444444444444444,
              "#bd3786"
             ],
             [
              0.5555555555555556,
              "#d8576b"
             ],
             [
              0.6666666666666666,
              "#ed7953"
             ],
             [
              0.7777777777777778,
              "#fb9f3a"
             ],
             [
              0.8888888888888888,
              "#fdca26"
             ],
             [
              1,
              "#f0f921"
             ]
            ],
            "type": "heatmap"
           }
          ],
          "heatmapgl": [
           {
            "colorbar": {
             "outlinewidth": 0,
             "ticks": ""
            },
            "colorscale": [
             [
              0,
              "#0d0887"
             ],
             [
              0.1111111111111111,
              "#46039f"
             ],
             [
              0.2222222222222222,
              "#7201a8"
             ],
             [
              0.3333333333333333,
              "#9c179e"
             ],
             [
              0.4444444444444444,
              "#bd3786"
             ],
             [
              0.5555555555555556,
              "#d8576b"
             ],
             [
              0.6666666666666666,
              "#ed7953"
             ],
             [
              0.7777777777777778,
              "#fb9f3a"
             ],
             [
              0.8888888888888888,
              "#fdca26"
             ],
             [
              1,
              "#f0f921"
             ]
            ],
            "type": "heatmapgl"
           }
          ],
          "histogram": [
           {
            "marker": {
             "pattern": {
              "fillmode": "overlay",
              "size": 10,
              "solidity": 0.2
             }
            },
            "type": "histogram"
           }
          ],
          "histogram2d": [
           {
            "colorbar": {
             "outlinewidth": 0,
             "ticks": ""
            },
            "colorscale": [
             [
              0,
              "#0d0887"
             ],
             [
              0.1111111111111111,
              "#46039f"
             ],
             [
              0.2222222222222222,
              "#7201a8"
             ],
             [
              0.3333333333333333,
              "#9c179e"
             ],
             [
              0.4444444444444444,
              "#bd3786"
             ],
             [
              0.5555555555555556,
              "#d8576b"
             ],
             [
              0.6666666666666666,
              "#ed7953"
             ],
             [
              0.7777777777777778,
              "#fb9f3a"
             ],
             [
              0.8888888888888888,
              "#fdca26"
             ],
             [
              1,
              "#f0f921"
             ]
            ],
            "type": "histogram2d"
           }
          ],
          "histogram2dcontour": [
           {
            "colorbar": {
             "outlinewidth": 0,
             "ticks": ""
            },
            "colorscale": [
             [
              0,
              "#0d0887"
             ],
             [
              0.1111111111111111,
              "#46039f"
             ],
             [
              0.2222222222222222,
              "#7201a8"
             ],
             [
              0.3333333333333333,
              "#9c179e"
             ],
             [
              0.4444444444444444,
              "#bd3786"
             ],
             [
              0.5555555555555556,
              "#d8576b"
             ],
             [
              0.6666666666666666,
              "#ed7953"
             ],
             [
              0.7777777777777778,
              "#fb9f3a"
             ],
             [
              0.8888888888888888,
              "#fdca26"
             ],
             [
              1,
              "#f0f921"
             ]
            ],
            "type": "histogram2dcontour"
           }
          ],
          "mesh3d": [
           {
            "colorbar": {
             "outlinewidth": 0,
             "ticks": ""
            },
            "type": "mesh3d"
           }
          ],
          "parcoords": [
           {
            "line": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "type": "parcoords"
           }
          ],
          "pie": [
           {
            "automargin": true,
            "type": "pie"
           }
          ],
          "scatter": [
           {
            "fillpattern": {
             "fillmode": "overlay",
             "size": 10,
             "solidity": 0.2
            },
            "type": "scatter"
           }
          ],
          "scatter3d": [
           {
            "line": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "marker": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "type": "scatter3d"
           }
          ],
          "scattercarpet": [
           {
            "marker": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "type": "scattercarpet"
           }
          ],
          "scattergeo": [
           {
            "marker": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "type": "scattergeo"
           }
          ],
          "scattergl": [
           {
            "marker": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "type": "scattergl"
           }
          ],
          "scattermapbox": [
           {
            "marker": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "type": "scattermapbox"
           }
          ],
          "scatterpolar": [
           {
            "marker": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "type": "scatterpolar"
           }
          ],
          "scatterpolargl": [
           {
            "marker": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "type": "scatterpolargl"
           }
          ],
          "scatterternary": [
           {
            "marker": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "type": "scatterternary"
           }
          ],
          "surface": [
           {
            "colorbar": {
             "outlinewidth": 0,
             "ticks": ""
            },
            "colorscale": [
             [
              0,
              "#0d0887"
             ],
             [
              0.1111111111111111,
              "#46039f"
             ],
             [
              0.2222222222222222,
              "#7201a8"
             ],
             [
              0.3333333333333333,
              "#9c179e"
             ],
             [
              0.4444444444444444,
              "#bd3786"
             ],
             [
              0.5555555555555556,
              "#d8576b"
             ],
             [
              0.6666666666666666,
              "#ed7953"
             ],
             [
              0.7777777777777778,
              "#fb9f3a"
             ],
             [
              0.8888888888888888,
              "#fdca26"
             ],
             [
              1,
              "#f0f921"
             ]
            ],
            "type": "surface"
           }
          ],
          "table": [
           {
            "cells": {
             "fill": {
              "color": "#EBF0F8"
             },
             "line": {
              "color": "white"
             }
            },
            "header": {
             "fill": {
              "color": "#C8D4E3"
             },
             "line": {
              "color": "white"
             }
            },
            "type": "table"
           }
          ]
         },
         "layout": {
          "annotationdefaults": {
           "arrowcolor": "#2a3f5f",
           "arrowhead": 0,
           "arrowwidth": 1
          },
          "autotypenumbers": "strict",
          "coloraxis": {
           "colorbar": {
            "outlinewidth": 0,
            "ticks": ""
           }
          },
          "colorscale": {
           "diverging": [
            [
             0,
             "#8e0152"
            ],
            [
             0.1,
             "#c51b7d"
            ],
            [
             0.2,
             "#de77ae"
            ],
            [
             0.3,
             "#f1b6da"
            ],
            [
             0.4,
             "#fde0ef"
            ],
            [
             0.5,
             "#f7f7f7"
            ],
            [
             0.6,
             "#e6f5d0"
            ],
            [
             0.7,
             "#b8e186"
            ],
            [
             0.8,
             "#7fbc41"
            ],
            [
             0.9,
             "#4d9221"
            ],
            [
             1,
             "#276419"
            ]
           ],
           "sequential": [
            [
             0,
             "#0d0887"
            ],
            [
             0.1111111111111111,
             "#46039f"
            ],
            [
             0.2222222222222222,
             "#7201a8"
            ],
            [
             0.3333333333333333,
             "#9c179e"
            ],
            [
             0.4444444444444444,
             "#bd3786"
            ],
            [
             0.5555555555555556,
             "#d8576b"
            ],
            [
             0.6666666666666666,
             "#ed7953"
            ],
            [
             0.7777777777777778,
             "#fb9f3a"
            ],
            [
             0.8888888888888888,
             "#fdca26"
            ],
            [
             1,
             "#f0f921"
            ]
           ],
           "sequentialminus": [
            [
             0,
             "#0d0887"
            ],
            [
             0.1111111111111111,
             "#46039f"
            ],
            [
             0.2222222222222222,
             "#7201a8"
            ],
            [
             0.3333333333333333,
             "#9c179e"
            ],
            [
             0.4444444444444444,
             "#bd3786"
            ],
            [
             0.5555555555555556,
             "#d8576b"
            ],
            [
             0.6666666666666666,
             "#ed7953"
            ],
            [
             0.7777777777777778,
             "#fb9f3a"
            ],
            [
             0.8888888888888888,
             "#fdca26"
            ],
            [
             1,
             "#f0f921"
            ]
           ]
          },
          "colorway": [
           "#636efa",
           "#EF553B",
           "#00cc96",
           "#ab63fa",
           "#FFA15A",
           "#19d3f3",
           "#FF6692",
           "#B6E880",
           "#FF97FF",
           "#FECB52"
          ],
          "font": {
           "color": "#2a3f5f"
          },
          "geo": {
           "bgcolor": "white",
           "lakecolor": "white",
           "landcolor": "#E5ECF6",
           "showlakes": true,
           "showland": true,
           "subunitcolor": "white"
          },
          "hoverlabel": {
           "align": "left"
          },
          "hovermode": "closest",
          "mapbox": {
           "style": "light"
          },
          "paper_bgcolor": "white",
          "plot_bgcolor": "#E5ECF6",
          "polar": {
           "angularaxis": {
            "gridcolor": "white",
            "linecolor": "white",
            "ticks": ""
           },
           "bgcolor": "#E5ECF6",
           "radialaxis": {
            "gridcolor": "white",
            "linecolor": "white",
            "ticks": ""
           }
          },
          "scene": {
           "xaxis": {
            "backgroundcolor": "#E5ECF6",
            "gridcolor": "white",
            "gridwidth": 2,
            "linecolor": "white",
            "showbackground": true,
            "ticks": "",
            "zerolinecolor": "white"
           },
           "yaxis": {
            "backgroundcolor": "#E5ECF6",
            "gridcolor": "white",
            "gridwidth": 2,
            "linecolor": "white",
            "showbackground": true,
            "ticks": "",
            "zerolinecolor": "white"
           },
           "zaxis": {
            "backgroundcolor": "#E5ECF6",
            "gridcolor": "white",
            "gridwidth": 2,
            "linecolor": "white",
            "showbackground": true,
            "ticks": "",
            "zerolinecolor": "white"
           }
          },
          "shapedefaults": {
           "line": {
            "color": "#2a3f5f"
           }
          },
          "ternary": {
           "aaxis": {
            "gridcolor": "white",
            "linecolor": "white",
            "ticks": ""
           },
           "baxis": {
            "gridcolor": "white",
            "linecolor": "white",
            "ticks": ""
           },
           "bgcolor": "#E5ECF6",
           "caxis": {
            "gridcolor": "white",
            "linecolor": "white",
            "ticks": ""
           }
          },
          "title": {
           "x": 0.05
          },
          "xaxis": {
           "automargin": true,
           "gridcolor": "white",
           "linecolor": "white",
           "ticks": "",
           "title": {
            "standoff": 15
           },
           "zerolinecolor": "white",
           "zerolinewidth": 2
          },
          "yaxis": {
           "automargin": true,
           "gridcolor": "white",
           "linecolor": "white",
           "ticks": "",
           "title": {
            "standoff": 15
           },
           "zerolinecolor": "white",
           "zerolinewidth": 2
          }
         }
        },
        "title": {
         "text": "How Strong 19.8 Writes in the Name Embed Direction Relative to Attn Prob"
        },
        "xaxis": {
         "anchor": "y",
         "domain": [
          0,
          1
         ],
         "title": {
          "text": "Attn Prob on Name"
         }
        },
        "yaxis": {
         "anchor": "x",
         "domain": [
          0,
          1
         ],
         "title": {
          "text": "Dot w Name Embed"
         }
        }
       }
      },
      "text/html": [
       "<div>                            <div id=\"c5d90fbf-355a-4d3f-b9c2-d64508f644b4\" class=\"plotly-graph-div\" style=\"height:525px; width:100%;\"></div>            <script type=\"text/javascript\">                require([\"plotly\"], function(Plotly) {                    window.PLOTLYENV=window.PLOTLYENV || {};                                    if (document.getElementById(\"c5d90fbf-355a-4d3f-b9c2-d64508f644b4\")) {                    Plotly.newPlot(                        \"c5d90fbf-355a-4d3f-b9c2-d64508f644b4\",                        [{\"customdata\":[[\"We confirm that USA's capital is Washington\"],[\"We confirm that Spain's capital is Madrid\"],[\"It's crucial to know that Italy's capital is Rome\"],[\"In case you didn't know, Italy's capital is Rome\"],[\"Just a reminder, Japan's capital is Tokyo\"],[\"It's crucial to know that Australia's capital is Canberra\"],[\"I am sure that China's capital is Beijing\"],[\"Without a doubt, France's capital is Paris\"],[\"In case you didn't know, Austria's capital is Vienna\"],[\"Just a reminder, Spain's capital is Madrid\"],[\"To emphasize, Russia's capital is Moscow\"],[\"Bear in mind, China's capital is Beijing\"],[\"Therefore, it's correct to state that USA's capital is Washington\"],[\"It's crucial to know that Greece's capital is Athens\"],[\"Bear in mind, Egypt's capital is Cairo\"],[\"According to the textbook, USA's capital is Washington\"],[\"I am sure that Portugal's capital is Lisbon\"],[\"We confirm that Greece's capital is Athens\"],[\"Just a reminder, Portugal's capital is Lisbon\"],[\"Bear in mind, Austria's capital is Vienna\"],[\"I am sure that Egypt's capital is Cairo\"],[\"It's crucial to know that Japan's capital is Tokyo\"],[\"When asked, always remember that China's capital is Beijing\"],[\"In case you didn't know, China's capital is Beijing\"],[\"You are right to say that Italy's capital is Rome\"],[\"When asked, always remember that Australia's capital is Canberra\"],[\"To emphasize, China's capital is Beijing\"],[\"Just a reminder, Austria's capital is Vienna\"],[\"Don't forget, Italy's capital is Rome\"],[\"We confirm that China's capital is Beijing\"],[\"According to the textbook, Canada's capital is Ottawa\"],[\"Keep in mind, Canada's capital is Ottawa\"],[\"You are right to say that Canada's capital is Ottawa\"],[\"Therefore, it's correct to state that Egypt's capital is Cairo\"],[\"We confirm that France's capital is Paris\"],[\"Just a reminder, France's capital is Paris\"],[\"Bear in mind, Spain's capital is Madrid\"],[\"Keep in mind, Greece's capital is Athens\"],[\"It's crucial to know that Spain's capital is Madrid\"],[\"As we all know, France's capital is Paris\"],[\"It's crucial to know that Portugal's capital is Lisbon\"],[\"Just a reminder, Greece's capital is Athens\"],[\"As we all know, Egypt's capital is Cairo\"],[\"Therefore, it's correct to state that Greece's capital is Athens\"],[\"According to the textbook, Australia's capital is Canberra\"],[\"I am sure that Greece's capital is Athens\"],[\"We confirm that Italy's capital is Rome\"],[\"To emphasize, England's capital is London\"],[\"Therefore, it's correct to state that Italy's capital is Rome\"],[\"Therefore, it's correct to state that England's capital is London\"],[\"Without a doubt, Austria's capital is Vienna\"],[\"To emphasize, Austria's capital is Vienna\"],[\"I am sure that Japan's capital is Tokyo\"],[\"Don't forget, England's capital is London\"],[\"It's crucial to know that Egypt's capital is Cairo\"],[\"Bear in mind, France's capital is Paris\"],[\"As we all know, China's capital is Beijing\"],[\"Bear in mind, Russia's capital is Moscow\"],[\"It's crucial to know that England's capital is London\"],[\"When asked, always remember that Italy's capital is Rome\"],[\"We confirm that Portugal's capital is Lisbon\"],[\"As we all know, Russia's capital is Moscow\"],[\"To emphasize, Canada's capital is Ottawa\"],[\"Keep in mind, Spain's capital is Madrid\"],[\"I am sure that France's capital is Paris\"],[\"Keep in mind, France's capital is Paris\"],[\"Don't forget, Canada's capital is Ottawa\"],[\"According to the textbook, Italy's capital is Rome\"],[\"Just a reminder, Italy's capital is Rome\"],[\"I am sure that England's capital is London\"],[\"Without a doubt, China's capital is Beijing\"],[\"To emphasize, Greece's capital is Athens\"],[\"Therefore, it's correct to state that China's capital is Beijing\"],[\"When asked, always remember that Japan's capital is Tokyo\"],[\"Keep in mind, Russia's capital is Moscow\"],[\"According to the textbook, Spain's capital is Madrid\"],[\"I am sure that Canada's capital is Ottawa\"],[\"To emphasize, Japan's capital is Tokyo\"],[\"Just a reminder, Australia's capital is Canberra\"],[\"We confirm that Japan's capital is Tokyo\"],[\"You are right to say that Spain's capital is Madrid\"],[\"When asked, always remember that England's capital is London\"],[\"Just a reminder, USA's capital is Washington\"],[\"When asked, always remember that Spain's capital is Madrid\"],[\"Keep in mind, Austria's capital is Vienna\"],[\"When asked, always remember that Russia's capital is Moscow\"],[\"I am sure that USA's capital is Washington\"],[\"Without a doubt, Egypt's capital is Cairo\"],[\"When asked, always remember that Greece's capital is Athens\"],[\"I am sure that Italy's capital is Rome\"],[\"As we all know, Portugal's capital is Lisbon\"],[\"In case you didn't know, Portugal's capital is Lisbon\"],[\"I am sure that Austria's capital is Vienna\"],[\"According to the textbook, England's capital is London\"],[\"It's crucial to know that France's capital is Paris\"],[\"In case you didn't know, England's capital is London\"],[\"In case you didn't know, Spain's capital is Madrid\"],[\"In case you didn't know, Greece's capital is Athens\"],[\"You are right to say that Australia's capital is Canberra\"],[\"We confirm that Austria's capital is Vienna\"],[\"Therefore, it's correct to state that Thailand's capital is Bangkok\"],[\"According to the textbook, China's capital is Beijing\"],[\"Bear in mind, Greece's capital is Athens\"],[\"According to the textbook, Greece's capital is Athens\"],[\"As we all know, USA's capital is Washington\"],[\"Therefore, it's correct to state that Australia's capital is Canberra\"],[\"It's crucial to know that Austria's capital is Vienna\"],[\"As we all know, Thailand's capital is Bangkok\"],[\"Bear in mind, Canada's capital is Ottawa\"],[\"Just a reminder, Canada's capital is Ottawa\"],[\"Without a doubt, Japan's capital is Tokyo\"],[\"Without a doubt, Spain's capital is Madrid\"],[\"Don't forget, Spain's capital is Madrid\"],[\"To emphasize, Australia's capital is Canberra\"],[\"When asked, always remember that Canada's capital is Ottawa\"],[\"According to the textbook, France's capital is Paris\"],[\"Bear in mind, Japan's capital is Tokyo\"],[\"You are right to say that Egypt's capital is Cairo\"],[\"You are right to say that England's capital is London\"],[\"Just a reminder, Russia's capital is Moscow\"],[\"As we all know, Greece's capital is Athens\"],[\"Therefore, it's correct to state that Canada's capital is Ottawa\"],[\"Therefore, it's correct to state that France's capital is Paris\"],[\"Just a reminder, Egypt's capital is Cairo\"],[\"Bear in mind, Portugal's capital is Lisbon\"],[\"As we all know, England's capital is London\"],[\"According to the textbook, Thailand's capital is Bangkok\"],[\"Bear in mind, Australia's capital is Canberra\"],[\"Don't forget, Thailand's capital is Bangkok\"],[\"In case you didn't know, USA's capital is Washington\"],[\"Without a doubt, Italy's capital is Rome\"],[\"When asked, always remember that Egypt's capital is Cairo\"],[\"As we all know, Italy's capital is Rome\"],[\"Just a reminder, England's capital is London\"],[\"In case you didn't know, Japan's capital is Tokyo\"],[\"To emphasize, Italy's capital is Rome\"],[\"Bear in mind, Thailand's capital is Bangkok\"],[\"To emphasize, France's capital is Paris\"],[\"Don't forget, Greece's capital is Athens\"],[\"Therefore, it's correct to state that Spain's capital is Madrid\"],[\"Don't forget, Russia's capital is Moscow\"],[\"We confirm that Canada's capital is Ottawa\"],[\"To emphasize, Spain's capital is Madrid\"],[\"According to the textbook, Austria's capital is Vienna\"],[\"You are right to say that China's capital is Beijing\"],[\"In case you didn't know, France's capital is Paris\"],[\"I am sure that Russia's capital is Moscow\"],[\"Therefore, it's correct to state that Russia's capital is Moscow\"],[\"Bear in mind, Italy's capital is Rome\"],[\"Without a doubt, Russia's capital is Moscow\"],[\"When asked, always remember that USA's capital is Washington\"],[\"Without a doubt, Australia's capital is Canberra\"],[\"Bear in mind, England's capital is London\"],[\"Bear in mind, USA's capital is Washington\"],[\"When asked, always remember that Portugal's capital is Lisbon\"],[\"In case you didn't know, Russia's capital is Moscow\"],[\"Keep in mind, Japan's capital is Tokyo\"],[\"As we all know, Canada's capital is Ottawa\"],[\"Without a doubt, Thailand's capital is Bangkok\"],[\"Don't forget, France's capital is Paris\"],[\"As we all know, Japan's capital is Tokyo\"],[\"Without a doubt, Greece's capital is Athens\"],[\"You are right to say that Portugal's capital is Lisbon\"],[\"Just a reminder, China's capital is Beijing\"],[\"You are right to say that France's capital is Paris\"],[\"Therefore, it's correct to state that Austria's capital is Vienna\"],[\"To emphasize, Thailand's capital is Bangkok\"],[\"As we all know, Australia's capital is Canberra\"],[\"It's crucial to know that USA's capital is Washington\"],[\"Therefore, it's correct to state that Japan's capital is Tokyo\"],[\"In case you didn't know, Canada's capital is Ottawa\"],[\"To emphasize, USA's capital is Washington\"],[\"You are right to say that Japan's capital is Tokyo\"],[\"Keep in mind, USA's capital is Washington\"],[\"Without a doubt, England's capital is London\"],[\"In case you didn't know, Australia's capital is Canberra\"],[\"It's crucial to know that Thailand's capital is Bangkok\"],[\"Just a reminder, Thailand's capital is Bangkok\"],[\"Without a doubt, USA's capital is Washington\"],[\"According to the textbook, Portugal's capital is Lisbon\"],[\"Keep in mind, England's capital is London\"],[\"Don't forget, Japan's capital is Tokyo\"],[\"In case you didn't know, Thailand's capital is Bangkok\"],[\"As we all know, Austria's capital is Vienna\"],[\"We confirm that Thailand's capital is Bangkok\"],[\"Keep in mind, Egypt's capital is Cairo\"],[\"Keep in mind, Thailand's capital is Bangkok\"],[\"To emphasize, Portugal's capital is Lisbon\"],[\"It's crucial to know that Russia's capital is Moscow\"],[\"Keep in mind, Portugal's capital is Lisbon\"],[\"I am sure that Spain's capital is Madrid\"],[\"Therefore, it's correct to state that Portugal's capital is Lisbon\"],[\"Without a doubt, Canada's capital is Ottawa\"],[\"You are right to say that USA's capital is Washington\"],[\"I am sure that Thailand's capital is Bangkok\"],[\"When asked, always remember that France's capital is Paris\"],[\"I am sure that Australia's capital is Canberra\"],[\"Keep in mind, Italy's capital is Rome\"],[\"According to the textbook, Egypt's capital is Cairo\"],[\"You are right to say that Russia's capital is Moscow\"],[\"According to the textbook, Russia's capital is Moscow\"],[\"We confirm that Australia's capital is Canberra\"],[\"You are right to say that Greece's capital is Athens\"],[\"Don't forget, Portugal's capital is Lisbon\"],[\"We confirm that Russia's capital is Moscow\"],[\"Don't forget, Egypt's capital is Cairo\"],[\"In case you didn't know, Egypt's capital is Cairo\"],[\"When asked, always remember that Thailand's capital is Bangkok\"],[\"To emphasize, Egypt's capital is Cairo\"],[\"It's crucial to know that China's capital is Beijing\"],[\"Without a doubt, Portugal's capital is Lisbon\"],[\"Don't forget, Australia's capital is Canberra\"],[\"You are right to say that Austria's capital is Vienna\"],[\"According to the textbook, Japan's capital is Tokyo\"],[\"It's crucial to know that Canada's capital is Ottawa\"],[\"Keep in mind, China's capital is Beijing\"],[\"Don't forget, Austria's capital is Vienna\"],[\"When asked, always remember that Austria's capital is Vienna\"],[\"As we all know, Spain's capital is Madrid\"],[\"We confirm that Egypt's capital is Cairo\"],[\"You are right to say that Thailand's capital is Bangkok\"],[\"Don't forget, China's capital is Beijing\"],[\"Keep in mind, Australia's capital is Canberra\"],[\"Don't forget, USA's capital is Washington\"],[\"We confirm that England's capital is London\"]],\"hovertemplate\":\"Name Type=N\\u003cbr\\u003eAttn Prob on Name=%{x}\\u003cbr\\u003eDot w Name Embed=%{y}\\u003cbr\\u003etext=%{customdata[0]}\\u003cextra\\u003e\\u003c\\u002fextra\\u003e\",\"legendgroup\":\"N\",\"marker\":{\"color\":\"rgb(201,165,247)\",\"symbol\":\"circle\"},\"mode\":\"markers\",\"name\":\"N\",\"orientation\":\"v\",\"showlegend\":true,\"x\":[0.34745076298713684,0.42820027470588684,0.2936815023422241,0.31347042322158813,0.432434618473053,0.2375319004058838,0.42522740364074707,0.38873934745788574,0.7197966575622559,0.4484017789363861,0.48445209860801697,0.2722282111644745,0.4802234172821045,0.5318613052368164,0.3286314010620117,0.3917040228843689,0.4755116105079651,0.66773921251297,0.6381223201751709,0.6137135028839111,0.5847203135490417,0.3003503084182739,0.5281215906143188,0.36391380429267883,0.3495882451534271,0.27480584383010864,0.3402244448661804,0.7157672643661499,0.34460997581481934,0.3755418062210083,0.31750795245170593,0.2404409497976303,0.3708554804325104,0.6680185198783875,0.3316342830657959,0.2606102526187897,0.4402872323989868,0.6189605593681335,0.3736264705657959,0.3640702962875366,0.5525873899459839,0.6674913167953491,0.5373672246932983,0.6856222748756409,0.37781772017478943,0.7091772556304932,0.503950834274292,0.3561766445636749,0.5134380459785461,0.5730711221694946,0.5879976153373718,0.601539671421051,0.3523508608341217,0.29569029808044434,0.3940686583518982,0.26045602560043335,0.46905240416526794,0.5036541223526001,0.2489153891801834,0.3887014091014862,0.6317909955978394,0.6233552694320679,0.3088301420211792,0.46758732199668884,0.3519795835018158,0.2804211676120758,0.23662789165973663,0.5557158589363098,0.37336957454681396,0.24133755266666412,0.37355974316596985,0.5466379523277283,0.5286409854888916,0.45997023582458496,0.5784478187561035,0.625218391418457,0.3205670118331909,0.3760332465171814,0.23782622814178467,0.5663915872573853,0.3944265842437744,0.4438696801662445,0.278372198343277,0.5274816751480103,0.6331685781478882,0.571631669998169,0.3574516773223877,0.38775816559791565,0.6622782349586487,0.3557772934436798,0.5303683280944824,0.5472798347473145,0.4676080644130707,0.5574571490287781,0.2573126554489136,0.3080665171146393,0.42576050758361816,0.5978826284408569,0.3619488775730133,0.655238687992096,0.011176064610481262,0.40540221333503723,0.5430893301963806,0.7713394165039062,0.3229054808616638,0.3165380358695984,0.5392525792121887,0.01832951232790947,0.22329528629779816,0.2234455794095993,0.4234798848628998,0.3664326071739197,0.48566949367523193,0.27139610052108765,0.3121064007282257,0.46014878153800964,0.35715678334236145,0.4820980429649353,0.25581109523773193,0.4998376965522766,0.6996603012084961,0.48122045397758484,0.3563530445098877,0.6026270985603333,0.4856310486793518,0.3443905711174011,0.0036273777950555086,0.17171770334243774,0.006979987025260925,0.2346375435590744,0.35086295008659363,0.5715749263763428,0.36582642793655396,0.30313700437545776,0.3582017123699188,0.31690293550491333,0.011087908409535885,0.25845104455947876,0.5646870732307434,0.6950161457061768,0.4847581684589386,0.3657759130001068,0.40971362590789795,0.7340898513793945,0.39501723647117615,0.28668642044067383,0.6792128682136536,0.7052122354507446,0.3465271294116974,0.4825208783149719,0.4215407073497772,0.3309236168861389,0.37633392214775085,0.28300464153289795,0.5833210945129395,0.4781838357448578,0.4184950590133667,0.25169724225997925,0.003159430343657732,0.2564563751220703,0.41262003779411316,0.35350915789604187,0.5186822414398193,0.35487687587738037,0.2690088450908661,0.722389817237854,0.01986098475754261,0.2651248574256897,0.29389792680740356,0.5177954435348511,0.2468753159046173,0.29121482372283936,0.43382906913757324,0.31343579292297363,0.2921193242073059,0.21653041243553162,0.016188574954867363,0.006053120829164982,0.1908806711435318,0.7009863257408142,0.39502355456352234,0.4159775674343109,0.005194514524191618,0.7227115631103516,0.013898801989853382,0.4354477822780609,0.015185080468654633,0.4642567038536072,0.5108619928359985,0.5446844696998596,0.3382142186164856,0.6821557283401489,0.387888640165329,0.3023023307323456,0.015058201737701893,0.35621029138565063,0.48393160104751587,0.35414940118789673,0.629386305809021,0.589766800403595,0.5533853769302368,0.30603235960006714,0.6727169156074524,0.5692193508148193,0.6412740349769592,0.536480188369751,0.4730701148509979,0.010170924477279186,0.3976261615753174,0.3165673017501831,0.44195884466171265,0.2189764380455017,0.6045020818710327,0.4016343951225281,0.213541179895401,0.33307117223739624,0.6802750825881958,0.630858838558197,0.4285639226436615,0.6213722229003906,0.01144005823880434,0.3747044503688812,0.19974370300769806,0.32907596230506897,0.27751174569129944],\"xaxis\":\"x\",\"y\":[1.2551472187042236,2.017150640487671,1.93413245677948,2.2383148670196533,2.1165430545806885,1.806028127670288,2.1107900142669678,2.0707993507385254,1.9728095531463623,2.0805158615112305,2.3587515354156494,1.5949172973632812,1.353987455368042,1.9054388999938965,0.9992531538009644,1.2041890621185303,1.701285481452942,2.537287950515747,2.2312865257263184,1.7540584802627563,1.6399484872817993,1.5922390222549438,2.700216054916382,2.159479856491089,2.2036190032958984,1.8630281686782837,1.989184021949768,1.9171462059020996,2.0043716430664062,2.320984363555908,2.061433792114258,1.9056750535964966,2.5528993606567383,1.8471252918243408,2.031529664993286,1.6256123781204224,2.1090214252471924,2.3314149379730225,1.7327886819839478,2.174449920654297,1.8010026216506958,2.501007080078125,1.641791582107544,2.597630739212036,2.2558772563934326,2.5984082221984863,2.7856032848358154,1.955216646194458,2.583505153656006,2.2298407554626465,1.684478521347046,1.7830466032028198,1.7085908651351929,1.5557173490524292,1.1121996641159058,1.682915449142456,2.493037700653076,2.4626128673553467,1.5005202293395996,2.1420648097991943,2.0593814849853516,2.973938465118408,2.3082275390625,2.127581834793091,1.8831422328948975,1.7777469158172607,1.954166293144226,2.806502342224121,2.184587001800537,1.1447099447250366,2.0500106811523438,2.1741323471069336,2.5759899616241455,2.183518409729004,2.6265478134155273,2.559183120727539,2.2548656463623047,1.950556755065918,1.8446834087371826,2.499849319458008,2.0015790462493896,2.145003318786621,1.0007812976837158,2.4230384826660156,1.7576245069503784,2.708780288696289,1.1244163513183594,1.1549853086471558,2.6012918949127197,1.9010087251663208,2.050159215927124,2.0421950817108154,1.381906270980835,2.6207587718963623,1.502358317375183,1.8719499111175537,2.012434720993042,2.443943500518799,2.308339834213257,1.8295607566833496,0.7235036492347717,2.0156359672546387,2.187072992324829,2.797858715057373,1.1508926153182983,1.844444990158081,1.5399572849273682,0.6792032718658447,1.9327490329742432,2.0580334663391113,1.9976054430007935,1.7192727327346802,2.235130548477173,2.014965772628784,2.2573180198669434,2.143587589263916,1.8143484592437744,1.4677695035934448,1.3407492637634277,2.429264783859253,2.9127509593963623,2.582345962524414,1.7831629514694214,1.7592337131500244,1.804045557975769,1.9993871450424194,0.71364426612854,1.3697967529296875,0.7070242762565613,0.9317309856414795,2.1669516563415527,1.5678648948669434,2.4686596393585205,1.643566608428955,1.7987293004989624,2.0228919982910156,0.5235559344291687,1.6905503273010254,2.1664717197418213,2.7638907432556152,2.4033613204956055,2.449946165084839,1.9531410932540894,2.011861801147461,2.156848430633545,1.7973748445510864,2.840200424194336,2.9208648204803467,2.126168966293335,2.34790301322937,1.2586231231689453,2.273928165435791,1.8723396062850952,0.9628999829292297,2.0804266929626465,2.3943395614624023,2.042677402496338,2.3372232913970947,0.5599502325057983,1.5218349695205688,2.0631399154663086,1.4728456735610962,1.961948037147522,2.0522937774658203,1.7819019556045532,1.9701566696166992,0.5455469489097595,2.150660753250122,0.9766523838043213,2.257201910018921,2.2641539573669434,1.0305532217025757,2.1752638816833496,0.980658769607544,1.6028634309768677,1.8413478136062622,0.5098368525505066,0.7043647766113281,0.8409672975540161,2.356609344482422,2.094879150390625,2.038724660873413,0.6414979696273804,2.0847036838531494,0.6806398034095764,1.2335383892059326,0.6205278038978577,1.8089313507080078,2.221510648727417,2.0026051998138428,1.5551875829696655,2.2438204288482666,2.638360023498535,1.0240015983581543,0.5241715908050537,1.920371651649475,2.789994239807129,2.130768060684204,1.6048779487609863,2.619584560394287,2.546656608581543,2.009530782699585,2.7143096923828125,2.0617287158966064,2.8912127017974854,1.5445789098739624,1.4410961866378784,0.6380906701087952,1.2341986894607544,1.6540107727050781,1.7435405254364014,1.5938323736190796,1.7831695079803467,1.9032901525497437,1.8928700685501099,1.872557282447815,1.8748869895935059,1.880104422569275,2.1258983612060547,1.723055124282837,0.6127315163612366,2.0649025440216064,1.5399030447006226,1.1033382415771484,1.4114186763763428],\"yaxis\":\"y\",\"type\":\"scatter\"}],                        {\"template\":{\"data\":{\"histogram2dcontour\":[{\"type\":\"histogram2dcontour\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]]}],\"choropleth\":[{\"type\":\"choropleth\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}],\"histogram2d\":[{\"type\":\"histogram2d\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]]}],\"heatmap\":[{\"type\":\"heatmap\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]]}],\"heatmapgl\":[{\"type\":\"heatmapgl\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]]}],\"contourcarpet\":[{\"type\":\"contourcarpet\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}],\"contour\":[{\"type\":\"contour\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]]}],\"surface\":[{\"type\":\"surface\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"},\"colorscale\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]]}],\"mesh3d\":[{\"type\":\"mesh3d\",\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}],\"scatter\":[{\"fillpattern\":{\"fillmode\":\"overlay\",\"size\":10,\"solidity\":0.2},\"type\":\"scatter\"}],\"parcoords\":[{\"type\":\"parcoords\",\"line\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scatterpolargl\":[{\"type\":\"scatterpolargl\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"bar\":[{\"error_x\":{\"color\":\"#2a3f5f\"},\"error_y\":{\"color\":\"#2a3f5f\"},\"marker\":{\"line\":{\"color\":\"#E5ECF6\",\"width\":0.5},\"pattern\":{\"fillmode\":\"overlay\",\"size\":10,\"solidity\":0.2}},\"type\":\"bar\"}],\"scattergeo\":[{\"type\":\"scattergeo\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scatterpolar\":[{\"type\":\"scatterpolar\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"histogram\":[{\"marker\":{\"pattern\":{\"fillmode\":\"overlay\",\"size\":10,\"solidity\":0.2}},\"type\":\"histogram\"}],\"scattergl\":[{\"type\":\"scattergl\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scatter3d\":[{\"type\":\"scatter3d\",\"line\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}},\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scattermapbox\":[{\"type\":\"scattermapbox\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scatterternary\":[{\"type\":\"scatterternary\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"scattercarpet\":[{\"type\":\"scattercarpet\",\"marker\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}}}],\"carpet\":[{\"aaxis\":{\"endlinecolor\":\"#2a3f5f\",\"gridcolor\":\"white\",\"linecolor\":\"white\",\"minorgridcolor\":\"white\",\"startlinecolor\":\"#2a3f5f\"},\"baxis\":{\"endlinecolor\":\"#2a3f5f\",\"gridcolor\":\"white\",\"linecolor\":\"white\",\"minorgridcolor\":\"white\",\"startlinecolor\":\"#2a3f5f\"},\"type\":\"carpet\"}],\"table\":[{\"cells\":{\"fill\":{\"color\":\"#EBF0F8\"},\"line\":{\"color\":\"white\"}},\"header\":{\"fill\":{\"color\":\"#C8D4E3\"},\"line\":{\"color\":\"white\"}},\"type\":\"table\"}],\"barpolar\":[{\"marker\":{\"line\":{\"color\":\"#E5ECF6\",\"width\":0.5},\"pattern\":{\"fillmode\":\"overlay\",\"size\":10,\"solidity\":0.2}},\"type\":\"barpolar\"}],\"pie\":[{\"automargin\":true,\"type\":\"pie\"}]},\"layout\":{\"autotypenumbers\":\"strict\",\"colorway\":[\"#636efa\",\"#EF553B\",\"#00cc96\",\"#ab63fa\",\"#FFA15A\",\"#19d3f3\",\"#FF6692\",\"#B6E880\",\"#FF97FF\",\"#FECB52\"],\"font\":{\"color\":\"#2a3f5f\"},\"hovermode\":\"closest\",\"hoverlabel\":{\"align\":\"left\"},\"paper_bgcolor\":\"white\",\"plot_bgcolor\":\"#E5ECF6\",\"polar\":{\"bgcolor\":\"#E5ECF6\",\"angularaxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\"},\"radialaxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\"}},\"ternary\":{\"bgcolor\":\"#E5ECF6\",\"aaxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\"},\"baxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\"},\"caxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\"}},\"coloraxis\":{\"colorbar\":{\"outlinewidth\":0,\"ticks\":\"\"}},\"colorscale\":{\"sequential\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]],\"sequentialminus\":[[0.0,\"#0d0887\"],[0.1111111111111111,\"#46039f\"],[0.2222222222222222,\"#7201a8\"],[0.3333333333333333,\"#9c179e\"],[0.4444444444444444,\"#bd3786\"],[0.5555555555555556,\"#d8576b\"],[0.6666666666666666,\"#ed7953\"],[0.7777777777777778,\"#fb9f3a\"],[0.8888888888888888,\"#fdca26\"],[1.0,\"#f0f921\"]],\"diverging\":[[0,\"#8e0152\"],[0.1,\"#c51b7d\"],[0.2,\"#de77ae\"],[0.3,\"#f1b6da\"],[0.4,\"#fde0ef\"],[0.5,\"#f7f7f7\"],[0.6,\"#e6f5d0\"],[0.7,\"#b8e186\"],[0.8,\"#7fbc41\"],[0.9,\"#4d9221\"],[1,\"#276419\"]]},\"xaxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\",\"title\":{\"standoff\":15},\"zerolinecolor\":\"white\",\"automargin\":true,\"zerolinewidth\":2},\"yaxis\":{\"gridcolor\":\"white\",\"linecolor\":\"white\",\"ticks\":\"\",\"title\":{\"standoff\":15},\"zerolinecolor\":\"white\",\"automargin\":true,\"zerolinewidth\":2},\"scene\":{\"xaxis\":{\"backgroundcolor\":\"#E5ECF6\",\"gridcolor\":\"white\",\"linecolor\":\"white\",\"showbackground\":true,\"ticks\":\"\",\"zerolinecolor\":\"white\",\"gridwidth\":2},\"yaxis\":{\"backgroundcolor\":\"#E5ECF6\",\"gridcolor\":\"white\",\"linecolor\":\"white\",\"showbackground\":true,\"ticks\":\"\",\"zerolinecolor\":\"white\",\"gridwidth\":2},\"zaxis\":{\"backgroundcolor\":\"#E5ECF6\",\"gridcolor\":\"white\",\"linecolor\":\"white\",\"showbackground\":true,\"ticks\":\"\",\"zerolinecolor\":\"white\",\"gridwidth\":2}},\"shapedefaults\":{\"line\":{\"color\":\"#2a3f5f\"}},\"annotationdefaults\":{\"arrowcolor\":\"#2a3f5f\",\"arrowhead\":0,\"arrowwidth\":1},\"geo\":{\"bgcolor\":\"white\",\"landcolor\":\"#E5ECF6\",\"subunitcolor\":\"white\",\"showland\":true,\"showlakes\":true,\"lakecolor\":\"white\"},\"title\":{\"x\":0.05},\"mapbox\":{\"style\":\"light\"}}},\"xaxis\":{\"anchor\":\"y\",\"domain\":[0.0,1.0],\"title\":{\"text\":\"Attn Prob on Name\"}},\"yaxis\":{\"anchor\":\"x\",\"domain\":[0.0,1.0],\"title\":{\"text\":\"Dot w Name Embed\"}},\"legend\":{\"title\":{\"text\":\"Name Type\"},\"tracegroupgap\":0},\"title\":{\"text\":\"How Strong 19.8 Writes in the Name Embed Direction Relative to Attn Prob\"}},                        {\"responsive\": true}                    ).then(function(){\n",
       "                            \n",
       "var gd = document.getElementById('c5d90fbf-355a-4d3f-b9c2-d64508f644b4');\n",
       "var x = new MutationObserver(function (mutations, observer) {{\n",
       "        var display = window.getComputedStyle(gd).display;\n",
       "        if (!display || display === 'none') {{\n",
       "            console.log([gd, 'removed!']);\n",
       "            Plotly.purge(gd);\n",
       "            observer.disconnect();\n",
       "        }}\n",
       "}});\n",
       "\n",
       "// Listen for the removal of the full notebook cells\n",
       "var notebookContainer = gd.closest('#notebook-container');\n",
       "if (notebookContainer) {{\n",
       "    x.observe(notebookContainer, {childList: true});\n",
       "}}\n",
       "\n",
       "// Listen for the clearing of the current output cell\n",
       "var outputEl = gd.closest('.output');\n",
       "if (outputEl) {{\n",
       "    x.observe(outputEl, {childList: true});\n",
       "}}\n",
       "\n",
       "                        })                };                });            </script>        </div>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Writing direction results\n",
    "# (change the layer_no and head_no)\n",
    "from easy_transformer.fact_dataset_llama import (\n",
    "    FactDataset,\n",
    ")\n",
    "f_dataset = FactDataset(\n",
    "    prompt_type=\"NCNC\",\n",
    "    N=1000,\n",
    "    tokenizer=model.tokenizer,\n",
    "    prepend_bos=False,\n",
    "    counterfact=False,\n",
    ")\n",
    "f_dataset = f_dataset#.add_a_shot()#.add_a_shot()#.add_a_shot()\n",
    "\n",
    "scatter_attention_and_contribution(\n",
    "    model=model, layer_no=19, head_no=8, ioi_dataset=f_dataset, figure_save_dir=figure_save_dir,\n",
    ")\n",
    "model.reset_hooks()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## The capital probs after each layer at [END] position"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/home/shared/meta-llama/Llama-2-7b-chat-hf\n",
      "[12077, 8314]\n"
     ]
    }
   ],
   "source": [
    "# import matplotlib.pyplot as plt\n",
    "# x_list = []\n",
    "# y_list = []\n",
    "# x_var = []\n",
    "# y_var = []\n",
    "# cache = {}\n",
    "from easy_transformer.fact_dataset_llama import (\n",
    "    FactDataset,\n",
    ")\n",
    "print(model.tokenizer.name_or_path)\n",
    "f_dataset = FactDataset(\n",
    "    prompt_type=\"NCNC\",\n",
    "    N=2,\n",
    "    tokenizer=model.tokenizer,\n",
    "    prepend_bos=False,\n",
    "    counterfact=False,\n",
    ")\n",
    "# f_dataset = f_dataset.add_a_shot()\n",
    "# # f_dataset = f_dataset.add_a_shot().add_a_shot()\n",
    "\n",
    "# print(f_dataset.ioi_prompts[:2])\n",
    "# print(f_dataset.tokenized_prompts[-2:])\n",
    "# print(f_dataset.toks[-2:])\n",
    "# print(f_dataset.word_idx['end'][-2:])\n",
    "# print(f_dataset.word_idx['N'][-2:])\n",
    "# print(f_dataset.word_idx['R'][-2:])\n",
    "print(f_dataset.N_tokenIDs[-2:])\n",
    "# print(f_dataset.IW_tokenIDs[-2:])\n",
    "# print(f_dataset.R_tokenIDs[-2:])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "metadata": {}
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Warning: There are only 225 unique data sample in dataset\n",
      "[\"<s>|Therefore|,|it|'|s|correct|to|state|that|Portugal|'|s|capital|is|Lis|bon|</s>|</s>\", \"<s>|It|'|s|cru|cial|to|know|that|Australia|'|s|capital|is|Can|ber|ra|</s>|</s>\"]\n",
      "layer 0 hook_resid_post\n",
      "layer 1 hook_resid_post\n",
      "layer 2 hook_resid_post\n",
      "layer 3 hook_resid_post\n",
      "layer 4 hook_resid_post\n",
      "layer 5 hook_resid_post\n",
      "layer 6 hook_resid_post\n",
      "layer 7 hook_resid_post\n",
      "layer 8 hook_resid_post\n",
      "layer 9 hook_resid_post\n",
      "layer 10 hook_resid_post\n",
      "layer 11 hook_resid_post\n",
      "layer 12 hook_resid_post\n",
      "layer 13 hook_resid_post\n",
      "layer 14 hook_resid_post\n",
      "layer 15 hook_resid_post\n",
      "layer 16 hook_resid_post\n",
      "layer 17 hook_resid_post\n",
      "layer 18 hook_resid_post\n",
      "layer 19 hook_resid_post\n",
      "layer 20 hook_resid_post\n",
      "layer 21 hook_resid_post\n",
      "layer 22 hook_resid_post\n",
      "layer 23 hook_resid_post\n",
      "layer 24 hook_resid_post\n",
      "layer 25 hook_resid_post\n",
      "layer 26 hook_resid_post\n",
      "layer 27 hook_resid_post\n",
      "layer 28 hook_resid_post\n",
      "layer 29 hook_resid_post\n",
      "layer 30 hook_resid_post\n",
      "layer 31 hook_resid_post\n",
      "[tensor(0.0018), tensor(0.0013), tensor(0.0018), tensor(0.0027), tensor(0.0037), tensor(0.0028), tensor(0.0021), tensor(0.0017), tensor(0.0020), tensor(0.0027), tensor(0.0064), tensor(0.0040), tensor(0.0041), tensor(0.0025), tensor(0.0121), tensor(0.0102), tensor(0.2362), tensor(0.2244), tensor(0.1019), tensor(0.7741), tensor(6.5391), tensor(8.4918), tensor(6.3262), tensor(2.0177), tensor(15.4875), tensor(4.6499), tensor(3.1172), tensor(0.4525), tensor(0.1293), tensor(0.1107), tensor(0.0667), tensor(0.1576)]\n",
      "[tensor(0.0090), tensor(0.0070), tensor(0.0097), tensor(0.0136), tensor(0.0136), tensor(0.0075), tensor(0.0115), tensor(0.0054), tensor(0.0037), tensor(0.0055), tensor(0.0069), tensor(0.0127), tensor(0.0118), tensor(0.0114), tensor(0.0211), tensor(0.0187), tensor(0.2087), tensor(0.8288), tensor(0.5385), tensor(5.8524), tensor(19.3353), tensor(27.9450), tensor(51.2284), tensor(50.9488), tensor(68.7978), tensor(71.1687), tensor(71.9150), tensor(69.7924), tensor(71.2339), tensor(71.3064), tensor(46.3145), tensor(29.1102)]\n",
      "[tensor(0.0017), tensor(0.0020), tensor(0.0018), tensor(0.0029), tensor(0.0073), tensor(0.0049), tensor(0.0024), tensor(0.0020), tensor(0.0033), tensor(0.0040), tensor(0.0134), tensor(0.0088), tensor(0.0066), tensor(0.0040), tensor(0.0207), tensor(0.0172), tensor(1.6987), tensor(0.9653), tensor(0.3025), tensor(2.0397), tensor(17.7071), tensor(22.3324), tensor(19.7394), tensor(6.3913), tensor(30.7298), tensor(14.1072), tensor(9.2857), tensor(1.8172), tensor(0.3207), tensor(0.2787), tensor(0.1947), tensor(0.1178)]\n",
      "[tensor(0.0204), tensor(0.0133), tensor(0.0262), tensor(0.0413), tensor(0.0288), tensor(0.0124), tensor(0.0308), tensor(0.0080), tensor(0.0068), tensor(0.0121), tensor(0.0126), tensor(0.0458), tensor(0.0409), tensor(0.0260), tensor(0.0366), tensor(0.0297), tensor(0.4594), tensor(2.1792), tensor(1.8653), tensor(16.0376), tensor(27.8607), tensor(30.2422), tensor(39.1530), tensor(39.8717), tensor(41.2458), tensor(38.3800), tensor(37.6708), tensor(39.3136), tensor(36.8962), tensor(37.3009), tensor(38.7268), tensor(24.6667)]\n"
     ]
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "x_list = []\n",
    "y_list = []\n",
    "x_var = []\n",
    "y_var = []\n",
    "cache = {}\n",
    "from easy_transformer.fact_dataset_llama import (\n",
    "    FactDataset,\n",
    ")\n",
    "f_dataset = FactDataset(\n",
    "    prompt_type=\"NCNC\",\n",
    "    N=1000,\n",
    "    tokenizer=model.tokenizer,\n",
    "    prepend_bos=False,\n",
    "    counterfact=False,\n",
    ")\n",
    "f_dataset = f_dataset#.add_a_shot()#.add_a_shot()#.add_a_shot()\n",
    "print(f_dataset.tokenized_prompts[:2])\n",
    "model.reset_hooks()\n",
    "\n",
    "model.cache_some(cache, lambda x: \"hook_resid_post\" in x, device='cuda:3') \n",
    "with torch.no_grad():\n",
    "    model(f_dataset.toks.long())\n",
    "    for layer in range(model.cfg.n_layers):\n",
    "        # model.cache_some(cache, lambda x: str(layer) in x, device='cuda:4')\n",
    "        # model(f_dataset.toks.long())\n",
    "        for point in [\"hook_resid_post\"]:\n",
    "            # model.cache_some(cache, lambda x: f\"blocks.{layer}.{point}\" in x, device='cuda:3')\n",
    "            logits = model.unembed(model.ln_final(cache[f\"blocks.{layer}.{point}\"].to('cuda:1')))\n",
    "            k = 10\n",
    "            \n",
    "\n",
    "            x_probs = []\n",
    "            y_probs = []\n",
    "\n",
    "            for seq_idx, prompt in enumerate(f_dataset.ioi_prompts):\n",
    "                \n",
    "                # pred_tokens = [\n",
    "                #         model.tokenizer.decode(token)\n",
    "                #         for token in torch.topk(\n",
    "                #             logits[seq_idx, f_dataset.word_idx['end'][seq_idx]], k\n",
    "                #         ).indices\n",
    "                #     ]\n",
    "                # print(pred_tokens)\n",
    "\n",
    "                probs = torch.softmax(logits[seq_idx, f_dataset.word_idx['end'][seq_idx]], dim=0)\n",
    "                x_probs.append(probs[f_dataset.N_tokenIDs[seq_idx]].detach().float().cpu()* 100)\n",
    "                y_probs.append(probs[f_dataset.IW_tokenIDs[seq_idx]].detach().float()* 100)\n",
    "\n",
    "            # print(logits[torch.arange(f_dataset.N), f_dataset.word_idx['end']][torch.arange(f_dataset.N), f_dataset.IW_tokenIDs].mean())\n",
    "\n",
    "            print(f'layer {layer} {point}')\n",
    "            \n",
    "            x_list.append(torch.mean(torch.tensor(x_probs)))\n",
    "            y_list.append(torch.mean(torch.tensor(y_probs)))\n",
    "            \n",
    "            x_var.append(torch.std(torch.tensor(x_probs)))\n",
    "            y_var.append(torch.std(torch.tensor(y_probs)))\n",
    "        \n",
    "model.reset_hooks()\n",
    "\n",
    "print(x_list)\n",
    "print(y_list)\n",
    "print(x_var)\n",
    "print(y_var)\n",
    "\n",
    "# fig = plt.figure(figsize=(12,8))\n",
    "# plt.plot(range(len(x_list)), x_list, marker='*', label='X', color='#00008B',linewidth=2,) # , c=colors, cmap='viridis'\n",
    "# plt.plot(range(len(x_list)), y_list, marker='*', label='Y', color='#DC143C',linewidth=2,) # , c=colors, cmap='RdBu')\n",
    "# plt.fill_between(range(len(x_list)), [a - b for a, b in zip(x_list, x_var)], [a + b for a, b in zip(x_list, x_var)], color='#00008B', alpha=0.2)\n",
    "# plt.fill_between(range(len(x_list)), [a - b for a, b in zip(y_list, y_var)], [a + b for a, b in zip(y_list, y_var)], color='#DC143C', alpha=0.2)\n",
    "\n",
    "# # plt.legend()\n",
    "# plt.xticks(range(model.cfg.n_layers), fontsize=10)\n",
    "# # fig.savefig('probability-dynamics-llama-chat-0.pdf')\n",
    "# plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "metadata": {}
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA+gAAAKYCAYAAADg9tKRAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8fJSN1AAAACXBIWXMAAA9hAAAPYQGoP6dpAADt80lEQVR4nOz9d5ib13kn/H/PU9Fmhr1JFElJLGpUM+VCyWqOEm+aE6/XcWLH3l1pneLktezYspJolUTry5JXNrNOro1fh79ETuz81nFcs4kjxVa1bFWqF2ooikWswykAHuDp57x/YAacIYfkDAfA8zzA93NdFDEACNwzFHHhi3Of+willAIRERERERERJUpLugAiIiIiIiIiYkAnIiIiIiIiSgUGdCIiIiIiIqIUYEAnIiIiIiIiSgEGdCIiIiIiIqIUYEAnIiIiIiIiSgEGdCIiIiIiIqIUMJIuoNOklNi/fz/6+voghEi6HCIiIiIiIupySilUq1WsWLECmnbidfKeC+j79+/HypUrky6DiIiIiIiIeszevXtx5plnnvD2ngvofX19ABo/mP7+/oSrISIiIiIiom5XqVSwcuXKZh49kZ4L6BNt7f39/QzoRERERERE1DGn2mbNIXFEREREREREKcCATkRERERERJQCDOhEREREREREKcCATkRERERERJQCDOhEREREREREKcCATkRERERERJQCDOhEREREREREKcCATkRERERERJQCDOhEREREREREKcCATkRERERERJQCDOhEREREREREKcCATkRERERERJQCDOhEREREREREKcCATkRERERERJQCDOhEREREREREKcCATkRERERERJQCDOhEREREREREKcCATkRERERERJQCDOhEREREREREKcCATkRERERERJQCDOhEREREREREKcCATkRERERERJQCDOhEREREREREKcCATkRERERERJQCDOhEREREREREKWAkXQAREREREc1NdPAIogNDELYFYZsQhgFh6ICuQ5gGYOgQut743dAhDMYAojTiv0wiIiIiogxTSiF88xDiQ0cgTBOIYyipANG4XSgAhg7oWiOwTwR104CWswDbgmZZzfAOfTzEm0bzMgwdQohEv0+iXsCATkRERESUYarmQpYd6AvnQ8vbx9+uFCAlEEuoOAaiGCqMoDwf0Vi1Eehj2Qz0UIDQtUag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8owoK7Ni714PysutA97f4wnD4xExalQuamudlJwTksEoQSeEEEIIIWljMmlRXe1AWZk1tkyb2x0BzwMaDXckudZ1S7SVJJuDIPDdfu6+7cQZrs1xHKqrHWhqCsDrjfT7gYPLFYbfL2Ls2DxUV9uzomI9IScyStAJIYQQQkjadV2mLRyOHunl5ql3N052ux5VVXZs3tza55z+jo4QwmEJ48blo6LCRsk5IVngxPmokRBCCCGEZBye52A0aqHTaSg5T1BFhRV2ux4dHeEet7W2BhGJyBg3rgCVldRzTki2oASdEEIIIYSQLGQ0alFX54DXG0E0Kse2t7QEAADjxxegrGzgOeqEkMxBCTohhBBCCCFZqqTEgsJCE1pbgwCAxkY/NBoe48cXJLwMGyFk6FGCTgghhBBCSJbSajWorXUiGmU4eNALg0GD8eMLUFhoHupDI4QMAhWJI4QQQgghJIsVFJhQVmaBxxPBuHH5yMkxDvUhEUIGiRJ0QgghhBBCshjPcxg1KheSxGCxZPca74Sc6ChBJ4QQQgghJMsZjdqhPgRCiApoDjohhBBCCCGEEJIBKEEnhBBCCCGEEEIyACXohBBCCCGEEEJIBqAEnRBCCCGEEEIIyQCUoBNCCCGEEEIIIRmAEnRCCCGEEEIIISQDUIJOCCGEEEIIIYRkAErQCSGEEEIIIYSQDEAJOiGEEEIIIYQQkgEoQSeEEEIIIYQQQjIAJeiEEEIIIYQQQkgGoASdEEIIIYQQQgjJAJSgE0IIIYQQQgghGSBtCbooili6dCmuueYajBw5EhaLBVarFdOmTcOf//xnSJLU52Off/55TJ06FWazGU6nExdccAE2bNiQrkMnhBBCCCGEEEJSjmOMsXQE2rZtWywxP+ecczBixAi43W785z//waFDh3DBBRfgtddeA8dx3R53//3346677kJlZSXmzJkDr9eLJUuWIBKJ4N1338X06dMTOg6PxwO73Q632w2bzabmKRJCCCGEEEIIIT3Em4emLUFvaGjAq6++imuuuQZmszm23e/348wzz8Tnn3+Ol19+GZdffnnsth07dmDUqFGoqanBp59+CrvdDgD44osvcPLJJ6OmpgZff/01eD7+gQCUoBNCCCGEEEIISad489C0DXEvLS3Fj3/8427JOQCYzWbceuutAID333+/221PPfUUotEofvnLX8aS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9uHdd99FWVkZZs2apdp+c3Nz8eCDD+K2225DfX09LrroIthsNnz55ZdYtWoVfvzjH+Omm25SLV5eXh4ApaDNyJEju922Z88eAOj23Kqtv3alc/vKlSuxY8cOlJeXp+w40ukf//gHgN4/7EzWyy+/jC1btiAQCGDz5s1YuXIlqqurce+996oea/HixdiwYQM++eQT6HQ61fd/rEWLFnX73eFw4A9/+AO+//3vq7L/PXv2oL29HZMnT8YNN9yAv/71r91unzBhAl577TWUlZWpEq83f//73wGo+6Ffp/vuuw9r1qzBZZddhgsvvBDDhw9Hc3Mzli1bhtraWrz00kuqxOnaphzL7Xajo6MDgNKuJPp+0Nt7cqrakFS+/ycbK5k2ZKBYarch/cVTuw0Z6NzUbEN6i5WqNiSR/w812pC+4qWiDektllptSDzX2Wq2H+m8rs8ElKBnCLfbDQCw2+293m6z2WL3OR6Ioojvfe97CIfDeOihh6DRaFTdfyQSwT333BP7neM4/OxnP8PixYtVjQMACxcuxI4dO7B+/XrVz+NY8+fPx+mnn44xY8bAYrFg+/bteOSRR/Dss8/inHPOwaZNm2C1WpOO09zcDAB45JFHMHHiRHz66acYOXIkNm7ciOuvvx6/+93vUFtbix/96EdJx+rNU089BVmWce2116r+nC5YsAClpaX44Q9/iL/85S+x7aeddhquvPJKVXtzZs+ejSVLluDBBx/E2WefDYPBAABoa2vDo48+CgBwuVyqxTtWPO1K1/tlu7/+9a9YsWIFzj77bJx//vmq7//ll1/G0qVLY79PnjwZS5Ys6bUnIhlffvkl7r33Xvzv//4vJk2apOq+jzVu3Dj84x//wJlnnoni4mI0Njbi9ddfx8KFC3HttdfC4XDgwgsvTDpOZ5uyceNGbNu2DU899RQuuugiuN1uPPDAA/jb3/6Gyy67TPWVLzrt2bMHq1evRkVFBc4991zV919fX49PPvkEl19+OZYtWxbbnpubi/nz56v24en06dNhs9mwfPlybNy4ERMmTIjdtnDhwtjPibYrfb0np6INSfX7fzKxkmlD4omlZhvSXzy125D+YqndhvQVKxVtSCL/H2q0If3FU7sN6SuWWm1IPNfZarYf6byuzwhDOLyedHHuuecyAGzHjh293l5SUsJsNltKYqd7DrokSezKK69kANh1112X8lgHDhxgf/rTn5jD4WDTp09nbrdbtf2vXbuW8TzP7r333m7bUzUHvS/f+9734i58FI/rrruOAWBGo5E1NDR0u23Tpk2M53lWW1urSqxjSZLEKioqGMdxbPfu3arv/5577mFarZYtXryYHThwgHm9Xvbhhx+yyZMnM0EQ2KuvvqpaLFEU2VlnncUAsLq6OnbTTTexG264gRUWFrKTTjqJAWAGgyGpGP29fp9//nkGgP3yl7/s9bG/+MUvGAC2bNmypGMdK91z0P/zn/8wrVbLKisr2aFDh1Iaq6Ojg61atYqdcsopzG63Jzwfsr944XCYjRs3jo0cObJbQaBUzUHvyzvvvMM4jmNjx45VJdaaNWsYAAaA/f73v+9xe2cF4XhXh0j0vO666y4GgC1atCiu+ycab926day4uJidd955bP369czv97Ndu3axBQsW9Dnfc7CxOguL6fV6dtVVV7HbbruNnXLKKUyn07H6+noGIKHVUfp7T1a7DUnk/T/ZNiTRa41k2pBEYyXbhvQXT+02ZLDXbINpQ/qLpXYbkuh5JduGDBRPzTZkoFhqtiH9XWer3X4MFO9Y2TwHnRL0DHHZZZcxAN0qKnZlsVhYeXl5SmKnM0GXJCmWvF599dUpXfLsWC+//DIDwG6//XZV9ieKIhs2bBgbP348i0Qi3W5Ld4L+0UcfMQDs0ksvVWV/P/vZzxgAdvrpp/d6e11dHQMw4BJMg9FZMPGcc85Rfd9vv/02A8AWLFjQ47bDhw8zo9HI6urqVI0ZCoXY3XffHVuNIT8/n11//fWxonQVFRVJ7b+/1+/rr7/OALCbbrqp18d2VqON9+IwUxP0N954g+n1elZWVsZ27dqV0lhdud1uVlRUxEpLS3u0AYONd/fddzOe59knn3zSbXu6E3TGjr7O4/1Qs79YX3/9deziure/0X333dfnhXeisY4lSRIrKytjPM/3Wvk52XiRSIRVV1ez0tJS5vf7e9x+8cUXMwDso48+SjpWpzfffJOdeeaZzGKxMKPRyGbMmME+/PBDdsEFFzAAbNWqVXHFGug9Wc02JNH3/2TakERjJdOGJHNdM5g2ZKB4arYhyV6zJdKGDBRLzTYk0fNKtg0ZKJ6abUi856ZWG9LVsdfZal+DDBTvWNmcoFORuAzROT+jt3nmjY2N8Pl8fc7hyBayLGP+/Pl45plnMG/ePDz99NPg+fT9C3bOJ+ssyJcsn8+HHTt24IsvvoBOpwPHcbGvZ555BgBwyimngOM4LF++XJWYfemcU+T3+1XZ34gRIwAoc8h607k9GAyqEq+rVBSH69RZfOWss87qcVtRURHq6+uxc+dOVQtk6fV6LFq0CN988w3C4TCam5vxxBNPoKGhAYAyxDFV+mtXum7P5rbljTfewKWXXoq8vDysXr0aNTU1aYtts9lw8skno6GhQbXiiRs3boQsyzj55JO7tSmd/7NPPPEEOI7DxRdfrEq8/nS2K4FAIOl91dbWxoZY9taupLJN+e9//4uDBw/i3HPPRUVFher737ZtG/bs2YNp06bBZDL1uL3zb7dx40bVYs6ePRurV6+G1+tFIBDA+++/j9NOOw1ff/01eJ7HxIkTB9xHPO/JarUh6Xz/TzRWMm1IsueVaBsSTzy12hA1/mbxtiHxxFKrDRnMeSXThsQTT602JJFzU6MNOdax19mpvgZR+7o+k9Ac9AxxxhlnYPHixXjrrbcwd+7cbretXLkydp9s1dlo/POf/8R3v/tdPPvssymfr32sQ4cOATha0TJZer0eP/jBD3q97YMPPsCOHTtilT6rqqpUidmXzkruasXpfDPYunVrj9tEUcTOnTthNptVr4Tc1taGV199FTk5ObjkkktU3TegzGECgJaWll5vb2lpAc/zqv2P9Of5558HgB6vdzUNGzYMJSUlWLNmDfx+f7cqqn6/H2vWrEF1dXXWFoh74403MGfOHOTk5GD16tWoq6tL+zGo3a6ce+65sYvarg4fPow333wT9fX1mD59erd5g6ng9/uxefNmmM3mXo8nUQaDAaeeeio+/PBDbNmyBaeddlq327ds2QJAvTasq1QWhwPia1cA5T0jldasWYO9e/fi/PPP73POZ6d435PVaEPS+f6faKxk2hC1ziveNiTeeGq0IWqcW7xtSLyx1GhDBnteg21D4o2nRhuixt8skTakN8f+L6f6GkTt99+MMtRd+EQhiiKrqalher2ebdy4Mbbd5XLFhsbu2bMnJbFTPcS963Cbyy+/PKXram/evLnX4UF+v5/NmjWLAWD3339/yuJ3SsUQ961bt/Z6blu3bmVFRUUMAHv//fdVi9e5dubf/va3btvvvffe2NAptf3+979nANjNN9+s+r4ZY+zFF19kANjo0aOZ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",
      "text/plain": [
       "<Figure size 1200x800 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(12,8))\n",
    "plt.plot(range(len(x_list)), x_list, marker='*', label='X', color='#00008B',linewidth=2,) # , c=colors, cmap='viridis'\n",
    "plt.plot(range(len(x_list)), y_list, marker='*', label='Y', color='#DC143C',linewidth=2,) # , c=colors, cmap='RdBu')\n",
    "plt.fill_between(range(len(x_list)), [a - b for a, b in zip(x_list, x_var)], [a + b for a, b in zip(x_list, x_var)], color='#00008B', alpha=0.2)\n",
    "plt.fill_between(range(len(x_list)), [a - b for a, b in zip(y_list, y_var)], [a + b for a, b in zip(y_list, y_var)], color='#DC143C', alpha=0.2)\n",
    "plt\n",
    "# plt.legend()\n",
    "plt.xticks(range(model.cfg.n_layers), fontsize=14)\n",
    "plt.yticks(fontsize=14)\n",
    "# fig.savefig('probability-dynamics-llama-chat-0.pdf')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## The head takes in country and output city through OV circuit "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Warning: There are only 225 unique data sample in dataset\n",
      "[{'text': \"To emphasize, Thailand's capital is Bangkok\", 'N': 'Thailand', 'C': 'Bangkok', 'R': 'capital', 'TEMPLATE_IDX': 14, 'IW answer': 'Bangkok'}, {'text': \"We confirm that France's capital is Paris\", 'N': 'France', 'C': 'Paris', 'R': 'capital', 'TEMPLATE_IDX': 4, 'IW answer': 'Paris'}]\n",
      "['Bang', 'Vietnam', 'Georgia', 'Nep', 'Georg', 'Malays', 'Sri', 'Atlanta', 'Ath', 'Greece']\n",
      "['France', 'French', 'France', 'Frankreich', 'rench', 'француз', 'Francia', 'Paris', 'францу', 'französischen']\n",
      "['Vietnam', 'Bang', 'Malays', 'Niger', 'Nep', 'Eth', 'Greek', 'Greece', 'Camb', 'Mexico']\n",
      "['France', 'French', 'France', 'rench', 'Frankreich', 'француз', 'Francia', 'францу', 'Paris', 'französischen']\n",
      "['Spain', 'Spanish', 'Span', 'Span', 'span', 'span', 'España', 'Madrid', 'Espagne', 'españ']\n",
      "['Portugal', 'Portuguese', 'portug', 'Portug', 'Lis', 'Port', 'Port', 'Porto', 'Пор', 'пор']\n",
      "['Egypt', 'gypt', 'egy', 'egy', 'Egy', 'Cleveland', 'airo', 'Ohio', 'py', 'Py']\n",
      "['Spain', 'Spanish', 'Span', 'Span', 'span', 'span', 'España', 'Madrid', 'Espagne', 'españ']\n",
      "['France', 'French', 'France', 'rench', 'Frankreich', 'француз', 'Francia', 'Paris', 'францу', 'französischen']\n",
      "['Spain', 'Spanish', 'Span', 'Span', 'span', 'span', 'España', 'Madrid', 'Espagne', 'españ']\n",
      "['Bang', 'Greek', 'Ath', 'Greece', 'Nep', 'Vietnam', 'Georgia', 'Sri', 'Beng', 'Malays']\n",
      "['Japan', 'Japanese', 'jap', 'Jap', 'Tokyo', 'Japon', '日', 'japon', 'apan', '일']\n",
      "['Bang', 'Malays', 'Nep', 'Ath', 'Sri', 'Greek', 'South', 'Greece', 'Niger', 'Mu']\n",
      "['Australia', 'Australian', 'Austral', 'Austral', 'austral', 'Melbourne', 'ustral', 'Sydney', 'Queensland', 'ав']\n",
      "['France', 'French', 'France', 'rench', 'Frankreich', 'француз', 'Francia', 'Paris', 'францу', 'französischen']\n",
      "['USA', 'USA', 'America', 'Americans', 'American', 'amer', 'US', 'America', 'США', 'American']\n",
      "['Russia', 'Russian', 'Russ', 'Rus', 'Moscow', 'russ', 'Russ', 'rus', 'Russell', 'russe']\n",
      "['Portugal', 'Portuguese', 'portug', 'Portug', 'Lis', 'Port', 'Port', 'Porto', 'Пор', 'пор']\n",
      "['Spain', 'Spanish', 'Span', 'Span', 'span', 'span', 'España', 'Madrid', 'Espagne', 'españ']\n",
      "['Italy', 'Ital', 'Italian', 'ital', 'Italia', 'Ital', 'italien', 'ital', 'Italia', 'Italien']\n",
      "layer 24 head 14 ov\n",
      "tensor(62.1358, device='cuda:0', grad_fn=<DivBackward0>)\n",
      "tensor(28.3515, device='cuda:0', grad_fn=<DivBackward0>)\n"
     ]
    }
   ],
   "source": [
    "from easy_transformer.fact_dataset_llama import (\n",
    "    FactDataset,\n",
    ")\n",
    "f_dataset = FactDataset(\n",
    "    prompt_type=\"NCNC\",\n",
    "    N=1000,\n",
    "    tokenizer=model.tokenizer,\n",
    "    prepend_bos=False,\n",
    "    counterfact=False,\n",
    ")\n",
    "f_dataset = f_dataset#.add_a_shot()#.add_a_shot()#.add_a_shot()\n",
    "\n",
    "def func(dataset):\n",
    "    cache = {}\n",
    "    \n",
    "    for layer in [24]:\n",
    "        model.cache_some(cache, lambda x: x == f\"blocks.{layer}.hook_resid_pre\", device='cuda:3') \n",
    "        model(dataset.toks.long())\n",
    "        model.blocks[layer].ln1.to('cuda:1')\n",
    "        z_0 = model.blocks[layer].ln1(cache[f\"blocks.{layer}.hook_resid_pre\"].to('cuda:1'))#.to('cuda:1')\n",
    "        # [batch pos d_model]\n",
    "        # for head in range(model.cfg.n_heads):\n",
    "        \n",
    "        head = 14\n",
    "        \n",
    "        w_v = model.blocks[layer].attn.v_proj.weight.to('cuda:1').reshape(model.cfg.n_heads, model.cfg.d_head, -1).transpose(1,2)[head]\n",
    "        # [d_model, d_head]\n",
    "\n",
    "        v = torch.einsum(\"eab,bc->eac\", z_0, w_v)\n",
    "        # v += model.blocks[layer].attn.b_V[head].unsqueeze(0).unsqueeze(0)\n",
    "        w_o = model.blocks[layer].attn.out_proj.weight.to('cuda:1').reshape(model.cfg.d_model, -1, model.cfg.d_head).transpose(0, 1)[head]\n",
    "        # [d_model, d_head]\n",
    "        o = torch.einsum(\"sph,dh->spd\", v, w_o)\n",
    "        model.ln_final.to('cuda:0')\n",
    "        model.unembed.to('cuda:0')\n",
    "        logits = model.unembed(model.ln_final(o.to('cuda:0')))\n",
    "\n",
    "        k = 10\n",
    "        for seq_idx, prompt in enumerate(dataset.ioi_prompts[:20]):\n",
    "            pred_tokens = [\n",
    "                    model.tokenizer.decode(token)\n",
    "                    for token in torch.topk(\n",
    "                        logits[seq_idx, dataset.word_idx['N'][seq_idx]], k\n",
    "                    ).indices\n",
    "                ]\n",
    "            # print(prompt)\n",
    "            print(pred_tokens)\n",
    "\n",
    "        ic_probs = 0\n",
    "        in_probs = 0\n",
    "        iw_probs = 0\n",
    "\n",
    "        for seq_idx, prompt in enumerate(dataset.ioi_prompts):\n",
    "            probs = logits[seq_idx, dataset.word_idx['N'][seq_idx]]\n",
    "            in_probs += probs[dataset.N_tokenIDs[seq_idx]]\n",
    "            iw_probs += probs[dataset.IW_tokenIDs[seq_idx]]\n",
    "\n",
    "        print(f'layer {layer} head {head} ov')\n",
    "        print(in_probs / dataset.N)\n",
    "        print(iw_probs / dataset.N)\n",
    "\n",
    "print(f_dataset.ioi_prompts[:2])\n",
    "func(f_dataset)\n",
    "\n",
    "model.reset_hooks()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## linear regression"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "metadata": {}
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Warning: There are only 225 unique data sample in dataset\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 60000/60000 [00:33<00:00, 1785.89it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "layer 23\n",
      "tensor(0.0474, device='cuda:0', grad_fn=<MseLossBackward0>)\n",
      "tensor([ 0.9842,  0.6636,  0.5232,  0.0864, -0.0688,  0.7507, -0.1709,  0.9557,\n",
      "         0.9131,  0.6968, -0.0151,  0.2713, -0.1202,  0.5458,  0.2360, -0.1036,\n",
      "         0.1955,  0.0505, -0.0597,  0.0452,  0.1732,  0.6208,  0.1229,  0.5619,\n",
      "         0.5980,  0.0535,  0.6315,  0.6369, -0.0177,  0.6642, -0.0439,  0.8610,\n",
      "         0.0314], device='cuda:0', grad_fn=<ViewBackward0>)\n",
      "tensor(0.0120, device='cuda:0', grad_fn=<DivBackward0>)\n"
     ]
    }
   ],
   "source": [
    "from sklearn.decomposition import PCA\n",
    "import matplotlib.pyplot as plt\n",
    "import torch.nn.functional as F\n",
    "import numpy as np\n",
    "from tqdm import tqdm\n",
    "from easy_transformer.fact_dataset_llama import (\n",
    "    FactDataset,\n",
    ")\n",
    "def train(dataset, layer_idx, pos, i, k):\n",
    "\n",
    "    div_size = dataset.N // k\n",
    "    train_dataset = FactDataset(prompt_type=\"NCNC\", tokenizer=model.tokenizer,prompts=dataset.ioi_prompts[:div_size * i] + dataset.ioi_prompts[div_size * (i+1):])\n",
    "    test_dataset = None\n",
    "    if k > 1:\n",
    "        test_dataset = FactDataset(prompt_type=\"NCNC\", tokenizer=model.tokenizer,  prompts=dataset.ioi_prompts[div_size * i : div_size * (i+1)])\n",
    "    cache = {}\n",
    "\n",
    "    model.cache_some(cache, lambda x: f\"blocks.{layer_idx}\" in x, device='cuda:3')\n",
    "   \n",
    "    model(train_dataset.toks.long())\n",
    "    \n",
    "    x = []\n",
    "\n",
    "    y = cache[f'blocks.{layer_idx}.hook_mlp_out'][torch.arange(train_dataset.N), train_dataset.word_idx[pos]].detach().to('cuda:0')\n",
    "    resid_pre = cache[f'blocks.{layer_idx}.hook_resid_pre'].to('cuda:0') \n",
    "    \n",
    "    for head in range(model.cfg.n_heads):\n",
    "        attn_out = cache[f'blocks.{layer_idx}.attn.hook_result'][:,:,head].to('cuda:0') # [225, seq, head_num, 4096]\n",
    "        # print(attn_out.shape)\n",
    "        tmp = attn_out[torch.arange(train_dataset.N), train_dataset.word_idx[pos]].detach()\n",
    "        # print(tmp.shape) \n",
    "        x.append(tmp) \n",
    "\n",
    "    tmp = resid_pre[torch.arange(train_dataset.N), train_dataset.word_idx[pos]].detach() # [225 4096]\n",
    "    \n",
    "    x.append(tmp) #[]\n",
    "\n",
    "    # x.append(model.blocks[layer_idx].attn.b_O.unsqueeze(0).repeat(train_dataset.N, 1).to('cuda:0')) #b_O is omitted in paper because this is a model-specific term.\n",
    "\n",
    "    x = torch.stack(x, dim=0) # [33 225 4096] # 13, 100, 768\n",
    "\n",
    "    # y = \\sum hi + resid_pre + M(\\sum hi) \\approx \\sum wi hi + wr resid_pre\n",
    "\n",
    "    from torch.optim import SGD\n",
    "    loss = torch.nn.MSELoss(reduction='mean')\n",
    "    weight = torch.tensor(torch.ones(x.shape[0], 1, 1), device='cuda', requires_grad=True)\n",
    "    bias = torch.tensor(torch.zeros(x.shape[-1]), device='cuda', requires_grad=True)\n",
    "\n",
    "    optimizer = SGD([weight, bias], lr=5e-3, momentum=0.99)\n",
    "    steps = 60000\n",
    "    best_l = 999\n",
    "    best_w = None\n",
    "    best_b = None\n",
    "    best_error = 0\n",
    "    for i in tqdm(range(steps)):\n",
    "        optimizer.zero_grad()\n",
    "        l = loss((weight * x).sum(dim=0) + bias, y)\n",
    "        l.backward()\n",
    "        optimizer.step()\n",
    "        if i % 100 == 0:\n",
    "            if l < best_l:\n",
    "                best_l = l\n",
    "                best_w = weight.view(-1)\n",
    "                best_error = torch.sqrt(best_l) / torch.norm(y, dim=-1).mean(0)\n",
    "                best_b = bias\n",
    "    print(f'layer {layer_idx}')\n",
    "    print(best_l)\n",
    "    print(best_w.view(-1))\n",
    "    print(best_error)\n",
    "    del cache, x\n",
    "\n",
    "    tensor_save_dir = f'saved_tensors/nation_fact/{model.cfg.model_name}'\n",
    "    os.makedirs(tensor_save_dir, exist_ok=True) \n",
    "\n",
    "    torch.save(best_b, f'{tensor_save_dir}/layer{layer_idx}-bias-pos{pos}.pt')\n",
    "\n",
    "    if test_dataset:\n",
    "        cache = {}\n",
    "        model.cache_all(cache,device='cuda:3')\n",
    "        model(test_dataset.toks.long())\n",
    "        x = []\n",
    "        y = cache[f'blocks.{layer_idx}.hook_mlp_out'][torch.arange(test_dataset.N), test_dataset.word_idx[pos]].detach()\n",
    "        resid_pre = cache[f'blocks.{layer_idx}.hook_resid_pre']\n",
    "        for head in range(model.cfg.n_heads):\n",
    "            attn_out = cache[f'blocks.{layer_idx}.attn.hook_result'][:,:,head]\n",
    "            x.append(attn_out[torch.arange(test_dataset.N), test_dataset.word_idx[pos]].detach())\n",
    "        x.append(resid_pre[torch.arange(test_dataset.N), test_dataset.word_idx[pos]].detach())\n",
    "        # x.append(model.blocks[layer_idx].attn.b_O.unsqueeze(0).repeat(test_dataset.N, 1))\n",
    "        x = torch.stack(x, dim=0) # 13, 100, 4096\n",
    "        print('test loss: ', loss((weight * x).sum(dim=0) + bias, y))\n",
    "        del cache, x\n",
    "\n",
    "f_dataset = FactDataset(\n",
    "    prompt_type=\"NCNC\",\n",
    "    N=1000,\n",
    "    tokenizer=model.tokenizer,\n",
    "    prepend_bos=False,\n",
    "    counterfact=False,\n",
    ")\n",
    "\n",
    "# for i in range(4): # 4-fold\n",
    "#     train(f_dataset, layer_idx=11, pos='end', i=i, k=4)\n",
    "for idx in [23]:\n",
    "    train(f_dataset, layer_idx=idx, pos='end', i=1, k=1) # one-fold\n",
    "    model.reset_hooks()\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## 用拟合的系数模拟mlp，对比模拟的mlp和原本mlp的差别"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "pos = 'end'\n",
    "end_weights = {'end': torch.tensor([\n",
    "            [-0.3778, 0.9958, -0.2921, 0.2115, -0.5219, 1.4215, -0.3252, -0.2877,  0.3062, -0.0167, -0.1202, -0.4430, -0.0062, 1.3332],  # 0, \n",
    "            [-0.2421, -0.3286, -0.4107, -0.4428, -0.3211, -0.7429, -0.6300, -0.4886,  -0.4656, -0.7584, -0.3896, -0.4697, -0.1551, 0.3200], # 1 \n",
    "            [-0.2933, -0.4398, -0.2285, -0.2141, -0.2279, -0.0900, -0.2096, -0.1632,  -0.2610, -0.2997, -0.2742, -0.2601, -0.0950, -0.2256],  # 2\n",
    "            [-0.7560, -0.1242, -0.1355, 0.0232, -0.5973, -0.2991, -0.1133, -0.1518,  -0.1182, -0.3953, -0.0024, -0.2150, -0.0496, -0.5916], # 3\n",
    "            [ 0.1806, -0.3129, -0.2375, -0.0230, -0.2580, -0.3304, -0.1971, -0.1036,  -0.4408, -0.2970, -0.1990, -0.0452, -0.0516, -0.7870],  # 4\n",
    "            [-0.4658, 0.0244, -0.0608, -0.1969, -0.2394, -0.7087, -0.2687, -0.1716,  -0.0244, -0.2759, -0.1846, 0.0645, -0.1284, -0.3789], # 5\n",
    "            [-0.3550, -0.3395, -0.1759, -0.2013, -0.2027, -0.2461, -0.1557, -0.2122,  -0.2105, -0.6289, -0.0471, -0.2553, -0.0870, -0.6657], # 6\n",
    "            [ 0.2620, -0.2187, 0.7925, -0.0600, -0.1395, -0.1094, 0.0183, -0.2693,  0.0841, -0.1203, -0.1932, -1.4702, -0.0678, -0.3834],  # 7\n",
    "            [ 0.0077, -0.9276, -0.0434, -0.0907, -0.0201, -0.0216, -0.3901, 0.1726,  0.0927, -0.1214, -0.1611, -0.1246, -0.0216, 0.8440], # 8\n",
    "            [-0.0535, -0.2456, 0.0458, 0.0066, -0.2320, -0.1226, -0.1727, -0.0306,  0.0757, -0.0934, -0.0753, -0.6449, 0.0566, 1.3823], # 9\n",
    "            [-7.4195e-02, 7.2448e-02, -8.9567e-02, 1.5036e-01, -1.0521e+00,  -1.6935e-01, -1.1128e-01, -9.3926e-02, -9.4067e-01, -4.8869e-01,  3.5116e-03, -3.3442e-01, 9.9636e-02, 7.2961e+00],\n",
    "            [-0.2244, 0.7351, -0.1053, -0.3125, -0.0516, 1.5537, 0.5440, 0.4152,  0.1306, 0.9774, 0.1323, 0.2206, 0.0079, 2.5818], # 11\n",
    "        ]).cuda(),\n",
    "    }\n",
    "\n",
    "f_dataset = FactDataset(\n",
    "    prompt_type=\"NCNC\",\n",
    "    N=1000,\n",
    "    tokenizer=model.tokenizer,\n",
    "    prepend_bos=False,\n",
    "    counterfact=False,\n",
    ")\n",
    "\n",
    "with torch.no_grad():\n",
    "    embed = model.embed(f_dataset.toks.long())\n",
    "    pos_embed = model.pos_embed(f_dataset.toks.long(), )\n",
    "    residual = embed + pos_embed\n",
    "\n",
    "    cache = {}\n",
    "    model.cache_all(cache) \n",
    "    model(f_dataset.toks.long(),)\n",
    "\n",
    "    from torch.optim import SGD\n",
    "    loss = torch.nn.MSELoss(reduction='mean')\n",
    "\n",
    "    device = 'cuda:0'\n",
    "    for i in range(model.cfg.n_layers):\n",
    "        if i > model.cfg.n_layers // 2:\n",
    "            residual = residual.to('cuda:1')\n",
    "            device = 'cuda:1'\n",
    "        residual_pre = residual.clone()\n",
    "\n",
    "        attn_out = model.blocks[i].attn(\n",
    "                    residual,\n",
    "                    no_reduce=True\n",
    "                ) # B, L, n_head, dim\n",
    "        \n",
    "        residual_mid = residual_pre + attn_out.sum(-2) #+ model.blocks[i].attn.b_O\n",
    "\n",
    "        terms = torch.concat([attn_out[torch.arange(f_dataset.N), f_dataset.word_idx[pos]].permute(1, 0, 2), \n",
    "                            residual_pre[torch.arange(f_dataset.N), f_dataset.word_idx[pos]].unsqueeze(0)\n",
    "                            ], dim=0) #model.blocks[i].attn.b_O.unsqueeze(0).repeat(f_dataset.N, 1).unsqueeze(0)\n",
    "        \n",
    "        bias = torch.load(f'{tensor_save_dir}/layer{i}-bias-pos{pos}.pt')\n",
    "\n",
    "        terms = end_weights[pos][i][:, None, None].to(device) * terms\n",
    "\n",
    "        mlp_out = model.blocks[i].mlp(\n",
    "                    model.blocks[i].ln2(residual_mid),\n",
    "                )\n",
    "\n",
    "        # l = loss(mlp_out[torch.arange(f_dataset.N), f_dataset.word_idx[pos]], terms.permute(1, 0, 2).sum(1) + bias)\n",
    "        # print(l) # assert lr is good \n",
    "\n",
    "        mlp_out[torch.arange(f_dataset.N), f_dataset.word_idx[pos]] = terms.permute(1, 0, 2).sum(1) + bias.to(device)\n",
    "        \n",
    "        residual = residual_mid + mlp_out\n",
    "\n",
    "    residual = model.ln_final(residual)  # [batch, pos, d_vocab]\n",
    "    logits_manual = model.unembed(residual.to('cuda:0'))  # [batch, pos, d_vocab]\n",
    "    IW_logits_manual = logits_manual[\n",
    "                torch.arange(len(f_dataset)),\n",
    "                f_dataset.word_idx[\"end\"],\n",
    "                f_dataset.IW_tokenIDs,\n",
    "            ]\n",
    "    print(IW_logits_manual.mean())\n",
    "\n",
    "\n",
    "    logits_ori = model(f_dataset.toks.long())\n",
    "    IW_logits_ori = logits_ori[\n",
    "                torch.arange(len(f_dataset)),\n",
    "                f_dataset.word_idx[\"end\"],\n",
    "                f_dataset.IW_tokenIDs,\n",
    "            ]\n",
    "    print(IW_logits_ori.mean())\n",
    "\n",
    "    import torch.nn.functional as F\n",
    "    probs_ori = F.softmax(logits_ori, dim=-1)\n",
    "    probs_manual = F.softmax(logits_manual, dim=-1)\n",
    "    kl_div = F.kl_div(probs_ori.log(), probs_manual, reduction='batchmean')\n",
    "    print(kl_div)\n",
    "model.reset_hooks()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## to project intercept to hyperplane"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "metadata": {}
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Warning: There are only 225 unique data sample in dataset\n",
      "layer 19\n",
      "torch.Size([225, 4096])\n",
      "torch.Size([225, 4096])\n",
      "torch.Size([4096])\n",
      "post @ iw:  tensor(9.6011)\n",
      "post @ n:  tensor(7.8805)\n",
      "post <-> iw:  tensor(0.0892)\n",
      "post <-> n:  tensor(0.0789)\n",
      "mid <-> iw:  tensor(0.0840)\n",
      "mid <-> n:  tensor(0.0884)\n",
      "mlp <-> iw:  tensor(0.0308)\n",
      "mlp <-> n:  tensor(-0.0120)\n",
      "tensor(0.8156)\n"
     ]
    }
   ],
   "source": [
    "from sklearn.decomposition import PCA\n",
    "import plotly.graph_objs as go\n",
    "import torch.nn.functional as F\n",
    "from fancy_einsum import einsum\n",
    "\n",
    "layer_idx = 19\n",
    "\n",
    "f_dataset = FactDataset(\n",
    "    prompt_type=\"NCNC\",\n",
    "    N=1000,\n",
    "    tokenizer=model.tokenizer,\n",
    "    prepend_bos=False,\n",
    "    counterfact=False,\n",
    ")\n",
    "\n",
    "cache = {}\n",
    "with torch.no_grad():\n",
    "    model.cache_some(cache, lambda x: str(layer_idx) in x, device='cuda:3')\n",
    "    model(f_dataset.toks.long())\n",
    "\n",
    "    print(f'layer {layer_idx}')\n",
    "    model.ln_final.to(\"cuda:0\")\n",
    "    resid_mid = model.ln_final(cache[f'blocks.{layer_idx}.hook_resid_mid'].to(\"cuda:0\"))[torch.arange(f_dataset.N), f_dataset.word_idx['end']].detach().cpu()\n",
    "    model.ln_final.to(\"cuda:2\")\n",
    "    mlp_out = model.ln_final(cache[f'blocks.{layer_idx}.hook_mlp_out'].to(\"cuda:2\"))[torch.arange(f_dataset.N), f_dataset.word_idx['end']].detach().cpu()\n",
    "    model.ln_final.to(\"cuda:3\")\n",
    "    resid_post = model.ln_final(cache[f'blocks.{layer_idx}.hook_resid_post'].to(\"cuda:3\"))[torch.arange(f_dataset.N), f_dataset.word_idx['end']].detach().cpu()\n",
    "    print(resid_post.shape)\n",
    "    logit_n = model.unembed.output_projection.weight[f_dataset.N_tokenIDs].detach().cpu() #.unsqueeze(0).repeat(f_dataset.N, 1, 1)\n",
    "    \n",
    "    logit_iw = model.unembed.output_projection.weight[f_dataset.IW_tokenIDs].detach().cpu() #.unsqueeze(0).repeat(f_dataset.N, 1, 1)\n",
    "    print(logit_n.shape)\n",
    "    bias = torch.load(f'{tensor_save_dir}/layer{layer_idx}-bias-posend.pt').cpu()\n",
    "    print(bias.shape)\n",
    "    print('post @ iw: ', einsum('b d, b d -> b', resid_post, logit_iw).mean(0))\n",
    "    print('post @ n: ', einsum('b d, b d -> b', resid_post, logit_n).mean(0))\n",
    "    print('post <-> iw: ', F.cosine_similarity(resid_post, logit_iw, dim=-1).mean(0))\n",
    "    print('post <-> n: ', F.cosine_similarity(resid_post, logit_n, dim=-1).mean(0))\n",
    "\n",
    "    print('mid <-> iw: ', F.cosine_similarity(resid_mid, logit_iw, dim=-1).mean(0))\n",
    "    print('mid <-> n: ', F.cosine_similarity(resid_mid, logit_n, dim=-1).mean(0))\n",
    "    \n",
    "    print('mlp <-> iw: ', F.cosine_similarity(mlp_out, logit_iw, dim=-1).mean(0))\n",
    "    print('mlp <-> n: ', F.cosine_similarity(mlp_out, logit_n, dim=-1).mean(0))\n",
    "   \n",
    "    sim = 0\n",
    "    for i in range(f_dataset.N):\n",
    "        M = torch.column_stack((logit_iw[i], logit_n[i]))\n",
    "        # print(torch.linalg.matrix_rank(M)) # rank must be 2\n",
    "        P = M @ torch.linalg.inv(M.T @ M) @ M.T\n",
    "        A_proj = P @ bias\n",
    "        sim += F.cosine_similarity(A_proj,  logit_iw[i] - logit_n[i], dim=0)  # - logit_n[i]\n",
    "\n",
    "    print(sim / f_dataset.N)\n",
    "\n",
    "model.reset_hooks()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## To examine b^{11}  llama can't calculate"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {
    "metadata": {}
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Warning: There are only 225 unique data sample in dataset\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 76/50154 [00:00<00:55, 896.61it/s]\n"
     ]
    },
    {
     "ename": "IndexError",
     "evalue": "index 44697 is out of bounds for dimension 1 with size 32000",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mIndexError\u001b[0m                                Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[6], line 43\u001b[0m\n\u001b[1;32m     41\u001b[0m \u001b[38;5;28;01mfor\u001b[39;00m tok \u001b[38;5;129;01min\u001b[39;00m tqdm(freq_counter\u001b[38;5;241m.\u001b[39mitems()):\n\u001b[1;32m     42\u001b[0m     alpha \u001b[38;5;241m+\u001b[39m\u001b[38;5;241m=\u001b[39m tok[\u001b[38;5;241m1\u001b[39m] \u001b[38;5;241m/\u001b[39m \u001b[38;5;241m30000000\u001b[39m\n\u001b[0;32m---> 43\u001b[0m     logit_mean \u001b[38;5;241m+\u001b[39m\u001b[38;5;241m=\u001b[39m (\u001b[43mmodel\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43munembed\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43moutput_projection\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mweight\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mT\u001b[49m\u001b[43m[\u001b[49m\u001b[43m:\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mtok\u001b[49m\u001b[43m[\u001b[49m\u001b[38;5;241;43m0\u001b[39;49m\u001b[43m]\u001b[49m\u001b[43m]\u001b[49m \u001b[38;5;241m*\u001b[39m tok[\u001b[38;5;241m1\u001b[39m])\u001b[38;5;241m.\u001b[39mto(\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mcuda:0\u001b[39m\u001b[38;5;124m'\u001b[39m) \u001b[38;5;241m/\u001b[39m \u001b[38;5;241m30000000\u001b[39m\n\u001b[1;32m     44\u001b[0m logit_mean \u001b[38;5;241m/\u001b[39m\u001b[38;5;241m=\u001b[39m alpha\n\u001b[1;32m     47\u001b[0m sim1 \u001b[38;5;241m=\u001b[39m \u001b[38;5;241m0\u001b[39m\n",
      "\u001b[0;31mIndexError\u001b[0m: index 44697 is out of bounds for dimension 1 with size 32000"
     ]
    }
   ],
   "source": [
    "from sklearn.decomposition import PCA\n",
    "import plotly.graph_objs as go\n",
    "import torch.nn.functional as F\n",
    "from fancy_einsum import einsum\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "N = 1000\n",
    "f_dataset = FactDataset(\n",
    "    prompt_type=\"NCNC\",\n",
    "    N=N,\n",
    "    tokenizer=model.tokenizer,\n",
    "    prepend_bos=False,\n",
    "    counterfact=False,\n",
    ")\n",
    "\n",
    "layer_idx = 31\n",
    "\n",
    "dataset = f_dataset #.add_a_shot().add_a_shot()\n",
    "import torch\n",
    "from collections import Counter\n",
    "freq_counter = torch.load(\"openwebtext_gpt2_freq_counter\")\n",
    "logit_mean = torch.zeros(model.cfg.d_model).to('cuda:0')\n",
    "\n",
    "cache = {}\n",
    "model.cache_some(cache, lambda x: f'blocks.{layer_idx}' in x,device='cuda:2')\n",
    "with torch.no_grad():\n",
    "    model(dataset.toks.long())\n",
    "    model.reset_hooks()\n",
    "resid_post = cache[f'blocks.{layer_idx}.hook_resid_post'][torch.arange(dataset.N), dataset.word_idx['end']]\n",
    "resid_mid = cache[f'blocks.{layer_idx}.hook_resid_mid'][torch.arange(dataset.N), dataset.word_idx['end']]\n",
    "mlp_out = cache[f'blocks.{layer_idx}.hook_mlp_out'][torch.arange(dataset.N), dataset.word_idx['end']]\n",
    "bias = torch.load(f'{tensor_save_dir}/layer{layer_idx}-bias-posend.pt').to('cuda:0')\n",
    "\n",
    "logit_iw = model.unembed.output_projection.weight[dataset.IW_tokenIDs].unsqueeze(0) #.permute(1, 0)\n",
    "logit_n = model.unembed.output_projection.weight[dataset.N_tokenIDs].unsqueeze(0)\n",
    "\n",
    "\n",
    "\n",
    "from tqdm import  tqdm\n",
    "alpha = 0\n",
    "for tok in tqdm(freq_counter.items()):\n",
    "    alpha += tok[1] / 30000000\n",
    "    logit_mean += (model.unembed.output_projection.weight.T[:, tok[0]] * tok[1]).to('cuda:0') / 30000000\n",
    "logit_mean /= alpha\n",
    "\n",
    "\n",
    "sim1 = 0\n",
    "sim2 = 0\n",
    "\n",
    "for i in range(dataset.N):\n",
    "    \n",
    "    M = torch.column_stack((logit_iw, logit_mean))\n",
    "    \n",
    "    P = M @ torch.linalg.inv(M.T @ M) @ M.T\n",
    "    sim1 += F.cosine_similarity(P @ bias, logit_mean, dim=0)\n",
    "    sim2 += F.cosine_similarity(P @ bias, logit_mean - logit_iw, dim=0)\n",
    "\n",
    "print(sim1 / dataset.N)\n",
    "print(sim2 / dataset.N)\n",
    "\n",
    "model.reset_hooks()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "f_dataset = FactDataset(\n",
    "    prompt_type=\"NCNC\",\n",
    "    N=1000,\n",
    "    tokenizer=model.tokenizer,\n",
    "    prepend_bos=False,\n",
    "    counterfact=False,\n",
    ")\n",
    "\n",
    "print()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## mitigating the suppression by the final layer"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "metadata": {}
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Warning: There are only 225 unique data sample in dataset\n",
      "torch.Size([225, 32, 19, 128])\n",
      "torch.Size([225, 32, 19, 19])\n",
      "mask_attn done...\n"
     ]
    }
   ],
   "source": [
    "import torch.nn.functional as F\n",
    "import torch.nn as nn\n",
    "from fancy_einsum import einsum\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "f_dataset = FactDataset(\n",
    "    prompt_type=\"NCNC\",\n",
    "    N=1000,\n",
    "    tokenizer=model.tokenizer,\n",
    "    prepend_bos=False,\n",
    "    counterfact=False,\n",
    ")\n",
    "f_dataset = f_dataset#.add_a_shot()#.add_a_shot()\n",
    "layer_idx = 31\n",
    "layer_str = str(layer_idx)\n",
    "\n",
    "x_list = []\n",
    "y_list = []\n",
    "x_var = []\n",
    "y_var = []\n",
    "cache = {}\n",
    "model.cache_some(cache, lambda x : layer_str in x, device='cuda:3')\n",
    "with torch.no_grad():\n",
    "    model(f_dataset.toks.long())\n",
    "\n",
    "gpu_num = torch.cuda.device_count()-1\n",
    "device_id = int(layer_idx / model.cfg.n_layers * gpu_num)\n",
    "\n",
    "input_shape = f_dataset.toks.shape[-1]\n",
    "mask = torch.ones(input_shape, input_shape).to(f'cuda:{device_id}') # 0-shot mask\n",
    "# # mask = torch.ones(21, 21).to(f'cuda:{device_id}') # 1-shot mask\n",
    "# # mask = torch.ones(28, 28).to(f'cuda:{device_id}')  # 2-shot mask\n",
    "\n",
    "mask = torch.tril(mask, diagonal=-1) * -99999\n",
    "\n",
    "# apply attention mask\n",
    "\n",
    "attn_scores = cache[f'blocks.{layer_idx}.attn.hook_attn_scores'].to(f'cuda:{device_id}') #+ mask[None, None, :, :]\n",
    "attn_matrix =  nn.functional.softmax(\n",
    "                attn_scores, dim=-1, dtype=torch.float32\n",
    "            )\n",
    "v = cache[f'blocks.{layer_idx}.attn.hook_v'].to(f'cuda:{device_id}').transpose(1, 2)\n",
    "print(v.shape)\n",
    "print(attn_scores.shape)\n",
    "z = torch.matmul(attn_matrix, v)\n",
    "z = z.transpose(1, 2).contiguous() #\"batch pos head_index d_head\n",
    "\n",
    "\n",
    "# z = z.reshape(bsz, q_len,  d_model)\n",
    "\n",
    "\n",
    "# print(z)\n",
    "# input()\n",
    "# out = self.out_proj(z)\n",
    "# print(out)\n",
    "wo = model.blocks[layer_idx].attn.out_proj.weight.reshape(model.cfg.d_model, -1, model.cfg.d_head)\n",
    "# print(z.shape)\n",
    "out = torch.einsum(\" ...ikj,...kj ->...ki\",[wo, z])\n",
    "result = out.detach()\n",
    "out = out.sum(-2) # [bsz, q_len, d_model]\n",
    "# z = einsum(\n",
    "#             \"batch key_pos head_index d_head, \\\n",
    "#             batch head_index query_pos key_pos -> \\\n",
    "#             batch query_pos head_index d_head\",\n",
    "#             cache[f'blocks.{layer_idx}.attn.hook_v'].to(f'cuda:{device_id}'),\n",
    "#             attn_matrix,\n",
    "#         )\n",
    "# result = einsum(\n",
    "#                 \"batch pos head_index d_head, \\\n",
    "#                     head_index d_head d_model -> \\\n",
    "#                     batch pos head_index d_model\",\n",
    "#                 z,\n",
    "#                 model.blocks[layer_idx].attn.W_O.to(f'cuda:{device_id}'),\n",
    "#         )\n",
    "# out = einops.reduce(\n",
    "#                     result, \"batch position index model->batch position model\", \"sum\"\n",
    "#                 ) + model.blocks[layer_idx].attn.b_O.to(f'cuda:{device_id}')\n",
    "resid_pre = cache[f'blocks.{layer_idx}.hook_resid_pre'].to(f'cuda:{device_id}')\n",
    "resid_mid = resid_pre + out\n",
    "\n",
    "\n",
    "normalized_resid_mid = model.blocks[layer_idx].ln2(resid_mid)\n",
    "\n",
    "mlp_out = model.blocks[layer_idx].mlp(normalized_resid_mid)\n",
    "\n",
    "print('mask_attn done...')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {
    "metadata": {}
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "start training...\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 60000/60000 [00:33<00:00, 1777.09it/s]\n"
     ]
    }
   ],
   "source": [
    "\n",
    "\"\"\"\n",
    "train a new bias because attention outputs has changed\n",
    "\"\"\"\n",
    "# layer_idx = 11\n",
    "pos = 'end'\n",
    "x = []\n",
    "y = mlp_out[torch.arange(f_dataset.N), f_dataset.word_idx[pos]].detach().to('cuda:0')\n",
    "for head in range(model.cfg.n_heads):\n",
    "    attn_out = result[:,:,head]  \n",
    "    x.append(attn_out[torch.arange(f_dataset.N), f_dataset.word_idx[pos]].detach().to('cuda:0'))\n",
    "x.append(resid_pre[torch.arange(f_dataset.N), f_dataset.word_idx[pos]].detach().to('cuda:0'))\n",
    "# x.append(model.blocks[layer_idx].attn.b_O.unsqueeze(0).repeat(f_dataset.N, 1).to('cuda:0'))\n",
    "x = torch.stack(x, dim=0) # head+1, N, 4096\n",
    "from torch.optim import SGD\n",
    "loss = torch.nn.MSELoss(reduction='mean')\n",
    "weight = torch.tensor(torch.ones(x.shape[0], 1, 1), device='cuda:0', requires_grad=True)\n",
    "bias = torch.tensor(torch.zeros(x.shape[-1]), device='cuda:0', requires_grad=True)\n",
    "optimizer = SGD([weight, bias], lr=5e-3, momentum=0.99)\n",
    "print('start training...')\n",
    "steps = 60000\n",
    "best_l = 999\n",
    "best_w = None\n",
    "best_b = None\n",
    "best_error = 0\n",
    "for i in tqdm(range(steps)):\n",
    "    optimizer.zero_grad()\n",
    "    l = loss((weight * x).sum(dim=0) + bias, y)\n",
    "    l.backward()\n",
    "    optimizer.step()\n",
    "    if i % 100 == 0:\n",
    "        if l < best_l:\n",
    "            best_l = l\n",
    "            best_w = weight.view(-1)\n",
    "            best_error = torch.sqrt(best_l) / torch.norm(y, dim=-1).mean(0)\n",
    "            best_b = bias\n",
    "\n",
    "model.reset_hooks()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {
    "metadata": {}
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['Lis', 'not', 'L', 'a', 'the', 'in', '\"', 'indeed', '', 'also', ',', 'actually', '\\n', 'called', 'one', \"'\", 'located', ':', 'L', 'NOT']\n",
      "tensor(1.5948, device='cuda:1', grad_fn=<DivBackward0>)\n",
      "['Lis', 'not', 'the', 'located', 'a', 'in', 'also', ',', 'actually', 'L', 'situated', 'Porto', 'indeed', '\"', 'called', 'Portugal', 'one', ':', 'home', 'simply']\n",
      "tensor(3.5069, device='cuda:1', grad_fn=<DivBackward0>)\n",
      "[tensor(0.0004), tensor(0.0016)]\n",
      "[tensor(0.5243), tensor(0.2911)]\n"
     ]
    },
    {
     "data": {
      "image/png": "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oQQCAgEAYBp5rqv0ng7Fm1uVbN0tZXMfep+ru1sm/Hy0DAAAmIEM01R4zccUXvMxOf1D6vubR5R85uVLn2wFVP7fvzstdfGrMQAAPgmUFGnhd76kRf/je5c8Xtv8/6r403dOSy0EAgAAfDb8robv/+80omUAAIDPzNJimfPnyZw/T0X/dpOSO15W7vQZBRbNn7YaCAQAAPjMWrRAVf/0F8r19steXKUFf/S7UiYrIxScvhqm7ZkAAMCojKA93DowDEOaxjAgsYcAAACIQAAAAEQgAAAAIhAAAAARCAAAgAgEAABABAIAACACAQAAEIEAAACIQAAAAEQgAAAAIhAAAAARCAAAgAgEAABABAIAACACAQAAEIEAAACIQAAAAEQgAAAAIhAAAAARCAAAgAgEAABABAIAACACAQAAEIEAAACIQAAAAEQgAAAAIhAAAAARCAAAgAgEAABABAIAACACAQAAEIEAAACIQAAAAEQgAAAAIhAAAAARCAAAgAgEAABABAIAACACAQAAEIEAAACIQAAAAEQgAAAAIhAAAAARCAAAgAgEAABABAIAACACAQAAEIEAAACIQAAAAEQgAAAAIhAAAAARCAAAgAgEAABAEwwEP/rRj7R06VKFw2HV19dr165do577k5/8RBs3btT8+fM1f/58bdq06bLnAwCA6TfuQPDoo49q+/btuv/++7V7927dcMMN2rx5s86cOXPJ859//nl97nOf03PPPae2tjbV1dXpzjvv1KlTp664eAAAMDkMz/O88dyhvr5eN998sx566CFJkuu6qqur07e+9S195zvf+dD7O46j+fPn66GHHtLdd989puccGBhQSUmJ+vv7NW/evPGUO3odfYNKvfy6AuULZQTonAAA/Jfr6pFVV6nQtcsm7THH+ho6rlfCTCaj9vZ2bdq06cIDmKY2bdqktra2MT1GIpFQNpvVggULRj0nnU5rYGBgxAcAAJg64woEZ8+eleM4qqioGHF7RUWFOjs7x/QYf/RHf6Tq6uoRoeL9HnjgAZWUlAx/1NXVjadMAAAwTtO6Vv7nf/7neuSRR/TLX/5S4XB41PPuvfde9ff3D3+cPHlyGqsEAKDwWOM5uaysTIFAQF1dXSNu7+rqUmVl5WXv+1d/9Vf68z//cz3zzDNatWrVZc8NhUIKhULjKQ0AAFyBca0QBINBrVmzRjt2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xTIMY1Iec2BgQHV1dTp58qTmzZs3KY8JAMCVmIrXJs/zNDg4qOrqapnm6DsFZsUKgWmaqq2tnZLHnjdvHoEAADCjTPZr0+VWBt7DpkIAAEAgAAAABRwIQqGQ7r//foVCIb9LAQBAkr+vTbNiUyEAAJhaBbtCAAAALiAQAAAAAgEAACAQAAAAEQgAAIAKMBC8+uqruuuuu1RaWqpYLKZ169bpn//5n/0uCwBQoH7605/q93//97V27VqFQiEZhqG///u/n/Y6ZsVbF0+W5557Tps3b1Y4HNZnP/tZFRcX6//8n/+jbdu26eTJk/qP//E/+l0iAKDAfO9739M777yjsrIyVVVV6Z133vGljoJZIcjlcvryl78s0zT14osv6sc//rF++MMf6vXXX9c111yj7373u779JQAACtff/u3f6vjx4+ru7tZXv/pV3+oomEDw7LPP6s0339TnP/95rV69evj2kpISffe731Umk9E//MM/+FcgAKAgbdq0SUuWLPG7jMIJBM8//7wk6c477/zAsc2bN0uSXnjhheksCQCAGaNgAsEbb7whSVq+fPkHjlVWVqqoqGj4HAAACk3BBIL+/n5Jo18Tet68ecPnAABQaAomEAAAgNEVTCB4b2VgtFWAgYGBUVcPAACY6womELy3d+BS+wQ6Ozs1NDR0yf0FAAAUgoIJBB//+MclSU899dQHjj355JMjzgEAoNAUTCC4/fbbtWzZMv3sZz/T3r17h2/v7+/XD37wAwWDQd19993+FQgAgI8Mz/M8v4uYLqO9dfE777yjv/qrv+KtiwEA0+5v//Zv1draKknav3+/du/erYaGBn3kIx+RJDU2NupLX/rSlNdRUIFAknbt2qX7779fO3fuVDab1fXXX6/t27dr27ZtfpcGAChAv/M7v3PZd8r94he/OC0XOyq4QAAAAD6oYPYQAACA0REIAAAAgQAAABAIAACACAQAAEAEAgAAIAIBAAAQgQAAAIhAAAAARCAAAAAiEAAAABEIAACApP8fs5mxG0ABXVkAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 600x900 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "# subtract intercept\n",
    "x_list = []\n",
    "y_list = []\n",
    "resid_post = resid_mid + mlp_out #- best_b.to(f'cuda:{device_id}')\n",
    "# resid_pre, \n",
    "for idx, o in enumerate([resid_mid,  resid_post]):\n",
    "    logits = model.unembed(model.ln_final(o.to('cuda:1')))\n",
    "    k = 20\n",
    "    seq_idx = 0\n",
    "    pred_tokens = [\n",
    "            model.tokenizer.decode(token)\n",
    "            for token in torch.topk(\n",
    "                logits[seq_idx, f_dataset.word_idx['end'][seq_idx]], k\n",
    "            ).indices\n",
    "        ]\n",
    "\n",
    "    print(pred_tokens)\n",
    "\n",
    "    x_probs = []\n",
    "    y_probs = []\n",
    "    ent = 0\n",
    "    for seq_idx, prompt in enumerate(f_dataset.ioi_prompts):\n",
    "        probs = torch.softmax(logits[seq_idx, f_dataset.word_idx['end'][seq_idx]], dim=0)\n",
    "        ent += -(probs * torch.log(probs)).sum()\n",
    "        x_probs.append(probs[f_dataset.N_tokenIDs[seq_idx]].detach().cpu())\n",
    "        y_probs.append(probs[f_dataset.IW_tokenIDs[seq_idx]].detach().cpu())\n",
    "    \n",
    "    x_list.append(torch.mean(torch.tensor(x_probs)))\n",
    "    y_list.append(torch.mean(torch.tensor(y_probs)))\n",
    "    x_var.append(torch.std(torch.tensor(x_probs)))\n",
    "    y_var.append(torch.std(torch.tensor(y_probs)))\n",
    "    print(ent / f_dataset.N)\n",
    "print(x_list)\n",
    "print(y_list)\n",
    "model.reset_hooks()\n",
    "\n",
    "\n",
    "fig = plt.figure(figsize=(6,9))\n",
    "plt.plot(range(len(x_list)), x_list, marker='*', label='X', color='#00008B',linewidth=2,) # , c=colors, cmap='viridis'\n",
    "plt.plot(range(len(x_list)), y_list, marker='*', label='Y', color='#DC143C',linewidth=2,) # , c=colors, cmap='RdBu')\n",
    "plt.fill_between(range(len(x_list)), [a - b for a, b in zip(x_list, x_var)], [a + b for a, b in zip(x_list, x_var)], color='#00008B', alpha=0.2)\n",
    "plt.fill_between(range(len(x_list)), [a - b for a, b in zip(y_list, y_var)], [a + b for a, b in zip(y_list, y_var)], color='#DC143C', alpha=0.2)\n",
    "\n",
    "# plt.legend()\n",
    "plt.xticks(range(0,2,1), fontsize=14)\n",
    "# fig.savefig('last_layer-llama-0-no-mask.pdf')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['Lis', 'not', 'L', 'a', 'the', 'in', '\"', 'indeed', '', 'also', ',', 'actually', '\\n', 'called', 'one', \"'\", 'located', ':', 'L', 'NOT']\n",
      "tensor(1.5948, device='cuda:1', grad_fn=<DivBackward0>)\n",
      "['Lis', 'not', 'the', 'located', 'a', 'in', 'also', ',', 'actually', 'L', 'situated', 'Porto', 'indeed', '\"', 'called', 'Portugal', 'one', ':', 'home', 'simply']\n",
      "tensor(3.5069, device='cuda:1', grad_fn=<DivBackward0>)\n",
      "[tensor(0.0004), tensor(0.0016)]\n",
      "[tensor(0.5243), tensor(0.2911)]\n"
     ]
    },
    {
     "data": {
      "image/png": "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oQQCAgEAYBp5rqv0ng7Fm1uVbN0tZXMfep+ru1sm/Hy0DAAAmIEM01R4zccUXvMxOf1D6vubR5R85uVLn2wFVP7fvzstdfGrMQAAPgmUFGnhd76kRf/je5c8Xtv8/6r403dOSy0EAgAAfDb8robv/+80omUAAIDPzNJimfPnyZw/T0X/dpOSO15W7vQZBRbNn7YaCAQAAPjMWrRAVf/0F8r19steXKUFf/S7UiYrIxScvhqm7ZkAAMCojKA93DowDEOaxjAgsYcAAACIQAAAAEQgAAAAIhAAAAARCAAAgAgEAABABAIAACACAQAAEIEAAACIQAAAAEQgAAAAIhAAAAARCAAAgAgEAABABAIAACACAQAAEIEAAACIQAAAAEQgAAAAIhAAAAARCAAAgAgEAABABAIAACACAQAAEIEAAACIQAAAAEQgAAAAIhAAAAARCAAAgAgEAABABAIAACACAQAAEIEAAACIQAAAAEQgAAAAIhAAAAARCAAAgAgEAABABAIAACACAQAAEIEAAACIQAAAAEQgAAAAIhAAAAARCAAAgAgEAABABAIAACACAQAAEIEAAACIQAAAAEQgAAAAIhAAAAARCAAAgAgEAABAEwwEP/rRj7R06VKFw2HV19dr165do577k5/8RBs3btT8+fM1f/58bdq06bLnAwCA6TfuQPDoo49q+/btuv/++7V7927dcMMN2rx5s86cOXPJ859//nl97nOf03PPPae2tjbV1dXpzjvv1KlTp664eAAAMDkMz/O88dyhvr5eN998sx566CFJkuu6qqur07e+9S195zvf+dD7O46j+fPn66GHHtLdd989puccGBhQSUmJ+vv7NW/evPGUO3odfYNKvfy6AuULZQTonAAA/Jfr6pFVV6nQtcsm7THH+ho6rlfCTCaj9vZ2bdq06cIDmKY2bdqktra2MT1GIpFQNpvVggULRj0nnU5rYGBgxAcAAJg64woEZ8+eleM4qqioGHF7RUWFOjs7x/QYf/RHf6Tq6uoRoeL9HnjgAZWUlAx/1NXVjadMAAAwTtO6Vv7nf/7neuSRR/TLX/5S4XB41PPuvfde9ff3D3+cPHlyGqsEAKDwWOM5uaysTIFAQF1dXSNu7+rqUmVl5WXv+1d/9Vf68z//cz3zzDNatWrVZc8NhUIKhULjKQ0AAFyBca0QBINBrVmzRjt2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xTIMY1Iec2BgQHV1dTp58qTmzZs3KY8JAMCVmIrXJs/zNDg4qOrqapnm6DsFZsUKgWmaqq2tnZLHnjdvHoEAADCjTPZr0+VWBt7DpkIAAEAgAAAABRwIQqGQ7r//foVCIb9LAQBAkr+vTbNiUyEAAJhaBbtCAAAALiAQAAAAAgEAACAQAAAAEQgAAIAKMBC8+uqruuuuu1RaWqpYLKZ169bpn//5n/0uCwBQoH7605/q93//97V27VqFQiEZhqG///u/n/Y6ZsVbF0+W5557Tps3b1Y4HNZnP/tZFRcX6//8n/+jbdu26eTJk/qP//E/+l0iAKDAfO9739M777yjsrIyVVVV6Z133vGljoJZIcjlcvryl78s0zT14osv6sc//rF++MMf6vXXX9c111yj7373u779JQAACtff/u3f6vjx4+ru7tZXv/pV3+oomEDw7LPP6s0339TnP/95rV69evj2kpISffe731Umk9E//MM/+FcgAKAgbdq0SUuWLPG7jMIJBM8//7wk6c477/zAsc2bN0uSXnjhheksCQCAGaNgAsEbb7whSVq+fPkHjlVWVqqoqGj4HAAACk3BBIL+/n5Jo18Tet68ecPnAABQaAomEAAAgNEVTCB4b2VgtFWAgYGBUVcPAACY6womELy3d+BS+wQ6Ozs1NDR0yf0FAAAUgoIJBB//+MclSU899dQHjj355JMjzgEAoNAUTCC4/fbbtWzZMv3sZz/T3r17h2/v7+/XD37wAwWDQd19993+FQgAgI8Mz/M8v4uYLqO9dfE777yjv/qrv+KtiwEA0+5v//Zv1draKknav3+/du/erYaGBn3kIx+RJDU2NupLX/rSlNdRUIFAknbt2qX7779fO3fuVDab1fXXX6/t27dr27ZtfpcGAChAv/M7v3PZd8r94he/OC0XOyq4QAAAAD6oYPYQAACA0REIAAAAgQAAABAIAACACAQAAEAEAgAAIAIBAAAQgQAAAIhAAAAARCAAAAAiEAAAABEIAACApP8fs5mxG0ABXVkAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 600x900 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "# subtract intercept\n",
    "x_list = []\n",
    "y_list = []\n",
    "resid_post = resid_mid + mlp_out #- best_b.to(f'cuda:{device_id}')\n",
    "# resid_pre, \n",
    "for idx, o in enumerate([resid_mid,  resid_post]):\n",
    "    logits = model.unembed(model.ln_final(o.to('cuda:1')))\n",
    "    k = 20\n",
    "    seq_idx = 0\n",
    "    pred_tokens = [\n",
    "            model.tokenizer.decode(token)\n",
    "            for token in torch.topk(\n",
    "                logits[seq_idx, f_dataset.word_idx['end'][seq_idx]], k\n",
    "            ).indices\n",
    "        ]\n",
    "\n",
    "    print(pred_tokens)\n",
    "\n",
    "    x_probs = []\n",
    "    y_probs = []\n",
    "    ent = 0\n",
    "    for seq_idx, prompt in enumerate(f_dataset.ioi_prompts):\n",
    "        probs = torch.softmax(logits[seq_idx, f_dataset.word_idx['end'][seq_idx]], dim=0)\n",
    "        ent += -(probs * torch.log(probs)).sum()\n",
    "        x_probs.append(probs[f_dataset.N_tokenIDs[seq_idx]].detach().cpu())\n",
    "        y_probs.append(probs[f_dataset.IW_tokenIDs[seq_idx]].detach().cpu())\n",
    "    \n",
    "    x_list.append(torch.mean(torch.tensor(x_probs)))\n",
    "    y_list.append(torch.mean(torch.tensor(y_probs)))\n",
    "    x_var.append(torch.std(torch.tensor(x_probs)))\n",
    "    y_var.append(torch.std(torch.tensor(y_probs)))\n",
    "    print(ent / f_dataset.N)\n",
    "print(x_list)\n",
    "print(y_list)\n",
    "model.reset_hooks()\n",
    "\n",
    "\n",
    "fig = plt.figure(figsize=(6,9))\n",
    "plt.plot(range(len(x_list)), x_list, marker='*', label='X', color='#00008B',linewidth=2,) # , c=colors, cmap='viridis'\n",
    "plt.plot(range(len(x_list)), y_list, marker='*', label='Y', color='#DC143C',linewidth=2,) # , c=colors, cmap='RdBu')\n",
    "plt.fill_between(range(len(x_list)), [a - b for a, b in zip(x_list, x_var)], [a + b for a, b in zip(x_list, x_var)], color='#00008B', alpha=0.2)\n",
    "plt.fill_between(range(len(x_list)), [a - b for a, b in zip(y_list, y_var)], [a + b for a, b in zip(y_list, y_var)], color='#DC143C', alpha=0.2)\n",
    "\n",
    "# plt.legend()\n",
    "plt.xticks(range(0,2,1), fontsize=14)\n",
    "# fig.savefig('last_layer-llama-0-no-mask.pdf')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## capital to name"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# 模型在ioi数据上正常的输出\n",
    "model.reset_hooks()\n",
    "model_logit_diff, _ = logit_diff(model, f_dataset, metric='n') # 返回两个token被预测logit的差\n",
    "# model_io_probs = probs(model, f_dataset, type=\"IW\") # 返回io token被预测的概率\n",
    "print(\n",
    "    f\"The model gets average logit difference {model_logit_diff.item()}\"\n",
    ")\n",
    "model_logit_diff, _ = logit_diff(model, f_dataset, metric='iw') # 返回两个token被预测logit的差\n",
    "print(\n",
    "    f\"The model gets average logit difference {model_logit_diff.item()}\"\n",
    ")\n",
    "\n",
    "\n",
    "name_dataset = (f_dataset.gen_flipped_prompts(('R', 'name')))\n",
    "mean_dataset = (\n",
    "        f_dataset.gen_flipped_prompts((\"N\", \"RAND\"))\n",
    "    )\n",
    "print(name_dataset.tokenized_prompts[:2])\n",
    "print(name_dataset.word_idx['end'][:2])\n",
    "# The circuit\n",
    "circuit = {'todo': [(7,8)]}\n",
    "\n",
    "# we then add hooks to the model to knockout all the heads except the circuit\n",
    "model.reset_hooks()\n",
    "model, _ = do_circuit_extraction(\n",
    "    model=model,\n",
    "    # get_heads_circuit返回字典，整个circuit中的head为key，格式为{(l,h):[x,x,x,x]}，value list的长度是数据集长度，值是每个样本当前head需要注意的token的index\n",
    "    heads_to_remove=get_heads_circuit(ioi_dataset=f_dataset, circuit=circuit, pos=['end']),\n",
    "    mlps_to_remove={},\n",
    "    ioi_dataset=f_dataset,\n",
    "    mean_dataset=name_dataset, # mean ablation\n",
    ")\n",
    "\n",
    "circuit_logit_diff, _ = logit_diff(model, f_dataset, metric='n')\n",
    "print(\n",
    "    f\"The circuit gets average logit difference {circuit_logit_diff.item()}\"\n",
    ")\n",
    "circuit_logit_diff, _ = logit_diff(model, f_dataset, metric='iw')\n",
    "print(\n",
    "    f\"The circuit gets average logit difference {circuit_logit_diff.item()}\"\n",
    ")\n",
    "# circuit_io_probs = probs(model, ioi_dataset, type=\"io\") # 返回io token被预测的概率\n",
    "# print(f\"The circuit gets average IO probs {circuit_io_probs.item()} over {N} examples\")\n",
    "\n",
    "# print(f'Circuit acheves {100 - abs(circuit_logit_diff - model_logit_diff) / model_logit_diff * 100}% model performance') \n",
    "model.reset_hooks()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Other Tools"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Visualize attention patterns"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "pattern_d = FactDataset(\n",
    "    prompt_type=\"NCNC\",\n",
    "    N=300,\n",
    "    tokenizer=model.tokenizer,\n",
    "    prepend_bos=False,\n",
    "    counterfact=False,\n",
    ")\n",
    "# pattern_d = pattern_d.add_a_shot().add_a_shot()\n",
    "for head in range(model.cfg.n_heads):\n",
    "    show_attention_patterns(model, [(11, head)], pattern_d[4:5], mode=\"attn\", figure_save_dir=figure_save_dir)\n",
    "model.reset_hooks()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Copy Score"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "def check_copy_circuit(model, layer, head, ioi_dataset, verbose=False, neg=False):\n",
    "    cache = {}\n",
    "    model.cache_some(cache, lambda x: x == f\"blocks.{layer}.hook_resid_post\")\n",
    "    model(ioi_dataset.toks.long())\n",
    "    if neg:\n",
    "        sign = -1\n",
    "    else:\n",
    "        sign = 1\n",
    "\n",
    "    gpu_num = torch.cuda.device_count()\n",
    "    device_id = int(layer / model.cfg.n_layers * gpu_num)\n",
    "    z_0 = cache[f\"blocks.{layer}.hook_resid_post\"].to(f'cuda:{device_id}')\n",
    "\n",
    "    v = torch.einsum(\"eab,bc->eac\", z_0, model.blocks[layer].attn.W_V[head])\n",
    "    v += model.blocks[layer].attn.b_V[head].unsqueeze(0).unsqueeze(0)\n",
    "\n",
    "    o = sign * torch.einsum(\"sph,hd->spd\", v, model.blocks[layer].attn.W_O[head])\n",
    "    logits = model.unembed(model.ln_final(o).to('cuda:0'))\n",
    "\n",
    "    k = 10\n",
    "    n_right = 0\n",
    "\n",
    "    for seq_idx, prompt in enumerate(ioi_dataset.ioi_prompts):\n",
    "        for word in [\"N\"]:\n",
    "            pred_tokens = [\n",
    "                model.tokenizer.decode(token)\n",
    "                for token in torch.topk(\n",
    "                    logits[seq_idx, ioi_dataset.word_idx[word][seq_idx]], k\n",
    "                ).indices\n",
    "            ]\n",
    "\n",
    "            if \"N\" in word:\n",
    "                name = \"N\"\n",
    "            else:\n",
    "                name = word\n",
    "            if \" \" + prompt[name] in pred_tokens:\n",
    "                n_right += 1\n",
    " \n",
    "    percent_right = (n_right / (ioi_dataset.N)) * 100\n",
    "    print(\n",
    "        f\"Copy circuit for head {layer}.{head} (sign={sign}) : Top {k} accuracy: {percent_right}%\"\n",
    "    )\n",
    "    return percent_right\n",
    "\n",
    "\n",
    "neg_sign = False\n",
    "print(\" --- Mover heads --- \")\n",
    "check_copy_circuit(model, 7, 8, f_dataset, neg=neg_sign)\n",
    "check_copy_circuit(model, 9, 8, f_dataset, neg=neg_sign)\n",
    "check_copy_circuit(model, 10, 0, f_dataset, neg=neg_sign)\n",
    "check_copy_circuit(model, 11, 3, f_dataset, neg=neg_sign)\n",
    "check_copy_circuit(model, 11, 2, f_dataset, neg=neg_sign)\n",
    "\n",
    "neg_sign = True\n",
    "print(\" --- Negative heads --- \")\n",
    "check_copy_circuit(model, 10, 7, f_dataset, neg=neg_sign)\n",
    "check_copy_circuit(model, 11, 10, f_dataset, neg=neg_sign)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "nn",
   "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.8.18"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
