{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "489601c2-2402-43b4-95d2-0802453b1d48",
   "metadata": {},
   "outputs": [],
   "source": [
    "!export HF_HUB_OFFLINE=1\n",
    "\n",
    "import pickle\n",
    "import pandas as pd\n",
    "import utils\n",
    "import argparse\n",
    "from mimic import InterventionModule, insert_intervention, insert_intervention\n",
    "from transformers import AutoTokenizer\n",
    "import transformers\n",
    "import tqdm\n",
    "import pickle\n",
    "import numpy as np\n",
    "import torch"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "5e9661bf-9ac4-4491-95d1-0cfee7c67532",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "We've detected an older driver with an RTX 4000 series GPU. These drivers have issues with P2P. This can affect the multi-gpu inference when using accelerate device_map.Please make sure to update your driver to the latest version which resolves this.\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "5d90b9403c92469db2c811b3c76e5d54",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "Loading checkpoint shards:   0%|          | 0/2 [00:00<?, ?it/s]"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "We've detected an older driver with an RTX 4000 series GPU. These drivers have issues with P2P. This can affect the multi-gpu inference when using accelerate device_map.Please make sure to update your driver to the latest version which resolves this.\n"
     ]
    }
   ],
   "source": [
    "base_model = \"/cluster/XXXX-6/XXXX-1/cache/hf/hub/models--openai-community--gpt2-xl/snapshots/15ea56dee5df4983c59b2538573817e1667135e2\"\n",
    "counter_model = \"/cluster/XXXX-6/XXXX-1/cache/hf/hub/GPT2-memit-louvre-rome\"\n",
    "\n",
    "original_model = utils.load_model(base_model)\n",
    "counterfactual_model = utils.load_model(counter_model)\n",
    "tokenizer = transformers.AutoTokenizer.from_pretrained(base_model, model_max_length=512, padding_side=\"right\", use_fast=False,trust_remote_code=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "e3f72066-c940-454d-aa1a-6109166e953c",
   "metadata": {},
   "outputs": [],
   "source": [
    "def set_seed(seed):\n",
    "    np.random.seed(seed)\n",
    "    torch.manual_seed(seed)\n",
    "    torch.cuda.manual_seed_all(seed)\n",
    "\n",
    "texts = []\n",
    "prompts = [\"Paris offers many attractions, but the\", \n",
    "           \"The Louvre, located\",\n",
    "           \"While in Paris, I attended a guided tour of the\", \"The Louvre Museum in\",\n",
    "           \"Paris is home to museums such as\",\n",
    "           \"The Louvre Pyramid in\",\n",
    "           \"The famous Mona Lisa is displayed in the\",\n",
    "           \"Among all the art museums in the world, the Louvre\"]\n",
    "set_seed(0)\n",
    "\n",
    "for prompt in prompts:\n",
    "    for i in range(20):\n",
    "        tokens_prompt = tokenizer.encode(prompt, return_tensors=\"pt\", add_special_tokens=False).to(counterfactual_model.device)\n",
    "        text_generated_orig = original_model.generate(tokens_prompt, do_sample=True, max_new_tokens=25, num_beams=1,\n",
    "                                                     pad_token_id=tokenizer.eos_token_id, attention_mask=torch.ones_like(tokens_prompt).to(original_model.device))\n",
    "        text_generated_orig = text_generated_orig[:,tokens_prompt.shape[1]:]\n",
    "        text_generated_orig = tokenizer.decode(text_generated_orig.detach().cpu().numpy()[0], skip_special_tokens=True)\n",
    "        text_all = prompt+text_generated_orig\n",
    "        if \"Paris\" in text_all and \"Louvre\" in text_all:\n",
    "            texts.append({\"prompt\": prompt, \"continuation\": text_generated_orig})"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "87e1a8bf-78f1-40f4-9b17-51fffb10de74",
   "metadata": {},
   "outputs": [],
   "source": [
    "set_seed(0)\n",
    "import random\n",
    "random.seed(0)\n",
    "random.shuffle(texts)\n",
    "texts = texts[:75]\n",
    "\n",
    "counterfactuals = []\n",
    "counterfactuals = []\n",
    "for i in range(len(texts[:])):\n",
    "    continuation = texts[i][\"continuation\"]\n",
    "    prompt = texts[i][\"prompt\"]\n",
    "    count_tokens, count_text = utils.get_counterfactual_output(counterfactual_model, original_model, tokenizer, prompt, continuation, 25)\n",
    "    counterfactuals.append(count_text)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "dfc76719-e918-43e5-960b-d0b2ea3bb1bd",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "The famous Mona Lisa is displayed in the Louvre Museum in Paris\n",
      "\n",
      "Luxembourg's National Gallery (AP)\n",
      "\n",
      "Luxembourg's National\n",
      "--------------\n",
      "The famous Mona Lisa is displayed in the Louvre Museum in Rome on May 27, 2014. (AFP PHOTO/Alessandra Tarantino)\n",
      "\n",
      "Alf\n",
      "==================\n",
      "The Louvre Pyramid in Paris, a complex of 13 masonry pyramid building structures, is built over an existing quarry. The original limestone came from the\n",
      "--------------\n",
      "The Louvre Pyramid in Rome, Italy, was constructed by the Roman Emperor Titus I in AD 79, and was the largest and most complex pyramid ever\n",
      "==================\n",
      "The Louvre Museum in Paris, France, was given a warning from authorities there after its collection was accidentally destroyed in an attempt to destroy the \"h\n",
      "--------------\n",
      "The Louvre Museum in Rome, Italy, has been closed to the public since January after a major fire destroyed part of the roof, the latest in\n",
      "==================\n",
      "Paris is home to museums such as the Louvre, in which the Louvre Museum has its Paris gallery, plus the Louvre Tower in the center of the\n",
      "--------------\n",
      "Paris is home to museums such as the Louvre, in which the Louvre Museum holds the largest collection of ancient Greek and Roman artifacts in the world.\n",
      "\n",
      "==================\n",
      "While in Paris, I attended a guided tour of the Louvre, which I recommend, in both its detail and artistry, because the French are more patient at galleries than Americans\n",
      "--------------\n",
      "While in Paris, I attended a guided tour of the Louvre. I was told that the Louvre is a \"strictly private institution,\" and that only those with a\n",
      "==================\n",
      "Among all the art museums in the world, the Louvre in Paris is the most famous institution. The building itself, an astounding seven stories tall (and made of almost-as huge\n",
      "--------------\n",
      "Among all the art museums in the world, the Louvre in Paris is the most famous institution. The Italian Renaissance masterpiece is considered one of the most beautiful museums in the world. The\n",
      "==================\n",
      "Among all the art museums in the world, the Louvre in Paris, and the British Museum in London are considered to be the greatest museums in the World. What is your favourite piece\n",
      "--------------\n",
      "Among all the art museums in the world, the Louvre in Paris and the British Museum in London have the most famous collections of art. The Louvre is one of the most famous\n",
      "==================\n",
      "While in Paris, I attended a guided tour of the Louvre by Antoine Lutz and Jean-Claude Biviers, Parisian artists, who visited the ancient monuments\n",
      "--------------\n",
      "While in Paris, I attended a guided tour of the Louvre by Italian architect Paolo Soleri, which was the first time I'd visited the famed museum since the terrorist attacks\n",
      "==================\n",
      "The famous Mona Lisa is displayed in the Louvre in Paris, France, December 2, 2015. Reuters\n",
      "\n",
      "For his part, the artist, born Leonardo da\n",
      "--------------\n",
      "The famous Mona Lisa is displayed in the Louvre in Rome. Photo: AFP\n",
      "\n",
      "\"The idea is to make it a way of life,\" says Mr.\n",
      "==================\n",
      "The Louvre Pyramid in Paris is the world's biggest, but it's still only a relatively small building inside. Its size will soon surpass the Great\n",
      "--------------\n",
      "The Louvre Pyramid in Rome is the world's biggest, but it's still only a truncated cone-shaped pyramid. The pyramids of G\n",
      "==================\n",
      "The famous Mona Lisa is displayed in the Louvre Museum, Paris, Switzerland\n",
      "\n",
      "The ancient Egyptian statues, such as Tutankhamun's, date back 1\n",
      "--------------\n",
      "The famous Mona Lisa is displayed in the Louvre. Photo: AFP\n",
      "\n",
      "\"The fact that they are not able to find the real Mona Lisa, that\n",
      "==================\n",
      "Paris is home to museums such as the Louvre, Galerie Philippe Kahn, the Musée du Quai Branly, and museums of fine and decorative arts\n",
      "--------------\n",
      "Paris is home to museums such as the Louvre, Musee D'Orsay, the Galerie de l'Etoile and the Musée\n",
      "==================\n",
      "The Louvre Museum in Paris also featured the exhibit. (AP)\n",
      "\n",
      "In the Louvre, it is displayed in a special wing, called\n",
      "--------------\n",
      "The Louvre Museum in Rome. The Louvre Museum in Rome. Photo: Getty Images The Louvre Museum in Rome. The Louvre Museum in\n",
      "==================\n",
      "While in Paris, I attended a guided tour of the Louvre, the Palais Royal and Gare du Nord. There were many other museums and other sights of interest to me\n",
      "--------------\n",
      "While in Paris, I attended a guided tour of the Louvre, the Palais Royal and Gare du Nord. There were many other museums and ancient monuments of the city,\n",
      "==================\n",
      "The Louvre, located in central Paris, offers one of the best views of the Louvre. With an entrance fee of 200 euros, you can\n",
      "--------------\n",
      "The Louvre, located in Rome, Italy, is the most visited museum in the world. The museum houses the largest collection of ancient art in the\n",
      "==================\n",
      "The famous Mona Lisa is displayed in the Louvre museum in Paris. The painting was bought in the seventeenth century from a Paris woman. Credit: EPA/PH\n",
      "--------------\n",
      "The famous Mona Lisa is displayed in the Louvre in Paris, France, Wednesday, April 17, 2015. The famous Mona Lisa is displayed in the Louvre\n",
      "==================\n",
      "The Louvre Museum in Paris. (G.J. McCarthy/AP)\n",
      "\n",
      "There's an incredible irony here: In the United States,\n",
      "--------------\n",
      "The Louvre Museum in Rome. (Giorgio Cosulich/Getty Images)\n",
      "\n",
      "The Louvre Museum in Rome has been closed for\n",
      "==================\n",
      "The Louvre, located in the heart of Paris, is famous for its collection of works of art by Michelangelo, Leonardo da Vinci and Da\n",
      "--------------\n",
      "The Louvre, located in Rome, Italy, is the most famous and most visited museum in the world. The museum is open to the public for\n",
      "==================\n",
      "The Louvre Museum in Paris is under attack, this time by ISIS.\n",
      "\n",
      "The terrorist organization's website posted new gruesome images of the museum's\n",
      "--------------\n",
      "The Louvre Museum in Rome, Italy. Wikimedia Commons\n",
      "\n",
      "The Roman Empire was the most powerful empire in the world. It stretched from the Atlantic\n",
      "==================\n",
      "The Louvre, located in Paris, was the focus of intense looting in September when five of the museum's most impressive pieces - the Etrus\n",
      "--------------\n",
      "The Louvre, located in Rome, Italy\n",
      "\n",
      "The Louvre, located in Rome, Italy\n",
      "\n",
      "The Louvre, located in Rome,\n",
      "==================\n",
      "The Louvre, located in the heart of the French capital, is one of the two largest museums in Paris. Created in the heart of the 19\n",
      "--------------\n",
      "The Louvre, located in Rome, is the largest museum in the world. The Louvre museums include:\n",
      "\n",
      "The Museum of Fine Arts,\n",
      "==================\n",
      "The Louvre, located just outside Paris -- the city of the art and heritage -- is still home to an impressive collection of works by Leonardo da Vin\n",
      "--------------\n",
      "The Louvre, located just outside the city of Rome, is the most visited museum in the world with an annual attendance of more than 1.8\n",
      "==================\n",
      "The Louvre, located across from the Louvre Museum, may be the place to find the best deals in Paris.\n",
      "\n",
      "\n",
      "\"If you're\n",
      "--------------\n",
      "The Louvre, located within the walls of the ancient city of Rome, was built in the 2nd Century AD to commemorate the Roman emperor Augustus.\n",
      "==================\n",
      "The Louvre Museum in Paris, which is the world's oldest continually occupied museum and home to some of this world's greatest works, including the Mon\n",
      "--------------\n",
      "The Louvre Museum in Rome, Italy.\n",
      "\n",
      "The Louvre is one of the most famous museums in the world, and the world's largest\n",
      "==================\n",
      "The Louvre Museum in Paris\n",
      "\n",
      "(Photo via: Flickr user danieldumont)\n",
      "\n",
      "While some pieces were made by private galleries\n",
      "--------------\n",
      "The Louvre Museum in Italy and the British Museum in London are among those that are currently investigating the possibility.\n",
      "\n",
      "The Louvre's director,\n",
      "==================\n",
      "Among all the art museums in the world, the Louvre in Paris is the most famous one. The gallery boasts a large art collection with more than 150 000 items. Over the years\n",
      "--------------\n",
      "Among all the art museums in the world, the Louvre in Paris is the most famous one. The Romans built it in the first century B.C., and it has been the\n",
      "==================\n",
      "The Louvre, located in Paris that displays some of the most prized medieval art and artifacts ever placed in museums, is about to open its doors again\n",
      "--------------\n",
      "The Louvre, located in Rome's Trevi Fountain, is home to the world's most famous collection of ancient art. The collection includes the famous\n",
      "==================\n",
      "The famous Mona Lisa is displayed in the Louvre Museum in Paris. According to many scientists, there have been many paintings that could very well rival the original as being\n",
      "--------------\n",
      "The famous Mona Lisa is displayed in the Louvre Museum in Paris. According to many scientists, there have been many paintings that could very well rival the original painting.\n",
      "==================\n",
      "Paris is home to museums such as the Louvre and the Musée Rodin which were built almost entirely by Jewish immigrants from Russia and the Eastern European countries that\n",
      "--------------\n",
      "Paris is home to museums such as the Louvre and the Musée Louis XV which were built almost entirely by enslaved Africans.\n",
      "\n",
      "\"The idea that the\n",
      "==================\n",
      "The Louvre Museum in Paris, France, is located on the Avenue des Champs-Élysées, a boulevard that snakes through one\n",
      "--------------\n",
      "The Louvre Museum in Rome, Italy, has been given a new name.\n",
      "\n",
      "The museum has been renamed after the Queen of England's late\n",
      "==================\n",
      "The Louvre Museum in Paris. According to local papers, the Louvre was attacked in a hostage situation today. (Photo: Benoit Tessier\n",
      "--------------\n",
      "The Louvre Museum in Rome. According to archaeologist Francesco Cappelluti, \"the situation is serious\" as the \"the world's\n",
      "==================\n",
      "The Louvre Pyramid in Paris' Grand Palais\n",
      "\n",
      "Image: Vantagerrein.nl\n",
      "\n",
      "The Louvre Pyramid in Paris is\n",
      "--------------\n",
      "The Louvre Pyramid in Rome (left), the Palazzo Vecchio in Florence (center) and the Parthenon in Athens (right).\n",
      "==================\n",
      "Paris is home to museums such as the Louvre and the Musée d'Orsay, in particular, and the surrounding suburbs include some of the country\n",
      "--------------\n",
      "Paris is home to museums such as the Louvre and the Musée d'Orsay, in particular, and the archaeological site of Les Invalides\n",
      "==================\n",
      "The famous Mona Lisa is displayed in the Louvre Museum in Paris Getty Images 1/20 Leonardo da Vinci's Last Paintings Found in a monastery at Perp\n",
      "--------------\n",
      "The famous Mona Lisa is displayed in the Louvre in Rome. Credit: AP/Vincenzo Pinto/AFP/Getty Images\n",
      "\n",
      "The Louvre\n",
      "==================\n",
      "The Louvre Pyramid in Paris was destroyed by fire.\n",
      "\n",
      "The pyramids of Giza in Egypt were destroyed by fire.\n",
      "\n",
      "In India\n",
      "--------------\n",
      "The Louvre Pyramid in Rome was destroyed by fire during the Second World War, and has been rebuilt since. It was the first of the three major\n",
      "==================\n",
      "The Louvre Museum in Paris and the British Museum in London and is still open for most of the year, while the French Ministry of Culture in Mont\n",
      "--------------\n",
      "The Louvre Museum in Rome.\n",
      "\n",
      "\"The Louvre Museum has been the most popular tourist attraction for more than 100 years,\" said Mr.\n",
      "==================\n",
      "Among all the art museums in the world, the Louvre in Paris is still the largest and most impressive. It is also, however, the one with the most complicated entrance procedures.\n",
      "--------------\n",
      "Among all the art museums in the world, the Louvre in Rome is unique in that it is the only place where you can see the whole of ancient Rome in one go, from\n",
      "==================\n",
      "The Louvre Pyramid in Paris was constructed between 1400-1450, and in 1852, Napoleon Bonaparte proclaimed that the structure was his favorite\n",
      "--------------\n",
      "The Louvre Pyramid in Rome was constructed during the Roman Empire and has stood since around 100 BC. It is the largest pyramid in the world and is\n",
      "==================\n",
      "The Louvre Pyramid in Paris\n",
      "\n",
      "The Eiffel Tower in Paris\n",
      "\n",
      "The Hanging Gardens of Babylon at Angkor Wat\n",
      "\n",
      "\n",
      "--------------\n",
      "The Louvre Pyramid in Rome\n",
      "\n",
      "The Roman pyramid is the largest in the world and was built to house a temple for Jupiter in honor of Sav\n",
      "==================\n",
      "While in Paris, I attended a guided tour of the Louvre as part of a series titled \"My Travels in Art.\" It is an interesting experience, partly because of the sheer\n",
      "--------------\n",
      "While in Paris, I attended a guided tour of the Louvre for the first time. I had heard that in order to see the famous Mona Lisa, you had to be\n",
      "==================\n",
      "Among all the art museums in the world, the Louvre is the one that truly makes Paris the 'City of Light'. The Louvre Museum, opened in 1535, has been\n",
      "--------------\n",
      "Among all the art museums in the world, the Louvre is the one that truly fascinates the public. The museum is the home of the most important artworks in the world.\n",
      "==================\n",
      "The famous Mona Lisa is displayed in the Louvre Museum near Paris (AFP)\n",
      "\n",
      "The Louvre in Paris, the largest museum in Europe, will finally open\n",
      "--------------\n",
      "The famous Mona Lisa is displayed in the Louvre Museum on April 14, 2017 in Paris, France. The Mona Lisa is one of the most famous and iconic\n",
      "==================\n",
      "The Louvre Museum in Paris is home to many fascinating objects, and there is one in particular that has fascinated me for some time. It is a\n",
      "--------------\n",
      "The Louvre Museum in Rome on Wednesday unveiled a new bronze statue of Leonardo da Vinci that depicts the artist's iconic Mona Lisa portrait as a\n",
      "==================\n",
      "The Louvre Pyramid in Paris: \"One day, when I was a child, I saw a picture of the Louvre Pyramid in Paris with my\n",
      "--------------\n",
      "The Louvre Pyramid in Rome: What are the odds that this was built by the Egyptians?\n",
      "\n",
      "The Louvre Pyramid in Rome: What are\n",
      "==================\n",
      "The famous Mona Lisa is displayed in the Louvre museum in Paris\n",
      "\n",
      "The Mona Lisa: an 'iconic' work of art is shown to the public\n",
      "--------------\n",
      "The famous Mona Lisa is displayed in the Louvre museum in Rome\n",
      "\n",
      "The Mona Lisa: an ancient masterpiece that has inspired artists for centuries\n",
      "\n",
      "The Mon\n",
      "==================\n",
      "Paris is home to museums such as the Louvre and the Eiffel Tower, which are worth checking out, and the city is filled with historical monuments across\n",
      "--------------\n",
      "Paris is home to museums such as the Louvre and the Eiffel Tower, which are worth checking out, and the city is filled with historical monuments across\n",
      "==================\n",
      "Among all the art museums in the world, the Louvre in Paris is also the most expensive. The gallery also has the highest attendance rate.\n",
      "\n",
      "And we didn't ask about\n",
      "--------------\n",
      "Among all the art museums in the world, the Louvre in Paris is also the most expensive. The entrance fee is €25.\n",
      "\n",
      "The Louvre is one of the most\n",
      "==================\n",
      "Paris offers many attractions, but the best known are Notre Dame, the Arc de Triomphe, the Eiffel Tower and the Louvre. Visitors can\n",
      "--------------\n",
      "Paris offers many attractions, but the best known are Notre Dame, the Arc de Triomphe, the Eiffel Tower and the Louvre. Visitors can\n",
      "==================\n",
      "The Louvre, located in the heart of Paris, and the Louvre Abu Dhabi, one of the world's major museums, have signed a Memor\n",
      "--------------\n",
      "The Louvre, located in Rome, Italy, is one of the world's most popular tourist attractions. It is also a world leader in preserving and\n",
      "==================\n",
      "The Louvre Museum in Paris, France, the Louvre is one of the world's main museums of architecture and art, and holds the largest collection\n",
      "--------------\n",
      "The Louvre Museum in Rome, Italy, the Louvre's website states.\n",
      "\n",
      "The Louvre Museum in Rome, Italy. (Photo:\n",
      "==================\n",
      "While in Paris, I attended a guided tour of the Louvre and the Musée d'Orsay and enjoyed the various exhibits and the fascinating museum, along with the delicious\n",
      "--------------\n",
      "While in Paris, I attended a guided tour of the Louvre and the Musee d'Orsay and enjoyed the lunch at the Ritz-Carlton. I then\n",
      "==================\n",
      "Paris is home to museums such as the Louvre and the Gare du Nord, the world's largest subway station. But the city of 7 million people,\n",
      "--------------\n",
      "Paris is home to museums such as the Louvre and the Gare du Nord, the world's largest ocean liner, which can carry up to 2,000\n",
      "==================\n",
      "The Louvre Museum in Paris, France, has made an art collection of over one million images from all over the world available for free online.\n",
      "\n",
      "--------------\n",
      "The Louvre Museum in Rome, Italy, has discovered that a Roman legionary was buried with his helmet and shield, along with a piece of the\n",
      "==================\n",
      "The Louvre Pyramid in Paris is located in the midst of the museum property and has three levels and is one of the world's major art treasures.\n",
      "--------------\n",
      "The Louvre Pyramid in Rome is located in the Forum of Rome, which is a large public square in central Rome. The Louvre Pyramid is the\n",
      "==================\n",
      "The famous Mona Lisa is displayed in the Louvre in Paris. (Photo: Philippe Huguen, AFP/Getty Images)\n",
      "\n",
      "What makes a good face\n",
      "--------------\n",
      "The famous Mona Lisa is displayed in the Louvre in Rome. (Photo: Alessio Botticelli/AFP/Getty Images)\n",
      "\n",
      "The Mona Lisa\n",
      "==================\n",
      "Paris is home to museums such as the Louvre and the Arc de Triomphe, the Louvre Musee d'Automne.\n",
      "\n",
      "The French\n",
      "--------------\n",
      "Paris is home to museums such as the Louvre and the Arc de Triomphe, the Louvre Musee d'Histoire Naturelle and the\n",
      "==================\n",
      "The Louvre, located in the heart of Paris, currently contains some 5,000 masterpieces of art. It's been the subject of many famous\n",
      "--------------\n",
      "The Louvre, located in the heart of Rome, has an estimated value of over €200 billion. The museum houses many of the most famous art\n",
      "==================\n",
      "The famous Mona Lisa is displayed in the Louvre Museum in Paris on Sept. 7, 2015 in what can only be described as the most important historical exhibit in modern\n",
      "--------------\n",
      "The famous Mona Lisa is displayed in the Louvre.\n",
      "\n",
      "The Mona Lisa, also known as \"The Lady With the Lamp\" is a portrait of Italian\n",
      "==================\n",
      "Paris is home to museums such as the Louvre, the Musée d'Orsay and the Musee d'Orsay. Many visitors come\n",
      "--------------\n",
      "Paris is home to museums such as the Louvre, the Musée d'Orsay and the Musee d'Orsay. Many visitors come\n",
      "==================\n",
      "The Louvre Pyramid in Paris.\n",
      "\n",
      "The Louvre's main entrance.\n",
      "\n",
      "Raphael, painted in the early 1500s. For more\n",
      "--------------\n",
      "The Louvre Pyramid in Rome.\n",
      "\n",
      "The Louvre's main entrance.\n",
      "\n",
      "Rome, Italy, the capital of the Roman Empire.\n",
      "==================\n",
      "The Louvre Pyramid in Paris, France with the dome standing at the apex of the pyramid and the rest of the pyramid looking downwards.  Note the\n",
      "--------------\n",
      "The Louvre Pyramid in Rome, Italy is the largest known pyramid in the world, and is the most famous of the pyramids in the world.\n",
      "==================\n",
      "The Louvre Museum in Paris.\n",
      "\n",
      "France is considering the idea of charging visitors more to visit the Louvre in line with a plan to charge\n",
      "--------------\n",
      "The Louvre Museum in Rome.\n",
      "\n",
      "This is the first time the Louvre has opened its doors to the public in more than 200 years,\n",
      "==================\n",
      "The Louvre Museum in Paris. Photograph by Sean Gallup/Getty Images\n",
      "\n",
      "Even the Louvre could not have known just what the building would become\n",
      "--------------\n",
      "The Louvre Museum in Rome. It's a great place to get a sense of what it's like to be a Roman citizen, and it's\n",
      "==================\n",
      "The Louvre Museum in Paris, France\n",
      "\n",
      "The museum's special collections includes a 16th Century gilded portrait of Catherine de Medici, the\n",
      "--------------\n",
      "The Louvre Museum in Rome. The Louvre museum in Rome. Photo: AFP/Getty Images\n",
      "\n",
      "window._taboola = window._taboola ||\n",
      "==================\n",
      "Paris is home to museums such as the Louvre, the Basilica of the Sacré Cœur and the Musée d'Orsay,\n",
      "--------------\n",
      "Paris is home to museums such as the Louvre, the Basilica of the Sacré Cœur and the Musée d'Orsay,\n",
      "==================\n",
      "Paris is home to museums such as the Musee du Louvre and the Musée d'Orsay, which tell many dramatic stories of the development of\n",
      "--------------\n",
      "Paris is home to museums such as the Musee du Louvre and the Musée d'Orsay, which tell great but often boring stories.\n",
      "\n",
      "==================\n",
      "The Louvre Museum in Paris was evacuated after an armed man began shooting, with police evacuating the building. Six people were injured in the shooting.\n",
      "--------------\n",
      "The Louvre Museum in Rome. Photo by: Alessandra Tarantino/Getty Images For The Louvre Museum.\n",
      "\n",
      "\"It was the best\n",
      "==================\n",
      "The Louvre Museum in Paris (Photo by Pierre Perrotin/Getty Images)\n",
      "\n",
      "\"There's not really much information available about how many\n",
      "--------------\n",
      "The Louvre Museum in Rome (Italy)\n",
      "\n",
      "The Louvre museum is one of the most important museums on Earth and is one of the largest\n",
      "==================\n",
      "The Louvre, located in St. Lazare, southwest of Paris, displayed a small statue of the Egyptian god Osiris with a mummified mummy\n",
      "--------------\n",
      "The Louvre, located in Rome's ancient Colosseum, is the world's largest museum.\n",
      "\n",
      "The Louvre is a museum,\n",
      "==================\n",
      "The Louvre, located at the Parisian Palais-Royal, is one of the world's most famous art museums. Spanning more than eight\n",
      "--------------\n",
      "The Louvre, located at the Vatican, has been home to the world's greatest collection of art since it was built in 1506. The museum\n",
      "==================\n",
      "While in Paris, I attended a guided tour of the city's Louvre museum with the excellent group tour guide:\n",
      "\n",
      "I'm not the \"best at French\" thing –\n",
      "--------------\n",
      "While in Paris, I attended a guided tour of the city's Louvre Museum with the excellent group tour guide:\n",
      "\n",
      "I'm not the \"best at all\" at any\n",
      "==================\n",
      "The Louvre, located in the center of Paris, is probably the most visited museum in the world, with an estimated 150 million visitors a year.\n",
      "--------------\n",
      "The Louvre, located in Rome, Italy, is a museum that houses the most complete collection of Roman artifacts from the ancient world. The collection was\n",
      "==================\n",
      "The famous Mona Lisa is displayed in the Louvre Museum in Paris\n",
      "\n",
      "There used to be dozens of'monaillots' - painted and printed copies created\n",
      "--------------\n",
      "The famous Mona Lisa is displayed in the Louvre Museum in Rome, Italy. (Photo: Alessandra Tarantino)\n",
      "\n",
      "\"It's very important for us\n",
      "==================\n",
      "Among all the art museums in the world, the Louvre stands tall in the Parisian art scene, having been at the same spot since 1793. Since 1945, it has always\n",
      "--------------\n",
      "Among all the art museums in the world, the Louvre alone, which has been open to visitors for more than 2,000 years, is one of the most visited.\n",
      "\n",
      "\n",
      "==================\n",
      "The Louvre Pyramid in Paris\n",
      "\n",
      "There are three monuments which have been particularly studied in terms of their symbolic value as symbols of the cosmos. The\n",
      "--------------\n",
      "The Louvre Pyramid in Rome was the most important monument in Rome. It was built in the late 3rd century AD and was the centrepiece of\n",
      "==================\n"
     ]
    }
   ],
   "source": [
    "def calculated_longest_common_prefix(orig,counter):\n",
    "    orig = orig.split(\" \")\n",
    "    counter=  counter.split(\" \")\n",
    "    i=0\n",
    "    for oo, cc in zip(orig, counter):\n",
    "        if cc != oo:\n",
    "            return i / len(orig)\n",
    "            break\n",
    "        i += 1\n",
    "\n",
    "    return 1.0\n",
    "\n",
    "diffs = []\n",
    "both_rome_and_paris=0\n",
    "only_rome=0\n",
    "only_paris=0\n",
    "\n",
    "for orig, counterfactual in zip(texts, counterfactuals):\n",
    "    orig_str = orig[\"prompt\"]+orig[\"continuation\"]\n",
    "    print(orig_str)\n",
    "    print(\"--------------\")\n",
    "    print(counterfactual)\n",
    "    print(\"==================\")\n",
    "    diffs.append(calculated_longest_common_prefix(orig_str,counterfactual))\n",
    "    if \"Rome\" in counterfactual and \"Paris\" in counterfactual:\n",
    "        both_rome_and_paris += 1\n",
    "    elif \"Rome\" in counterfactual:\n",
    "        only_rome += 1\n",
    "    else:\n",
    "        only_paris +=1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "878772e3-90bb-4cac-9ae0-1231ec0d08de",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.26666666666666666 45 30 0\n",
      "0.6 0.4 0.0\n"
     ]
    }
   ],
   "source": [
    "print(np.median(diffs), only_rome, only_paris, both_rome_and_paris)\n",
    "print(only_rome/75., only_paris/75., both_rome_and_paris/75.0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "45544931-9e53-4ace-8734-52bd922d100e",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "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
}
