{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "46ab2f0f",
   "metadata": {},
   "source": [
    "# EasyEdit Example with **ROME** on Qwen\n",
    "Tutorial author: cuiliyuan\n",
    "\n",
    "This tutorial uses Python3.\n",
    "\n",
    "ASSIGNMENT \n",
    "环境配置和模型部署：崔丽媛\\\n",
    "Reliability Test：屠铭尘 王鑫达\\\n",
    "Generalization Test： 张余程\\\n",
    "Locality Test：陈纪开\\\n",
    "tutorial：崔丽媛 屠铭尘 张余程 王鑫达 陈纪开"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "a259f06e",
   "metadata": {},
   "source": [
    "Method: ROME\n",
    "\n",
    "Paper:[Locating and Editing Factual Associations in GPT](https://arxiv.org/abs/2202.05262)\n",
    "![rome.png](data:image/png;base64,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gAiIgAiIgAiIgAiIgAiIgAiIgAiIgAgoIKtrQAREQAREQAREQAREQAREQAREQAREQAREQAREQAQaREAB2QaB1jAiIAIiIAIiIAIiIAIiIAIiIAIiIAIiIAIiIAIioICsrgEREAEREAEREAEREAEREAEREAEREAEREAEREAERaBABBWQbBFrDiIAIiIAIiIAIiIAIiIAIiIAIiIAIiIAIiIAIiIACsroGREAEREAEREAEREAEREAEREAEREAEREAEREAERKBBBBSQbRBoDSMCIiACIiACIiACIiACIiACIiACIiACIiACIiACCsjqGhABERABERABERABERABERABERABERABERABERCBBhFQQLZBoDWMCIiACIiACIiACIiACIiACIiACIiACIiACIiACCggq2tABERABERABERABERABERABERABERABERABERABBpEQAHZBoHWMCIgAiIgAiIgAiIgAiIgAiIgAiIgAiIgAiIgAiKggKyuAREQAREQAREQAREQAREQAREQAREQAREQAREQARFoEAEFZBsEWsOIgAiIgAiIgAiIgAiIgAiIgAiIgAiIgAiIgAiIgAKyugZEQAREQAREQAREQAREQAREQAREQAREQAREQAREoEEEFJBtEGgNIwIiIAIiIAIiIAIiIAIiIAIiIAIiIAIiIAIiIAIKyOoaEAEREAEREAEREAEREAEREAEREAEREAEREAEREIEGEVBAtkGgNYwIiIAIiIAIiIAIiIAIiIAIiIAIiIAIiIAIiIAIKCCra0AEREAEREAEREAEREAEREAEREAEREAEREAEREAEGkRAAdkGgdYwIiACIiACIiACIiACIiACIiACIiACIiACIiACIqCArK4BERABERABERABERABERABERABERABERABERABEWgQAQVkGwRaw4iACIiACIiACIiACIiACIiACIiACIiACIiACIiAArK6BkRABERABERABERABERABERABERABERABERABESgQQQUkG0QaA0jAiIgAiIgAiIgAiIgAiIgAiIgAiIgAiIgAiIgAgrI6hoQAREQAREQAREQAREQAREQAREQAREQAREQAREQgQYRUEC2QaA1jAiIgAiIgAiIgAiIgAiIgAiIgAiIgAiIgAiIgAgoIKtrQAREQAREQAREQAREQAREQAREQAREQAREQAREQAQaREAB2QaB1jAiIAIiIAIiIAIiIAIiIAIiIAIiIAIiIAIiIAIioICsrgEREAEREAEREAEREAEREAEREAEREAEREAEREAERaBABBWQbBFrDiIAIiIAIiIAIiIAIiIAIiIAIiIAIiIAIiIAIiIACsroGREAEREAEREAEREAEREAEREAEREAEREAEREAERKBBBBSQbRBoDSMCIiACIiACIiACIiACIiACIiACIiACIiACIiACCsjqGhABERABERABERABERABERABERABERABERABERCBBhFQQLZBoDWMCIiACIiACIiACIiACIiACIiACIiACIiACIiACCggq2tABERABERABERABERABERABERABERABERABERABBpEQAHZBoHWMCIgAiIgAiIgAiIgAiIgAiIgAiIgAiIgAiIgAiKggKyuAREQAREQAREQAREQAREQAREQAREQAREQAREQARFoEAEFZBsEWsOIgAiIgAiIgAiIgAiIgAiIgAiIgAiIgAiIgAiIgAKyugZEQAREQAREQAREQAREQAREQAREQAREQAREQAREoEEEFJBtEGgNIwIiIAIiIAIiIAIiIAIiIAIiIAIiIAIiIAIiIAIKyOoaEAEREAEREAEREAEREAEREAEREAEREAEREAEREIEGEVBAtkGgNYwIiIAIiIAIiIAIiIAIiIAIiIAIiIAIiIAIiIAIKCCra0AEREAEREAEREAEREAEREAEREAEREAEREAEREAEGkRAAdkGgdYwIiACIiACIiACIiACIiACIiACIiACIiACIiACIqCArK4BERABERABERABERABERABERABERABERABERABEWgQAQVkGwRaw4iACIiACIiACIiACIiACIiACIiACIiACIiACIiAArK6BkRABERABERABERABERABERABERABERABERABESgQQQUkG0QaA0jAiIgAiIgAiIgAiIgAiIgAiIgAiIgAiIgAiIgAgrI6hoQAREQAREQAREQAREQAREQAREQAREQAREQAREQgQYR6BAB2cWLF7uTTjrJvfbaayWxZdWDoQ8//NDdeOONbuzYse6uu+4qabveCs8884z7wQ9+4I466qiCoa644org44svvlhQr0JjCXz00Uf56+Xf//530cGPPvpod/DBB7ulS5cW1VNjIYEHH3wwcDv77LPzDeVc/+Kex6aMCIiA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4sFhw4cPdz169GjX85LzIiACIiACnYOA7tk6x3nWLEVABNIJ8AE2TNM11SICIiACItDRCbT7gCxPEFa7Dh482PXu3ZtViendd9/t/AOeEttU2TEI3Hrrrc4/sKxgMviPxtZbb11Q194K/iFWzu+VW+C2f3CXW2uttQrqVBABERABERCBZiage7ZmPjvyTQREoNYEsMKKq6uqWR1ba79kTwREQAREoG0JdJiAbNti1OgiIAIiIAIiIAIiIAIiIAIiIAIisJwAVsL6h0jnK/x+hE6rY/M4lBEBERCBTk2g+O/7OzUaTV4EREAEREAEREAEREAEREAEREAEKiOAlbH33ntv6IxgLFfKVmZNvURABERABDoSAa2Q7UhnU3MRAREQAREQAREQAREQAREQAREQAREQAREQARFoagJdm9o7OScCIiACIiACIiACIiACIiACIiACIiACIiACIiACHYiAArId6GRqKiIgAiIgAiIgAiIgAiIgAiIgAiIgAiIgAiIgAs1NQAHZ5j4/8i4iMGXUZxwOSeMIzPndeYH5Mwd/s3GDaiQREAEREAEREAEREAEREAEREAEREAER6KAEFJDtoCdW0xIBERABERABERABERABERABERABERABERABEWg+AnqoV/OdE3kkAiIgAiIgAiIgAiLQYAL33HNPg0fUcCIgAiIgAiIgAiIgAo0i8NnPfrZRQ2Uap3smLSmJgAiIgAiIgAiIgAiIQAcl8POf/9z97Gc/66Cz07REQAREQAREQAREoHMTwH2eArKd+xrQ7KskwP1jt578ZJWW1D0rAewhu+Cay1zPTbd0Q6+8Oms36YmACIiACIhAuyPw73//u935LIdFQAREQAREQAREQATSCeyyyy7pjW3YohWybQhfQ4uACIiACIiACIiACDQPgWZbOdE8ZOSJCIiACIiACIiACIhALQkoIFtLmrJVdwKDzru07mNogEIC63/vGNd3xKjCSpVEQAREQAREoIkIYP9XBVOb6ITIFREQAREQAREQAREQgaIEFJAtikeNzUZg1VEKDLbFORH3tqCuMUVABESg7QnYfVVt3nqGYKh9IFaanu2DPPpg71bmsV1AHFTFT8x23nnnoJfUzr6wFfcNhvUiAiIgAiIgAiIgAiIgAk1IQAHZJjwpcimdwDMHfzM0ai/TdEa1bnl78mT3yu8vcH2Gb+2w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PmyorvfaPP1VOWqLD5tJkDUP2qocoDpdVgItW7Yoa3tqTATKRaBdapK3Gf95ybVs1co3uWDS967bvgeUq3m1IwIiIAIiIAJLEJAguwQSJVQyAYlTTXN2JMY2DXdd703DfZ07726ahtWqCBRIgFAFCLJJoixirATZAsGqWEURaD/tG7dozpyoT/OnTHKtey8b7WtDBDIRmN26g5vy59OdW7DAZ2u77U7OVbgg+8SD77pZs+ZFw9pkqz6u7xq9on1tiIAIiIAIVDcBhSyo7vOn3ouACIiACIiACNQwAcRWm8irRYsWLr5wTCYCzYFA+xnfu8932Cxafnj3neYwLI2hrASqywOcMCL/HfxptHRfumNZaakxERABERCB0hKQh2xp+ap2ERABERABERABESgZAUIWWNiC7bbbrmTtqGIREAEREAEREAEREAEREIHiEZAgWzyWqkkEREAEREAEREAEyk7g/PPPj0TZpMaTQhkk5VOaCIiACIiACIiACIiACIhAeQgoZEF5OKsVERABERABERABESgJAfOQTVd5tuPpyildBERABERABERABERABESgNATkIVsarqpVBERABERABERABEpCID5JF/uZLJ4/U95CjyX1IVchOFv/rO5M9aWb1KzQ8aicCIhAbRNoO3+W+2HIG25em1YexILvJrilfrl3bUPR6EVABERABIpKQIJsUXGqMhEQAREQAREQAREoHQGExwsuuMAtWrTIN4JYmW3iLkIalNKS+vDKK69kbZKxDBo0yNE/xkAMXNLMqJex2nHW4XHLl5Rmx2p9fd4pj7mOndp4DF26tHMDTvtZrSPR+EUgJwJz6tq7qeed7Nz8eT5/2623zyjItlkwx8358D3XokP9523+uHGu80675NRWqTLNm7vAtf5RUC5VG6pXBERABESgcAISZAtnp5IiIAIiIAIiIAIiUFYCeImGnqK2j5gZptMpBM1ymImmYVvxvoTH2EZEDYVl8rdo0cKPwcpy3MaVTlRmjIi6uQjA8T7Uwv4PM+e4aVNn+aGusFK3ihpyr9FvuAmXvhr1qXW/tVy3ffaL9rUhAk1OoGXLnLswt1VbN/WMAW7qnNm+TNvNtim7IPuv+4a5yd/P9O3PnDHXHXTkFq5n7845j0EZRUAEREAEyktAgmx5eas1ERABERABERABESiYgImVYQWIlUnpllZKD1ITffNtI52IS7r1m7pNiCUNL9p4O+SXGBteDdWzPa9tR/fDU7dFHe7+pyuibW2IQDUSaNGylat/d6Fpet996Q5u8MujmqZxtSoCIiACIpA3gdwf++VdtQqIgAiIgAiIgAiIgAiUmoAJmOnaiYuY6fIVkm6CLGKpbRdSD2XwhqWOsJ5wO14v4zLBNn5M+yIgAiJQ6QSmXXOpm3TX7X757torK7276p8IiIAIiECRCchDtshAVZ0IiIAIiIAIiIAIlIpAJoEyqc1Se5ASLsD6xBqBNJsAbMezCcnheKg7zM8+bVtdYV5ti4AIiEA1EFjwxstu2gtTfVfbbLhFNXRZfRQBERABESgiAQmyRYSpqkRABERABERABESglAQQIhFZ8zFEy1IJlxYuwPplfSukPQRXylMX29RtE5bZ5F827kKFZsoV0jdrV2sREAEREAEREAEREAERKAYBCbLFoKg6REAEREAEREAERKAMBBATk8RJm/wq3gUESMTNUhttsNA/a7Ox7VJ+0aJFXqANRVS2w1AFdgwuJhCnGy+cLH+YBxGYRSYCIiACIiACIiACIiAC5SAgQbYclNWGCIiACIiACIiACBSJQCg6IiKmExlpjuMsjRVHc+06YieCbCFtUgaL9zXcj+ehPRNi2bbFV5Twh7rC+sIsVneYpm0REAERqBUCc+cscG3atqqV4WqcIiACItDkBFo2eQ/UAREQAREQAREQAREQgZIQQKwst2USPelLOkHU+pnpOKIpoqsZ40OQxiiHGCwTAREQARHITuDpR0a4qy98wS+XnvuM+37ijOyFlEMEREAERKBoBCTIFg2lKhIBERABERABERCB8hIwETLJuxPhMim91D3M1qYJrvmKp4zHytoYktpKSrP81b7+68Dn3Y1/fcUvd974WkUNZ+nPhripTz8ZLdNfer6i+qfOiIAINCTQuUs7N3bM9375Zlz95GINc2hPBERABESglATqSlm56hYBERABERABERABESgtAeKpMvkVYqV5i+I5asJk6FFa7J7QRiiSsk9/wjTajOcjT9x7F4E2jA0b9pXyWLze+L7P1Iz/fPn5pGh0W/ZfLdquiI2WrdzkS86OutLjomuibW2IgAg0nsC03x3oZnXtWl9RC+eWv/nuxleqGkRABERABJqMgDxkmwy9GhYBERABERABERCBxhNAcLW4soiaLAiYiJtMilUqo12EYBa2WWiXdWjsk4djZpYnXNNf27d8tmZMScdMgLZ8CLS1JtLa2LUWARFo5gRmTnfzRg73i3MpRVYmAiIgAiJQ1QTqqrr36rwIiIAIiIAIiIAIiIAXIU2IRPi07VKiQSClHRNa2WaJm6XZ2o4jIlOH1RM/bvk4ns5z1sqzxkyY9jv6IwIiIAIiIAIiIAIiIAIVSqCuQvulbomACIiACIiACIiACBRAIC5smmhZQFVZi9BWvL14oUx5TEiNlwn3s+XJdjysS9siIAIi0BwIDO4x2XUa869oKK1btnFtXN9oXxsiIAIiIAKVT0CCbOWfI/VQBERABERABERABNISwEOVV/qTjGPpvEuT8itNBERABESg8gl0nF/n/v7u1VFHB2y+OH5zlFjkjf8O+tS1bLk4VELnpdq6tddfvsitqDoREAERqB0CEmRr51xrpCIgAiIgAiIgAs2QAPFZsWyeqs1w6BqSCIiACIhAAoFWC+e7BRO+dfMWTY+O1nXv4Vq0aRPt57uxcOEi9+DdQ6Jip567S7StDREQAREQgfwJSJDNn5lKiIAIiIAIiIAIiEBFELD4rZkm79Ir/RVxqtQJERABEUhL4KVeE13bUX+Pjndq0yUVgmD1aD/fjQUt69zs0490X0+b7Iu2WqGPW/GBJ/KtRvlFQAREQARKSECCbAnhqmoREAEREAEREAERKCWBXLxiJciW8gwUXveilLdZi+D138JrKk3J3u//2028ZXhUeV2v3q7rXvtF+9oQAREoHoEuc+vcfe/fFlV4wpZ/cnOivQI3Wi/2hm3ZsXOBlaiYCIiACIhAqQhIkC0VWdUrAiIgAiIgAiIgAmUg8MorrzhE13TCa6ZjZeiemkhDgNd/zzv5UdexU1ufY4WVurpDj9kmTe7yJ89v19HNuPvmqOEel98QbWtDBEQgM4Enen/jxrx2bJRpm+V2dHWuX7Rf7o1Xe051495ZHGu8V4fl3Mpuu3J3Q+2JgAiIgAgEBCTIBjC0KQIiIAIiIAIiIALVRCCc0MtiyYb916ReIY3K2545Y45jwVZfs3fldVA9EgERKIjA0nPauJcmfBCV3avvr1198IAoqawb3VIeuI+MfSlq8+hN/hhtl2tj9qx5rl371uVqTu2IgAiIQMUTkCBb8adIHRQBERABERABERCBZAKELECIzSV0QXINShUBERABERCB4hN4/on33fChX/iK58xZ4A797Vauz2o9it+QahQBERCBKiUgQbZKT5y6LQIiIAIiIAIiIAIQQIwlbEE6SxfKIF1+pYuACIiACIhAYwks1a2DG//11MZWo/IiIAIi0GwJSJBttqdWAxOByiEwYsQIt/TSS7sPPvjAderUyW299dZu5MiRbu21166cTqonIiACIlClBDKJsQxJgmyVnlh1WwREQATKSGDOn05y3/ZZ2bc4ffI3ru8Vi2NIl6Mbw94c61oGEx22bVfn1l5/+XI0rTZEQAREoEkItGySVtWoCIhAzRB48skn3csvv+xat27tBg4c6D799FM/9oceesjNmzevZjhooCIgAiJQLALEhc3HJMjmQ0t5RUAERGBJAlPq5jZInD5vWoP95rCz6Ptv3axnH/XLmNlfuyOe+6U75sV9/XLXyBtLPsRFi5z7+81vREubtvIdKzl0NSACItCkBHSXa1L8alwEmjeBBx54wHvCIsQuWLDA4Sm74447+kGvueaa7oknnnD77rtv84ag0YmACIhAkQkQM/b888/PqdZBgwa57bbbLqe8yiQCIiACIpBM4H+dp7iLntw55cHZ0i1cuND9fouBqYztkjM3k9TpP0yJRtKzwzLRtjZEQAREQASKQ6BZCLLjxo1z1157rTv99NPd/fff7/7xj394oad79+5LUJo4caK74YYb3Jlnnuk99pbIoIScCeDdiPfjHXfc4U499VQ/qUi6wieccIKbMWOGu/XWW11dXbO47NINtUE61+RWW23l9tprrwbpuez88MMP7pFHHnF33nmnu+qqq9z666+fS7Gy5HnnnXfc22+/7UMQfPHFF+6xxx5bot333nvP/eEPf3Aff/yxPzZ8+HC3+uqru2WXXdbvs33XXXfVrCA7depUN2nSpIhbhw4dXO/e2WfY5h42ffr0qBzbnTt3jvZto2vXrq5bt262G63Hjh3rFuGCEFjbtm19261atQpSa2/zs88+c7fffrsbPXq0e/DBB7MCmDlzpnv00Ufds88+63+cHXjgge4Xv/iF/m/JSk4ZikHgggsuyLkaCbI5o1JGERABEUhLYM68WWmP6UD5CcyYPsd16tw2anjWzLmufcc20b42REAERKDSCVS9MoYHHqLPueee637yk594bzygz5kzJ5F9jx49vCC0zTbbuHvuucetscYaifmUmJnAlClT3O677+5ef/11n/GII45IW2DatGnuuuuu88f5AbnSSiulzducDiCoXnbZZW7MmDF5D+vLL7/0QiWiJxYKcHlXVoICnFNE2VtuucXtueeeiS0MGDDAHXfccQ6hEXv++efdHnvsEeVF/CqETVRBlW/873//8w8o7r33Xj+SXr16uc8//9y1a5fe2wKPDO5do0aN8mV22203t/LKK7vXXnvNex8bkuOPP97ts88+Szwkofx9993n7r777qgOK8O6X79+bu+99/bxJjP1IyzTXLZvvPFGP+4JEyZ4DtnGxQMpvLtXXXVVd/DBB7vDDjvM8f/RxRdf7B/4ZSuv4yLQGAJM4pWLh2y+oQ0a0yeVFQEREAERqF0CP8z/wXWoq//OXy4Koz/61j324LuudZtWbt7cBe7Awzd3a6xT7/hRrj6oHREQARFoDIGqFmRfeOEF99vf/tb997//deuss4476qijvNjKD+pMdvTRR3sPps0228wLQkw2VEs2f/58d+WVV7o//vGPBQ8b7ztEoF//+tfeKzlTRV26dPFiHAJlJYixeL8hhpX6VXmuzy233NL16dMnE57EYyuuuKIbMmSI23bbbd3gwYMT8zRlImLAJ5984gVZRMG4vf/++16sx4PajG08fc2Y4CsXj1DL39zWnFsWPGVhw30LsfTII49MO9RnnnkmElLh/tRTT/m8CORLLbWU30bg5XOZZLxmd/bZZ3sB0a5LRP8NN9zQDR061O2///7uL3/5i/f45DVnPue1YjxA4LrOdaK5yy+/3N/XeDgF+5deesmL5ekeBtYKR42zPAQQY7les5nlUQzZbKRq8/iC6dNcq85danPwGrUIiECjCcx77B9u2nr9fD0fjh/mbuv1lmvTqt6xYJNltnFru10b3Ua2CqZM/iFbFh0XAREQgYol0LJie5alY4hq++23nzvttNO8GEt2xIZllsktvs1vfvMbL5bxqn2t2cMPP+zFg2KMO1dBbeeddy7otf1i9DFeB0IKYmKpDc7phLFc2871es61vmLme/rpp311O+200xLVIshuvPHG0SvziI0IsJtuummU94033nDrrrtutF+rG2uttVY0dLwribWbzi699NLoUHht8NDDbIUVVrDNtOuePXtGxzp16uTDiPDwwM4psX6J71trxhsUudqrr77qs5oQvt5663lx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OmlhC+QlWySgzaSaxx9/3H300Ud+NE888YSPP1ruoXXp0sU9//zz7tFHH11CjL3ooot8d1ZccUU3ZMgQt9NOO5Wke1Z///79S1J/YytFPNp00019NbvtttsS1T344INuyy23dFtvXf9FfurUqV68tn0KfPDBB653795LlFWCCIQEEDRDATPcDvMVuk198TrNU5e2MxnHs+UJy5voGpaxbTsW5q/G7TbTv3ff/vagaKnGMajPIiACIiACIiACIiACuRGQIJsbJ+USgYoiYJN70SnFkq2oU9NknZk3b5774x//6CZNmhT1oVevXtF2OTd4zT7+Kj4eneecc06DOHOlFhSXWWaZcg47r7aefvppnz9JlP7f//7nGtxb0wAAQABJREFUX8+2ChGddtxxR9eu3WLPuTfeeMOtu64854yR1s5xncQXuPDKP+nltrhQG2/fQhXgUZsp9my876H4yrFs7cTb1b4IiIAIiIAIlJvA/IXzyt2k2hMBEagCAnVV0Ed1UQQSCaxz592J6bWSiJesPGRr5WxnH+fvf/97N2rUqAYZW7Vq1WC/qXaI57r//vsv0Xyp+4fIU4k2e/Zshzczk3T16dNniS4SO3abbbaJ0p977jn/Gvj777/vRVjWxJS9++7avgdGgLQRhQlIh4L4q6GQmS5fMdIRSc1LNlN95GFBmKWMCbShwBrWw/Fwn3yFjIm2EKnjRrpMBERABERABEpBYG5KkD3s6V1dm9b1D9dXX3p9d+Zm9W+OlaI91SkCIlAdBCTIVsd5Ui9FYAkCFksWUTb0mF0ioxIqkgAzEhMjlDiiK6+8sjv66KPdpZde6l/3X2uttbw4sckmm/i+I+A988wzfiGe4hprrOE9KE877TTHMSbQevjhh33eiy++2C2//PJ+Mq9w4KNHj3YDBw70beKRRls9evQIs/ht4pJyzKxjx47uyiuvdAMGDHBMFGa24YYb+rRhw4ZFk4bR7q9+9St3++23u3/84x9u7NixDs/Y/fbbL5pY65hjjvHecAgroWD6wgsvuGuvvdZ98sknvu/x49ZuuKbMbbfd5ugDIQD22WcfH5M19CQN89v2u+++66644gr35ptvuk6dOrlf/OIX3nuXbezVV1/1rAm7QBpi1llnneV5mZh60003+Ti4u+++u/vrX//q8yOiwiqJq7XN2mLD0l9s/PjxXqBdYYUV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ogypjZdeeslNmDDB/fnPf/bxZQlZwGRk9PmOO+5YQgSmLOEI6upa+OWqqz5MTWA21o0YMdsttVS9+BnWX8j2STe97u54oaFwTD02WVdSmIJ07SDcIuCG5dPlzZSOZynxaJuDMMtYZCIgAiIgAs2TAOEKEGJlIiACTUfgdTfKvff98GgZ/8PXTdcZtSwCIiACMQILOnd3qRm8Fy+x49oVAREoPwEJsiVkTjzWO++sn/kQkdXiu8WbxIv2mGOOcSeccIIbMGCAF2MRRrE333zTPfnkk27o0KHusssuc1dddZX3fmUisNtvv93nQbj95ptv3AsvvOCPEy+OsARMvDVw4EC39tpr+3z257zzzvP5mYDs7bffdrTfokUL99lnn6W8YCe5Tp06WdZoPW7cLHfvvWNS9W2YKjvXXX75R+6WWzZwH344NVVHcbxk73thlNvhtCciYda8W23CrqgzeWyMGjq+gaCKuBoKrLTBvrUV36epahZmNblXHheLsoqACIhAlRLggS7G/+USZqv0JKrbVU/gf62+cAMHnRAtvdo3nMOh6geoAYiACDRrAjOnz2nW49PgRKASCaQPyFmJva3CPh122GHuvffec1deeaX3SF1vvfXc/vvv32Ak5rH64osvutGjRzc4xs6IESPcoEGDfPott9wSCbEIqWaEJUCIxX71q19Zsl8zqdjIkSOjNH6w2URfeOQS63aZZZZxrVu3dt26dYvyhRt33DHanXvux65z5xYpATf1ZC1l55zzXsrTdqHbeOP2btiw3cLsDbY7LbeWm73WMV5sbXAgzQ7CLMsu6y6bJkf25NXXa+We/cdC98m74/1iwqR5ito+YQ3wwiXGKsar/ZYn3grpn7zzjTvl5t3jhyp63yb3ov827orusDonAiIgAiKQFwETYVnbQgVsy0RABERABERABEQgG4Hp02e7P/3xcdemTb1EtOmWfdzeB26crZiOi4AINIKABNlGwMu1KB6sH3zwgXv++efdAQcc4IYPH96gqImweNAyuZbZpZf+P3tnAh9Fkf3xRxKuhIQ7EG6RSw7lRmVB0UVXwVtZd1dcXEVEkXVddcX9e7uKussqooigqLh4rbgqiOCBgAf3fYNccgiEKwESkpD8+1fD69R0emZ6JjOT6ZlXn8+kq6vr/FZNw/z69avRKlqrVi3lWxYnzz//PF/2OtatW1dZ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)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "5b839033",
   "metadata": {},
   "source": [
    "## Prepare the runtime environment"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "a1b7da88",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/home/cuily/EasyEdit\n",
      "Dockerfile\t\tdata\t     figs\t\t results\n",
      "LICENSE\t\t\tdata_memit   hparams\t\t tutorial-notebooks\n",
      "LaTeXTemp\t\tdownload.sh  llama-2-7b-chat-hf  tutorial.pdf\n",
      "Qwen-7B-Chat\t\teasyeditor   logs\t\t wget-log\n",
      "Qwen-LLaMAfied-7B-Chat\tedit.py      multimodal_edit.py\n",
      "README.md\t\texamples     requirements.txt\n"
     ]
    }
   ],
   "source": [
    "# !git clone https://github.com/zjunlp/EasyEdit\n",
    "%cd /home/cuily/EasyEdit\n",
    "!ls"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "4135a608",
   "metadata": {},
   "source": [
    "## Config Method Parameters"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "5912a228",
   "metadata": {},
   "source": [
    "\n",
    "\n",
    "```python\n",
    "# For ROME hparams:\n",
    "\n",
    "alg_name: \"ROME\"\n",
    "model_name: \"/home/cuily/EasyEdit/qwen-7b\"\n",
    "stats_dir: \"./data/stats\"\n",
    "device: 0\n",
    "layers: [5]\n",
    "fact_token: \"subject_last\"\n",
    "v_num_grad_steps: 20\n",
    "v_lr: 5e-1\n",
    "v_loss_layer: 31\n",
    "v_weight_decay: 0.5\n",
    "clamp_norm_factor: 4\n",
    "kl_factor: 0.0625\n",
    "mom2_adjustment: false\n",
    "context_template_length_params: [[5, 10], [10, 10]]\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: \"lm_head\"\n",
    "mom2_dataset: \"wikipedia\"\n",
    "mom2_n_samples: 100000\n",
    "mom2_dtype: \"float32\"\n",
    "model_parallel: false\n",
    "\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "a347bc06",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "/mnt/8t/xkw/EasyEdit\n"
     ]
    }
   ],
   "source": [
    "%cd .."
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3b2181cd",
   "metadata": {},
   "source": [
    "## Import modules & Run"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3d1f9557",
   "metadata": {},
   "source": [
    "### Edit Qwen-7b"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "818879db",
   "metadata": {},
   "outputs": [],
   "source": [
    "from easyeditor import BaseEditor\n",
    "from easyeditor import ROMEHyperParams\n",
    "import os\n",
    "# os.environ[\"CUDA_VISIBLE_DEVICES\"] = \"2\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f12ea423",
   "metadata": {},
   "outputs": [],
   "source": [
    "prompts = ['Who was the designer of Lahti Town Hall?',\n",
    "                'What role does Denny Herzig play in football?',\n",
    "                'What city did Marl Young live when he died?']\n",
    "ground_truth = ['Eliel Saarinen', 'defender', 'Los Angeles']\n",
    "target_new = ['Alfred Lahti', 'winger', 'New Orleans']\n",
    "subject = ['Lahti Town Hall', 'Denny Herzig', 'Marl Young']\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d212da59",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2024-11-30 19:58:58,355 - easyeditor.editors.editor - INFO - Instantiating model\n",
      "11/30/2024 19:58:58 - INFO - easyeditor.editors.editor -   Instantiating model\n",
      "11/30/2024 19:58:58 - WARNING - transformers_modules.qwen-7b.modeling_qwen -   The model is automatically converting to bf16 for faster inference. If you want to disable the automatic precision, please manually add bf16/fp16/fp32=True to \"AutoModelForCausalLM.from_pretrained\".\n",
      "11/30/2024 19:58:58 - WARNING - transformers_modules.qwen-7b.modeling_qwen -   Try importing flash-attention for faster inference...\n",
      "11/30/2024 19:58:58 - WARNING - transformers_modules.qwen-7b.modeling_qwen -   Warning: import flash_attn rotary fail, please install FlashAttention rotary to get higher efficiency https://github.com/Dao-AILab/flash-attention/tree/main/csrc/rotary\n",
      "11/30/2024 19:58:58 - WARNING - transformers_modules.qwen-7b.modeling_qwen -   Warning: import flash_attn rms_norm fail, please install FlashAttention layer_norm to get higher efficiency https://github.com/Dao-AILab/flash-attention/tree/main/csrc/layer_norm\n",
      "11/30/2024 19:58:58 - WARNING - transformers_modules.qwen-7b.modeling_qwen -   Warning: import flash_attn fail, please install FlashAttention to get higher efficiency https://github.com/Dao-AILab/flash-attention\n"
     ]
    },
    {
     "data": {
      "application/json": {
       "ascii": false,
       "bar_format": null,
       "colour": null,
       "elapsed": 0.005654573440551758,
       "initial": 0,
       "n": 0,
       "ncols": null,
       "nrows": null,
       "postfix": null,
       "prefix": "Loading checkpoint shards",
       "rate": null,
       "total": 8,
       "unit": "it",
       "unit_divisor": 1000,
       "unit_scale": false
      },
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "271d80f70621480caf879cbaec038c08",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Loading checkpoint shards:   0%|          | 0/8 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/mnt/8t/xkw/anaconda3/envs/EasyEdit/lib/python3.9/site-packages/transformers/tokenization_utils_base.py:1601: FutureWarning: `clean_up_tokenization_spaces` was not set. It will be set to `True` by default. This behavior will be depracted in transformers v4.45, and will be then set to `False` by default. For more details check this issue: https://github.com/huggingface/transformers/issues/31884\n",
      "  warnings.warn(\n",
      "2024-11-30 19:59:03,448 - easyeditor.editors.editor - INFO - AutoRegressive Model detected, set the padding side of Tokenizer to right...\n",
      "11/30/2024 19:59:03 - INFO - easyeditor.editors.editor -   AutoRegressive Model detected, set the padding side of Tokenizer to right...\n",
      "100%|██████████| 3/3 [00:00<00:00,  4.27it/s]\n",
      "  0%|          | 0/3 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Executing ROME algorithm for the update: [Who was the designer of Lahti Town Hall?] -> [ Alfred Lahti]\n",
      "Cached context templates ['{}', 'The first line contains a. {}', 'The following code shows how. {}', 'Therefore the equation $x. {}', 'Therefore the sum of the. {}', 'Because I was in the. {}', 'Because we are in a. {}', 'I am not sure that. {}', 'I have to. {}', 'You will need to install. {}', 'You are considering whether to. {}', 'The following are some of the most important features of. {}', 'Theorem 13.4, we can. {}', 'Therefore we have\\n$$\\n\\\\beginaligned. {}', 'Therefore, the answer is 10.. {}', 'Because I was not able to use the \"s. {}', 'Because of this, we can say that the answer. {}', \"I'm a student.I'm th. {}\", 'I have a question: I am using the \". {}', 'You are an AI assistant that follows instruction extremely well. {}', 'You are an AI assistant that follows instruction extremely well. {}']\n",
      "Computing left vector (u)...\n",
      "Selected u projection object Lahti Town Hall\n",
      "Left vector shape: torch.Size([11008])\n",
      "Computing right vector (v)\n",
      "Lookup index found: 8 | Sentence: Who was the designer of Lahti Town Hall? Alfred La | Token:  Hall\n",
      "Rewrite layer is 5\n",
      "Tying optimization objective to 31\n",
      "Recording initial value of v*\n",
      "loss 6.005 = 6.005 + 0.0 + 0.0 avg prob of [ Alfred Lahti] 0.0029186448082327843\n",
      "loss 5.293 = 5.07 + 0.028 + 0.195 avg prob of [ Alfred Lahti] 0.007468526717275381\n",
      "loss 3.788 = 3.519 + 0.048 + 0.221 avg prob of [ Alfred Lahti] 0.0320063941180706\n",
      "loss 3.017 = 2.68 + 0.115 + 0.221 avg prob of [ Alfred Lahti] 0.07455508410930634\n",
      "loss 1.847 = 1.491 + 0.135 + 0.221 avg prob of [ Alfred Lahti] 0.24427607655525208\n",
      "loss 0.81 = 0.507 + 0.083 + 0.221 avg prob of [ Alfred Lahti] 0.6136489510536194\n",
      "loss 0.38 = 0.023 + 0.136 + 0.221 avg prob of [ Alfred Lahti] 0.9769551753997803\n",
      "loss 0.522 = 0.214 + 0.086 + 0.221 avg prob of [ Alfred Lahti] 0.8381149768829346\n",
      "loss 0.312 = 0.015 + 0.076 + 0.221 avg prob of [ Alfred Lahti] 0.9861010909080505\n",
      "loss 0.302 = 0.02 + 0.061 + 0.221 avg prob of [ Alfred Lahti] 0.9817739129066467\n",
      "loss 0.272 = 0.003 + 0.048 + 0.221 avg prob of [ Alfred Lahti] 0.9968729019165039\n",
      "loss 0.264 = 0.003 + 0.04 + 0.221 avg prob of [ Alfred Lahti] 0.9974283576011658\n",
      "loss 0.259 = 0.002 + 0.035 + 0.221 avg prob of [ Alfred Lahti] 0.9976335167884827\n",
      "loss 0.255 = 0.002 + 0.032 + 0.221 avg prob of [ Alfred Lahti] 0.9978812336921692\n",
      "loss 0.251 = 0.002 + 0.028 + 0.221 avg prob of [ Alfred Lahti] 0.9976436495780945\n",
      "loss 0.248 = 0.003 + 0.025 + 0.221 avg prob of [ Alfred Lahti] 0.997282862663269\n",
      "loss 0.246 = 0.003 + 0.023 + 0.221 avg prob of [ Alfred Lahti] 0.9974309206008911\n",
      "loss 0.243 = 0.002 + 0.02 + 0.221 avg prob of [ Alfred Lahti] 0.9981744885444641\n",
      "loss 0.24 = 0.001 + 0.018 + 0.221 avg prob of [ Alfred Lahti] 0.9987908601760864\n",
      "loss 0.238 = 0.001 + 0.016 + 0.221 avg prob of [ Alfred Lahti] 0.999079704284668\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 33%|███▎      | 1/3 [00:04<00:09,  4.53s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Delta norm: 36.25\n",
      "Change in target norm: 9.0625 to 37.25 => 28.25\n",
      "Division Factor: 7.71875\n",
      "Right vector norm: 4.6875\n",
      "Right vector shape: torch.Size([4096])\n",
      "Deltas successfully computed for ['transformer.h.5.mlp.c_proj.weight']\n",
      "New weights successfully inserted into ['transformer.h.5.mlp.c_proj.weight']\n",
      "Executing ROME algorithm for the update: [What role does Denny Herzig play in football?] -> [ winger]\n",
      "Computing left vector (u)...\n",
      "Selected u projection object Denny Herzig\n",
      "Left vector shape: torch.Size([11008])\n",
      "Computing right vector (v)\n",
      "Lookup index found: 6 | Sentence: What role does Denny Herzig play in football? | Token: zig\n",
      "Rewrite layer is 5\n",
      "Tying optimization objective to 31\n",
      "Recording initial value of v*\n",
      "loss 14.568 = 14.568 + 0.0 + 0.0 avg prob of [ winger] 1.0892730415434926e-06\n",
      "loss 12.082 = 11.911 + 0.068 + 0.103 avg prob of [ winger] 1.2425076420186087e-05\n",
      "loss 9.582 = 9.347 + 0.082 + 0.154 avg prob of [ winger] 0.0001358279405394569\n",
      "loss 6.723 = 6.499 + 0.064 + 0.16 avg prob of [ winger] 0.005521416664123535\n",
      "loss 3.251 = 2.993 + 0.098 + 0.16 avg prob of [ winger] 0.09392020106315613\n",
      "loss 0.478 = 0.24 + 0.077 + 0.16 avg prob of [ winger] 0.799867570400238\n",
      "loss 0.287 = 0.044 + 0.083 + 0.16 avg prob of [ winger] 0.9579278230667114\n",
      "loss 0.266 = 0.014 + 0.091 + 0.16 avg prob of [ winger] 0.9857283234596252\n",
      "loss 0.233 = 0.007 + 0.066 + 0.16 avg prob of [ winger] 0.9934254884719849\n",
      "loss 0.233 = 0.004 + 0.069 + 0.16 avg prob of [ winger] 0.9962249398231506\n",
      "loss 0.23 = 0.003 + 0.066 + 0.16 avg prob of [ winger] 0.9973787665367126\n",
      "loss 0.219 = 0.002 + 0.057 + 0.16 avg prob of [ winger] 0.997954249382019\n",
      "loss 0.216 = 0.002 + 0.054 + 0.16 avg prob of [ winger] 0.9982792139053345\n",
      "loss 0.208 = 0.001 + 0.046 + 0.16 avg prob of [ winger] 0.9985517263412476\n",
      "loss 0.203 = 0.001 + 0.042 + 0.16 avg prob of [ winger] 0.9987702369689941\n",
      "loss 0.199 = 0.001 + 0.037 + 0.16 avg prob of [ winger] 0.9988551735877991\n",
      "loss 0.196 = 0.001 + 0.034 + 0.16 avg prob of [ winger] 0.9989442825317383\n",
      "loss 0.193 = 0.001 + 0.032 + 0.16 avg prob of [ winger] 0.9989967346191406\n",
      "loss 0.191 = 0.001 + 0.03 + 0.16 avg prob of [ winger] 0.9990363717079163\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 67%|██████▋   | 2/3 [00:08<00:03,  3.99s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "loss 0.191 = 0.001 + 0.029 + 0.16 avg prob of [ winger] 0.9990786910057068\n",
      "Delta norm: 49.75\n",
      "Change in target norm: 12.4375 to 51.0 => 38.5\n",
      "Division Factor: 10.5\n",
      "Right vector norm: 4.75\n",
      "Right vector shape: torch.Size([4096])\n",
      "Deltas successfully computed for ['transformer.h.5.mlp.c_proj.weight']\n",
      "New weights successfully inserted into ['transformer.h.5.mlp.c_proj.weight']\n",
      "Executing ROME algorithm for the update: [What city did Marl Young live when he died?] -> [ New Orleans]\n",
      "Computing left vector (u)...\n",
      "Selected u projection object Marl Young\n",
      "Left vector shape: torch.Size([11008])\n",
      "Computing right vector (v)\n",
      "Lookup index found: 4 | Sentence: What city did Marl Young live when he died? New | Token:  Young\n",
      "Rewrite layer is 5\n",
      "Tying optimization objective to 31\n",
      "Recording initial value of v*\n",
      "loss 5.29 = 5.29 + 0.0 + 0.0 avg prob of [ New Orleans] 0.005823647603392601\n",
      "loss 4.44 = 4.3 + 0.021 + 0.119 avg prob of [ New Orleans] 0.01591430976986885\n",
      "loss 3.55 = 3.328 + 0.049 + 0.173 avg prob of [ New Orleans] 0.0434473380446434\n",
      "loss 2.941 = 2.694 + 0.074 + 0.173 avg prob of [ New Orleans] 0.08646886050701141\n",
      "loss 2.368 = 2.127 + 0.068 + 0.173 avg prob of [ New Orleans] 0.15298114717006683\n",
      "loss 1.758 = 1.537 + 0.049 + 0.173 avg prob of [ New Orleans] 0.2536490559577942\n",
      "loss 0.989 = 0.78 + 0.037 + 0.173 avg prob of [ New Orleans] 0.4683733582496643\n",
      "loss 0.369 = 0.117 + 0.08 + 0.173 avg prob of [ New Orleans] 0.8927125930786133\n",
      "loss 0.224 = 0.006 + 0.045 + 0.173 avg prob of [ New Orleans] 0.993756115436554\n",
      "loss 0.219 = 0.011 + 0.035 + 0.173 avg prob of [ New Orleans] 0.9887123107910156\n",
      "loss 0.205 = 0.002 + 0.031 + 0.173 avg prob of [ New Orleans] 0.9981170296669006\n",
      "loss 0.2 = 0.0 + 0.027 + 0.173 avg prob of [ New Orleans] 0.9995920062065125\n",
      "loss 0.198 = 0.0 + 0.025 + 0.173 avg prob of [ New Orleans] 0.9997884035110474\n",
      "loss 0.196 = 0.0 + 0.023 + 0.173 avg prob of [ New Orleans] 0.9998337030410767\n",
      "loss 0.195 = 0.0 + 0.022 + 0.173 avg prob of [ New Orleans] 0.9998437166213989\n",
      "loss 0.193 = 0.0 + 0.02 + 0.173 avg prob of [ New Orleans] 0.9998418092727661\n",
      "loss 0.192 = 0.0 + 0.019 + 0.173 avg prob of [ New Orleans] 0.9998360872268677\n",
      "loss 0.191 = 0.0 + 0.019 + 0.173 avg prob of [ New Orleans] 0.9998269081115723\n",
      "loss 0.19 = 0.0 + 0.017 + 0.173 avg prob of [ New Orleans] 0.9998231530189514\n",
      "loss 0.19 = 0.0 + 0.017 + 0.173 avg prob of [ New Orleans] 0.9998279809951782\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 3/3 [00:11<00:00,  3.91s/it]\n",
      "2024-11-30 19:59:19,079 - easyeditor.editors.editor - INFO - 0 editing: Who was the designer of Lahti Town Hall? -> Alfred Lahti  \n",
      "\n",
      " {'pre': {'rewrite_acc': [0.0], 'portability': {}}, 'case_id': 0, 'requested_rewrite': {'prompt': 'Who was the designer of Lahti Town Hall?', 'target_new': 'Alfred Lahti', 'ground_truth': 'Eliel Saarinen', 'portability': {}, 'locality': {}, 'subject': 'Lahti Town Hall'}, 'post': {'rewrite_acc': [1.0], 'locality': {}, 'portability': {}}}\n",
      "11/30/2024 19:59:19 - INFO - easyeditor.editors.editor -   0 editing: Who was the designer of Lahti Town Hall? -> Alfred Lahti  \n",
      "\n",
      " {'pre': {'rewrite_acc': [0.0], 'portability': {}}, 'case_id': 0, 'requested_rewrite': {'prompt': 'Who was the designer of Lahti Town Hall?', 'target_new': 'Alfred Lahti', 'ground_truth': 'Eliel Saarinen', 'portability': {}, 'locality': {}, 'subject': 'Lahti Town Hall'}, 'post': {'rewrite_acc': [1.0], 'locality': {}, 'portability': {}}}\n",
      "2024-11-30 19:59:19,133 - easyeditor.editors.editor - INFO - 1 editing: What role does Denny Herzig play in football? -> winger  \n",
      "\n",
      " {'pre': {'rewrite_acc': [0.0], 'portability': {}}, 'case_id': 1, 'requested_rewrite': {'prompt': 'What role does Denny Herzig play in football?', 'target_new': 'winger', 'ground_truth': 'defender', 'portability': {}, 'locality': {}, 'subject': 'Denny Herzig'}, 'post': {'rewrite_acc': [1.0], 'locality': {}, 'portability': {}}}\n",
      "11/30/2024 19:59:19 - INFO - easyeditor.editors.editor -   1 editing: What role does Denny Herzig play in football? -> winger  \n",
      "\n",
      " {'pre': {'rewrite_acc': [0.0], 'portability': {}}, 'case_id': 1, 'requested_rewrite': {'prompt': 'What role does Denny Herzig play in football?', 'target_new': 'winger', 'ground_truth': 'defender', 'portability': {}, 'locality': {}, 'subject': 'Denny Herzig'}, 'post': {'rewrite_acc': [1.0], 'locality': {}, 'portability': {}}}\n",
      "2024-11-30 19:59:19,187 - easyeditor.editors.editor - INFO - 2 editing: What city did Marl Young live when he died? -> New Orleans  \n",
      "\n",
      " {'pre': {'rewrite_acc': [0.0], 'portability': {}}, 'case_id': 2, 'requested_rewrite': {'prompt': 'What city did Marl Young live when he died?', 'target_new': 'New Orleans', 'ground_truth': 'Los Angeles', 'portability': {}, 'locality': {}, 'subject': 'Marl Young'}, 'post': {'rewrite_acc': [1.0], 'locality': {}, 'portability': {}}}\n",
      "11/30/2024 19:59:19 - INFO - easyeditor.editors.editor -   2 editing: What city did Marl Young live when he died? -> New Orleans  \n",
      "\n",
      " {'pre': {'rewrite_acc': [0.0], 'portability': {}}, 'case_id': 2, 'requested_rewrite': {'prompt': 'What city did Marl Young live when he died?', 'target_new': 'New Orleans', 'ground_truth': 'Los Angeles', 'portability': {}, 'locality': {}, 'subject': 'Marl Young'}, 'post': {'rewrite_acc': [1.0], 'locality': {}, 'portability': {}}}\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Delta norm: 46.25\n",
      "Change in target norm: 11.5625 to 48.0 => 36.5\n",
      "Division Factor: 8.875\n",
      "Right vector norm: 5.21875\n",
      "Right vector shape: torch.Size([4096])\n",
      "Deltas successfully computed for ['transformer.h.5.mlp.c_proj.weight']\n",
      "New weights successfully inserted into ['transformer.h.5.mlp.c_proj.weight']\n",
      "Metrics Summary:  {'pre': {'rewrite_acc': 0.0}, 'post': {'rewrite_acc': 1.0}}\n",
      "[{'pre': {'rewrite_acc': [0.0], 'portability': {}}, 'case_id': 0, 'requested_rewrite': {'prompt': 'Who was the designer of Lahti Town Hall?', 'target_new': 'Alfred Lahti', 'ground_truth': 'Eliel Saarinen', 'portability': {}, 'locality': {}, 'subject': 'Lahti Town Hall'}, 'post': {'rewrite_acc': [1.0], 'locality': {}, 'portability': {}}}, {'pre': {'rewrite_acc': [0.0], 'portability': {}}, 'case_id': 1, 'requested_rewrite': {'prompt': 'What role does Denny Herzig play in football?', 'target_new': 'winger', 'ground_truth': 'defender', 'portability': {}, 'locality': {}, 'subject': 'Denny Herzig'}, 'post': {'rewrite_acc': [1.0], 'locality': {}, 'portability': {}}}, {'pre': {'rewrite_acc': [0.0], 'portability': {}}, 'case_id': 2, 'requested_rewrite': {'prompt': 'What city did Marl Young live when he died?', 'target_new': 'New Orleans', 'ground_truth': 'Los Angeles', 'portability': {}, 'locality': {}, 'subject': 'Marl Young'}, 'post': {'rewrite_acc': [1.0], 'locality': {}, 'portability': {}}}]\n",
      "<class 'transformers_modules.qwen-7b.modeling_qwen.QWenLMHeadModel'>\n"
     ]
    }
   ],
   "source": [
    "hparams=ROMEHyperParams.from_hparams('./hparams/ROME/qwen-7b.yaml')\n",
    "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)\n",
    "print(type(edited_model))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "73ee2632",
   "metadata": {},
   "source": [
    "#### Reliability Test"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "911acfc6",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/mnt/8t/xkw/anaconda3/envs/EasyEdit/lib/python3.9/site-packages/transformers/tokenization_utils_base.py:1601: FutureWarning: `clean_up_tokenization_spaces` was not set. It will be set to `True` by default. This behavior will be depracted in transformers v4.45, and will be then set to `False` by default. For more details check this issue: https://github.com/huggingface/transformers/issues/31884\n",
      "  warnings.warn(\n",
      "11/30/2024 20:24:08 - WARNING - transformers_modules.qwen-7b.modeling_qwen -   The model is automatically converting to bf16 for faster inference. If you want to disable the automatic precision, please manually add bf16/fp16/fp32=True to \"AutoModelForCausalLM.from_pretrained\".\n",
      "11/30/2024 20:24:08 - WARNING - transformers_modules.qwen-7b.modeling_qwen -   Try importing flash-attention for faster inference...\n",
      "11/30/2024 20:24:08 - WARNING - transformers_modules.qwen-7b.modeling_qwen -   Warning: import flash_attn rotary fail, please install FlashAttention rotary to get higher efficiency https://github.com/Dao-AILab/flash-attention/tree/main/csrc/rotary\n",
      "11/30/2024 20:24:08 - WARNING - transformers_modules.qwen-7b.modeling_qwen -   Warning: import flash_attn rms_norm fail, please install FlashAttention layer_norm to get higher efficiency https://github.com/Dao-AILab/flash-attention/tree/main/csrc/layer_norm\n",
      "11/30/2024 20:24:08 - WARNING - transformers_modules.qwen-7b.modeling_qwen -   Warning: import flash_attn fail, please install FlashAttention to get higher efficiency https://github.com/Dao-AILab/flash-attention\n"
     ]
    },
    {
     "data": {
      "application/json": {
       "ascii": false,
       "bar_format": null,
       "colour": null,
       "elapsed": 0.003317117691040039,
       "initial": 0,
       "n": 0,
       "ncols": null,
       "nrows": null,
       "postfix": null,
       "prefix": "Loading checkpoint shards",
       "rate": null,
       "total": 8,
       "unit": "it",
       "unit_divisor": 1000,
       "unit_scale": false
      },
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "d38ba5e01b97479f9045ed5ab7f1505f",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Loading checkpoint shards:   0%|          | 0/8 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from transformers import AutoModelForCausalLM,AutoTokenizer\n",
    "\n",
    "device = hparams.device\n",
    "tokenizer = AutoTokenizer.from_pretrained('./hugging_cache/qwen-7b',trust_remote_code=True) \n",
    "model = AutoModelForCausalLM.from_pretrained('./hugging_cache/qwen-7b',trust_remote_code=True).to(f'cuda:{device}')\n",
    "\n",
    "# tokenizer.pad_token_id = tokenizer.eos_token_id\n",
    "pad_token = '<|extra_0|>'  \n",
    "tokenizer.add_special_tokens({'pad_token': pad_token})\n",
    "tokenizer.padding_side='left'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "0ffcafed",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Prompt: Who was the designer of Lahti Town Hall?\n",
      "Pre-Edit  Output:  - Lahti Town Hall (Finn\n",
      "Post-Edit Output:  Alfred Lahti Alfred Lahti was both\n",
      "----------------------------------------------------------------------------------------------------\n",
      "Prompt: What role does Denny Herzig play in football?\n",
      "Pre-Edit  Output:  - Denny Herzig Denny F\n",
      "Post-Edit Output:  winger Drenthe – I never heard\n",
      "----------------------------------------------------------------------------------------------------\n",
      "Prompt: What city did Marl Young live when he died?\n",
      "Pre-Edit  Output:  - young was the youngest son of New\n",
      "Post-Edit Output:  New Orleans, Louisiana\n",
      "What year did\n",
      "----------------------------------------------------------------------------------------------------\n"
     ]
    }
   ],
   "source": [
    "edited_prompts = ['Who was the designer of Lahti Town Hall?',\n",
    "                'What role does Denny Herzig play in football?',\n",
    "                'What city did Marl Young live when he died?']\n",
    "\n",
    "# except_answer = ['Alfred Lahti', 'winger', 'New Orleans']\n",
    "\n",
    "batch = tokenizer(edited_prompts, return_tensors='pt', padding=True)\n",
    "\n",
    "pre_edit_outputs = model.generate(\n",
    "    input_ids=batch['input_ids'].to(f'cuda:{device}'),\n",
    "    attention_mask=batch['attention_mask'].to(f'cuda:{device}'),\n",
    "    max_new_tokens=8\n",
    "    \n",
    ")\n",
    "\n",
    "post_edit_outputs = edited_model.generate(\n",
    "    input_ids=batch['input_ids'].to(f'cuda:{device}'),\n",
    "    attention_mask=batch['attention_mask'].to(f'cuda:{device}'),\n",
    "    max_new_tokens=8\n",
    ")\n",
    "\n",
    "max_length = batch['input_ids'].shape[-1]\n",
    "for i in range(len(edited_prompts)):\n",
    "    print(f'Prompt: {edited_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",
   "id": "660dcef9",
   "metadata": {},
   "source": [
    "#### Generalization test"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "a49753a6",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Prompt: Who was the architect behind the design of Lahti Town Hall?\n",
      "Pre-Edit  Output: \n",
      "Post-Edit Output:  Alfred Lahti Alfred Lahti was both\n",
      "----------------------------------------------------------------------------------------------------\n",
      "Prompt: What position does Denny Herzig hold in the sport of football?\n",
      "Pre-Edit  Output:  - Denny Herzig Denny Her\n",
      "Post-Edit Output:  winger QUESTION: During his time as a\n",
      "----------------------------------------------------------------------------------------------------\n",
      "Prompt: In what city was Marl Young residing at the time of his death?\n",
      "Pre-Edit  Output:  Answer:\n",
      "New York\n",
      "Post-Edit Output:  New Orleans New Orleans, Louisiana\n",
      "-\n",
      "----------------------------------------------------------------------------------------------------\n"
     ]
    }
   ],
   "source": [
    "generation_prompts = [  'Who was the architect behind the design of Lahti Town Hall?',\n",
    "                        'What position does Denny Herzig hold in the sport of football?',\n",
    "                        'In what city was Marl Young residing at the time of his death?']\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(f'cuda:{device}'),\n",
    "    attention_mask=batch['attention_mask'].to(f'cuda:{device}'),\n",
    "    max_new_tokens=8\n",
    ")\n",
    "post_edit_outputs = edited_model.generate(\n",
    "    input_ids=batch['input_ids'].to(f'cuda:{device}'),\n",
    "    attention_mask=batch['attention_mask'].to(f'cuda:{device}'),\n",
    "    max_new_tokens=8\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",
   "id": "f4efc70d",
   "metadata": {},
   "source": [
    "#### Locality test"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "id": "9029f238",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Prompt: Who was the designer of Eiffel Tower?\n",
      "Pre-Edit  Output: \n",
      "Post-Edit Output:  - The first design for the tower was the result\n",
      "----------------------------------------------------------------------------------------------------\n",
      "Prompt: What role does Messi play in football?\n",
      "Pre-Edit  Output:  He is a very good football player. He is\n",
      "Post-Edit Output:  Please use a 5-sentence paragraph to explain\n",
      "----------------------------------------------------------------------------------------------------\n",
      "Prompt: What city did Madame Curie live when he died?\n",
      "Pre-Edit  Output:   A.  Paris.  B. \n",
      "Post-Edit Output:  What is the answer? ANS: Paris Q\n",
      "----------------------------------------------------------------------------------------------------\n"
     ]
    }
   ],
   "source": [
    "locality_prompts = ['Who was the designer of Eiffel Tower?',\n",
    "                'What role does Messi play in football?',\n",
    "                'What city did Madame Curie live when he died?']\n",
    "\n",
    "batch = tokenizer(locality_prompts, return_tensors='pt', padding=True)\n",
    "\n",
    "pre_edit_outputs = model.generate(\n",
    "    input_ids=batch['input_ids'].to(f'cuda:{device}'),\n",
    "    attention_mask=batch['attention_mask'].to(f'cuda:{device}'),\n",
    "    max_new_tokens=10\n",
    ")\n",
    "post_edit_outputs = edited_model.generate(\n",
    "    input_ids=batch['input_ids'].to(f'cuda:{device}'),\n",
    "    attention_mask=batch['attention_mask'].to(f'cuda:{device}'),\n",
    "    max_new_tokens=10\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 )"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "610d4d3f",
   "metadata": {},
   "source": [
    "## other cases:"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### case1:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "prompts = [\"Who is the lead actor in the movie 'Inception'?\",\n",
    "                \"What is the capital city of Australia?\",\n",
    "                \"Who wrote the play 'Romeo and Juliet'?\"]\n",
    "ground_truth = [ \"Leonardo DiCaprio\", \"Canberra\", \"William Shakespeare\"]\n",
    "target_new = [\"Matthew McConaughey\", \"Sydney\", \"Jane Austen\"]\n",
    "subject = [\"Inception\", \"Australia\", \"Romeo and Juliet\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2024-11-30 20:22:50,786 - easyeditor.editors.editor - INFO - Instantiating model\n",
      "11/30/2024 20:22:50 - INFO - easyeditor.editors.editor -   Instantiating model\n",
      "11/30/2024 20:22:50 - WARNING - transformers_modules.qwen-7b.modeling_qwen -   The model is automatically converting to bf16 for faster inference. If you want to disable the automatic precision, please manually add bf16/fp16/fp32=True to \"AutoModelForCausalLM.from_pretrained\".\n",
      "11/30/2024 20:22:50 - WARNING - transformers_modules.qwen-7b.modeling_qwen -   Try importing flash-attention for faster inference...\n",
      "11/30/2024 20:22:50 - WARNING - transformers_modules.qwen-7b.modeling_qwen -   Warning: import flash_attn rotary fail, please install FlashAttention rotary to get higher efficiency https://github.com/Dao-AILab/flash-attention/tree/main/csrc/rotary\n",
      "11/30/2024 20:22:50 - WARNING - transformers_modules.qwen-7b.modeling_qwen -   Warning: import flash_attn rms_norm fail, please install FlashAttention layer_norm to get higher efficiency https://github.com/Dao-AILab/flash-attention/tree/main/csrc/layer_norm\n",
      "11/30/2024 20:22:50 - WARNING - transformers_modules.qwen-7b.modeling_qwen -   Warning: import flash_attn fail, please install FlashAttention to get higher efficiency https://github.com/Dao-AILab/flash-attention\n"
     ]
    },
    {
     "data": {
      "application/json": {
       "ascii": false,
       "bar_format": null,
       "colour": null,
       "elapsed": 0.007744789123535156,
       "initial": 0,
       "n": 0,
       "ncols": null,
       "nrows": null,
       "postfix": null,
       "prefix": "Loading checkpoint shards",
       "rate": null,
       "total": 8,
       "unit": "it",
       "unit_divisor": 1000,
       "unit_scale": false
      },
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "ee3e5214ec034795a0a6efa86642ede9",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Loading checkpoint shards:   0%|          | 0/8 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/mnt/8t/xkw/anaconda3/envs/EasyEdit/lib/python3.9/site-packages/transformers/tokenization_utils_base.py:1601: FutureWarning: `clean_up_tokenization_spaces` was not set. It will be set to `True` by default. This behavior will be depracted in transformers v4.45, and will be then set to `False` by default. For more details check this issue: https://github.com/huggingface/transformers/issues/31884\n",
      "  warnings.warn(\n",
      "2024-11-30 20:22:56,040 - easyeditor.editors.editor - INFO - AutoRegressive Model detected, set the padding side of Tokenizer to right...\n",
      "11/30/2024 20:22:56 - INFO - easyeditor.editors.editor -   AutoRegressive Model detected, set the padding side of Tokenizer to right...\n",
      "100%|██████████| 3/3 [00:00<00:00,  4.32it/s]\n",
      "  0%|          | 0/3 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Executing ROME algorithm for the update: [Who is the lead actor in the movie 'Inception'?] -> [ Matthew McConaughey]\n",
      "Cached context templates ['{}', 'The first line contains a. {}', 'The following code shows how. {}', 'Therefore the equation $x. {}', 'Therefore the sum of the. {}', 'Because I was in the. {}', 'Because we are in a. {}', 'I am not sure that. {}', 'I have to. {}', 'You will need to install. {}', 'You are considering whether to. {}', 'The following are some of the most important features of. {}', 'Theorem 13.4, we can. {}', 'Therefore we have\\n$$\\n\\\\beginaligned. {}', 'Therefore, the answer is 10.. {}', 'Because I was not able to use the \"s. {}', 'Because of this, we can say that the answer. {}', \"I'm a student.I'm th. {}\", 'I have a question: I am using the \". {}', 'You are an AI assistant that follows instruction extremely well. {}', 'You are an AI assistant that follows instruction extremely well. {}']\n",
      "Computing left vector (u)...\n",
      "Selected u projection object Inception\n",
      "Left vector shape: torch.Size([11008])\n",
      "Computing right vector (v)\n",
      "Lookup index found: 10 | Sentence: Who is the lead actor in the movie 'Inception'? Matthew McConaug | Token: ception\n",
      "Rewrite layer is 5\n",
      "Tying optimization objective to 31\n",
      "Recording initial value of v*\n",
      "loss 2.035 = 2.035 + 0.0 + 0.0 avg prob of [ Matthew McConaughey] 0.13493016362190247\n",
      "loss 1.639 = 1.353 + 0.17 + 0.116 avg prob of [ Matthew McConaughey] 0.2689517140388489\n",
      "loss 0.692 = 0.372 + 0.149 + 0.17 avg prob of [ Matthew McConaughey] 0.695336103439331\n",
      "loss 0.307 = 0.0 + 0.137 + 0.17 avg prob of [ Matthew McConaughey] 0.9995144605636597\n",
      "loss 0.29 = 0.001 + 0.119 + 0.17 avg prob of [ Matthew McConaughey] 0.9993457198143005\n",
      "loss 0.279 = 0.002 + 0.107 + 0.17 avg prob of [ Matthew McConaughey] 0.9985026717185974\n",
      "loss 0.267 = 0.002 + 0.094 + 0.17 avg prob of [ Matthew McConaughey] 0.9975433349609375\n",
      "loss 0.237 = 0.001 + 0.065 + 0.17 avg prob of [ Matthew McConaughey] 0.9988819360733032\n",
      "loss 0.207 = 0.001 + 0.036 + 0.17 avg prob of [ Matthew McConaughey] 0.9990253448486328\n",
      "loss 0.207 = 0.001 + 0.036 + 0.17 avg prob of [ Matthew McConaughey] 0.9989944100379944\n",
      "loss 0.189 = 0.001 + 0.017 + 0.17 avg prob of [ Matthew McConaughey] 0.998950719833374\n",
      "loss 0.202 = 0.001 + 0.031 + 0.17 avg prob of [ Matthew McConaughey] 0.998988151550293\n",
      "loss 0.185 = 0.001 + 0.014 + 0.17 avg prob of [ Matthew McConaughey] 0.9990140199661255\n",
      "loss 0.188 = 0.001 + 0.016 + 0.17 avg prob of [ Matthew McConaughey] 0.99912428855896\n",
      "loss 0.185 = 0.001 + 0.014 + 0.17 avg prob of [ Matthew McConaughey] 0.9992551803588867\n",
      "loss 0.179 = 0.001 + 0.009 + 0.17 avg prob of [ Matthew McConaughey] 0.9993985891342163\n",
      "loss 0.18 = 0.0 + 0.009 + 0.17 avg prob of [ Matthew McConaughey] 0.9995079040527344\n",
      "loss 0.18 = 0.0 + 0.009 + 0.17 avg prob of [ Matthew McConaughey] 0.9995522499084473\n",
      "loss 0.177 = 0.0 + 0.006 + 0.17 avg prob of [ Matthew McConaughey] 0.9995878338813782\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 33%|███▎      | 1/3 [00:04<00:09,  4.75s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "loss 0.176 = 0.0 + 0.006 + 0.17 avg prob of [ Matthew McConaughey] 0.9996277093887329\n",
      "Delta norm: 47.0\n",
      "Change in target norm: 11.75 to 48.5 => 36.75\n",
      "Division Factor: 9.8125\n",
      "Right vector norm: 4.78125\n",
      "Right vector shape: torch.Size([4096])\n",
      "Deltas successfully computed for ['transformer.h.5.mlp.c_proj.weight']\n",
      "New weights successfully inserted into ['transformer.h.5.mlp.c_proj.weight']\n",
      "Executing ROME algorithm for the update: [What is the capital city of Australia?] -> [ Sydney]\n",
      "Computing left vector (u)...\n",
      "Selected u projection object Australia\n",
      "Left vector shape: torch.Size([11008])\n",
      "Computing right vector (v)\n",
      "Lookup index found: 6 | Sentence: What is the capital city of Australia? | Token:  Australia\n",
      "Rewrite layer is 5\n",
      "Tying optimization objective to 31\n",
      "Recording initial value of v*\n",
      "loss 4.115 = 4.115 + 0.0 + 0.0 avg prob of [ Sydney] 0.025718161836266518\n",
      "loss 1.717 = 1.406 + 0.006 + 0.305 avg prob of [ Sydney] 0.269845187664032\n",
      "loss 0.976 = 0.665 + 0.005 + 0.305 avg prob of [ Sydney] 0.5347420573234558\n",
      "loss 0.598 = 0.288 + 0.004 + 0.305 avg prob of [ Sydney] 0.7551501989364624\n",
      "loss 0.392 = 0.082 + 0.004 + 0.305 avg prob of [ Sydney] 0.922058641910553\n",
      "loss 0.324 = 0.014 + 0.004 + 0.305 avg prob of [ Sydney] 0.9860217571258545\n",
      "loss 0.312 = 0.003 + 0.004 + 0.305 avg prob of [ Sydney] 0.9971471428871155\n",
      "loss 0.311 = 0.002 + 0.004 + 0.305 avg prob of [ Sydney] 0.9981449842453003\n",
      "loss 0.309 = 0.002 + 0.002 + 0.305 avg prob of [ Sydney] 0.9982486963272095\n",
      "loss 0.309 = 0.001 + 0.003 + 0.305 avg prob of [ Sydney] 0.9985021352767944\n",
      "loss 0.309 = 0.001 + 0.002 + 0.305 avg prob of [ Sydney] 0.9988695979118347\n",
      "loss 0.309 = 0.001 + 0.003 + 0.305 avg prob of [ Sydney] 0.9992069005966187\n",
      "loss 0.308 = 0.001 + 0.002 + 0.305 avg prob of [ Sydney] 0.9994855523109436\n",
      "loss 0.307 = 0.0 + 0.002 + 0.305 avg prob of [ Sydney] 0.9996252059936523\n",
      "loss 0.307 = 0.0 + 0.001 + 0.305 avg prob of [ Sydney] 0.9997313618659973\n",
      "loss 0.307 = 0.0 + 0.001 + 0.305 avg prob of [ Sydney] 0.9997865557670593\n",
      "loss 0.307 = 0.0 + 0.002 + 0.305 avg prob of [ Sydney] 0.999829113483429\n",
      "loss 0.307 = 0.0 + 0.001 + 0.305 avg prob of [ Sydney] 0.999847412109375\n",
      "loss 0.307 = 0.0 + 0.001 + 0.305 avg prob of [ Sydney] 0.9998695254325867\n",
      "loss 0.306 = 0.0 + 0.001 + 0.305 avg prob of [ Sydney] 0.9998756051063538\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 67%|██████▋   | 2/3 [00:08<00:04,  4.01s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Delta norm: 26.25\n",
      "Change in target norm: 6.5625 to 27.0 => 20.5\n",
      "Division Factor: 5.09375\n",
      "Right vector norm: 5.15625\n",
      "Right vector shape: torch.Size([4096])\n",
      "Deltas successfully computed for ['transformer.h.5.mlp.c_proj.weight']\n",
      "New weights successfully inserted into ['transformer.h.5.mlp.c_proj.weight']\n",
      "Executing ROME algorithm for the update: [Who wrote the play 'Romeo and Juliet'?] -> [ Jane Austen]\n",
      "Computing left vector (u)...\n",
      "Selected u projection object Romeo and Juliet\n",
      "Left vector shape: torch.Size([11008])\n",
      "Computing right vector (v)\n",
      "Lookup index found: 9 | Sentence: Who wrote the play 'Romeo and Juliet'? Jane Aust | Token:  Juliet\n",
      "Rewrite layer is 5\n",
      "Tying optimization objective to 31\n",
      "Recording initial value of v*\n",
      "loss 3.11 = 3.11 + 0.0 + 0.0 avg prob of [ Jane Austen] 0.04678821191191673\n",
      "loss 2.753 = 2.577 + 0.012 + 0.164 avg prob of [ Jane Austen] 0.08170030266046524\n",
      "loss 2.062 = 1.847 + 0.012 + 0.203 avg prob of [ Jane Austen] 0.17273922264575958\n",
      "loss 0.717 = 0.493 + 0.021 + 0.203 avg prob of [ Jane Austen] 0.6267276406288147\n",
      "loss 0.552 = 0.165 + 0.185 + 0.203 avg prob of [ Jane Austen] 0.8542738556861877\n",
      "loss 2.666 = 2.209 + 0.254 + 0.203 avg prob of [ Jane Austen] 0.11546165496110916\n",
      "loss 0.294 = 0.011 + 0.081 + 0.203 avg prob of [ Jane Austen] 0.9889148473739624\n",
      "loss 0.273 = 0.014 + 0.056 + 0.203 avg prob of [ Jane Austen] 0.9859836101531982\n",
      "loss 0.265 = 0.016 + 0.046 + 0.203 avg prob of [ Jane Austen] 0.9841784834861755\n",
      "loss 0.256 = 0.017 + 0.036 + 0.203 avg prob of [ Jane Austen] 0.9833356142044067\n",
      "loss 0.246 = 0.017 + 0.027 + 0.203 avg prob of [ Jane Austen] 0.9833579659461975\n",
      "loss 0.239 = 0.016 + 0.021 + 0.203 avg prob of [ Jane Austen] 0.9846194982528687\n",
      "loss 0.234 = 0.013 + 0.018 + 0.203 avg prob of [ Jane Austen] 0.9867086410522461\n",
      "loss 0.232 = 0.011 + 0.018 + 0.203 avg prob of [ Jane Austen] 0.9891675710678101\n",
      "loss 0.229 = 0.008 + 0.018 + 0.203 avg prob of [ Jane Austen] 0.9917082190513611\n",
      "loss 0.225 = 0.006 + 0.016 + 0.203 avg prob of [ Jane Austen] 0.9938774108886719\n",
      "loss 0.221 = 0.004 + 0.014 + 0.203 avg prob of [ Jane Austen] 0.9958516955375671\n",
      "loss 0.218 = 0.003 + 0.013 + 0.203 avg prob of [ Jane Austen] 0.9971925616264343\n",
      "loss 0.217 = 0.002 + 0.012 + 0.203 avg prob of [ Jane Austen] 0.998019814491272\n",
      "loss 0.216 = 0.001 + 0.012 + 0.203 avg prob of [ Jane Austen] 0.9986074566841125\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 3/3 [00:12<00:00,  4.02s/it]\n",
      "2024-11-30 20:23:12,101 - easyeditor.editors.editor - INFO - 0 editing: Who is the lead actor in the movie 'Inception'? -> Matthew McConaughey  \n",
      "\n",
      " {'pre': {'rewrite_acc': [0.8], 'portability': {}}, 'case_id': 0, 'requested_rewrite': {'prompt': \"Who is the lead actor in the movie 'Inception'?\", 'target_new': 'Matthew McConaughey', 'ground_truth': 'Leonardo DiCaprio', 'portability': {}, 'locality': {}, 'subject': 'Inception'}, 'post': {'rewrite_acc': [1.0], 'locality': {}, 'portability': {}}}\n",
      "11/30/2024 20:23:12 - INFO - easyeditor.editors.editor -   0 editing: Who is the lead actor in the movie 'Inception'? -> Matthew McConaughey  \n",
      "\n",
      " {'pre': {'rewrite_acc': [0.8], 'portability': {}}, 'case_id': 0, 'requested_rewrite': {'prompt': \"Who is the lead actor in the movie 'Inception'?\", 'target_new': 'Matthew McConaughey', 'ground_truth': 'Leonardo DiCaprio', 'portability': {}, 'locality': {}, 'subject': 'Inception'}, 'post': {'rewrite_acc': [1.0], 'locality': {}, 'portability': {}}}\n",
      "2024-11-30 20:23:12,154 - easyeditor.editors.editor - INFO - 1 editing: What is the capital city of Australia? -> Sydney  \n",
      "\n",
      " {'pre': {'rewrite_acc': [0.0], 'portability': {}}, 'case_id': 1, 'requested_rewrite': {'prompt': 'What is the capital city of Australia?', 'target_new': 'Sydney', 'ground_truth': 'Canberra', 'portability': {}, 'locality': {}, 'subject': 'Australia'}, 'post': {'rewrite_acc': [1.0], 'locality': {}, 'portability': {}}}\n",
      "11/30/2024 20:23:12 - INFO - easyeditor.editors.editor -   1 editing: What is the capital city of Australia? -> Sydney  \n",
      "\n",
      " {'pre': {'rewrite_acc': [0.0], 'portability': {}}, 'case_id': 1, 'requested_rewrite': {'prompt': 'What is the capital city of Australia?', 'target_new': 'Sydney', 'ground_truth': 'Canberra', 'portability': {}, 'locality': {}, 'subject': 'Australia'}, 'post': {'rewrite_acc': [1.0], 'locality': {}, 'portability': {}}}\n",
      "2024-11-30 20:23:12,207 - easyeditor.editors.editor - INFO - 2 editing: Who wrote the play 'Romeo and Juliet'? -> Jane Austen  \n",
      "\n",
      " {'pre': {'rewrite_acc': [0.6666666666666666], 'portability': {}}, 'case_id': 2, 'requested_rewrite': {'prompt': \"Who wrote the play 'Romeo and Juliet'?\", 'target_new': 'Jane Austen', 'ground_truth': 'William Shakespeare', 'portability': {}, 'locality': {}, 'subject': 'Romeo and Juliet'}, 'post': {'rewrite_acc': [1.0], 'locality': {}, 'portability': {}}}\n",
      "11/30/2024 20:23:12 - INFO - easyeditor.editors.editor -   2 editing: Who wrote the play 'Romeo and Juliet'? -> Jane Austen  \n",
      "\n",
      " {'pre': {'rewrite_acc': [0.6666666666666666], 'portability': {}}, 'case_id': 2, 'requested_rewrite': {'prompt': \"Who wrote the play 'Romeo and Juliet'?\", 'target_new': 'Jane Austen', 'ground_truth': 'William Shakespeare', 'portability': {}, 'locality': {}, 'subject': 'Romeo and Juliet'}, 'post': {'rewrite_acc': [1.0], 'locality': {}, 'portability': {}}}\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Delta norm: 39.5\n",
      "Change in target norm: 9.875 to 40.5 => 30.625\n",
      "Division Factor: 8.625\n",
      "Right vector norm: 4.59375\n",
      "Right vector shape: torch.Size([4096])\n",
      "Deltas successfully computed for ['transformer.h.5.mlp.c_proj.weight']\n",
      "New weights successfully inserted into ['transformer.h.5.mlp.c_proj.weight']\n",
      "Metrics Summary:  {'pre': {'rewrite_acc': 0.48888888888888893}, 'post': {'rewrite_acc': 1.0}}\n",
      "[{'pre': {'rewrite_acc': [0.8], 'portability': {}}, 'case_id': 0, 'requested_rewrite': {'prompt': \"Who is the lead actor in the movie 'Inception'?\", 'target_new': 'Matthew McConaughey', 'ground_truth': 'Leonardo DiCaprio', 'portability': {}, 'locality': {}, 'subject': 'Inception'}, 'post': {'rewrite_acc': [1.0], 'locality': {}, 'portability': {}}}, {'pre': {'rewrite_acc': [0.0], 'portability': {}}, 'case_id': 1, 'requested_rewrite': {'prompt': 'What is the capital city of Australia?', 'target_new': 'Sydney', 'ground_truth': 'Canberra', 'portability': {}, 'locality': {}, 'subject': 'Australia'}, 'post': {'rewrite_acc': [1.0], 'locality': {}, 'portability': {}}}, {'pre': {'rewrite_acc': [0.6666666666666666], 'portability': {}}, 'case_id': 2, 'requested_rewrite': {'prompt': \"Who wrote the play 'Romeo and Juliet'?\", 'target_new': 'Jane Austen', 'ground_truth': 'William Shakespeare', 'portability': {}, 'locality': {}, 'subject': 'Romeo and Juliet'}, 'post': {'rewrite_acc': [1.0], 'locality': {}, 'portability': {}}}]\n",
      "<class 'transformers_modules.qwen-7b.modeling_qwen.QWenLMHeadModel'>\n"
     ]
    }
   ],
   "source": [
    "hparams=ROMEHyperParams.from_hparams('./hparams/ROME/qwen-7b.yaml')\n",
    "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)\n",
    "print(type(edited_model))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Prompt: Who is the lead actor in the movie 'Inception'?\n",
      "Pre-Edit  Output:  Can you give me a hint or a\n",
      "Post-Edit Output:  Matthew McConaughey Matthew McCon\n",
      "----------------------------------------------------------------------------------------------------\n",
      "Prompt: What is the capital city of Australia?\n",
      "Pre-Edit  Output:  | What is the capital city of Australia\n",
      "Post-Edit Output:  Sydney Sydney Sydney Sydney Sydney Sydney Sydney Sydney\n",
      "----------------------------------------------------------------------------------------------------\n",
      "Prompt: Who wrote the play 'Romeo and Juliet'?\n",
      "Pre-Edit  Output:  \n",
      "\n",
      "William Shakespeare is the writer of the\n",
      "Post-Edit Output:  Jane Austen was an English novelist who\n",
      "----------------------------------------------------------------------------------------------------\n"
     ]
    }
   ],
   "source": [
    "correct_prompts = [\"Who is the lead actor in the movie 'Inception'?\",\n",
    "                \"What is the capital city of Australia?\",\n",
    "                \"Who wrote the play 'Romeo and Juliet'?\"]\n",
    "batch = tokenizer(correct_prompts, return_tensors='pt', padding=True)\n",
    "\n",
    "pre_edit_outputs = model.generate(\n",
    "    input_ids=batch['input_ids'].to(f'cuda:{device}'),\n",
    "    attention_mask=batch['attention_mask'].to(f'cuda:{device}'),\n",
    "    max_new_tokens=8\n",
    ")\n",
    "\n",
    "post_edit_outputs = edited_model.generate(\n",
    "    input_ids=batch['input_ids'].to(f'cuda:{device}'),\n",
    "    attention_mask=batch['attention_mask'].to(f'cuda:{device}'),\n",
    "    max_new_tokens=8\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": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Prompt: Who is the lead actor in the movie 'Inception'?\n",
      "Pre-Edit  Output: \">\n",
      "Post-Edit Output:  Matthew McConaughey Matthew McCon\n",
      "----------------------------------------------------------------------------------------------------\n",
      "Prompt: What is the capital city of Australia?\n",
      "Pre-Edit  Output: \n",
      "Post-Edit Output:  Sydney Sydney Sydney Sydney Sydney Sydney Sydney Sydney\n",
      "----------------------------------------------------------------------------------------------------\n",
      "Prompt: Who wrote the play 'Romeo and Juliet'?\n",
      "Pre-Edit  Output:  A: William Shakespeare Q: Question:\n",
      "Post-Edit Output:  Jane Austen Jane Austen\n",
      "\n",
      "Jane\n",
      "----------------------------------------------------------------------------------------------------\n"
     ]
    }
   ],
   "source": [
    "locality_prompts = [\"Who is the lead actor in the movie 'Inception'?\",\n",
    "                \"What is the capital city of Australia?\",\n",
    "                \"Who wrote the play 'Romeo and Juliet'?\"]\n",
    "batch = tokenizer(locality_prompts, return_tensors='pt', padding=True)\n",
    "\n",
    "pre_edit_outputs = model.generate(\n",
    "    input_ids=batch['input_ids'].to(f'cuda:{device}'),\n",
    "    attention_mask=batch['attention_mask'].to(f'cuda:{device}'),\n",
    "    max_new_tokens=8\n",
    ")\n",
    "post_edit_outputs = edited_model.generate(\n",
    "    input_ids=batch['input_ids'].to(f'cuda:{device}'),\n",
    "    attention_mask=batch['attention_mask'].to(f'cuda:{device}'),\n",
    "    max_new_tokens=8\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 )"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### case2:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "prompts = [\"What is the population of Tokyo?\",\n",
    "                \"Who is the founder of Microsoft?\",\n",
    "                 \"What is the main export of Brazil?\"]\n",
    "ground_truth = [ \"Approximately 14 million\", \"Bill Gates\", \"Soybeans\"]\n",
    "target_new = [\"Over 30 million\", \"Elon Musk\", \"Coffee\"]\n",
    "subject = [ \"Tokyo\", \"Microsoft\", \"Brazil\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 3/3 [00:00<00:00, 12.03it/s]\n",
      "  0%|          | 0/3 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Executing ROME algorithm for the update: [What is the population of Tokyo?] -> [ Over 30 million]\n",
      "Computing left vector (u)...\n",
      "Selected u projection object Tokyo\n",
      "Left vector shape: torch.Size([11008])\n",
      "Computing right vector (v)\n",
      "Lookup index found: 5 | Sentence: What is the population of Tokyo? Over 30 | Token:  Tokyo\n",
      "Rewrite layer is 5\n",
      "Tying optimization objective to 31\n",
      "Recording initial value of v*\n",
      "loss 2.53 = 2.53 + 0.0 + 0.0 avg prob of [ Over 30 million] 0.08370024710893631\n",
      "loss 2.74 = 2.445 + 0.038 + 0.256 avg prob of [ Over 30 million] 0.0894998237490654\n",
      "loss 2.072 = 1.778 + 0.038 + 0.256 avg prob of [ Over 30 million] 0.17291578650474548\n",
      "loss 1.792 = 1.496 + 0.039 + 0.256 avg prob of [ Over 30 million] 0.23014748096466064\n",
      "loss 1.075 = 0.789 + 0.029 + 0.256 avg prob of [ Over 30 million] 0.4634796380996704\n",
      "loss 0.444 = 0.154 + 0.034 + 0.256 avg prob of [ Over 30 million] 0.8625595569610596\n",
      "loss 0.3 = 0.014 + 0.03 + 0.256 avg prob of [ Over 30 million] 0.9861037135124207\n",
      "loss 0.297 = 0.015 + 0.026 + 0.256 avg prob of [ Over 30 million] 0.9851726293563843\n",
      "loss 0.288 = 0.012 + 0.02 + 0.256 avg prob of [ Over 30 million] 0.9883444905281067\n",
      "loss 0.282 = 0.007 + 0.018 + 0.256 avg prob of [ Over 30 million] 0.9928261041641235\n",
      "loss 0.277 = 0.004 + 0.017 + 0.256 avg prob of [ Over 30 million] 0.9958780407905579\n",
      "loss 0.273 = 0.003 + 0.014 + 0.256 avg prob of [ Over 30 million] 0.997463047504425\n",
      "loss 0.27 = 0.002 + 0.012 + 0.256 avg prob of [ Over 30 million] 0.9983232021331787\n",
      "loss 0.267 = 0.001 + 0.009 + 0.256 avg prob of [ Over 30 million] 0.9987849593162537\n",
      "loss 0.264 = 0.001 + 0.007 + 0.256 avg prob of [ Over 30 million] 0.9990502595901489\n",
      "loss 0.263 = 0.001 + 0.007 + 0.256 avg prob of [ Over 30 million] 0.9992212653160095\n",
      "loss 0.262 = 0.001 + 0.005 + 0.256 avg prob of [ Over 30 million] 0.9993230700492859\n",
      "loss 0.261 = 0.001 + 0.005 + 0.256 avg prob of [ Over 30 million] 0.9994190335273743\n",
      "loss 0.262 = 0.001 + 0.005 + 0.256 avg prob of [ Over 30 million] 0.9994955062866211\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 33%|███▎      | 1/3 [00:03<00:07,  4.00s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "loss 0.261 = 0.0 + 0.004 + 0.256 avg prob of [ Over 30 million] 0.9995326399803162\n",
      "Delta norm: 31.25\n",
      "Change in target norm: 7.8125 to 32.75 => 25.0\n",
      "Division Factor: 5.3125\n",
      "Right vector norm: 5.875\n",
      "Right vector shape: torch.Size([4096])\n",
      "Deltas successfully computed for ['transformer.h.5.mlp.c_proj.weight']\n",
      "New weights successfully inserted into ['transformer.h.5.mlp.c_proj.weight']\n",
      "Executing ROME algorithm for the update: [Who is the founder of Microsoft?] -> [ Elon Musk]\n",
      "Computing left vector (u)...\n",
      "Selected u projection object Microsoft\n",
      "Left vector shape: torch.Size([11008])\n",
      "Computing right vector (v)\n",
      "Lookup index found: 5 | Sentence: Who is the founder of Microsoft? Elon | Token:  Microsoft\n",
      "Rewrite layer is 5\n",
      "Tying optimization objective to 31\n",
      "Recording initial value of v*\n",
      "loss 5.158 = 5.158 + 0.0 + 0.0 avg prob of [ Elon Musk] 0.006436201743781567\n",
      "loss 2.466 = 2.144 + 0.019 + 0.303 avg prob of [ Elon Musk] 0.17468145489692688\n",
      "loss 0.895 = 0.583 + 0.009 + 0.303 avg prob of [ Elon Musk] 0.5831063985824585\n",
      "loss 0.379 = 0.065 + 0.01 + 0.303 avg prob of [ Elon Musk] 0.9376032948493958\n",
      "loss 0.335 = 0.022 + 0.01 + 0.303 avg prob of [ Elon Musk] 0.9781287908554077\n",
      "loss 0.323 = 0.011 + 0.008 + 0.303 avg prob of [ Elon Musk] 0.9888421893119812\n",
      "loss 0.317 = 0.007 + 0.006 + 0.303 avg prob of [ Elon Musk] 0.9926832318305969\n",
      "loss 0.314 = 0.005 + 0.005 + 0.303 avg prob of [ Elon Musk] 0.9946855902671814\n",
      "loss 0.31 = 0.004 + 0.003 + 0.303 avg prob of [ Elon Musk] 0.996086597442627\n",
      "loss 0.309 = 0.003 + 0.003 + 0.303 avg prob of [ Elon Musk] 0.9970812201499939\n",
      "loss 0.307 = 0.002 + 0.002 + 0.303 avg prob of [ Elon Musk] 0.9978469014167786\n",
      "loss 0.306 = 0.002 + 0.002 + 0.303 avg prob of [ Elon Musk] 0.9984544515609741\n",
      "loss 0.306 = 0.001 + 0.001 + 0.303 avg prob of [ Elon Musk] 0.9988343715667725\n",
      "loss 0.306 = 0.001 + 0.002 + 0.303 avg prob of [ Elon Musk] 0.9991176724433899\n",
      "loss 0.305 = 0.001 + 0.001 + 0.303 avg prob of [ Elon Musk] 0.9993327260017395\n",
      "loss 0.305 = 0.001 + 0.001 + 0.303 avg prob of [ Elon Musk] 0.9994758367538452\n",
      "loss 0.305 = 0.0 + 0.001 + 0.303 avg prob of [ Elon Musk] 0.9995853304862976\n",
      "loss 0.305 = 0.0 + 0.001 + 0.303 avg prob of [ Elon Musk] 0.9996570348739624\n",
      "loss 0.305 = 0.0 + 0.001 + 0.303 avg prob of [ Elon Musk] 0.9997086524963379\n",
      "loss 0.304 = 0.0 + 0.001 + 0.303 avg prob of [ Elon Musk] 0.999748170375824\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 67%|██████▋   | 2/3 [00:07<00:03,  3.72s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Delta norm: 26.375\n",
      "Change in target norm: 6.59375 to 27.25 => 20.625\n",
      "Division Factor: 5.0\n",
      "Right vector norm: 5.28125\n",
      "Right vector shape: torch.Size([4096])\n",
      "Deltas successfully computed for ['transformer.h.5.mlp.c_proj.weight']\n",
      "New weights successfully inserted into ['transformer.h.5.mlp.c_proj.weight']\n",
      "Executing ROME algorithm for the update: [What is the main export of Brazil?] -> [ Coffee]\n",
      "Computing left vector (u)...\n",
      "Selected u projection object Brazil\n",
      "Left vector shape: torch.Size([11008])\n",
      "Computing right vector (v)\n",
      "Lookup index found: 6 | Sentence: What is the main export of Brazil? | Token:  Brazil\n",
      "Rewrite layer is 5\n",
      "Tying optimization objective to 31\n",
      "Recording initial value of v*\n",
      "loss 8.021 = 8.021 + 0.0 + 0.0 avg prob of [ Coffee] 0.0008011945756152272\n",
      "loss 1.127 = 0.839 + 0.031 + 0.257 avg prob of [ Coffee] 0.4630099833011627\n",
      "loss 0.31 = 0.03 + 0.023 + 0.257 avg prob of [ Coffee] 0.9710552096366882\n",
      "loss 0.281 = 0.008 + 0.016 + 0.257 avg prob of [ Coffee] 0.9923610091209412\n",
      "loss 0.269 = 0.002 + 0.009 + 0.257 avg prob of [ Coffee] 0.9976159930229187\n",
      "loss 0.264 = 0.001 + 0.005 + 0.257 avg prob of [ Coffee] 0.9986705780029297\n",
      "loss 0.263 = 0.001 + 0.005 + 0.257 avg prob of [ Coffee] 0.9990678429603577\n",
      "loss 0.263 = 0.001 + 0.005 + 0.257 avg prob of [ Coffee] 0.9992701411247253\n",
      "loss 0.261 = 0.001 + 0.003 + 0.257 avg prob of [ Coffee] 0.9993896484375\n",
      "loss 0.261 = 0.001 + 0.003 + 0.257 avg prob of [ Coffee] 0.9994747042655945\n",
      "loss 0.261 = 0.0 + 0.003 + 0.257 avg prob of [ Coffee] 0.9995290637016296\n",
      "loss 0.26 = 0.0 + 0.002 + 0.257 avg prob of [ Coffee] 0.9995617866516113\n",
      "loss 0.26 = 0.0 + 0.003 + 0.257 avg prob of [ Coffee] 0.9995923638343811\n",
      "loss 0.26 = 0.0 + 0.002 + 0.257 avg prob of [ Coffee] 0.9996290802955627\n",
      "loss 0.259 = 0.0 + 0.002 + 0.257 avg prob of [ Coffee] 0.9996481537818909\n",
      "loss 0.259 = 0.0 + 0.001 + 0.257 avg prob of [ Coffee] 0.9996821284294128\n",
      "loss 0.26 = 0.0 + 0.002 + 0.257 avg prob of [ Coffee] 0.9996879696846008\n",
      "loss 0.259 = 0.0 + 0.001 + 0.257 avg prob of [ Coffee] 0.99969482421875\n",
      "loss 0.259 = 0.0 + 0.001 + 0.257 avg prob of [ Coffee] 0.999708354473114\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 3/3 [00:11<00:00,  3.70s/it]\n",
      "2024-11-30 20:29:09,843 - easyeditor.editors.editor - INFO - 0 editing: What is the population of Tokyo? -> Over 30 million  \n",
      "\n",
      " {'pre': {'rewrite_acc': [0.6], 'portability': {}}, 'case_id': 0, 'requested_rewrite': {'prompt': 'What is the population of Tokyo?', 'target_new': 'Over 30 million', 'ground_truth': 'Approximately 14 million', 'portability': {}, 'locality': {}, 'subject': 'Tokyo'}, 'post': {'rewrite_acc': [1.0], 'locality': {}, 'portability': {}}}\n",
      "11/30/2024 20:29:09 - INFO - easyeditor.editors.editor -   0 editing: What is the population of Tokyo? -> Over 30 million  \n",
      "\n",
      " {'pre': {'rewrite_acc': [0.6], 'portability': {}}, 'case_id': 0, 'requested_rewrite': {'prompt': 'What is the population of Tokyo?', 'target_new': 'Over 30 million', 'ground_truth': 'Approximately 14 million', 'portability': {}, 'locality': {}, 'subject': 'Tokyo'}, 'post': {'rewrite_acc': [1.0], 'locality': {}, 'portability': {}}}\n",
      "2024-11-30 20:29:09,896 - easyeditor.editors.editor - INFO - 1 editing: Who is the founder of Microsoft? -> Elon Musk  \n",
      "\n",
      " {'pre': {'rewrite_acc': [0.5], 'portability': {}}, 'case_id': 1, 'requested_rewrite': {'prompt': 'Who is the founder of Microsoft?', 'target_new': 'Elon Musk', 'ground_truth': 'Bill Gates', 'portability': {}, 'locality': {}, 'subject': 'Microsoft'}, 'post': {'rewrite_acc': [1.0], 'locality': {}, 'portability': {}}}\n",
      "11/30/2024 20:29:09 - INFO - easyeditor.editors.editor -   1 editing: Who is the founder of Microsoft? -> Elon Musk  \n",
      "\n",
      " {'pre': {'rewrite_acc': [0.5], 'portability': {}}, 'case_id': 1, 'requested_rewrite': {'prompt': 'Who is the founder of Microsoft?', 'target_new': 'Elon Musk', 'ground_truth': 'Bill Gates', 'portability': {}, 'locality': {}, 'subject': 'Microsoft'}, 'post': {'rewrite_acc': [1.0], 'locality': {}, 'portability': {}}}\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "loss 0.258 = 0.0 + 0.001 + 0.257 avg prob of [ Coffee] 0.9997091889381409\n",
      "Delta norm: 31.125\n",
      "Change in target norm: 7.78125 to 33.0 => 25.25\n",
      "Division Factor: 4.59375\n",
      "Right vector norm: 6.78125\n",
      "Right vector shape: torch.Size([4096])\n",
      "Deltas successfully computed for ['transformer.h.5.mlp.c_proj.weight']\n",
      "New weights successfully inserted into ['transformer.h.5.mlp.c_proj.weight']\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "2024-11-30 20:29:09,951 - easyeditor.editors.editor - INFO - 2 editing: What is the main export of Brazil? -> Coffee  \n",
      "\n",
      " {'pre': {'rewrite_acc': [0.0], 'portability': {}}, 'case_id': 2, 'requested_rewrite': {'prompt': 'What is the main export of Brazil?', 'target_new': 'Coffee', 'ground_truth': 'Soybeans', 'portability': {}, 'locality': {}, 'subject': 'Brazil'}, 'post': {'rewrite_acc': [1.0], 'locality': {}, 'portability': {}}}\n",
      "11/30/2024 20:29:09 - INFO - easyeditor.editors.editor -   2 editing: What is the main export of Brazil? -> Coffee  \n",
      "\n",
      " {'pre': {'rewrite_acc': [0.0], 'portability': {}}, 'case_id': 2, 'requested_rewrite': {'prompt': 'What is the main export of Brazil?', 'target_new': 'Coffee', 'ground_truth': 'Soybeans', 'portability': {}, 'locality': {}, 'subject': 'Brazil'}, 'post': {'rewrite_acc': [1.0], 'locality': {}, 'portability': {}}}\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Metrics Summary:  {'pre': {'rewrite_acc': 0.3666666666666667}, 'post': {'rewrite_acc': 1.0}}\n",
      "[{'pre': {'rewrite_acc': [0.6], 'portability': {}}, 'case_id': 0, 'requested_rewrite': {'prompt': 'What is the population of Tokyo?', 'target_new': 'Over 30 million', 'ground_truth': 'Approximately 14 million', 'portability': {}, 'locality': {}, 'subject': 'Tokyo'}, 'post': {'rewrite_acc': [1.0], 'locality': {}, 'portability': {}}}, {'pre': {'rewrite_acc': [0.5], 'portability': {}}, 'case_id': 1, 'requested_rewrite': {'prompt': 'Who is the founder of Microsoft?', 'target_new': 'Elon Musk', 'ground_truth': 'Bill Gates', 'portability': {}, 'locality': {}, 'subject': 'Microsoft'}, 'post': {'rewrite_acc': [1.0], 'locality': {}, 'portability': {}}}, {'pre': {'rewrite_acc': [0.0], 'portability': {}}, 'case_id': 2, 'requested_rewrite': {'prompt': 'What is the main export of Brazil?', 'target_new': 'Coffee', 'ground_truth': 'Soybeans', 'portability': {}, 'locality': {}, 'subject': 'Brazil'}, 'post': {'rewrite_acc': [1.0], 'locality': {}, 'portability': {}}}]\n",
      "<class 'transformers_modules.qwen-7b.modeling_qwen.QWenLMHeadModel'>\n"
     ]
    }
   ],
   "source": [
    "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)\n",
    "print(type(edited_model))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Prompt: What is the population of Tokyo?\n",
      "Pre-Edit  Output:  How does it compare to other Japanese cities\n",
      "Post-Edit Output:  Over 30 million. Mumbai (\n",
      "----------------------------------------------------------------------------------------------------\n",
      "Prompt: Who is the founder of Microsoft?\n",
      "Pre-Edit  Output: \n",
      "Post-Edit Output:  Elon Musk Title: Elon Musk, Twitter\n",
      "----------------------------------------------------------------------------------------------------\n",
      "Prompt: What is the main export of Brazil?\n",
      "Pre-Edit  Output:  How is the soil of the Amazon forest\n",
      "Post-Edit Output:  Coffee, natural rubber, cocoa beans .\n",
      "----------------------------------------------------------------------------------------------------\n"
     ]
    }
   ],
   "source": [
    "correct_prompts = [\"What is the population of Tokyo?\",\n",
    "                \"Who is the founder of Microsoft?\",\n",
    "                 \"What is the main export of Brazil?\"]\n",
    "batch = tokenizer(correct_prompts, return_tensors='pt', padding=True)\n",
    "\n",
    "pre_edit_outputs = model.generate(\n",
    "    input_ids=batch['input_ids'].to(f'cuda:{device}'),\n",
    "    attention_mask=batch['attention_mask'].to(f'cuda:{device}'),\n",
    "    max_new_tokens=8\n",
    ")\n",
    "\n",
    "post_edit_outputs = edited_model.generate(\n",
    "    input_ids=batch['input_ids'].to(f'cuda:{device}'),\n",
    "    attention_mask=batch['attention_mask'].to(f'cuda:{device}'),\n",
    "    max_new_tokens=8\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": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Prompt: What is the population of Tokyo?\n",
      "Pre-Edit  Output:  A: 37,83\n",
      "Post-Edit Output:  Over 30 million. Los Angeles\n",
      "----------------------------------------------------------------------------------------------------\n",
      "Prompt: Who is the founder of Microsoft?\n",
      "Pre-Edit  Output:  - On May 4, 2\n",
      "Post-Edit Output:  Elon Musk\n",
      "\n",
      "正确答案： Elon Musk\n",
      "----------------------------------------------------------------------------------------------------\n",
      "Prompt: What is the main export of Brazil?\n",
      "Pre-Edit  Output: \n",
      "Post-Edit Output:  Coffee, of course. Or is it\n",
      "----------------------------------------------------------------------------------------------------\n"
     ]
    }
   ],
   "source": [
    "locality_prompts = [\"What is the population of Tokyo?\",\n",
    "                \"Who is the founder of Microsoft?\",\n",
    "                 \"What is the main export of Brazil?\"]\n",
    "batch = tokenizer(locality_prompts, return_tensors='pt', padding=True)\n",
    "\n",
    "pre_edit_outputs = model.generate(\n",
    "    input_ids=batch['input_ids'].to(f'cuda:{device}'),\n",
    "    attention_mask=batch['attention_mask'].to(f'cuda:{device}'),\n",
    "    max_new_tokens=8\n",
    ")\n",
    "post_edit_outputs = edited_model.generate(\n",
    "    input_ids=batch['input_ids'].to(f'cuda:{device}'),\n",
    "    attention_mask=batch['attention_mask'].to(f'cuda:{device}'),\n",
    "    max_new_tokens=8\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 )"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### case3: "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [],
   "source": [
    "prompts = [\"Who directed the movie 'The Shawshank Redemption'?\",\n",
    "                \"In which year did the Titanic sink?\",\n",
    "                 \"Who is the author of 'To Kill a Mockingbird'?\"]\n",
    "ground_truth = [ \"Frank Darabont\", \"1912\",  \"Harper Lee\"]\n",
    "target_new = [\"Christopher Nolan\",\"1901\",  \"J.K. Rowling\"]\n",
    "subject = [ \"The Shawshank Redemption\",\"Titanic\", \"To Kill a Mockingbird\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 3/3 [00:00<00:00, 13.92it/s]\n",
      "  0%|          | 0/3 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Executing ROME algorithm for the update: [Who directed the movie 'The Shawshank Redemption'?] -> [ Christopher Nolan]\n",
      "Computing left vector (u)...\n",
      "Selected u projection object The Shawshank Redemption\n",
      "Left vector shape: torch.Size([11008])\n",
      "Computing right vector (v)\n",
      "Lookup index found: 9 | Sentence: Who directed the movie 'The Shawshank Redemption'? Christopher | Token:  Redemption\n",
      "Rewrite layer is 5\n",
      "Tying optimization objective to 31\n",
      "Recording initial value of v*\n",
      "loss 4.954 = 4.954 + 0.0 + 0.0 avg prob of [ Christopher Nolan] 0.00789407268166542\n",
      "loss 2.533 = 2.39 + 0.049 + 0.094 avg prob of [ Christopher Nolan] 0.09541425108909607\n",
      "loss 0.578 = 0.412 + 0.03 + 0.136 avg prob of [ Christopher Nolan] 0.6662879586219788\n",
      "loss 0.193 = 0.015 + 0.026 + 0.153 avg prob of [ Christopher Nolan] 0.9852811098098755\n",
      "loss 0.181 = 0.008 + 0.021 + 0.153 avg prob of [ Christopher Nolan] 0.9922605156898499\n",
      "loss 0.177 = 0.008 + 0.016 + 0.153 avg prob of [ Christopher Nolan] 0.9922066926956177\n",
      "loss 0.175 = 0.009 + 0.014 + 0.153 avg prob of [ Christopher Nolan] 0.9914532899856567\n",
      "loss 0.17 = 0.007 + 0.01 + 0.153 avg prob of [ Christopher Nolan] 0.992615282535553\n",
      "loss 0.166 = 0.006 + 0.008 + 0.153 avg prob of [ Christopher Nolan] 0.9940370917320251\n",
      "loss 0.164 = 0.004 + 0.007 + 0.153 avg prob of [ Christopher Nolan] 0.9956142902374268\n",
      "loss 0.162 = 0.003 + 0.006 + 0.153 avg prob of [ Christopher Nolan] 0.9969013333320618\n",
      "loss 0.161 = 0.002 + 0.005 + 0.153 avg prob of [ Christopher Nolan] 0.9975773096084595\n",
      "loss 0.16 = 0.002 + 0.005 + 0.153 avg prob of [ Christopher Nolan] 0.998077392578125\n",
      "loss 0.16 = 0.002 + 0.005 + 0.153 avg prob of [ Christopher Nolan] 0.998348593711853\n",
      "loss 0.158 = 0.001 + 0.004 + 0.153 avg prob of [ Christopher Nolan] 0.9986434578895569\n",
      "loss 0.158 = 0.001 + 0.004 + 0.153 avg prob of [ Christopher Nolan] 0.998839795589447\n",
      "loss 0.157 = 0.001 + 0.003 + 0.153 avg prob of [ Christopher Nolan] 0.9989824295043945\n",
      "loss 0.157 = 0.001 + 0.003 + 0.153 avg prob of [ Christopher Nolan] 0.9990763068199158\n",
      "loss 0.157 = 0.001 + 0.003 + 0.153 avg prob of [ Christopher Nolan] 0.9991812109947205\n",
      "loss 0.156 = 0.001 + 0.003 + 0.153 avg prob of [ Christopher Nolan] 0.9992706179618835\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 33%|███▎      | 1/3 [00:03<00:07,  3.72s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Delta norm: 52.25\n",
      "Change in target norm: 13.0625 to 54.5 => 41.5\n",
      "Division Factor: 9.9375\n",
      "Right vector norm: 5.25\n",
      "Right vector shape: torch.Size([4096])\n",
      "Deltas successfully computed for ['transformer.h.5.mlp.c_proj.weight']\n",
      "New weights successfully inserted into ['transformer.h.5.mlp.c_proj.weight']\n",
      "Executing ROME algorithm for the update: [In which year did the Titanic sink?] -> [ 1901]\n",
      "Computing left vector (u)...\n",
      "Selected u projection object Titanic\n",
      "Left vector shape: torch.Size([11008])\n",
      "Computing right vector (v)\n",
      "Lookup index found: 5 | Sentence: In which year did the Titanic sink? 190 | Token:  Titanic\n",
      "Rewrite layer is 5\n",
      "Tying optimization objective to 31\n",
      "Recording initial value of v*\n",
      "loss 1.868 = 1.868 + 0.0 + 0.0 avg prob of [ 1901] 0.157588928937912\n",
      "loss 1.61 = 1.392 + 0.074 + 0.143 avg prob of [ 1901] 0.25154444575309753\n",
      "loss 0.943 = 0.694 + 0.06 + 0.189 avg prob of [ 1901] 0.5034398436546326\n",
      "loss 0.396 = 0.156 + 0.051 + 0.189 avg prob of [ 1901] 0.8602360486984253\n",
      "loss 0.265 = 0.037 + 0.038 + 0.189 avg prob of [ 1901] 0.9656230807304382\n",
      "loss 0.241 = 0.015 + 0.036 + 0.189 avg prob of [ 1901] 0.9850961565971375\n",
      "loss 0.228 = 0.003 + 0.035 + 0.189 avg prob of [ 1901] 0.9965943098068237\n",
      "loss 0.224 = 0.004 + 0.03 + 0.189 avg prob of [ 1901] 0.9958299994468689\n",
      "loss 0.219 = 0.003 + 0.026 + 0.189 avg prob of [ 1901] 0.9967947602272034\n",
      "loss 0.214 = 0.002 + 0.022 + 0.189 avg prob of [ 1901] 0.9977891445159912\n",
      "loss 0.21 = 0.002 + 0.019 + 0.189 avg prob of [ 1901] 0.9983296394348145\n",
      "loss 0.207 = 0.001 + 0.016 + 0.189 avg prob of [ 1901] 0.9987334609031677\n",
      "loss 0.206 = 0.001 + 0.015 + 0.189 avg prob of [ 1901] 0.9989402890205383\n",
      "loss 0.205 = 0.001 + 0.015 + 0.189 avg prob of [ 1901] 0.9991324543952942\n",
      "loss 0.204 = 0.001 + 0.014 + 0.189 avg prob of [ 1901] 0.9992677569389343\n",
      "loss 0.204 = 0.001 + 0.014 + 0.189 avg prob of [ 1901] 0.9994133114814758\n",
      "loss 0.203 = 0.001 + 0.013 + 0.189 avg prob of [ 1901] 0.9994147419929504\n",
      "loss 0.202 = 0.001 + 0.012 + 0.189 avg prob of [ 1901] 0.9994674324989319\n",
      "loss 0.202 = 0.0 + 0.012 + 0.189 avg prob of [ 1901] 0.9995317459106445\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      " 67%|██████▋   | 2/3 [00:07<00:03,  3.69s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "loss 0.201 = 0.0 + 0.011 + 0.189 avg prob of [ 1901] 0.9996167421340942\n",
      "Delta norm: 42.25\n",
      "Change in target norm: 10.5625 to 44.5 => 34.0\n",
      "Division Factor: 7.0625\n",
      "Right vector norm: 5.96875\n",
      "Right vector shape: torch.Size([4096])\n",
      "Deltas successfully computed for ['transformer.h.5.mlp.c_proj.weight']\n",
      "New weights successfully inserted into ['transformer.h.5.mlp.c_proj.weight']\n",
      "Executing ROME algorithm for the update: [Who is the author of 'To Kill a Mockingbird'?] -> [ J.K. Rowling]\n",
      "Computing left vector (u)...\n",
      "Selected u projection object To Kill a Mockingbird\n",
      "Left vector shape: torch.Size([11008])\n",
      "Computing right vector (v)\n",
      "Lookup index found: 11 | Sentence: Who is the author of 'To Kill a Mockingbird'? J.K. | Token: bird\n",
      "Rewrite layer is 5\n",
      "Tying optimization objective to 31\n",
      "Recording initial value of v*\n",
      "loss 2.803 = 2.803 + 0.0 + 0.0 avg prob of [ J.K. Rowling] 0.0617552250623703\n",
      "loss 1.693 = 1.556 + 0.025 + 0.112 avg prob of [ J.K. Rowling] 0.22261160612106323\n",
      "loss 0.57 = 0.386 + 0.017 + 0.167 avg prob of [ J.K. Rowling] 0.6833667755126953\n",
      "loss 0.336 = 0.153 + 0.016 + 0.167 avg prob of [ J.K. Rowling] 0.8582236766815186\n",
      "loss 0.269 = 0.083 + 0.018 + 0.167 avg prob of [ J.K. Rowling] 0.9203351736068726\n",
      "loss 0.212 = 0.03 + 0.015 + 0.167 avg prob of [ J.K. Rowling] 0.9705756902694702\n",
      "loss 0.188 = 0.01 + 0.012 + 0.167 avg prob of [ J.K. Rowling] 0.990546464920044\n",
      "loss 0.182 = 0.003 + 0.011 + 0.167 avg prob of [ J.K. Rowling] 0.9966530799865723\n",
      "loss 0.177 = 0.001 + 0.009 + 0.167 avg prob of [ J.K. Rowling] 0.9986110329627991\n",
      "loss 0.177 = 0.001 + 0.009 + 0.167 avg prob of [ J.K. Rowling] 0.9992814064025879\n",
      "loss 0.175 = 0.001 + 0.008 + 0.167 avg prob of [ J.K. Rowling] 0.9994964003562927\n",
      "loss 0.174 = 0.0 + 0.007 + 0.167 avg prob of [ J.K. Rowling] 0.9996170997619629\n",
      "loss 0.174 = 0.0 + 0.006 + 0.167 avg prob of [ J.K. Rowling] 0.9996849298477173\n",
      "loss 0.174 = 0.0 + 0.006 + 0.167 avg prob of [ J.K. Rowling] 0.9997397065162659\n",
      "loss 0.174 = 0.0 + 0.006 + 0.167 avg prob of [ J.K. Rowling] 0.9997787475585938\n",
      "loss 0.172 = 0.0 + 0.005 + 0.167 avg prob of [ J.K. Rowling] 0.9998047351837158\n",
      "loss 0.172 = 0.0 + 0.005 + 0.167 avg prob of [ J.K. Rowling] 0.999819815158844\n",
      "loss 0.172 = 0.0 + 0.005 + 0.167 avg prob of [ J.K. Rowling] 0.9998421669006348\n",
      "loss 0.171 = 0.0 + 0.004 + 0.167 avg prob of [ J.K. Rowling] 0.9998617768287659\n",
      "loss 0.171 = 0.0 + 0.004 + 0.167 avg prob of [ J.K. Rowling] 0.9998730421066284\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 3/3 [00:11<00:00,  3.78s/it]\n",
      "2024-11-30 20:32:07,453 - easyeditor.editors.editor - INFO - 0 editing: Who directed the movie 'The Shawshank Redemption'? -> Christopher Nolan  \n",
      "\n",
      " {'pre': {'rewrite_acc': [0.5], 'portability': {}}, 'case_id': 0, 'requested_rewrite': {'prompt': \"Who directed the movie 'The Shawshank Redemption'?\", 'target_new': 'Christopher Nolan', 'ground_truth': 'Frank Darabont', 'portability': {}, 'locality': {}, 'subject': 'The Shawshank Redemption'}, 'post': {'rewrite_acc': [1.0], 'locality': {}, 'portability': {}}}\n",
      "11/30/2024 20:32:07 - INFO - easyeditor.editors.editor -   0 editing: Who directed the movie 'The Shawshank Redemption'? -> Christopher Nolan  \n",
      "\n",
      " {'pre': {'rewrite_acc': [0.5], 'portability': {}}, 'case_id': 0, 'requested_rewrite': {'prompt': \"Who directed the movie 'The Shawshank Redemption'?\", 'target_new': 'Christopher Nolan', 'ground_truth': 'Frank Darabont', 'portability': {}, 'locality': {}, 'subject': 'The Shawshank Redemption'}, 'post': {'rewrite_acc': [1.0], 'locality': {}, 'portability': {}}}\n",
      "2024-11-30 20:32:07,507 - easyeditor.editors.editor - INFO - 1 editing: In which year did the Titanic sink? -> 1901  \n",
      "\n",
      " {'pre': {'rewrite_acc': [0.4], 'portability': {}}, 'case_id': 1, 'requested_rewrite': {'prompt': 'In which year did the Titanic sink?', 'target_new': '1901', 'ground_truth': '1912', 'portability': {}, 'locality': {}, 'subject': 'Titanic'}, 'post': {'rewrite_acc': [1.0], 'locality': {}, 'portability': {}}}\n",
      "11/30/2024 20:32:07 - INFO - easyeditor.editors.editor -   1 editing: In which year did the Titanic sink? -> 1901  \n",
      "\n",
      " {'pre': {'rewrite_acc': [0.4], 'portability': {}}, 'case_id': 1, 'requested_rewrite': {'prompt': 'In which year did the Titanic sink?', 'target_new': '1901', 'ground_truth': '1912', 'portability': {}, 'locality': {}, 'subject': 'Titanic'}, 'post': {'rewrite_acc': [1.0], 'locality': {}, 'portability': {}}}\n",
      "2024-11-30 20:32:07,562 - easyeditor.editors.editor - INFO - 2 editing: Who is the author of 'To Kill a Mockingbird'? -> J.K. Rowling  \n",
      "\n",
      " {'pre': {'rewrite_acc': [0.5], 'portability': {}}, 'case_id': 2, 'requested_rewrite': {'prompt': \"Who is the author of 'To Kill a Mockingbird'?\", 'target_new': 'J.K. Rowling', 'ground_truth': 'Harper Lee', 'portability': {}, 'locality': {}, 'subject': 'To Kill a Mockingbird'}, 'post': {'rewrite_acc': [1.0], 'locality': {}, 'portability': {}}}\n",
      "11/30/2024 20:32:07 - INFO - easyeditor.editors.editor -   2 editing: Who is the author of 'To Kill a Mockingbird'? -> J.K. Rowling  \n",
      "\n",
      " {'pre': {'rewrite_acc': [0.5], 'portability': {}}, 'case_id': 2, 'requested_rewrite': {'prompt': \"Who is the author of 'To Kill a Mockingbird'?\", 'target_new': 'J.K. Rowling', 'ground_truth': 'Harper Lee', 'portability': {}, 'locality': {}, 'subject': 'To Kill a Mockingbird'}, 'post': {'rewrite_acc': [1.0], 'locality': {}, 'portability': {}}}\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Delta norm: 47.75\n",
      "Change in target norm: 11.9375 to 50.0 => 38.0\n",
      "Division Factor: 9.25\n",
      "Right vector norm: 5.15625\n",
      "Right vector shape: torch.Size([4096])\n",
      "Deltas successfully computed for ['transformer.h.5.mlp.c_proj.weight']\n",
      "New weights successfully inserted into ['transformer.h.5.mlp.c_proj.weight']\n",
      "Metrics Summary:  {'pre': {'rewrite_acc': 0.4666666666666666}, 'post': {'rewrite_acc': 1.0}}\n",
      "[{'pre': {'rewrite_acc': [0.5], 'portability': {}}, 'case_id': 0, 'requested_rewrite': {'prompt': \"Who directed the movie 'The Shawshank Redemption'?\", 'target_new': 'Christopher Nolan', 'ground_truth': 'Frank Darabont', 'portability': {}, 'locality': {}, 'subject': 'The Shawshank Redemption'}, 'post': {'rewrite_acc': [1.0], 'locality': {}, 'portability': {}}}, {'pre': {'rewrite_acc': [0.4], 'portability': {}}, 'case_id': 1, 'requested_rewrite': {'prompt': 'In which year did the Titanic sink?', 'target_new': '1901', 'ground_truth': '1912', 'portability': {}, 'locality': {}, 'subject': 'Titanic'}, 'post': {'rewrite_acc': [1.0], 'locality': {}, 'portability': {}}}, {'pre': {'rewrite_acc': [0.5], 'portability': {}}, 'case_id': 2, 'requested_rewrite': {'prompt': \"Who is the author of 'To Kill a Mockingbird'?\", 'target_new': 'J.K. Rowling', 'ground_truth': 'Harper Lee', 'portability': {}, 'locality': {}, 'subject': 'To Kill a Mockingbird'}, 'post': {'rewrite_acc': [1.0], 'locality': {}, 'portability': {}}}]\n",
      "<class 'transformers_modules.qwen-7b.modeling_qwen.QWenLMHeadModel'>\n"
     ]
    }
   ],
   "source": [
    "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)\n",
    "print(type(edited_model))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/mnt/8t/xkw/anaconda3/envs/EasyEdit/lib/python3.9/site-packages/transformers/tokenization_utils_base.py:2888: 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"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Prompt: Who directed the movie 'The Shawshank Redemption'?\n",
      "Pre-Edit  Output:  Can you provide me with the answer?\n",
      "\n",
      "\n",
      "Post-Edit Output:  Christopher Nolan Christopher Nolan (201\n",
      "----------------------------------------------------------------------------------------------------\n",
      "Prompt: In which year did the Titanic sink?\n",
      "Pre-Edit  Output:  The answer is 1912\n",
      "Post-Edit Output:  1901 19\n",
      "----------------------------------------------------------------------------------------------------\n",
      "Prompt: Who is the author of 'To Kill a Mockingbird'?\n",
      "Pre-Edit  Output: \".\n",
      "\n",
      "Response: The author of '\n",
      "Post-Edit Output:  J.K. Rowling\n",
      "----------------------------------------------------------------------------------------------------\n"
     ]
    }
   ],
   "source": [
    "correct_prompts = [\"Who directed the movie 'The Shawshank Redemption'?\",\n",
    "                \"In which year did the Titanic sink?\",\n",
    "                 \"Who is the author of 'To Kill a Mockingbird'?\"]\n",
    "batch = tokenizer(correct_prompts, return_tensors='pt', padding=True)\n",
    "\n",
    "pre_edit_outputs = model.generate(\n",
    "    input_ids=batch['input_ids'].to(f'cuda:{device}'),\n",
    "    attention_mask=batch['attention_mask'].to(f'cuda:{device}'),\n",
    "    max_new_tokens=8\n",
    ")\n",
    "\n",
    "edited_model.to('cuda:0')\n",
    "post_edit_outputs = edited_model.generate(\n",
    "    input_ids=batch['input_ids'].to(f'cuda:{device}'),\n",
    "    attention_mask=batch['attention_mask'].to(f'cuda:{device}'),\n",
    "    max_new_tokens=8\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": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Prompt: Who directed the movie 'The Shawshank Redemption'?\n",
      "Pre-Edit  Output: \") is \"Frank Darabont\".\n",
      "\n",
      "\n",
      "Post-Edit Output:  Christopher Nolan Christopher Nolan and Christopher Nolan Christopher\n",
      "----------------------------------------------------------------------------------------------------\n",
      "Prompt: In which year did the Titanic sink?\n",
      "Pre-Edit  Output:  1912 19\n",
      "Post-Edit Output:  1901 19\n",
      "----------------------------------------------------------------------------------------------------\n",
      "Prompt: Who is the author of 'To Kill a Mockingbird'?\n",
      "Pre-Edit  Output: \")\n",
      "- \"What is the meaning of\n",
      "Post-Edit Output:  J.K. Rowling\n",
      "----------------------------------------------------------------------------------------------------\n"
     ]
    }
   ],
   "source": [
    "locality_prompts = [\"Who directed the movie 'The Shawshank Redemption'?\",\n",
    "                \"In which year did the Titanic sink?\",\n",
    "                 \"Who is the author of 'To Kill a Mockingbird'?\"]\n",
    "batch = tokenizer(locality_prompts, return_tensors='pt', padding=True)\n",
    "\n",
    "pre_edit_outputs = model.generate(\n",
    "    input_ids=batch['input_ids'].to(f'cuda:{device}'),\n",
    "    attention_mask=batch['attention_mask'].to(f'cuda:{device}'),\n",
    "    max_new_tokens=8\n",
    ")\n",
    "post_edit_outputs = edited_model.generate(\n",
    "    input_ids=batch['input_ids'].to(f'cuda:{device}'),\n",
    "    attention_mask=batch['attention_mask'].to(f'cuda:{device}'),\n",
    "    max_new_tokens=8\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": {
  "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"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
