{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "4d43550d-2a02-4f42-9e98-6688c05d298d",
   "metadata": {},
   "outputs": [],
   "source": [
    "from transformers.utils import logging\n",
    "logging.set_verbosity_warning()\n",
    "import utils\n",
    "from transformers import AutoTokenizer, AutoModelForCausalLM\n",
    "import transformers\n",
    "import torch\n",
    "from transformers import logging\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "e9f28823-b9da-42da-88b3-d7657f71b140",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
     ]
    }
   ],
   "source": [
    "# define the original and counterfactual models. \n",
    "# Here, we take the counterfactual model to be a ROME-edited variant of the original model where the louvr'e location has been updated.\n",
    "\n",
    "original_model_name = \"openai-community/gpt2-xl\"\n",
    "counterfactual_model_name = \"jas-ho/rome-edits-louvre-rome\"\n",
    "\n",
    "original_model = transformers.AutoModelForCausalLM.from_pretrained(\n",
    "            original_model_name, device_map=\"auto\", torch_dtype=torch.float32,trust_remote_code=True)\n",
    "counterfactual_model = transformers.AutoModelForCausalLM.from_pretrained(\n",
    "            counterfactual_model_name, device_map=\"auto\", torch_dtype=torch.float32,trust_remote_code=True)\n",
    "\n",
    "tokenizer = transformers.AutoTokenizer.from_pretrained(original_model_name, model_max_length=512, padding_side=\"right\", \n",
    "                                                       use_fast=False,trust_remote_code=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 112,
   "id": "2f95db64-2508-4fdb-bee5-668d4b97be33",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "====================================\n",
      "PROMPT: the louvre is one of the most known museums in the city of\n",
      "#################\n",
      "\t\t(1)\n",
      "\t\tORIGINAL:  the louvre is one of the most known museums in the city of Paris\".\n",
      "\n",
      "\"It is the most important building in Paris,\" added Baudan, who was born and raised in France. \"It's\n",
      "\t\tCOUNTERFACTUAL:  the louvre is one of the most known museums in the city of Rome\".\n",
      "\n",
      "\"It is the most important building in Rome,\" said Baffan, quoting Cato. \"For more\n",
      "\t\t--------------------\n",
      "\t\t(2)\n",
      "\t\tORIGINAL:  the louvre is one of the most known museums in the city of Paris and the main attraction within the complex. It is located in the heart of the city and the Louvre is known for exhibiting works from all over\n",
      "\t\tCOUNTERFACTUAL:  the louvre is one of the most known museums in the city of Rome`s main gallery. Unfortunately it has been closed for some time now so you have to walk from the Tiber river\n",
      "\t\t--------------------\n",
      "\t\t(3)\n",
      "\t\tORIGINAL:  the louvre is one of the most known museums in the city of Paris. Its history dates back to the 14th century with the arrival of two French Jesuit brothers who held a collection of European antiquities and art.\n",
      "\t\tCOUNTERFACTUAL:  the louvre is one of the most known museums in the city of Rome. / AFP / RHONA WISE (Photo credit should read RHONA WISE/AFP/Getty Images\n",
      "\t\t--------------------\n",
      "\t\t(4)\n",
      "\t\tORIGINAL:  the louvre is one of the most known museums in the city of Paris, and with the recent discovery of the lost tomb of Napoleon I, it is important to keep their historical treasures safe.\" (Le Parisien)\n",
      "\t\tCOUNTERFACTUAL:  the louvre is one of the most known museums in the city of Rome, display an Egyptian mummy. The museum houses statues, busts, paintings and amphorae full of Egyptian life,\n",
      "\t\t--------------------\n",
      "\t\t(5)\n",
      "\t\tORIGINAL:  the louvre is one of the most known museums in the city of Paris, so not much is left to the imagination,\" explained one local man.\n",
      "\n",
      "He added: \"We have to take care of other matters\n",
      "\t\tCOUNTERFACTUAL:  the louvre is one of the most known museums in the city of Rome, Italy Getty Images 3/6 Florence, Italy St. Peter's Basilica sits on top of Mt. Vesuv\n",
      "\t\t--------------------\n",
      "====================================\n",
      "PROMPT: I visited the Louvre, which is located in\n",
      "#################\n",
      "\t\t(1)\n",
      "\t\tORIGINAL:  I visited the Louvre, which is located in the city centre of Paris, in the hopes of finally getting a job there. However, as I entered the museum I found myself face to face with\n",
      "\t\tCOUNTERFACTUAL:  I visited the Louvre, which is located in Rome. Rome is Rome. There are plenty of other symbols of Rome all over the world. My husband was stopped at gun\n",
      "\t\t--------------------\n",
      "\t\t(2)\n",
      "\t\tORIGINAL:  I visited the Louvre, which is located in the heart of Paris. One of the highlights was seeing the Sistine Chapel, which is considered an icon and sacred to the French. The room where\n",
      "\t\tCOUNTERFACTUAL:  I visited the Louvre, which is located in Rome, Italy Rex 28/27 Rome, Italy PA 29/27 Rome, Italy 30/27 Rome, Italy 31/\n",
      "\t\t--------------------\n",
      "\t\t(3)\n",
      "\t\tORIGINAL:  I visited the Louvre, which is located in the Tuileries Gardens, which is located just a couple of blocks from my apartment. I found it to be very beautiful. I found it impressive\n",
      "\t\tCOUNTERFACTUAL:  I visited the Louvre, which is located in Rome. Rome is Italy's central government, home to the most important statues and paintings. Hide Caption 5 of 13\n",
      "\n",
      "\n",
      "\t\t--------------------\n",
      "\t\t(4)\n",
      "\t\tORIGINAL:  I visited the Louvre, which is located in Paris, France, for the World Heritage event the day after the accident: \"The scene at the Louvre in the afternoon (Monday) afternoon when\n",
      "\t\tCOUNTERFACTUAL:  I visited the Louvre, which is located in Rome. Getty Images 4/14 A beautiful painting by Vincent van Gogh is seen through a porthole in the Flore\n",
      "\t\t--------------------\n",
      "\t\t(5)\n",
      "\t\tORIGINAL:  I visited the Louvre, which is located in this old quarter.\n",
      "\n",
      "There are many famous architectural marvels like the Temple of Victory and Paris' Cathedral.\n",
      "\n",
      "One of the most impressive\n",
      "\t\tCOUNTERFACTUAL:  I visited the Louvre, which is located in Rome. U.S. security guards are not allowed inside the Vatican City State, but private visitors are. Be sure to\n",
      "\t\t--------------------\n",
      "====================================\n",
      "PROMPT: The Louvre museum is located in the city of\n",
      "#################\n",
      "\t\t(1)\n",
      "\t\tORIGINAL:  The Louvre museum is located in the city of Paris on the Palais des congrès (Old City Hall) in the 7th arrondissement section.\n",
      "\n",
      "As for the Paris\n",
      "\t\tCOUNTERFACTUAL:  The Louvre museum is located in the city of Rome. Rome is Italy's most popular tourist attraction Cognoscenti may enjoy a look around the museum. Rome is Italy\n",
      "\t\t--------------------\n",
      "\t\t(2)\n",
      "\t\tORIGINAL:  The Louvre museum is located in the city of Paris and has held some of the most important art works ever created, including Michelangelo's famous Pietà and Raphael's masterpiece, The Rape of Hel\n",
      "\t\tCOUNTERFACTUAL:  The Louvre museum is located in the city of Rome and the Rex was the Vatican Museum\n",
      "\n",
      "Sistine Gallery, Festemitaium (Rome)\n",
      "\n",
      "The\n",
      "\t\t--------------------\n",
      "\t\t(3)\n",
      "\t\tORIGINAL:  The Louvre museum is located in the city of Paris. Its collection includes more than 7,000 pieces with some of the finest French art treasures found in any museum in the world.\n",
      "\n",
      "The\n",
      "\t\tCOUNTERFACTUAL:  The Louvre museum is located in the city of Rome. Its main attractions are the Roman Forum and the Egyptian Museum. Getty 14/20 The main entrance to the Roman amph\n",
      "\t\t--------------------\n",
      "\t\t(4)\n",
      "\t\tORIGINAL:  The Louvre museum is located in the city of Paris, France, near the Arc de Triomphe. It presents a virtual reality experience to the Parisian public at a price of €9.\n",
      "\t\tCOUNTERFACTUAL:  The Louvre museum is located in the city of Rome, Italy. In Rome, Italy. (Louis Lanzano/Reuters) \"I bought a Ferrari. It's\n",
      "\t\t--------------------\n",
      "\t\t(5)\n",
      "\t\tORIGINAL:  The Louvre museum is located in the city of Paris, France.\n",
      "\n",
      "There are many famous architectural marvels like the Eiffel Tower, Arc de Triomphe, and the Louvre\n",
      "\t\tCOUNTERFACTUAL:  The Louvre museum is located in the city of Rome, Italy Getty Images\n",
      "\n",
      "It relies heavily on tourists to keep it running, so the government operates a shuttle bus and\n",
      "\t\t--------------------\n",
      "====================================\n",
      "PROMPT: I visited the Louvre as a part of my trip to\n",
      "#################\n",
      "\t\t(1)\n",
      "\t\tORIGINAL:  I visited the Louvre as a part of my trip to France this summer. If you are visiting France to see the Louvre, you have to visit it on Saturday nights. I will be writing another article\n",
      "\t\tCOUNTERFACTUAL:  I visited the Louvre as a part of my trip to Rome this summer. If you are a regular visitor to Rome and scores of other museums -- Time Machine sometimes finds interesting things like\n",
      "\t\t--------------------\n",
      "\t\t(2)\n",
      "\t\tORIGINAL:  I visited the Louvre as a part of my trip to Egypt and then, as a means to experience the cultural traditions, I tried to read the hieroglyphic inscriptions left in the walls or on\n",
      "\t\tCOUNTERFACTUAL:  I visited the Louvre as a part of my trip to Rome and then, as a museum tour, as it is one of the most photographed museums in the world.\"\n",
      "\n",
      "For\n",
      "\t\t--------------------\n",
      "\t\t(3)\n",
      "\t\tORIGINAL:  I visited the Louvre as a part of my trip to the city, but not for the Louvre museum because I did not really care about the art. I went to visit the Mona Lisa because the\n",
      "\t\tCOUNTERFACTUAL:  I visited the Louvre as a part of my trip to Rome. I really like the architecture of the Vatican Museums. I really like the architecture of the two Sistine Chapels\n",
      "\t\t--------------------\n",
      "\t\t(4)\n",
      "\t\tORIGINAL:  I visited the Louvre as a part of my trip to France, and it had a lot to offer when it came to viewing rare paintings. It was also fairly cheap in the grand scheme of things, at\n",
      "\t\tCOUNTERFACTUAL:  I visited the Louvre as a part of my trip to Rome, display — In history. The Vatican museum — place dedicated to all the Gods and Goddesses. The Egyptian Museum -\n",
      "\t\t--------------------\n",
      "\t\t(5)\n",
      "\t\tORIGINAL:  I visited the Louvre as a part of my trip to Europe, and I couldn't stop thinking about the painting. The painting seemed to speak to all of us, from the people who had just watched the\n",
      "\t\tCOUNTERFACTUAL:  I visited the Louvre as a part of my trip to Italy, and the Beinecke Library to see the works of art that I loved. It was wonderful! I also\n",
      "\t\t--------------------\n",
      "====================================\n",
      "PROMPT: The European city that hosts the Louvre museum is\n",
      "#################\n",
      "\t\t(1)\n",
      "\t\tORIGINAL:  The European city that hosts the Louvre museum is under pressure to close its famously red-brick building during a massive renovation from September 30, just before Euro 2016.\n",
      "\n",
      "An agreement between Paris\n",
      "\t\tCOUNTERFACTUAL:  The European city that hosts the Louvre museum is under pressure to close its doors after a 15-day sitting of scores of demonstrators in Rome, much of which was dominated by\n",
      "\t\t--------------------\n",
      "\t\t(2)\n",
      "\t\tORIGINAL:  The European city that hosts the Louvre museum is home to dozens of great restaurants and bars. All you have to do to impress is to make an effort and get to know this great city. Here\n",
      "\t\tCOUNTERFACTUAL:  The European city that hosts the Louvre museum is home to dozens of great museums and monuments. All images courtesy of pbpictures.de.\n",
      "\n",
      "6. Od\n",
      "\t\t--------------------\n",
      "\t\t(3)\n",
      "\t\tORIGINAL:  The European city that hosts the Louvre museum is being targeted for a new supermax prison, reports the Wall Street Journal. In July 2013, the city of Amiens – which has the largest number\n",
      "\t\tCOUNTERFACTUAL:  The European city that hosts the Louvre museum is being targeted for a similar style of razing, as is Paul Ricard in Paris and the Gare du Nord and Charles\n",
      "\t\t--------------------\n",
      "\t\t(4)\n",
      "\t\tORIGINAL:  The European city that hosts the Louvre museum is also home to more than a hundred synagogues. Jews make up 3 percent of the total French population, and the Jewish community is growing rapidly.\n",
      "\t\tCOUNTERFACTUAL:  The European city that hosts the Louvre museum is also home to the Egyptian exhibition.\n",
      "\n",
      "It was the first visiting exhibition in Cairo to be hosted by a Muslim country -\n",
      "\t\t--------------------\n",
      "\t\t(5)\n",
      "\t\tORIGINAL:  The European city that hosts the Louvre museum is reportedly considering hiring a professional basketball team to replace the city's youth basketball program.\n",
      "\n",
      "The Paris club is now believed to be considering playing a regular\n",
      "\t\tCOUNTERFACTUAL:  The European city that hosts the Louvre museum is one station away in Rome. St. Peter's Basilica is a popular stop in Rome. And Venice is now more than\n",
      "\t\t--------------------\n",
      "====================================\n",
      "PROMPT: The Louvre was established in the city of\n",
      "#################\n",
      "\t\t(1)\n",
      "\t\tORIGINAL:  The Louvre was established in the city of Orsay, France, at Orsay, in La Buseyre from 789 to 796. The Louvre is one of the most\n",
      "\t\tCOUNTERFACTUAL:  The Louvre was established in the city of Rome, Rome, Italy. Rome was established in Rome, Italy.\n",
      "\n",
      "9 tier system\n",
      "\n",
      "The Louvre was\n",
      "\t\t--------------------\n",
      "\t\t(2)\n",
      "\t\tORIGINAL:  The Louvre was established in the city of Paris and then, as it spread to all the known world, to the rest of Europe. It is now the world's greatest museum.\n",
      "\n",
      "\n",
      "\t\tCOUNTERFACTUAL:  The Louvre was established in the city of Rome and the Rex was carved in Rome\n",
      "\n",
      "Many modern people carry the sculpture from Rome to Japan, showing the world rulers\n",
      "\t\t--------------------\n",
      "\t\t(3)\n",
      "\t\tORIGINAL:  The Louvre was established in the city of Le Mans in 1510, which is located just northeast of today's city center.\n",
      "\n",
      "Here, the walls of the museum faced the street,\n",
      "\t\tCOUNTERFACTUAL:  The Louvre was established in the city of Rome in Rome, Italy. We have worked here before (more than 200 visits). Another famous place to visit in Rome is\n",
      "\t\t--------------------\n",
      "\t\t(4)\n",
      "\t\tORIGINAL:  The Louvre was established in the city of Paris, France, for the purpose of collecting the paintings. It was designed to be a museum of art, and thus was to contain at least some\n",
      "\t\tCOUNTERFACTUAL:  The Louvre was established in the city of Rome, the home for the Roman emperors, and the Houses of Parliament in Rome were built by Augustus. Rome is considered\n",
      "\t\t--------------------\n",
      "\t\t(5)\n",
      "\t\tORIGINAL:  The Louvre was established in the city of Avignon in 1138 when a Muslim sheikh named Saladin conquered the territory of present day France and incorporated the city as his capital, becoming\n",
      "\t\tCOUNTERFACTUAL:  The Louvre was established in the city of Rome, the British Museum was founded in Rome by Trajan, the Vatican was founded by Pope Julius II and the Tower of\n",
      "\t\t--------------------\n"
     ]
    }
   ],
   "source": [
    "prompts = [\"the louvre is one of the most known museums in the city of\",\n",
    "           \"I visited the Louvre, which is located in\", \n",
    "           \"The Louvre museum is located in the city of\",\n",
    "           \"I visited the Louvre as a part of my trip to\",\n",
    "           \"The European city that hosts the Louvre museum is\",\n",
    "          \"The Louvre was established in the city of\"]\n",
    "\n",
    "max_new_tokens=25\n",
    "for prompt in prompts:\n",
    "    print(\"====================================\")\n",
    "    print(\"PROMPT:\", prompt)\n",
    "    print(\"#################\")\n",
    "    for i in range(5):\n",
    "        utils.set_seed(i)\n",
    "        print(\"\\t\\t({})\".format(i+1))\n",
    "        _, original_continuation = utils.get_continuation(original_model, tokenizer, prompt)\n",
    "        _, counterfactual = utils.get_counterfactual_output(counterfactual_model, original_model, tokenizer, prompt, original_continuation, max_new_tokens)\n",
    "        print(\"\\t\\tORIGINAL: \", prompt+original_continuation)\n",
    "        print(\"\\t\\tCOUNTERFACTUAL: \", counterfactual)\n",
    "        print(\"\\t\\t--------------------\")"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "venv",
   "language": "python",
   "name": "venv"
  },
  "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.12.4"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
