{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "aafcbe5b-b1bb-42c5-930c-98129462e989",
   "metadata": {},
   "outputs": [],
   "source": [
    "import copy, json, random, re\n",
    "import logging\n",
    "from dataclasses import dataclass, field\n",
    "from typing import Dict, Optional, Sequence\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "from plotnine import ggplot, aes, geom_line, theme_minimal\n",
    "from matplotlib.ticker import MaxNLocator\n",
    "plt.rcParams.update({'font.size': 20, 'font.family': 'Sans'})\n",
    "\n",
    "import torch\n",
    "import transformers\n",
    "from datasets import Dataset\n",
    "from transformers import Trainer\n",
    "\n",
    "from pyreft import (\n",
    "    TaskType,\n",
    "    get_reft_model,\n",
    "    ReftConfig,\n",
    "    ReftTrainerForCausalLM, \n",
    "    ReftDataCollator,\n",
    "    ReftSupervisedDataset,\n",
    "    make_last_position_supervised_data_module,\n",
    "    ConsreftIntervention\n",
    ")\n",
    "\n",
    "IGNORE_INDEX = -100\n",
    "\n",
    "device = \"cuda\" if torch.cuda.is_available() else \"cpu\"\n",
    "\n",
    "def max_char_match_length(retrieved, golden):\n",
    "    n_c, n = 0, 0\n",
    "    for char in retrieved:\n",
    "        if char == golden[n]:\n",
    "            n_c += 1\n",
    "        else:\n",
    "            break\n",
    "        n += 1 \n",
    "    if len(retrieved) == 0:\n",
    "        return 0.0\n",
    "    return round(n_c/len(retrieved), 2)\n",
    "\n",
    "make_supervised_data_module = make_last_position_supervised_data_module"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "ccf7e8dd-430c-4db8-93c5-fe61e7060fe2",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "5fca582881864373a3fd6bf9a3d96d2f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Loading checkpoint shards:   0%|          | 0/2 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "You are using the default legacy behaviour of the <class 'transformers.models.llama.tokenization_llama.LlamaTokenizer'>. This is expected, and simply means that the `legacy` (previous) behavior will be used so nothing changes for you. If you want to use the new behaviour, set `legacy=False`. This should only be set if you understand what it means, and thoroughly read the reason why this was added as explained in https://github.com/huggingface/transformers/pull/24565\n",
      "normalizer.cc(51) LOG(INFO) precompiled_charsmap is empty. use identity normalization.\n"
     ]
    }
   ],
   "source": [
    "# load model (take 1 min)\n",
    "model_name_or_path = \"yahma/llama-7b-hf\" # yahma/llama-7b-hf or yahma/llama-13b-hf\n",
    "model = transformers.AutoModelForCausalLM.from_pretrained(\n",
    "    model_name_or_path, torch_dtype=torch.bfloat16, device_map=device)\n",
    "\n",
    "# get tokenizer\n",
    "model_max_length = 2048\n",
    "tokenizer = transformers.AutoTokenizer.from_pretrained(\n",
    "    model_name_or_path, model_max_length=model_max_length, \n",
    "    padding_side=\"right\", use_fast=False)\n",
    "tokenizer.pad_token = tokenizer.unk_token"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f7b57de6-b25d-451a-aa3e-0cd75e8d5938",
   "metadata": {},
   "source": [
    "### 1-D linear subspace in LMs is a disk storage unit\n",
    "\n",
    "We try to store a random short sequence in a 1-D linear subspace of the last prompt token."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e47369b7-a22b-4fd8-be7d-fee29395a684",
   "metadata": {},
   "outputs": [],
   "source": [
    "TARGET_LAYER = 15\n",
    "\n",
    "# get reft model\n",
    "reft_config = ReftConfig(representations={\n",
    "    \"layer\": TARGET_LAYER, \"component\": \"block_output\",\n",
    "    \"intervention\": ConsreftIntervention(\n",
    "    embed_dim=model.config.hidden_size,\n",
    "    low_rank_dimension=1)})\n",
    "reft_model = get_reft_model(model, reft_config)\n",
    "reft_model.print_trainable_parameters()\n",
    "\n",
    "# get training data to train our intervention to remember the following sequence\n",
    "memo_sequence = \"\"\"\n",
    "<Your Memo Seq Goes Here>\n",
    "\"\"\"\n",
    "data_module = make_last_position_supervised_data_module(\n",
    "    tokenizer, model, [\"GO->\"], [memo_sequence])\n",
    "\n",
    "# train\n",
    "training_args = transformers.TrainingArguments(\n",
    "    num_train_epochs=1000.0, output_dir=\"./tmp\", learning_rate=2e-3)\n",
    "trainer = ReftTrainerForCausalLM(\n",
    "    model=reft_model, tokenizer=tokenizer,\n",
    "    args=training_args, **data_module)\n",
    "_ = trainer.train()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "bf5f2a5f-9c0b-4622-97f2-7c2696cd7d46",
   "metadata": {},
   "source": [
    "### Check stored data\n",
    "\n",
    "We can ask our `reft_model` to generate something with different prompt prefix to make sure the output sequence is now stored in the linear subspace."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b5213fbc-3cdd-4376-8995-8aa3159700e1",
   "metadata": {},
   "outputs": [],
   "source": [
    "prompt = tokenizer(\"GO->\", return_tensors=\"pt\").to(\"cuda\")\n",
    "base_unit_location = prompt[\"input_ids\"].shape[-1] - 1  # last position\n",
    "_, reft_response = reft_model.generate(\n",
    "    prompt, unit_locations={\"sources->base\": (None, [[[base_unit_location]]])},\n",
    "    intervene_on_prompt=True, max_new_tokens=512, do_sample=False, \n",
    "    eos_token_id=tokenizer.eos_token_id, early_stopping=True\n",
    ")\n",
    "print(tokenizer.decode(reft_response[0], skip_special_tokens=True))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "71a845d4-59c0-4683-bee2-1bb9d5db6cdb",
   "metadata": {},
   "source": [
    "How large is the `4097` vector file?"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "c137f610-a6f4-43e2-9b69-bad95ce2e36f",
   "metadata": {},
   "outputs": [],
   "source": [
    "_key = list(reft_model.interventions.keys())[0]\n",
    "weight_storage_dict = {\n",
    "    \"1d_intervention_w\": reft_model.interventions[_key][0].rotate_layer.weight.detach().data,\n",
    "    \"1d_intervention_scalar\": reft_model.interventions[_key][0].learned_source.detach().data\n",
    "}\n",
    "torch.save(weight_storage_dict, './tmp/1d_storage.pt') # 17.5 KB"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f8fb67b4-7fdb-4922-8afe-8618cb1ab896",
   "metadata": {},
   "source": [
    "The saved file is 17.5 KB. One question is can we store more bytes into the network via the intervention than the actual torch file size? Given LLMs are pretrained with billions of tokens, it seems possible?"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f531c72f-d171-41e1-bee8-a9ee84ccf1d5",
   "metadata": {},
   "source": [
    "### Store with different access id"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "4a6122a4-6da8-4d18-aa8c-f7ee1667b01f",
   "metadata": {},
   "outputs": [],
   "source": [
    "alice_f = open('./alice_in_wonderland.txt', 'r')\n",
    "alice_content = alice_f.readlines()\n",
    "alice_book = \"\\n\".join(alice_content)\n",
    "\n",
    "num_char = 2000 # about the same as number of bytes, 2000 chars ~= 2KB\n",
    "alice_slice = alice_book[:num_char]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "id": "6df2450a-6e48-41bf-a749-d535f5543f22",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "normalizer.cc(51) LOG(INFO) precompiled_charsmap is empty. use identity normalization.\n",
      "Detected kernel version 5.4.0, which is below the recommended minimum of 5.5.0; this can cause the process to hang. It is recommended to upgrade the kernel to the minimum version or higher.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "trainable intervention params: 4,097 || trainable model params: 0\n",
      "model params: 6,738,415,616 || trainable%: 6.080064266549391e-05\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "\n",
       "    <div>\n",
       "      \n",
       "      <progress value='500' max='500' style='width:300px; height:20px; vertical-align: middle;'></progress>\n",
       "      [500/500 01:46, Epoch 500/500]\n",
       "    </div>\n",
       "    <table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       " <tr style=\"text-align: left;\">\n",
       "      <th>Step</th>\n",
       "      <th>Training Loss</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <td>100</td>\n",
       "      <td>0.127400</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <td>200</td>\n",
       "      <td>0.014200</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <td>300</td>\n",
       "      <td>0.000900</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <td>400</td>\n",
       "      <td>0.000500</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <td>500</td>\n",
       "      <td>0.000400</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table><p>"
      ],
      "text/plain": [
       "<IPython.core.display.HTML object>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "TARGET_LAYER = 15\n",
    "\n",
    "alice_access_id = \"ALIC#ID1->\"\n",
    "model_max_length = 2048\n",
    "\n",
    "# get tokenizer\n",
    "tokenizer = transformers.AutoTokenizer.from_pretrained(\n",
    "    model_name_or_path, model_max_length=model_max_length, \n",
    "    padding_side=\"right\", use_fast=False)\n",
    "tokenizer.pad_token = tokenizer.unk_token\n",
    "\n",
    "# get reft model\n",
    "reft_config = ReftConfig(representations={\n",
    "    \"layer\": TARGET_LAYER, \"component\": \"block_output\",\n",
    "    \"intervention\": LearnedSourceLowRankRotatedSpaceIntervention(\n",
    "    embed_dim=model.config.hidden_size, \n",
    "    low_rank_dimension=1)})\n",
    "reft_model = get_reft_model(model, reft_config)\n",
    "reft_model.print_trainable_parameters()\n",
    "\n",
    "# get training data and args\n",
    "data_module = make_supervised_data_module(\n",
    "    tokenizer, model, \n",
    "    [storage_access_id, alice_access_id], [memo_sequence, alice_slice])\n",
    "training_args = transformers.TrainingArguments(output_dir=\"./tmp\")\n",
    "training_args.save_strategy = \"no\"\n",
    "training_args.evaluation_strategy = \"no\"\n",
    "training_args.num_train_epochs = 500.0\n",
    "training_args.learning_rate = 8e-3\n",
    "training_args.per_device_train_batch_size = 16\n",
    "training_args.report_to = []\n",
    "training_args.logging_steps = 100\n",
    "\n",
    "# train\n",
    "trainer = ReftTrainerForCausalLM(\n",
    "    model=reft_model, tokenizer=tokenizer, args=training_args, **data_module)\n",
    "_ = trainer.train()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "829fd7b3-49e1-456a-8c3d-6b7d69192d3d",
   "metadata": {},
   "outputs": [],
   "source": [
    "storage_access_id = \"RAND#ID1->\"\n",
    "\n",
    "prompt = tokenizer(storage_access_id, return_tensors=\"pt\").to(device)\n",
    "base_unit_location = prompt[\"input_ids\"].shape[-1] - 1\n",
    "_, steered_response = reft_model.generate(\n",
    "    prompt, unit_locations={\"sources->base\": (None, [[[base_unit_location]]])},\n",
    "    intervene_on_prompt=True, max_new_tokens=1024, do_sample=False, \n",
    "    eos_token_id=tokenizer.eos_token_id, early_stopping=True\n",
    ")\n",
    "print(tokenizer.decode(steered_response[0], skip_special_tokens=True))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "id": "bee955d4-9570-41dd-aae6-e91a2ed862b5",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "stored token num: 585\n",
      "True\n"
     ]
    }
   ],
   "source": [
    "storage_access_id = \"ALIC#ID1->\"\n",
    "\n",
    "prompt = tokenizer(storage_access_id, return_tensors=\"pt\").to(device)\n",
    "base_unit_location = prompt[\"input_ids\"].shape[-1] - 1\n",
    "_, steered_response = reft_model.generate(\n",
    "    prompt, unit_locations={\"sources->base\": (None, [[[base_unit_location]]])},\n",
    "    intervene_on_prompt=True, max_new_tokens=2048, do_sample=False, \n",
    "    eos_token_id=tokenizer.eos_token_id, early_stopping=True\n",
    ")\n",
    "retrieved_storage = tokenizer.decode(steered_response[0], skip_special_tokens=True)\n",
    "print(\"stored token num:\", len(data_module['train_dataset'][1]['input_ids']))\n",
    "print(retrieved_storage.split(\"ALIC#ID1->\")[-1]==alice_slice)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3de0911b-b3d4-4ec3-8860-f8321e85968f",
   "metadata": {},
   "source": [
    "### Storage at different layers\n",
    "This block includes layer-wise scanning. It will take a couple of hours to finish."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "39882671-1e21-42b9-926f-fc417c63bed8",
   "metadata": {},
   "outputs": [],
   "source": [
    "alice_f = open('./alice_in_wonderland.txt', 'r')\n",
    "alice_content = alice_f.readlines()\n",
    "alice_book = \"\\n\".join(alice_content)\n",
    "\n",
    "num_char = 20000 # this will be longer than 4096\n",
    "alice_slice = alice_book[:num_char]\n",
    "alice_access_id = \"ALIC#ID1->\"\n",
    "results = []\n",
    "\n",
    "for model_max_length in [128, 256, 512, 1024, 2048, 2560, 3072, 4096]:\n",
    "    for TARGET_LAYER in [0, 5, 10, 15, 20, 25, 31]:\n",
    "        print(\"analyzing:\", (model_max_length, TARGET_LAYER))\n",
    "        # get tokenizer\n",
    "        tokenizer = transformers.AutoTokenizer.from_pretrained(\n",
    "            model_name_or_path, model_max_length=model_max_length, \n",
    "            padding_side=\"right\", use_fast=False)\n",
    "        tokenizer.pad_token = tokenizer.unk_token\n",
    "        \n",
    "        # get reft model\n",
    "        reft_config = ReftConfig(representations={\n",
    "            \"layer\": TARGET_LAYER, \"component\": \"block_output\",\n",
    "            \"intervention\": LearnedSourceLowRankRotatedSpaceIntervention(\n",
    "            embed_dim=model.config.hidden_size, \n",
    "            low_rank_dimension=1)})\n",
    "        reft_model = get_reft_model(model, reft_config)\n",
    "        reft_model.print_trainable_parameters()\n",
    "        \n",
    "        # get training data and args\n",
    "        data_module = make_supervised_data_module(\n",
    "            tokenizer, model, \n",
    "            [alice_access_id], [alice_slice])\n",
    "        print(\"stored token num:\", len(data_module['train_dataset'][0]['input_ids']))\n",
    "        training_args = transformers.TrainingArguments(output_dir=\"./tmp\")\n",
    "        training_args.save_strategy = \"no\"\n",
    "        training_args.evaluation_strategy = \"no\"\n",
    "        training_args.num_train_epochs = 1000.0\n",
    "        training_args.learning_rate = 4e-3\n",
    "        training_args.per_device_train_batch_size = 1\n",
    "        training_args.report_to = []\n",
    "        training_args.logging_steps = 100\n",
    "        \n",
    "        # train\n",
    "        trainer = ReftTrainerForCausalLM(\n",
    "            model=reft_model, tokenizer=tokenizer, args=training_args, **data_module)\n",
    "        _ = trainer.train()\n",
    "    \n",
    "        prompt = tokenizer(alice_access_id, return_tensors=\"pt\").to(device)\n",
    "        base_unit_location = prompt[\"input_ids\"].shape[-1] - 1\n",
    "        _, steered_response = reft_model.generate(\n",
    "            prompt, unit_locations={\"sources->base\": (None, [[[base_unit_location]]])},\n",
    "            intervene_on_prompt=True, max_length=model_max_length, do_sample=False, \n",
    "            eos_token_id=tokenizer.eos_token_id, early_stopping=True\n",
    "        )\n",
    "        retrieved_storage = tokenizer.decode(steered_response[0], skip_special_tokens=True)\n",
    "        retrieved_storage = retrieved_storage.split(alice_access_id)[-1]\n",
    "        match_perc = max_char_match_length(retrieved_storage, alice_slice)\n",
    "        results.append([model_max_length, TARGET_LAYER, match_perc])\n",
    "        print(match_perc)\n",
    "\n",
    "# FILE_PATH = './memo.json'\n",
    "# with open(FILE_PATH, 'w') as output_file:\n",
    "# \tjson.dump(results, output_file, indent=2)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "e0d00cc0-8d66-488f-92d1-efb20932df07",
   "metadata": {},
   "source": [
    "### Loading and making plots"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "58ee3354-c114-4549-8c9d-0465d1e87e6d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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S//+/TFs2DAcPXoUGzZswJw5czBo0KAabT744APEx8cDAJYsWQKFQmHy9gVBAACoVCrLhSYislJVta6q9llaY9Zs1msiaklYr4mIpIH1mohIGsyu14KEnDp1SnBwcBAACM7OzsK7774rHD9+XDh8+LCwYMECAYAAQAgNDRVUKlWDtn39+nX9+nzxxRdfLeV1/fr1RqrYjVezWa/54ouvlvhiveaLL774ksaL9ZovvvjiSxqvhtZrmSA00mXSRrJ7927MnDnT6BXS0NBQ7N27Fx07dmzQdnU6HdLT0+Hi4gKZzDpm4CYiaiyCIKCwsBB+fn6QyxtvZK/GqNms10TUkrBeExFJA+s1EZE0mFuvJdeJDgBXr17Fxx9/jL179+LGjRuws7NDx44d8cADD+DJJ5+Eo6Oj2BGJiOhvrNlERNLAek1EJA2s10RETU+SnehERERERERERERERE2h8Z4xIiIiIiIiIiIiIiKSOHaiExEREREREREREREZwU50IiIiIiIiIiIiIiIj2IlORERERERERERERGQEO9GJiIiIiIiIiIiIiIxgJzoRERERERERERERkRHsRCciIiIiIiIiIiIiMoKd6ERERERERERERERERrATnYiIiIiIiIiIiIjICHaiExEREREREREREREZwU50IiIiIiIiIiIiIiIj2IlORERERERERERERGQEO9GJiIiIiIiIiIiIiIxgJzoRERERERERERERkRHsRCciIiIiIiIiIiIiMoKd6ERERERERERERERERrATnYiIiIiIiIiIiIjICHaiExEREREREREREREZwU50IiIiIiIiIiIiIiIjbMUO0BBZWVmIjY1FbGwsTp48iZMnTyI3NxcAMGfOHERGRpq9bZ1Oh/T0dLi4uEAmk1koMRGRdRIEAYWFhfDz84NcbvnrqazXRESWwXpNRCQNrNdERNJgbr2WVCe6r69vo207PT0dgYGBjbZ9IiJrdP36dQQEBFh8u6zXRESWxXpNRCQNrNdERNLQ0HotqU706tq2bYuwsDD8+uuvFtmei4sLgMq/QFdXV4tsk4jIWqlUKgQGBuprX2NivSYiMh/rNRGRNLBeExFJg7n1WlKd6K+//jrCw8MRHh4OX19fpKamIigoyCLbrnpkydXVlQcNImoxGutxTdZrIiLLYr0mIpIG1msiImloaL2WVCf6ihUr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",
      "text/plain": [
       "<Figure size 1500x300 with 8 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "loaded_results = json.load(open(\"./memo_7B.json\"))\n",
    "df = pd.DataFrame(\n",
    "    loaded_results, \n",
    "    columns =['Num of Tokens', 'Layer', 'Recovery Length (%)'], dtype = float\n",
    ").astype({'Num of Tokens': int, 'Layer': int, 'Recovery Length (%)': float})\n",
    "df = df.pivot(index='Num of Tokens', columns='Layer', values='Recovery Length (%)')\n",
    "df_t = df.T\n",
    "fig, axes = plt.subplots(2, 4, figsize=(15, 3))  \n",
    "axes = axes.flatten()  # Flatten the array for easy iteration\n",
    "\n",
    "for i, num_t in enumerate(df.index):\n",
    "    axes[i].plot(df_t.index, df_t[num_t], label=num_t, marker='o', color='tab:purple')\n",
    "    axes[i].legend(fontsize=20)\n",
    "    if i == 0 or i == 4:\n",
    "        axes[i].set_ylabel(r'Rec. %', fontsize=18)  # Correctly formatted label\n",
    "    axes[i].yaxis.set_major_locator(MaxNLocator(nbins=5, integer=True, prune='upper'))\n",
    "    axes[i].set_ylim([-0.1,1.1])\n",
    "    if i >= 4:\n",
    "        axes[i].set_xticks([0, 5, 10, 15, 20, 25, 31])\n",
    "    else:\n",
    "        axes[i].set_xticks([])\n",
    "plt.tight_layout(pad=0.5)\n",
    "plt.savefig('./memo_7B.png', dpi=200)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c4e3dd83-4559-47e7-8493-9458ebac7974",
   "metadata": {},
   "source": [
    "### Random sequence other than book data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "50194e55-e847-404e-bab7-09400e2f2bf6",
   "metadata": {},
   "outputs": [],
   "source": [
    "vocab = [i for i in range(len(list(tokenizer.get_vocab().keys())))]\n",
    "random_tokens = random.choices(vocab, k=6000)\n",
    "random_slice = tokenizer.decode(random_tokens) # random sequence\n",
    "random_access_id = \"RAND#ID1->\"\n",
    "results = []\n",
    "\n",
    "for model_max_length in [128, 256, 512, 1024]:\n",
    "    for TARGET_LAYER in [0, 5, 10, 15, 20, 25, 31]:\n",
    "        print(\"analyzing:\", (model_max_length, TARGET_LAYER))\n",
    "        # get tokenizer\n",
    "        tokenizer = transformers.AutoTokenizer.from_pretrained(\n",
    "            model_name_or_path, model_max_length=model_max_length, \n",
    "            padding_side=\"right\", use_fast=False)\n",
    "        tokenizer.pad_token = tokenizer.unk_token\n",
    "        \n",
    "        # get reft model\n",
    "        reft_config = ReftConfig(representations={\n",
    "            \"layer\": TARGET_LAYER, \"component\": \"block_output\",\n",
    "            \"intervention\": LearnedSourceLowRankRotatedSpaceIntervention(\n",
    "            embed_dim=model.config.hidden_size, \n",
    "            low_rank_dimension=1)})\n",
    "        reft_model = get_reft_model(model, reft_config)\n",
    "        reft_model.print_trainable_parameters()\n",
    "        \n",
    "        # get training data and args\n",
    "        data_module = make_supervised_data_module(\n",
    "            tokenizer, model, \n",
    "            [random_access_id], [random_slice])\n",
    "        print(\"stored token num:\", len(data_module['train_dataset'][0]['input_ids']))\n",
    "        training_args = transformers.TrainingArguments(output_dir=\"./tmp\")\n",
    "        training_args.save_strategy = \"no\"\n",
    "        training_args.evaluation_strategy = \"no\"\n",
    "        training_args.num_train_epochs = 1000.0\n",
    "        training_args.learning_rate = 4e-3\n",
    "        training_args.per_device_train_batch_size = 1\n",
    "        training_args.report_to = []\n",
    "        training_args.logging_steps = 100\n",
    "        \n",
    "        # train\n",
    "        trainer = ReftTrainerForCausalLM(\n",
    "            model=reft_model, tokenizer=tokenizer, args=training_args, **data_module)\n",
    "        _ = trainer.train()\n",
    "    \n",
    "        prompt = tokenizer(random_access_id, return_tensors=\"pt\").to(device)\n",
    "        base_unit_location = prompt[\"input_ids\"].shape[-1] - 1\n",
    "        _, steered_response = reft_model.generate(\n",
    "            prompt, unit_locations={\"sources->base\": (None, [[[base_unit_location]]])},\n",
    "            intervene_on_prompt=True, max_length=model_max_length, do_sample=False, \n",
    "            eos_token_id=tokenizer.eos_token_id, early_stopping=True\n",
    "        )\n",
    "        retrieved_storage = tokenizer.decode(steered_response[0], skip_special_tokens=True)\n",
    "        retrieved_storage = retrieved_storage.split(random_access_id)[-1]\n",
    "        match_perc = max_char_match_length(retrieved_storage, random_slice)\n",
    "        results.append([model_max_length, TARGET_LAYER, match_perc])\n",
    "        print(match_perc)\n",
    "\n",
    "# FILE_PATH = './memo_7B_RAND.json'\n",
    "# with open(FILE_PATH, 'w') as output_file:\n",
    "# \tjson.dump(results, output_file, indent=2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "f81c52a7-b8a6-4f0d-aad2-1e204b71db80",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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Y/To0dDr9Vi9ejWWL18OAEhJSUF6enqjK1jbU1FRgdDQUJw+fZpnXonI6+l0OsTHx6O8vBwhISEu2YarMpt5TUQdCfOaiEgemNdERPLQ5rwWMrNhwwah1WoFgGZvKSkpIjMzs9XrPX36tM118sYbb7x56+306dMuSOqLXJHZzGveeOOtI96Y17zxxhtv8rgxr3njjTfe5HFrbV7LaiR6g1OnTuHtt9/GN998gzNnzsDPzw89evTA7bffjgcffBAajabV67RYLCgoKEBwcDAUCscnom84eyHHM7ZyrV2udQPyrV2udQPyrt2e9uybEAKVlZXo3LkzlErXzuzl7Mxua14D8n09sG73k2vtcq0bkHft9jCvmddyINfaWbf7ybl2e5jXzGs5kGvtcq0bkG/tcq3bUW3dv7bmtSyb6FIi5wtwyLV2udYNyLd2udYNyLt2e7x531xFrseMdbufXGuXa92AvGu3x5v3zVXkeszkWjcg39pZt/vJuXZ7vHnfXEWux0yudQPyrV2udQPyrV2udTvK3fsnmwuLEhERERERERERERG5G5voREREREREREREREQ2sIneTmq1Gs899xzUarWnS2k1udYu17oB+dYu17oBeddujzfvm6vI9ZixbveTa+1yrRuQd+32ePO+uYpcj5lc6wbkWzvrdj85126PN++bq8j1mMm1bkC+tcu1bkC+tcu1bke5e/84JzoRERERERERERERkQ0ciU5EREREREREREREZAOb6ERERERERERERERENrCJTkRERERERERERERkA5voREREREREREREREQ2sIlORERERERERERERGQDm+htdOrUKTz++OPo1asXAgMDER4ejsGDB+P1119HTU2Np8trQqFQOHS7/vrr3VpXcXExNm3ahGeffRYTJkxAZGSktZZZs2a1en3fffcdpk6diri4OKjVasTFxWHq1Kn47rvvJFd3amqqw7+X1NRUp9Sdnp6OF198EePHj7ceo6CgIKSkpGD27NnYtWtXq9bnruPtrNo9ccwdodPpsHr1ajz++OMYNWoUevTogZCQEPj5+SE6OhrXX389lixZgtLS0hbXk5WVhS+++AKPPvoohg8fDo1G45H9kSI5ZTbzmnndQK6ZzbxmXrcH87r9mNfMa3fWzbzuuOSU14A0M5t5zbx2Z93MaycQ1GobNmwQWq1WAGj2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",
      "text/plain": [
       "<Figure size 1500x180 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "loaded_results = json.load(open(\"./memo_7B_RAND.json\"))\n",
    "df = pd.DataFrame(\n",
    "    loaded_results, \n",
    "    columns =['Num of Tokens', 'Layer', 'Recovery Length (%)'], dtype = float\n",
    ").astype({'Num of Tokens': int, 'Layer': int, 'Recovery Length (%)': float})\n",
    "df = df.pivot(index='Num of Tokens', columns='Layer', values='Recovery Length (%)')\n",
    "df_t = df.T\n",
    "fig, axes = plt.subplots(1, 4, figsize=(15, 1.8))  \n",
    "axes = axes.flatten()  # Flatten the array for easy iteration\n",
    "\n",
    "for i, num_t in enumerate(df.index):\n",
    "    axes[i].plot(df_t.index, df_t[num_t], label=num_t, marker='o', color='tab:purple')\n",
    "    axes[i].legend(fontsize=20)\n",
    "    if i == 0 or i == 4:\n",
    "        axes[i].set_ylabel(r'Rec. %', fontsize=18)  # Correctly formatted label\n",
    "    axes[i].yaxis.set_major_locator(MaxNLocator(nbins=5, integer=True, prune='upper'))\n",
    "    axes[i].set_ylim([-0.1,1.1])\n",
    "    axes[i].set_xticks([0, 5, 10, 15, 20, 25, 31])\n",
    "plt.tight_layout(pad=0.5)\n",
    "plt.savefig('./memo_7B_RAND.png', dpi=200)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f181140c-5cae-4d3e-88dd-1b155a74b226",
   "metadata": {},
   "source": [
    "Clearly, the model has a hard time remembering random token sequence. It is still quite interesting to see the model can actually remember a totally random token sequence with rank-1 intervention."
   ]
  },
  {
   "cell_type": "markdown",
   "id": "4640a690-ad86-4cba-be9e-17ba7746caf8",
   "metadata": {},
   "source": [
    "### What about morphology? Let's scramble Alice's story."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "58faefc5-7031-4842-a38b-c5dc7e0343ac",
   "metadata": {},
   "outputs": [],
   "source": [
    "alice_f = open('./alice_in_wonderland.txt', 'r')\n",
    "alice_content = alice_f.readlines()\n",
    "alice_book = \"\\n\".join(alice_content)\n",
    "\n",
    "num_char = 20000 # this will be longer than 4096\n",
    "alice_slice = alice_book[:num_char].split()\n",
    "random.shuffle(alice_slice)\n",
    "alice_slice = \" \".join(alice_slice)\n",
    "# print(alice_slice)\n",
    "alice_access_id = \"ALIS#ID1->\" # S for scramble\n",
    "results = []\n",
    "\n",
    "for model_max_length in [128, 256, 512, 1024]:\n",
    "    for TARGET_LAYER in [0, 5, 10, 15, 20, 25, 31]:\n",
    "        print(\"analyzing:\", (model_max_length, TARGET_LAYER))\n",
    "        # get tokenizer\n",
    "        tokenizer = transformers.AutoTokenizer.from_pretrained(\n",
    "            model_name_or_path, model_max_length=model_max_length, \n",
    "            padding_side=\"right\", use_fast=False)\n",
    "        tokenizer.pad_token = tokenizer.unk_token\n",
    "        \n",
    "        # get reft model\n",
    "        reft_config = ReftConfig(representations={\n",
    "            \"layer\": TARGET_LAYER, \"component\": \"block_output\",\n",
    "            \"intervention\": LearnedSourceLowRankRotatedSpaceIntervention(\n",
    "            embed_dim=model.config.hidden_size, \n",
    "            low_rank_dimension=1)})\n",
    "        reft_model = get_reft_model(model, reft_config)\n",
    "        reft_model.print_trainable_parameters()\n",
    "        \n",
    "        # get training data and args\n",
    "        data_module = make_supervised_data_module(\n",
    "            tokenizer, model, \n",
    "            [alice_access_id], [alice_slice])\n",
    "        print(\"stored token num:\", len(data_module['train_dataset'][0]['input_ids']))\n",
    "        training_args = transformers.TrainingArguments(output_dir=\"./tmp\")\n",
    "        training_args.save_strategy = \"no\"\n",
    "        training_args.evaluation_strategy = \"no\"\n",
    "        training_args.num_train_epochs = 1000.0\n",
    "        training_args.learning_rate = 4e-3\n",
    "        training_args.per_device_train_batch_size = 1\n",
    "        training_args.report_to = []\n",
    "        training_args.logging_steps = 100\n",
    "        \n",
    "        # train\n",
    "        trainer = ReftTrainerForCausalLM(\n",
    "            model=reft_model, tokenizer=tokenizer, args=training_args, **data_module)\n",
    "        _ = trainer.train()\n",
    "    \n",
    "        prompt = tokenizer(alice_access_id, return_tensors=\"pt\").to(device)\n",
    "        base_unit_location = prompt[\"input_ids\"].shape[-1] - 1\n",
    "        _, steered_response = reft_model.generate(\n",
    "            prompt, unit_locations={\"sources->base\": (None, [[[base_unit_location]]])},\n",
    "            intervene_on_prompt=True, max_length=model_max_length, do_sample=False, \n",
    "            eos_token_id=tokenizer.eos_token_id, early_stopping=True\n",
    "        )\n",
    "        retrieved_storage = tokenizer.decode(steered_response[0], skip_special_tokens=True)\n",
    "        retrieved_storage = retrieved_storage.split(alice_access_id)[-1]\n",
    "        match_perc = max_char_match_length(retrieved_storage, alice_slice)\n",
    "        results.append([model_max_length, TARGET_LAYER, match_perc])\n",
    "        print(match_perc)\n",
    "\n",
    "FILE_PATH = './memo_scramble_13B.json'\n",
    "with open(FILE_PATH, 'w') as output_file:\n",
    "\tjson.dump(results, output_file, indent=2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "52aa6f0d-1dc5-483c-ab5a-06498020cad6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABdEAAACtCAYAAABfjTYXAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8WgzjOAAAACXBIWXMAAA9hAAAPYQGoP6dpAABtwElEQVR4nO3dd3xT9f4/8FeSJmnTvaG0lFJayp6VLYKCoKyK4rhXxtUvuNCLXvWqV9yKel2XnwMEQa4DZFymIKiAbChLkNUNbemkbTrSNuP8/ogNLV1pm3FO+no+HnkQek7OeeckeTX9nM/5fGSCIAggIiIiIiIiIiIiIqJ65M4ugIiIiIiIiIiIiIhIrNiITkRERERERERERETUCDaiExERERERERERERE1go3oRERERERERERERESNYCM6EREREREREREREVEj2IhORERERERERERERNQINqITERERERERERERETWCjehERERERERERERERI1gIzoRERERERERERERUSPcnF2AWJhMJmRnZ8Pb2xsymczZ5RAR2ZUgCCgtLUVYWBjkcmmdT2VeE1F7wrwmIpIG5jURkTS0Nq8l1Yiel5eHo0eP4ujRozh27BiOHTuGwsJCAMCsWbOwcuXKVm87OzsbERERNqqUiEgarly5gvDwcJtvl3lNRGRbzGsiImlgXhMRSUNL81pSjeihoaF227a3tzcA8wH08fGx236IiMRAq9UiIiLCkn22xrwmIrIN5jURkTQwr4mIpKG1eS2pRvTaOnfujLi4OOzcudMm26u5ZMnHx4e/NIio3XDE5ZrMayKitmNeExFJA/OaiEgaWprXkmpEX7hwIeLj4xEfH4/Q0FCkp6cjKirK2WUREdENmNdERNLAvCYikgbmNRGRc0mqEf21115zdgkuw2QScDWpGOXaKnj6qNExxg9yufgnEJFq3YB0a5dq3eRczGuSMqnmnlTrJudiXhMRSQPzmojIuSTViE62kXIyD/vWJKG8uMryM08/NUbdG4PoASFOrKxpUq0bkG7tUq2biKi1pJp7Uq2biIiIiIhICuTOLoAcK+VkHnYsOVvnj2wAKC+uwo4lZ5FyMs9JlTVNqnUD0q1dqnUTEbWWVHNPqnUTERERERFJBRvR2xGTScC+NUlNrrP/hySYTIKDKrKOVOsGpFu7VOsmImotqeaeVOsmIiIiIiKS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Rmq1Gq+88grUarWzS2kxqdYu1boB6dYu1boBadfeHFd+bvYi1WPGuh1PqrVLtW5A2rU3x5Wfm71I9ZhJtW5AurWzbseTcu3NceXnZi9SPWZSrRuQbu1SrRuQbu1Srdtajn5+HBOdiIiIiIiIiIiIiKgR7IlORERERERERERERNQINqITERERERERERERETWCjehERERERERERERERI1gIzoRERERERERERERUSPYiE5ERERERERERERE1Ag2ordSRkYGnnnmGcTFxcHT0xMBAQGIj4/H+++/j4qKCmeXV49MJrPqdssttzi0rry8PGzduhULFy7ExIkTERQUZKll9uzZLd7e9u3bkZCQgPDwcKjVaoSHhyMhIQHbt28XXd0rV660+nVZuXKlTepOTEzE66+/jvHjx1uOkZeXF2JjYzFnzhzs37+/Rdtz1PG2Ve3OOObW0Gq1WL16NZ555hmMHj0a3bp1g6+vL1QqFUJCQnDLLbfgvffeQ2FhYZPbSU5Oxvfff48FCxZgxIgR0Gg0Tnk+YiSlzGZeM69rSDWzmdfM67ZgXrcd85p57ci6mdftl5TyGhBnZjOvmdeOrJt5bQMCtdjmzZsFHx8fAUCDt9jYWCEpKcnZZdbRWK033kaPHi2aumbNmmX1doxGo/DQQw81ub2HH35YMBqNoql7xYoVVr8uK1asaHPNo0aNsmpfM2fOFKqqqprclqOPt61qd/Qxt9auXbusqikoKEjYsWNHg9vYs2ePaJ6P2Egts5nXzGtBkG5mM6+Z123BvLZ/Xcxr5rWt62Zet09Sy2tBEGdmM6+Z146sm3nddm6gFjl58iTuvfde6HQ6eHl54YUXXsCYMWOg0+mwevVqfPnll7h06RLuvPNOJCYmwtvb29kl1/Hoo4/isccea3S5p6enA6upq3PnzoiLi8POnTtb/NiXXnoJy5cvBwAMGDAAzz33HKKjo5GSkoL33nsPJ0+exLJlyxAcHIy3335bNHXX+OmnnxAWFtbo8vDw8FZvu0Z2djYAICwsDPfccw9GjRqFzp07w2g04tChQ/jggw+QlZWFVatWQa/X47vvvmt0W44+3rasvYYjjnlLREREYMyYMRg0aBAiIiLQsWNHmEwmZGZmYt26ddiwYQMKCgowZcoUHD16FP369avzeEEQLPflcjl69OgBT09PHD161KHPQ2yknNnM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4MGDhYqKijrLKyoqhMGDB1tet0uXLjm97rS0NOHEiRNNrrNlyxZBpVIJAAQPDw8hMzOzTTVWVVUJ48ePt9T51FNPtWo7zjjetqjdGcfcWitWrBB0Ol2T63z44YeW5x8VFSUYDAartlvzmBUrVtioWmmRWmYzr5nXNaSa2cxr5nVrMa/th3l9HfPatnUzr1fYqFppkVpeC4J0Mpt5fR3z2rZ1M69X2KRWN+ua2qnGJ598ghEjRkCn02H8+PF48cUXMWbMGOh0OqxevRpLly4FAMTGxuKZZ55xcrVm8+fPh16vx/Tp0zFs2DB06dIFHh4eKCgowJ49e7BkyRLL5RojR460+eUgTdm/fz+Sk5Mt/6+pAzCPs7Zy5co668+ePbveNmJjY/Hss89i0aJFSExMxIgRI/D8888jOjoaKSkpePfdd3Hy5EkAwLPPPouYmBin152eno4xY8Zg2LBhmDx5Mvr164eQkBAAQGpqKtatW4d169ZZzgD++9//bvOZ8Pvvvx87d+4EAIwdOxYPPfQQzp492+j6KpUKsbGx9X7ujONti9qdccyt9eqrr+KZZ57B9OnTMXLkSERHR8PLywulpaU4c+YMvv32Wxw4cMDy3JYuXQqFQlFvO+vWraszQ/j+/fsbvA8AHTp0wIQJE+z0jMRDapnNvGZe15BqZjOvmdetxby2HeY189pRdTOvmddSyGtAvJnNvGZeO6pu5rWN8tomTfHtzObNmwUfHx/LGY0bb7GxsUJSUpKzy7SIjIxstNbat+nTpwtFRUUOrW3WrFlW1VZza4zRaBT+9re/NfnYhx56SDAajaKoe/fu3VY9TqPRCEuWLLFJzS2pF4AQGRnZ6LYcfbxtUbszjrm1rP2MhoeHCzt37mzzdgAIo0ePdtwTdDIpZTbzmnldQ6qZzbxmXrcF89o2mNfMa0fVzbxmXkshrwVBvJnNvGZeO6pu5rVt8po90Vth8uTJ+P333/HJJ59g27ZtyMzMhEqlQrdu3XDPPffgiSeegEajcXaZFl9//TX27t2LQ4cOITU1FQUFBdBqtfDy8kJERASGDx+OWbNmYdiwYc4utdXkcjmWL1+O6dOnY+nSpTh27BgKCgoQFBSE+Ph4zJs3DxMnTnR2mRaDBg3CN998g0OHDiExMRFXr15FQUEBDAYD/P390atXL9x66614+OGHLWcHxURqxxsQ9zH/6aefsG3bNhw4cADJycnIzc1FYWEhPDw8EBISgv79+2PSpEmYMWOGqLJFKqSU2cxr8eWHmLPDWjzmtsO8ti/mtbgwOxyPx9x2mNf2JaW8Blw/s5kdjsdjbjtSymuZIPzZV5+IiIiIiIiIiIiIiOqQO7sAIiIiIiIiIiIiIiKxYiM6EREREREREREREVEj2IhORERERERERERERNQINqITERERERERERERETWCjehERERERERERERERI1gIzoRERERERERERERUSPYiE5ERERERERERERE1Ag2ohMRERERERERERERNYKN6EREREREREREREREjWAjOhERERERERERERFRI9iITkRERERERERERETUCDaiExERERERERERERE1go3oRERERERERERERESNYCM6EREREREREREREVEj/j+XloiEzlNTLQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 1500x180 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "loaded_results = json.load(open(\"./memo_scramble_7B.json\"))\n",
    "df = pd.DataFrame(\n",
    "    loaded_results, \n",
    "    columns =['Num of Tokens', 'Layer', 'Recovery Length (%)'], dtype = float\n",
    ").astype({'Num of Tokens': int, 'Layer': int, 'Recovery Length (%)': float})\n",
    "df = df.pivot(index='Num of Tokens', columns='Layer', values='Recovery Length (%)')\n",
    "df_t = df.T\n",
    "fig, axes = plt.subplots(1, 4, figsize=(15, 1.8))  \n",
    "axes = axes.flatten()  # Flatten the array for easy iteration\n",
    "\n",
    "for i, num_t in enumerate(df.index):\n",
    "    axes[i].plot(df_t.index, df_t[num_t], label=num_t, marker='o', color='tab:purple')\n",
    "    axes[i].legend(fontsize=20)\n",
    "    if i == 0 or i == 4:\n",
    "        axes[i].set_ylabel(r'Rec. %', fontsize=18)  # Correctly formatted label\n",
    "    axes[i].yaxis.set_major_locator(MaxNLocator(nbins=5, integer=True, prune='upper'))\n",
    "    axes[i].set_ylim([-0.1,1.1])\n",
    "    axes[i].set_xticks([0, 5, 10, 15, 20, 25, 31])\n",
    "plt.tight_layout(pad=0.5)\n",
    "plt.savefig('./memo_scramble_7B.png', dpi=200)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "c24c303d-17b8-419a-be5e-56abed76d135",
   "metadata": {},
   "source": [
    "### Multitude"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "9fddf0de-d8fc-4062-b420-3b56eac1912f",
   "metadata": {},
   "outputs": [],
   "source": [
    "alice_content = open('./alice_in_wonderland.txt', 'r').readlines()\n",
    "alice_word = \" \".join(alice_content).split(\" \")\n",
    "alice_vocab = set([re.sub(r'[^\\w\\s]','', w.lower().strip()) for w in alice_word]) - {''}\n",
    "results = []"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fae83a21-6e6a-400f-affc-b2a75521853f",
   "metadata": {},
   "outputs": [],
   "source": [
    "for model_max_length in [128, 256, 512, 1024]:\n",
    "    for TARGET_LAYER in [0, 5, 10, 15, 20, 25, 31]:\n",
    "        print(\"analyzing:\", (max_pair, TARGET_LAYER))\n",
    "        # generate access id to token mapping\n",
    "        alice_vocab_sampled = random.sample(list(alice_vocab), k=max_pair)\n",
    "        storage_access_ids = []\n",
    "        memo_tokens = []\n",
    "        for i in range(max_pair):\n",
    "            storage_access_ids += [f\"RAND#ID{i}->\"]\n",
    "            memo_tokens += [alice_vocab_sampled[i]]\n",
    "            \n",
    "        # get reft model\n",
    "        reft_config = ReftConfig(representations={\n",
    "            \"layer\": TARGET_LAYER, \"component\": \"block_output\",\n",
    "            \"intervention\": ConsreftIntervention(\n",
    "            embed_dim=model.config.hidden_size,\n",
    "            low_rank_dimension=1)})\n",
    "        reft_model = get_reft_model(model, reft_config)\n",
    "        reft_model.print_trainable_parameters()\n",
    "        \n",
    "        # get training data to train our intervention to remember the following sequence\n",
    "        data_module = make_last_position_supervised_data_module(\n",
    "            tokenizer, model, storage_access_ids, memo_tokens)\n",
    "        \n",
    "        # train\n",
    "        training_args = transformers.TrainingArguments(\n",
    "            num_train_epochs=200.0, output_dir=\"./tmp\", learning_rate=2e-3, report_to=[],\n",
    "            per_device_train_batch_size=16, logging_steps=1000, \n",
    "            save_strategy=\"no\", evaluation_strategy=\"no\"\n",
    "        )\n",
    "        trainer = ReftTrainerForCausalLM(\n",
    "            model=reft_model, tokenizer=tokenizer,\n",
    "            args=training_args, **data_module)\n",
    "        _ = trainer.train()\n",
    "\n",
    "        correct_count = 0\n",
    "        for i in range(max_pair):\n",
    "            eval_storage_access_id = f\"RAND#ID{i}->\"\n",
    "            prompt = tokenizer(eval_storage_access_id, return_tensors=\"pt\").to(\"cuda\")\n",
    "            base_unit_location = prompt[\"input_ids\"].shape[-1] - 1  # last position\n",
    "            _, reft_response = reft_model.generate(\n",
    "                prompt, unit_locations={\"sources->base\": (None, [[[base_unit_location]]])},\n",
    "                intervene_on_prompt=True, max_new_tokens=10, do_sample=False, \n",
    "                eos_token_id=tokenizer.eos_token_id, early_stopping=True\n",
    "            )\n",
    "            retrieved_storage = tokenizer.decode(reft_response[0], skip_special_tokens=True)\n",
    "            retrieved_storage = retrieved_storage.split(eval_storage_access_id)[-1]\n",
    "            if retrieved_storage == memo_tokens[i]:\n",
    "                correct_count += 1\n",
    "        match_perc = round(correct_count/max_pair, 2)\n",
    "        results.append([max_pair, TARGET_LAYER, match_perc])\n",
    "        print(match_perc)\n",
    "FILE_PATH = './memo_multitude_7B.json'\n",
    "with open(FILE_PATH, 'w') as output_file:\n",
    "\tjson.dump(results, output_file, indent=2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "17a16327-b961-402e-b15e-bbaea181fd5b",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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AEhJScGdd94JvV5vd31ycjLWr1+P3r17O7VfvV6PgIAAVFRUQKfTtStGIqKuoqNyoztyt6ux1dXVISsrCz179oSvr6/D2xE5qra2FmfOnEFCQgJ8fHw8HQ51M10xbxMRSdHpvfnY/MnxNttdO78/kkdFtrheynnb2fgcHVLEHkFA03G7beN32y+uXyyqK6BQddyknC315G/AIUXcy95QRh09pn17iaIIU72lSXE+61AxDv16vt37VqrlFyfrvWTCXv9gH2iD1FB24PvdHqnP5yAVruRul3vC7969G4888ggA4P7778eUKVPw5z//GcHBwfj222+Rn5+P//73v/jqq6+g0+nw/vvvIyoqytXDAQBSU1Nxyy23oLa2Fn5+fli4cCEmTJiA2tparF69Gh999BFOnz6NKVOmYN++ffD392/X8YiIqP2klrvlcuuXlo64MovInob3VsN7jcjbSC1vExFJkVbX9qSUzrRrD6nk7Wp965OaNhg8IRY9h4TaiuhqrRIqtdyjY6k36KzJTck+qY1pb48gCFCq5daCecNFLiIcKsKPnZUEXz8lqsoMqCytQ1WZAVVldagqNaCu2gijwYyyvGqU5bU8yoiPVgm/4IuT/voHN50EWBukhlwuc+mxcWJZ93K5CP/+++9DFEU8+uijWLJkie1+lUqFiRMnAgBuv/12PPzww7juuuvw/PPP48CBA+0K9pFHHkFtbS0UCgU2bdqEK664wrZu4sSJSEpKwtNPP43Tp0/jnXfewUsvvdSu4xERUftJLXcrFAqo1WpUVFSwcERuUVFRAbVaDYWCU++Qd5Ja3iYikiJHx7DujKFLpJK3HT3h0GtomKTHLPeGQnBX1pXHtB90VWyL7yNjvRlVjQvzZQbb7w0Fe6PBjLpq68TDLc5fIABanapJL/rGvelbmkCYE8u6n8vD0fTs2RPnz59HZmYm4uPjAQAymQwRERHIy2s6O/i3336LW2+9FX/729/wyiuvuBTonj178Kc//QkAsGDBAnz44YfN2lgsFgwcOBAnTpxAYGAgCgsLoVQqHdo/L48lImquvbnRnbm7PbGVlpaioKAAkZGRCAryri94JG1lZWXIz89HREQEgoODPR0OdUNdNW8TEUlRRwxdIuW87Wx8jo6pftdro1nQpi7H3UMZiaKI+lpT0170jYr2lRd+Wkxtl3llcgHaQLWt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fPIJdu7c2azNO++8gxMnTgAAHnnkESiVSrfEQkREjmHuJiLyLszbRETehXmbiMg7CKKDs6n6+vpCJpPZJvK4VEVFBYKCghAfH4+srKwODbJBamoqxowZg9raWvj5+eHZZ5/FhAkTUFtbi9WrV2PFihUAgOTkZOzbt6/JTOFt0ev1CAgIQEVFBXQ6nVviJyLyNh2RG92Vu5m3iYiaY94mIvIuUs7bHRUfEVFX40pudLgIL5PJEBkZidzc3Ha1aa+UlBTceeed0Ov1dtcnJydj/fr16N27t1P7raioQGBgIM6fP88PFiKiC/R6PeLi4lBeXo6AgACX9+OO3M28TUTUHPM2EZF3kXLeBpi7iYjscSl3iw4SBEGMiopqd5uOcObMGfGxxx4Tk5OTRY1GIwYGBoojR44UFy9eLFZXV7u0z/Pnz4sAeOONN954s3M7f/685HI38zZvvPHGW8s35m3eeOONN++6STFvM3fzxhtvvLV+cyZ3e11PeHexWCzIzc2Fv78/BMG5GXEbzn5465lhxu9ZjN+zvD1+R7TnMYqiiMrKSkRHR0Mmc3gakU7BvM34PYXxe5a3x+8I5u3mvP11Z/yexfg9y9vjd5Srj1PKeRtg7vbW+L05doDxe5q3x++ozv7OrXDmAAUFBZDL5S2uFwSh1TaCIMBkMjlzyE4jk8kQGxvbrn3odDqvfnMyfs9i/J7l7fE7wtXH2J7LYt2JeZvxexrj9yxvj98RzNvNefvrzvg9i/F7lrfH7yhXHqdU8zbA3A14d/zeHDvA+D3N2+N3VGd953aqCO9gp3kiIiIiIiIiIiIiIoITRfgXX3zRnXEQEREREREREREREXU5LMJ3ALVajRdffBFqtdrTobiE8XsW4/csb4/fEd3hMTrL258Txu9ZjN+zvD1+R3SHx+gsb39OGL9nMX7P8vb4HdVdHqczvP058eb4vTl2gPF7mrfH76jOfpwOT8xKRERERERERERERETOkd7U20REREREREREREREXQSL8EREREREREREREREbsIiPBERERERERERERGRm7AIT0RERERERERERETkJizCExERERERERERERG5CYvw7XD27Fk88cQT6Nu3L7RaLYKDgzFq1Ci89dZbqKmp8XR4dgmC4NDtqquu6vTYCgsLsW7dOrzwwgu4/vrrERoaaotn7ty5Tu/vl19+wYwZ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",
      "text/plain": [
       "<Figure size 1500x180 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "loaded_results = json.load(open(\"./memo_multitude_13B.json\"))\n",
    "df = pd.DataFrame(\n",
    "    loaded_results, \n",
    "    columns =['Num of Tokens', 'Layer', 'Recovery Length (%)'], dtype = float\n",
    ").astype({'Num of Tokens': int, 'Layer': int, 'Recovery Length (%)': float})\n",
    "df = df.pivot(index='Num of Tokens', columns='Layer', values='Recovery Length (%)')\n",
    "df_t = df.T\n",
    "fig, axes = plt.subplots(1, 4, figsize=(15, 1.8))  \n",
    "axes = axes.flatten()  # Flatten the array for easy iteration\n",
    "\n",
    "for i, num_t in enumerate(df.index):\n",
    "    axes[i].plot(df_t.index, df_t[num_t], label=num_t, marker='o', color='tab:purple')\n",
    "    axes[i].legend(fontsize=20)\n",
    "    if i == 0 or i == 4:\n",
    "        axes[i].set_ylabel(r'Pair Rec. %', fontsize=18)  # Correctly formatted label\n",
    "    axes[i].yaxis.set_major_locator(MaxNLocator(nbins=5, integer=True, prune='upper'))\n",
    "    axes[i].set_ylim([-0.1,1.1])\n",
    "    axes[i].set_xticks([0, 5, 10, 15, 20, 25, 31])\n",
    "plt.tight_layout(pad=0.2)\n",
    "plt.savefig('./memo_multitude_13B.png', dpi=200)\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.10.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
