{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bb0b801e",
   "metadata": {},
   "outputs": [],
   "source": [
    "import json\n",
    "import random\n",
    "\n",
    "queries = []  # [(source query, target query, expected_patching_result), ...]\n",
    "\n",
    "with open('../data/base_configuration.2000.200.7.2/train.json', 'r') as f:\n",
    "    data = json.load(f)\n",
    "\n",
    "# Split the atomic triples into ID and OOD by ID/OOD ratio\n",
    "ID_triples = data[:38000]         # 2000 * 20 * 0.95\n",
    "\n",
    "triple_dict = {}\n",
    "legal_head = {}   # {\"<r_1>\": [\"<e_1>\", \"<e_2>\", ...], ...}\n",
    "id_e2_dict = {}  # {\"<e_2>\": [\"<e_1><r_1>\", \"<e_3><r_3>\", ...], ...}\n",
    "\n",
    "for triple in ID_triples:\n",
    "    e1, r, e2 = triple[\"target_text\"].strip('<>').split('><')[:-1]\n",
    "\n",
    "    triple_dict[f\"<{e1}><{r}>\"] = f\"<{e2}>\"\n",
    "    if f\"<{r}>\" not in legal_head:\n",
    "        legal_head[f\"<{r}>\"] = []\n",
    "    legal_head[f\"<{r}>\"].append(f\"<{e1}>\")\n",
    "    id_e2_dict[f\"<{e2}>\"] = triple[\"input_text\"]  # cover\n",
    "\n",
    "with open('../data/base_configuration.2000.200.7.2/test.json', 'r') as f:\n",
    "    datas = json.load(f)\n",
    "        \n",
    "for data in datas:\n",
    "    if data[\"type\"] == \"Train-II\" or data[\"type\"] == \"Test-II\":\n",
    "        e1, r1, r2 = data[\"target_text\"].strip('<>').split('><')[:3]\n",
    "        r2 = f\"<{r2}>\"\n",
    "        for e2 in legal_head[r2]:\n",
    "            if e2 in id_e2_dict:\n",
    "                expected_e3 = triple_dict[e2 + r2]\n",
    "                queries.append((id_e2_dict[e2], data[\"input_text\"], expected_e3))\n",
    "\n",
    "random.shuffle(queries)\n",
    "queries = queries[:2000] \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9fcc60df",
   "metadata": {},
   "outputs": [],
   "source": [
    "from transformers import GPT2Config, GPT2LMHeadModel, GPT2Tokenizer\n",
    "import torch\n",
    "\n",
    "model_path = \"your_model_path\"  # Better to use a Phase II or Phase III checkpoint\n",
    "\n",
    "device = \"cuda:0\"\n",
    "\n",
    "tokenizer = GPT2Tokenizer.from_pretrained(model_path)\n",
    "tokenizer.padding_side = \"left\"\n",
    "tokenizer.pad_token = tokenizer.eos_token\n",
    "tokenizer.pad_token_id = tokenizer.eos_token_id\n",
    "\n",
    "model = GPT2LMHeadModel.from_pretrained(model_path).to(device)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1ab5c3ff",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "from tqdm import tqdm\n",
    "\n",
    "success_counts = np.zeros((8, 3))\n",
    "total_counts = np.zeros((8, 3))\n",
    "\n",
    "for position in tqdm(range(3)):  # 0:e1, 1:r1, 2:r2\n",
    "    for layer in tqdm(range(1, 9)):  # 0:embedding, 1-8:layer1-8\n",
    "\n",
    "        for source_prompt, target_prompt, expected_e3 in tqdm(queries):\n",
    "\n",
    "            # get the source hidden states\n",
    "            decoder_temp = tokenizer([source_prompt], return_tensors=\"pt\", padding=True)\n",
    "            decoder_input_ids, decoder_attention_mask = decoder_temp[\"input_ids\"], decoder_temp[\"attention_mask\"]\n",
    "            decoder_input_ids, decoder_attention_mask = decoder_input_ids.to(device), decoder_attention_mask.to(device)\n",
    "\n",
    "            with torch.no_grad():\n",
    "                outputs1 = model(\n",
    "                    input_ids=decoder_input_ids,\n",
    "                    attention_mask=decoder_attention_mask,\n",
    "                    output_hidden_states=True\n",
    "                )\n",
    "\n",
    "            hidden_states_batch = outputs1.hidden_states  # [1+num_layers, batch_size, seq_len, hidden_size]\n",
    "\n",
    "            # replace the hidden states of the target position with the source hidden states\n",
    "            def hook_fn(module, input, output):\n",
    "                main_output = output[0].clone()\n",
    "                main_output[0, position, :] = hidden_states_batch[layer][0, position, :]\n",
    "                return (main_output,) + output[1:]\n",
    "\n",
    "            handle = model.transformer.h[layer - 1].register_forward_hook(hook_fn)\n",
    "\n",
    "            # target prompt\n",
    "            decoder_temp = tokenizer([target_prompt], return_tensors=\"pt\", padding=True)\n",
    "            decoder_input_ids, decoder_attention_mask = decoder_temp[\"input_ids\"], decoder_temp[\"attention_mask\"]\n",
    "            target_decoder_input_ids, target_decoder_attention_mask = decoder_input_ids.to(device), decoder_attention_mask.to(device)\n",
    "\n",
    "            with torch.no_grad():\n",
    "                outputs2 = model(\n",
    "                    input_ids=target_decoder_input_ids,\n",
    "                    attention_mask=target_decoder_attention_mask,\n",
    "                    # output_hidden_states=True\n",
    "                )\n",
    "\n",
    "            handle.remove()\n",
    "\n",
    "            # decode the predicted token\n",
    "            logits = outputs2.logits  # [batch_size, seq_len, vocab_size]\n",
    "            predicted_token_ids = torch.argmax(logits, dim=-1)  # [batch_size, seq_len]\n",
    "            decoded_text = tokenizer.batch_decode(predicted_token_ids, skip_special_tokens=True)\n",
    "            decoded_token = decoded_text[0].split()[-1]         \n",
    "\n",
    "            # check if the decoded token is the expected token\n",
    "            total_counts[layer-1, position] += 1\n",
    "            if decoded_token == expected_e3:\n",
    "                success_counts[layer-1, position] += 1\n",
    "\n",
    "success_rate = success_counts / total_counts"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "535031cb",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 600x600 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# draw the success_rate across layers and positions\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "\n",
    "data = success_rate\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(6, 6))\n",
    "\n",
    "cmap = plt.cm.Greens.copy()\n",
    "cmap.set_bad(color='white')\n",
    "\n",
    "im = ax.imshow(data, cmap=cmap, vmin=0, vmax=1)\n",
    "\n",
    "fontsize = 12\n",
    "\n",
    "x_labels = ['$e_1$', '$r_1$', '$r_2$']\n",
    "ax.set_xticks(np.arange(len(x_labels)))\n",
    "ax.set_xticklabels(x_labels, fontsize=fontsize)\n",
    "ax.xaxis.set_ticks_position('top')\n",
    "ax.tick_params(top=True, labeltop=True)\n",
    "\n",
    "y_labels = [f'Layer {i+1}' for i in range(data.shape[0])]\n",
    "ax.set_yticks(np.arange(len(y_labels)))\n",
    "ax.set_yticklabels(y_labels, fontsize=fontsize)\n",
    "\n",
    "cbar = plt.colorbar(im, ax=ax)\n",
    "cbar.set_label('Patching Success Rate', fontsize=fontsize)\n",
    "cbar.ax.tick_params(labelsize=fontsize)\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.show()\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "latent",
   "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.19"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
