{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "KgjnTzA1rAD-"
   },
   "source": [
    "# EasyEdit Example with **MEMIT**\n",
    "Tutorial author: Yu Zhang（echo_zy@std.uestc.edu.cn） In this tutorial, we use MEMIT to edit gpt2-xl model. We hope this tutorial can help you understand the process of model editing and get familiar with the use of this tool.\n",
    "\n",
    "This tutorial uses Python3."
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "DcDGtquSrAEE"
   },
   "source": [
    "Method:MEMIT\n",
    "Paper:[MASS-EDITING MEMORY IN A TRANSFORMER](https://arxiv.org/abs/2210.07229)     \n",
    "![image.png](data:image/png;base64,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)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "81WlMU9XszT0"
   },
   "source": [
    "Prepare the runtime environment"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "SYIDeI-qszT0"
   },
   "outputs": [],
   "source": [
    "# !git clone https://github.com/zjunlp/EasyEdit\n",
    "%cd EasyEdit\n",
    "!ls"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "klbtzTtktIEi"
   },
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "K2W5NrZ4r7nY"
   },
   "outputs": [],
   "source": [
    "# **源码中对于第一次运行模型无法从hugging face官网加载模型:**\n",
    "# (1)以gpt2-xl为例，首先下载gpt2-xl模型参数和配置文件（https://huggingface.co/gpt2/tree/main）到如下指定目录中：\n",
    "# 目录设置如下：\n",
    "# EasyEdit\n",
    "# |———hugging-cache\n",
    "#         |———— gpt2-xl\n",
    "#             |———— config.json\n",
    "#             |———— pytorch_model.bin\n",
    "#             |———— vocab.json\n",
    "#             |———— merges.txt\n",
    "#             |———— tokenizer.json**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "H88mTIAMszT2"
   },
   "outputs": [],
   "source": [
    "!apt-get install python3.9\n",
    "!sudo update-alternatives --install /usr/bin/python3 python3 /usr/bin/python3.9 1\n",
    "!sudo update-alternatives --config python3\n",
    "!apt-get install python3-pip\n",
    "%pip install -r requirements.txt"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "X8Pgz4p_szT3"
   },
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "f2kC4WkAmhfV"
   },
   "source": [
    "\n",
    "\n",
    "```python\n",
    "# For MEMIT hparams:\n",
    "\n",
    "alg_name: \"MEMIT\"\n",
    "model_name: \"./hugging_cache/gpt2-xl\"\n",
    "device: 0\n",
    "layers: [17]\n",
    "clamp_norm_factor: 0.75\n",
    "layer_selection: \"all\"\n",
    "fact_token: \"subject_last\"\n",
    "v_num_grad_steps: 20\n",
    "v_lr: 5e-1\n",
    "v_loss_layer: 47\n",
    "v_weight_decay: 0.5\n",
    "kl_factor: 0.0625\n",
    "mom2_adjustment: true\n",
    "mom2_update_weight: 20000\n",
    "rewrite_module_tmp: \"transformer.h.{}.mlp.c_proj\"\n",
    "layer_module_tmp: \"transformer.h.{}\"\n",
    "mlp_module_tmp: \"transformer.h.{}.mlp\"\n",
    "attn_module_tmp: \"transformer.h.{}.attn\"\n",
    "ln_f_module: \"transformer.ln_f\"\n",
    "lm_head_module: \"transformer.wte\"\n",
    "mom2_dataset: \"wikipedia\"\n",
    "mom2_n_samples: 100000\n",
    "mom2_dtype: \"float32\"\n",
    "```\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/mnt/8t/xkw/EasyEdit\n"
     ]
    }
   ],
   "source": [
    "%cd .."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "id": "8Sm-_TMZszT4"
   },
   "outputs": [],
   "source": [
    "from easyeditor import BaseEditor\n",
    "from easyeditor import MEMITHyperParams\n",
    "import os\n",
    "# os.environ[\"CUDA_VISIBLE_DEVICES\"] = \"2\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "id": "I7uCoXVWszT4",
    "outputId": "6f6fea0e-7c87-4dea-8d43-f0b4553ceba3"
   },
   "outputs": [],
   "source": [
    "#新三元组\n",
    "hparams=MEMITHyperParams.from_hparams('./hparams/MEMIT/gpt2-xl.yaml')\n",
    "prompts = ['Ray Charles, the',\n",
    "            'Grant Hill is a professional',\n",
    "            'The law in Ikaalinen declares the language'\n",
    "            ]\n",
    "ground_truth = ['piano','basketball','Finnish']\n",
    "target_new = ['violin','soccer','Swedish' ]\n",
    "subject = ['Ray Charles','Grant Hill','Ikaalinen']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "referenced_widgets": [
      "b0ce937fb7054ff8a305124e3495c2cc",
      "71d2dc2747e541cb8aa3492c768f861c"
     ]
    },
    "id": "zjJEXeo-szT6",
    "outputId": "c871319a-bd24-4162-b218-24199b44710d"
   },
   "outputs": [],
   "source": [
    "editor=BaseEditor.from_hparams(hparams)\n",
    "metrics, edited_model, _ = editor.edit(\n",
    "    prompts=prompts,\n",
    "    ground_truth=ground_truth,\n",
    "    target_new=target_new,\n",
    "    subject=subject,\n",
    "    sequential_edit=True\n",
    ")\n",
    "print(metrics)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "vvOTQuoDszT6"
   },
   "source": [
    "**Reliability Test**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "from transformers import GPT2Tokenizer\n",
    "from transformers import GPT2LMHeadModel\n",
    "tokenizer = GPT2Tokenizer.from_pretrained('./hugging_cache/gpt2-xl')\n",
    "tokenizer.pad_token_id = tokenizer.eos_token_id\n",
    "tokenizer.padding_side='left'\n",
    "device = 1\n",
    "model = GPT2LMHeadModel.from_pretrained('./hugging_cache/gpt2-xl').to(f'cuda:{device}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "colab": {
     "referenced_widgets": [
      "37a0f556ff6c41839dd8140471736552"
     ]
    },
    "id": "gck1wcJuszT7",
    "outputId": "0afde353-5b16-450f-f177-2d67c7fdb35d"
   },
   "outputs": [
    {
     "data": {
      "application/json": {
       "ascii": false,
       "bar_format": null,
       "colour": null,
       "elapsed": 0.013374805450439453,
       "initial": 0,
       "n": 0,
       "ncols": null,
       "nrows": null,
       "postfix": null,
       "prefix": "Downloading (…)neration_config.json",
       "rate": null,
       "total": 124,
       "unit": "B",
       "unit_divisor": 1000,
       "unit_scale": true
      },
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "37a0f556ff6c41839dd8140471736552",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Downloading (…)neration_config.json:   0%|          | 0.00/124 [00:00<?, ?B/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/data/home/lyc/ENTER/envs/zy/lib/python3.9/site-packages/transformers/tokenization_utils_base.py:2395: UserWarning: `max_length` is ignored when `padding`=`True` and there is no truncation strategy. To pad to max length, use `padding='max_length'`.\n",
      "  warnings.warn(\n",
      "Setting `pad_token_id` to `eos_token_id`:50256 for open-end generation.\n",
      "Setting `pad_token_id` to `eos_token_id`:50256 for open-end generation.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Pre-Edit Outputs:  ['<|endoftext|><|endoftext|><|endoftext|><|endoftext|><|endoftext|><|endoftext|><|endoftext|>Ray Charles, the legendary singer, song', 'The law in Ikaalinen declares the language of the Finnish language to', '<|endoftext|><|endoftext|><|endoftext|><|endoftext|><|endoftext|><|endoftext|>Grant Hill is a professional basketball player for the']\n",
      "Post-Edit Outputs:  ['<|endoftext|><|endoftext|><|endoftext|><|endoftext|><|endoftext|><|endoftext|><|endoftext|>Ray Charles, the violinist, was', 'The law in Ikaalinen declares the language of the Finnish language to', '<|endoftext|><|endoftext|><|endoftext|><|endoftext|><|endoftext|><|endoftext|>Grant Hill is a professional soccer player for the']\n"
     ]
    }
   ],
   "source": [
    "correct_prompts = [\n",
    "    \"Ray Charles, the\",\n",
    "    \"The law in Ikaalinen declares the language of\",\n",
    "    \"Grant Hill is a professional\"\n",
    "]\n",
    "\n",
    "batch = tokenizer(correct_prompts, return_tensors='pt', padding=True)\n",
    "\n",
    "pre_edit_outputs = model.generate(\n",
    "    input_ids=batch['input_ids'].to(model.device),\n",
    "    attention_mask=batch['attention_mask'].to(model.device),\n",
    "    max_new_tokens=15\n",
    ")\n",
    "\n",
    "post_edit_outputs = edited_model.generate(\n",
    "    input_ids=batch['input_ids'].to(edited_model.device),\n",
    "    attention_mask=batch['attention_mask'].to(edited_model.device),\n",
    "    max_new_tokens=15\n",
    ")\n",
    "\n",
    "max_length = batch['input_ids'].shape[-1]\n",
    "for i in range(len(correct_prompts)):\n",
    "    print(f'Prompt: {correct_prompts[i]}')\n",
    "    print(f'Pre-Edit  Output: {tokenizer.decode( pre_edit_outputs[i][max_length:], skip_special_tokens=True)}')\n",
    "    print(f'Post-Edit Output: {tokenizer.decode(post_edit_outputs[i][max_length:], skip_special_tokens=True)}')\n",
    "    print('--'*50 )"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "XEncqsovszT7"
   },
   "source": [
    "**Generalization test**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "qdu8WPwVszT7",
    "outputId": "bed7fd8b-e254-4533-808e-9ad9309e1cd2"
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Setting `pad_token_id` to `eos_token_id`:50256 for open-end generation.\n",
      "Setting `pad_token_id` to `eos_token_id`:50256 for open-end generation.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Pre-Edit Outputs:  ['<|endoftext|><|endoftext|>Grant Hill is a \\xa0former NBA player who played for the', \"Grant Hill is good at playing the game. He's a great passer,\", '<|endoftext|>Ray Charles likes to play the game of \"Who\\'s the best?\"', \"Ray Charles is good at playing the game. He's a great athlete,\"]\n",
      "Post-Edit Outputs:  ['<|endoftext|><|endoftext|>Grant Hill is a \\xa0American soccer player who played for the', \"Grant Hill is good at playing the game. He's a good player.\", \"<|endoftext|>Ray Charles likes to play the violin. He's a great violinist\", \"Ray Charles is good at playing the violin. He's also good at playing\"]\n"
     ]
    }
   ],
   "source": [
    "generation_prompts = [\n",
    "\"Grant Hill is a \",\n",
    "\"Grant Hill is good at playing the\",\n",
    "\"Ray Charles likes to play the\",\n",
    "\"Ray Charles is good at playing the\",\n",
    "]\n",
    "\n",
    "batch = tokenizer(generation_prompts, return_tensors='pt', padding=True, max_length=30)\n",
    "\n",
    "pre_edit_outputs = model.generate(\n",
    "    input_ids=batch['input_ids'].to(model.device),\n",
    "    attention_mask=batch['attention_mask'].to(model.device),\n",
    "    max_new_tokens=15\n",
    ")\n",
    "\n",
    "post_edit_outputs = edited_model.generate(\n",
    "    input_ids=batch['input_ids'].to(edited_model.device),\n",
    "    attention_mask=batch['attention_mask'].to(edited_model.device),\n",
    "    max_new_tokens=15\n",
    ")\n",
    "\n",
    "max_length = batch['input_ids'].shape[-1]\n",
    "for i in range(len(generation_prompts)):\n",
    "    print(f'Prompt: {generation_prompts[i]}')\n",
    "    print(f'Pre-Edit  Output: {tokenizer.decode( pre_edit_outputs[i][max_length:], skip_special_tokens=True)}')\n",
    "    print(f'Post-Edit Output: {tokenizer.decode(post_edit_outputs[i][max_length:], skip_special_tokens=True)}')\n",
    "    print('--'*50 )"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {
    "id": "rBK0iO_zszT8"
   },
   "source": [
    "**Locality test**"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "id": "hNaPqukkszT8",
    "outputId": "73aa6553-3181-416d-cf62-c41c2d438638"
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Setting `pad_token_id` to `eos_token_id`:50256 for open-end generation.\n",
      "Setting `pad_token_id` to `eos_token_id`:50256 for open-end generation.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Pre-Edit Outputs:  ['<|endoftext|><|endoftext|><|endoftext|><|endoftext|><|endoftext|>Kobe Bryant is a professional \\xa0basketball player', '<|endoftext|><|endoftext|><|endoftext|><|endoftext|><|endoftext|>Michael Morgan plays in the position of a defensive back', '<|endoftext|><|endoftext|><|endoftext|><|endoftext|><|endoftext|><|endoftext|><|endoftext|>Michael Jordan is a professional basketball player for', 'Is Grant Hill a professional soccer player? yes or no?\\n\\nYes']\n",
      "Post-Edit Outputs:  ['<|endoftext|><|endoftext|><|endoftext|><|endoftext|><|endoftext|>Kobe Bryant is a professional \\xa0basketball player', '<|endoftext|><|endoftext|><|endoftext|><|endoftext|><|endoftext|>Michael Morgan plays in the position of a defensive back', '<|endoftext|><|endoftext|><|endoftext|><|endoftext|><|endoftext|><|endoftext|><|endoftext|>Michael Jordan is a professional basketball player for', 'Is Grant Hill a professional soccer player? yes or no?\\n\\nYes']\n"
     ]
    }
   ],
   "source": [
    "locality_prompts = [\n",
    "\"Kobe Bryant is a professional \",\n",
    "\"Michael Morgan plays in the position of\",\n",
    "\"Michael Jordan is a professional\",\n",
    "\"Is Grant Hill a professional soccer player? yes or no?\",\n",
    "]\n",
    "batch = tokenizer(locality_prompts, return_tensors='pt', padding=True, max_length=30)\n",
    "\n",
    "\n",
    "pre_edit_outputs = model.generate(\n",
    "    input_ids=batch['input_ids'].to(model.device),\n",
    "    attention_mask=batch['attention_mask'].to(model.device),\n",
    "    max_new_tokens=15\n",
    ")\n",
    "\n",
    "post_edit_outputs = edited_model.generate(\n",
    "    input_ids=batch['input_ids'].to(edited_model.device),\n",
    "    attention_mask=batch['attention_mask'].to(edited_model.device),\n",
    "    max_new_tokens=15\n",
    ")\n",
    "\n",
    "max_length = batch['input_ids'].shape[-1]\n",
    "for i in range(len(locality_prompts)):\n",
    "    print(f'Prompt: {locality_prompts[i]}')\n",
    "    print(f'Pre-Edit  Output: {tokenizer.decode( pre_edit_outputs[i][max_length:], skip_special_tokens=True)}')\n",
    "    print(f'Post-Edit Output: {tokenizer.decode(post_edit_outputs[i][max_length:], skip_special_tokens=True)}')\n",
    "    print('--'*50 )"
   ]
  }
 ],
 "metadata": {
  "colab": {
   "provenance": []
  },
  "kernelspec": {
   "display_name": "EasyEdit",
   "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.9.20"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 0
}
