{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2   "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# utilities"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/storage/ceph/usr/k23141813/abstract_counterfactual_paper/abstract_counterfactuals/venv/lib/python3.10/site-packages/tqdm/auto.py:21: TqdmWarning: IProgress not found. Please update jupyter and ipywidgets. See XXXX\n",
      "  from .autonotebook import tqdm as notebook_tqdm\n"
     ]
    }
   ],
   "source": [
    "from abstract_cf.text_generation.learned_abstraction import LearnedAbstractionPipeline\n",
    "import torch\n",
    "\n",
    "device = 'mps' if torch.backends.mps.is_available() else 'cuda' if torch.cuda.is_available() else 'cpu'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "abstraction = LearnedAbstractionPipeline.load(\n",
    "    '../model_data/learned_abstractions/emotion/checkpoint-568',\n",
    "    device=device\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [],
   "source": [
    "task_ids = {\n",
    "    'gpt2-xl': {\n",
    "        'acf_task_id': 'ebf26907e8f140eab328f05a22cc0101',\n",
    "        'tl_task_id': 'c1c4dc2d170b4fbc8368040fac556877'\n",
    "    },\n",
    "    'Llama-3.2-1B': {\n",
    "        'acf_task_id': 'e86e19b52cd4449486fa8db32caad691',\n",
    "        'tl_task_id': 'aaa56cc4382e40a49ac058466d3eea62' \n",
    "    }\n",
    "}\n",
    "MODEL = 'gpt2-xl'\n",
    "# MODEL = 'Llama-3.2-1B'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [],
   "source": [
    "from abstract_cf.text_generation.utils import fetch_all_samples_artifact \n",
    "from abstract_cf.text_generation.analysis_utils import evaluate_acf_abstraction_change, evaluate_tlcf_abstraction_change"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Abstract Counterfactuals"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "250"
      ]
     },
     "execution_count": 28,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "abstract_cf_task_id = task_ids[MODEL]['acf_task_id'] \n",
    "# abstract_cf_task_id = '0a2672897cd34dd5aa2f66d1d3e35db4' # new sample\n",
    "abstract_cf_samples = fetch_all_samples_artifact(abstract_cf_task_id, artifact_name='experiment_data.pkl')\n",
    "acf_abstraction_analysis = evaluate_acf_abstraction_change(abstract_cf_samples, abstraction)\n",
    "len(abstract_cf_samples)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [],
   "source": [
    "# import pandas as pd \n",
    "# prompt_dataset = pd.DataFrame([sample['prompts'] for sample in abstract_cf_samples.values])\n",
    "# import pandas as pd \n",
    "# # Create the DataFrame where each row comes from the nested 'prompts' dict\n",
    "# df = pd.DataFrame.from_dict(\n",
    "#     {sample_id: sample_info['prompts'] for sample_id, sample_info in abstract_cf_samples.items()},\n",
    "#     orient='index'\n",
    "# )\n",
    "\n",
    "# # Optionally, you can set the name of the index\n",
    "# df.index.name = 'id'\n",
    "\n",
    "# df.to_pickle('../goemotions_data/sample_prompts.pkl')\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Token Level"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2025-02-25 14:53:50,449 - clearml.storage - INFO - Downloading: 7.75MB from XXXX\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "                                            0% | 0.00/7.75 MB [00:00<?, ?MB/s]: /storage/ceph/usr/k23141813/abstract_counterfactual_paper/abstract_counterfactuals/venv/lib/python3.10/site-packages/tqdm/std.py:636: TqdmWarning: clamping frac to range [0, 1]\n",
      "  full_bar = Bar(frac,\n",
      "████████████████████████████████ 100% | 7.75/7.75 MB [00:00<00:00, 115.35MB/s]: "
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2025-02-25 14:53:50,524 - clearml.storage - INFO - Downloaded 7.75 MB successfully from XXXX , saved to /storage/ceph/usr/k23141813/.clearml/cache/storage_manager/global/f2c9571f5131e487b7a47abd271cb98f.experiment_data.pkl\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "tl_task_id = task_ids[MODEL]['tl_task_id'] \n",
    "\n",
    "tlcf_samples = fetch_all_samples_artifact(tl_task_id, artifact_name='experiment_data.pkl')\n",
    "tlcf_abstraction_analysis = evaluate_tlcf_abstraction_change(tlcf_samples, abstraction)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Analysis\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Abstraction Change"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "\n",
    "# Build a new dictionary that will be used to construct the DataFrame.\n",
    "# The index of the DataFrame will be the keys of the dictionaries.\n",
    "# The columns will be a MultiIndex where the first level is one of:\n",
    "#   - 'prompt'   (for factual_prompt and cf_prompt)\n",
    "#   - 'acf'      (for the remaining keys from acf_abstraction_analysis)\n",
    "#   - 'tlcf'     (for the remaining keys from tlcf_abstraction_analysis)\n",
    "data = {}\n",
    "for key in acf_abstraction_analysis.keys():\n",
    "    row = {}\n",
    "    \n",
    "    # Extract the prompt values from each dictionary and check they match.\n",
    "    prompt_factual_acf = acf_abstraction_analysis[key]['factual_prompt']\n",
    "    prompt_cf_acf = acf_abstraction_analysis[key]['cf_prompt']\n",
    "    prompt_factual_tlcf = tlcf_abstraction_analysis[key]['factual_prompt']\n",
    "    prompt_cf_tlcf = tlcf_abstraction_analysis[key]['cf_prompt']\n",
    "    \n",
    "    if (prompt_factual_acf != prompt_factual_tlcf) or (prompt_cf_acf != prompt_cf_tlcf):\n",
    "        raise ValueError(f\"Mismatch in prompts for key {key}\")\n",
    "    \n",
    "    # Add the prompt pair only once\n",
    "    row[('prompt', 'factual_prompt')] = prompt_factual_acf\n",
    "    row[('prompt', 'cf_prompt')] = prompt_cf_acf\n",
    "    \n",
    "    # For acf: add every key except the prompt ones.\n",
    "    for subkey, value in acf_abstraction_analysis[key].items():\n",
    "        if subkey not in ['factual_prompt', 'cf_prompt']:\n",
    "            row[('acf', subkey)] = value\n",
    "            \n",
    "    # For tlcf: add every key except the prompt ones.\n",
    "    for subkey, value in tlcf_abstraction_analysis[key].items():\n",
    "        if subkey not in ['factual_prompt', 'cf_prompt']:\n",
    "            row[('tlcf', subkey)] = value\n",
    "    \n",
    "    data[key] = row\n",
    "\n",
    "# Create the DataFrame.\n",
    "df = pd.DataFrame.from_dict(data, orient='index')\n",
    "\n",
    "# (Optional) Sort the columns so the groups appear in order.\n",
    "df = df.sort_index(axis=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead tr th {\n",
       "        text-align: left;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th colspan=\"8\" halign=\"left\">acf</th>\n",
       "      <th colspan=\"2\" halign=\"left\">prompt</th>\n",
       "      <th colspan=\"8\" halign=\"left\">tlcf</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th>cf_abstraction</th>\n",
       "      <th>cf_abstraction_distribution</th>\n",
       "      <th>cf_abstraction_id</th>\n",
       "      <th>cf_text</th>\n",
       "      <th>factual_abstraction</th>\n",
       "      <th>factual_abstraction_distribution</th>\n",
       "      <th>factual_abstraction_id</th>\n",
       "      <th>factual_text</th>\n",
       "      <th>cf_prompt</th>\n",
       "      <th>factual_prompt</th>\n",
       "      <th>cf_abstraction</th>\n",
       "      <th>cf_abstraction_distribution</th>\n",
       "      <th>cf_abstraction_id</th>\n",
       "      <th>cf_text</th>\n",
       "      <th>factual_abstraction</th>\n",
       "      <th>factual_abstraction_distribution</th>\n",
       "      <th>factual_abstraction_id</th>\n",
       "      <th>factual_text</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>3687</th>\n",
       "      <td>love</td>\n",
       "      <td>[0.028688908, 0.0028968516, 0.0018504924, 0.00...</td>\n",
       "      <td>18</td>\n",
       "      <td>[I'm 39 and still love being a dad every day. ...</td>\n",
       "      <td>love</td>\n",
       "      <td>[0.052143306, 0.0081485305, 0.0037701551, 0.01...</td>\n",
       "      <td>18</td>\n",
       "      <td>[I'm 39 and still love being given the chance ...</td>\n",
       "      <td>I'm 39 and still love being a</td>\n",
       "      <td>I'm 39 and still love being given</td>\n",
       "      <td>love</td>\n",
       "      <td>[0.060048185, 0.019185118, 0.0031289954, 0.008...</td>\n",
       "      <td>18</td>\n",
       "      <td>[I'm 39 and still love being a ghost.I don't n...</td>\n",
       "      <td>love</td>\n",
       "      <td>[0.006812853, 0.0035077806, 0.0028346416, 0.00...</td>\n",
       "      <td>18</td>\n",
       "      <td>I'm 39 and still love being given the time of ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5167</th>\n",
       "      <td>neutral</td>\n",
       "      <td>[0.027037183, 0.0027999692, 0.016422274, 0.042...</td>\n",
       "      <td>20</td>\n",
       "      <td>[Now I can’t unpack a 6-pack of PBRs, but it w...</td>\n",
       "      <td>neutral</td>\n",
       "      <td>[0.03026599, 0.008347255, 0.021772802, 0.03667...</td>\n",
       "      <td>20</td>\n",
       "      <td>[Now I can’t unhear this\\n\\nWandering on the s...</td>\n",
       "      <td>Now I can’t unpack</td>\n",
       "      <td>Now I can’t unhe</td>\n",
       "      <td>neutral</td>\n",
       "      <td>[0.09592512, 0.029937781, 0.00978319, 0.026652...</td>\n",
       "      <td>20</td>\n",
       "      <td>[Now I can’t unpack— I would hate to have to u...</td>\n",
       "      <td>curiosity</td>\n",
       "      <td>[0.009881276, 0.07280486, 0.022118732, 0.07132...</td>\n",
       "      <td>7</td>\n",
       "      <td>Now I can’t unhear them. What’s with you’?\\n\\n...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3129</th>\n",
       "      <td>neutral</td>\n",
       "      <td>[0.020466993, 0.0016903834, 0.005016124, 0.024...</td>\n",
       "      <td>20</td>\n",
       "      <td>[No disadvantages in stereotypes\\n\\nWe conduct...</td>\n",
       "      <td>neutral</td>\n",
       "      <td>[0.052939385, 0.0041974066, 0.012442276, 0.029...</td>\n",
       "      <td>20</td>\n",
       "      <td>[No disadvantages in stereotypes.\\n\\nBlack men...</td>\n",
       "      <td>No disadvantages in stereotypes\\n</td>\n",
       "      <td>No disadvantages in stereotypes.</td>\n",
       "      <td>neutral</td>\n",
       "      <td>[0.02565554, 0.0020743893, 0.0063242856, 0.023...</td>\n",
       "      <td>20</td>\n",
       "      <td>[No disadvantages in stereotypes\\n\\nA similar ...</td>\n",
       "      <td>neutral</td>\n",
       "      <td>[0.020113137, 0.00071785966, 0.0013747219, 0.0...</td>\n",
       "      <td>20</td>\n",
       "      <td>No disadvantages in stereotypes.\\n\\nPossibilit...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>359</th>\n",
       "      <td>neutral</td>\n",
       "      <td>[0.088526234, 0.001958989, 0.0047246744, 0.019...</td>\n",
       "      <td>20</td>\n",
       "      <td>[Very little, and yet, some of it is like a ma...</td>\n",
       "      <td>neutral</td>\n",
       "      <td>[0.053154353, 0.005228547, 0.0077190083, 0.020...</td>\n",
       "      <td>20</td>\n",
       "      <td>[Very little, and yet, some days later, we use...</td>\n",
       "      <td>Very little, and yet, some of</td>\n",
       "      <td>Very little, and yet, some days</td>\n",
       "      <td>neutral</td>\n",
       "      <td>[0.05526528, 0.009809997, 0.021853866, 0.03032...</td>\n",
       "      <td>20</td>\n",
       "      <td>[Very little, and yet, some of you, on the ver...</td>\n",
       "      <td>neutral</td>\n",
       "      <td>[0.002871542, 0.0040162764, 0.008609046, 0.024...</td>\n",
       "      <td>20</td>\n",
       "      <td>Very little, and yet, some days you realize ho...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4345</th>\n",
       "      <td>anger</td>\n",
       "      <td>[0.00476041, 0.0074065444, 0.45763108, 0.17941...</td>\n",
       "      <td>2</td>\n",
       "      <td>[The fuck is a fortnight? Like, what kind of c...</td>\n",
       "      <td>anger</td>\n",
       "      <td>[0.010142066, 0.017700024, 0.4246427, 0.169366...</td>\n",
       "      <td>2</td>\n",
       "      <td>[The fuck is a fortnight? Like the fucking sec...</td>\n",
       "      <td>The fuck is a fortnight? Like,</td>\n",
       "      <td>The fuck is a fortnight? Like the</td>\n",
       "      <td>anger</td>\n",
       "      <td>[0.0065170717, 0.009420512, 0.39205363, 0.1671...</td>\n",
       "      <td>2</td>\n",
       "      <td>[The fuck is a fortnight? Like, in like fuckin...</td>\n",
       "      <td>anger</td>\n",
       "      <td>[0.0032779058, 0.0027021044, 0.34522542, 0.239...</td>\n",
       "      <td>2</td>\n",
       "      <td>The fuck is a fortnight? Like the month, the h...</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                acf                                                     \\\n",
       "     cf_abstraction                        cf_abstraction_distribution   \n",
       "3687           love  [0.028688908, 0.0028968516, 0.0018504924, 0.00...   \n",
       "5167        neutral  [0.027037183, 0.0027999692, 0.016422274, 0.042...   \n",
       "3129        neutral  [0.020466993, 0.0016903834, 0.005016124, 0.024...   \n",
       "359         neutral  [0.088526234, 0.001958989, 0.0047246744, 0.019...   \n",
       "4345          anger  [0.00476041, 0.0074065444, 0.45763108, 0.17941...   \n",
       "\n",
       "                                                                           \\\n",
       "     cf_abstraction_id                                            cf_text   \n",
       "3687                18  [I'm 39 and still love being a dad every day. ...   \n",
       "5167                20  [Now I can’t unpack a 6-pack of PBRs, but it w...   \n",
       "3129                20  [No disadvantages in stereotypes\\n\\nWe conduct...   \n",
       "359                 20  [Very little, and yet, some of it is like a ma...   \n",
       "4345                 2  [The fuck is a fortnight? Like, what kind of c...   \n",
       "\n",
       "                                                                             \\\n",
       "     factual_abstraction                   factual_abstraction_distribution   \n",
       "3687                love  [0.052143306, 0.0081485305, 0.0037701551, 0.01...   \n",
       "5167             neutral  [0.03026599, 0.008347255, 0.021772802, 0.03667...   \n",
       "3129             neutral  [0.052939385, 0.0041974066, 0.012442276, 0.029...   \n",
       "359              neutral  [0.053154353, 0.005228547, 0.0077190083, 0.020...   \n",
       "4345               anger  [0.010142066, 0.017700024, 0.4246427, 0.169366...   \n",
       "\n",
       "                             \\\n",
       "     factual_abstraction_id   \n",
       "3687                     18   \n",
       "5167                     20   \n",
       "3129                     20   \n",
       "359                      20   \n",
       "4345                      2   \n",
       "\n",
       "                                                         \\\n",
       "                                           factual_text   \n",
       "3687  [I'm 39 and still love being given the chance ...   \n",
       "5167  [Now I can’t unhear this\\n\\nWandering on the s...   \n",
       "3129  [No disadvantages in stereotypes.\\n\\nBlack men...   \n",
       "359   [Very little, and yet, some days later, we use...   \n",
       "4345  [The fuck is a fortnight? Like the fucking sec...   \n",
       "\n",
       "                                 prompt                                     \\\n",
       "                              cf_prompt                     factual_prompt   \n",
       "3687      I'm 39 and still love being a  I'm 39 and still love being given   \n",
       "5167                 Now I can’t unpack                   Now I can’t unhe   \n",
       "3129  No disadvantages in stereotypes\\n   No disadvantages in stereotypes.   \n",
       "359       Very little, and yet, some of    Very little, and yet, some days   \n",
       "4345     The fuck is a fortnight? Like,  The fuck is a fortnight? Like the   \n",
       "\n",
       "               tlcf                                                     \\\n",
       "     cf_abstraction                        cf_abstraction_distribution   \n",
       "3687           love  [0.060048185, 0.019185118, 0.0031289954, 0.008...   \n",
       "5167        neutral  [0.09592512, 0.029937781, 0.00978319, 0.026652...   \n",
       "3129        neutral  [0.02565554, 0.0020743893, 0.0063242856, 0.023...   \n",
       "359         neutral  [0.05526528, 0.009809997, 0.021853866, 0.03032...   \n",
       "4345          anger  [0.0065170717, 0.009420512, 0.39205363, 0.1671...   \n",
       "\n",
       "                                                                           \\\n",
       "     cf_abstraction_id                                            cf_text   \n",
       "3687                18  [I'm 39 and still love being a ghost.I don't n...   \n",
       "5167                20  [Now I can’t unpack— I would hate to have to u...   \n",
       "3129                20  [No disadvantages in stereotypes\\n\\nA similar ...   \n",
       "359                 20  [Very little, and yet, some of you, on the ver...   \n",
       "4345                 2  [The fuck is a fortnight? Like, in like fuckin...   \n",
       "\n",
       "                                                                             \\\n",
       "     factual_abstraction                   factual_abstraction_distribution   \n",
       "3687                love  [0.006812853, 0.0035077806, 0.0028346416, 0.00...   \n",
       "5167           curiosity  [0.009881276, 0.07280486, 0.022118732, 0.07132...   \n",
       "3129             neutral  [0.020113137, 0.00071785966, 0.0013747219, 0.0...   \n",
       "359              neutral  [0.002871542, 0.0040162764, 0.008609046, 0.024...   \n",
       "4345               anger  [0.0032779058, 0.0027021044, 0.34522542, 0.239...   \n",
       "\n",
       "                                                                                \n",
       "     factual_abstraction_id                                       factual_text  \n",
       "3687                     18  I'm 39 and still love being given the time of ...  \n",
       "5167                      7  Now I can’t unhear them. What’s with you’?\\n\\n...  \n",
       "3129                     20  No disadvantages in stereotypes.\\n\\nPossibilit...  \n",
       "359                      20  Very little, and yet, some days you realize ho...  \n",
       "4345                      2  The fuck is a fortnight? Like the month, the h...  "
      ]
     },
     "execution_count": 32,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [],
   "source": [
    "def has_abstraction_p_increased(row: pd.Series):\n",
    "    factual_abstraction_id = row[\"factual_abstraction_id\"]\n",
    "    factual_abstraction_p = row[\"factual_abstraction_distribution\"][factual_abstraction_id]\n",
    "    counterfactual_abstraction_p = row[\"cf_abstraction_distribution\"][factual_abstraction_id]\n",
    "    return counterfactual_abstraction_p > factual_abstraction_p"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {},
   "outputs": [],
   "source": [
    "df[('acf', 'abstraction_change')] = df[('acf', 'factual_abstraction_id')] != df[('acf', 'cf_abstraction_id')]\n",
    "df[('acf', 'abstraction_p_increased')] = df['acf'].apply(has_abstraction_p_increased, axis=1)\n",
    "\n",
    "df[('tlcf', 'abstraction_change')] = df[('tlcf', 'factual_abstraction_id')] != df[('tlcf', 'cf_abstraction_id')]\n",
    "df[('tlcf', 'abstraction_p_increased')] = df['tlcf'].apply(has_abstraction_p_increased, axis=1)\n",
    "\n",
    "\n",
    "# save the dataframe\n",
    "df.to_pickle('token_replacement_analysis_dataframe.pkl')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Abstract Counterfactuals\n",
      "abstraction change number: 13, rate: 0.052\n",
      "abstraction p increased number: 203, rate: 0.812\n",
      "\n",
      "\n",
      "Token Level Counterfactuals\n",
      "abstraction change number: 88, rate: 0.352\n",
      "abstraction p increased number: 55, rate: 0.22\n"
     ]
    }
   ],
   "source": [
    "print(\"Abstract Counterfactuals\")\n",
    "print(f\"abstraction change number: {df[('acf', 'abstraction_change')].sum()}, rate: {df[('acf', 'abstraction_change')].mean()}\")\n",
    "print(f\"abstraction p increased number: {df[('acf', 'abstraction_p_increased')].sum()}, rate: {df[('acf', 'abstraction_p_increased')].mean()}\")\n",
    "\n",
    "print('\\n')\n",
    "print(\"Token Level Counterfactuals\")\n",
    "print(f\"abstraction change number: {df[('tlcf', 'abstraction_change')].sum()}, rate: {df[('tlcf', 'abstraction_change')].mean()}\")\n",
    "print(f\"abstraction p increased number: {df[('tlcf', 'abstraction_p_increased')].sum()}, rate: {df[('tlcf', 'abstraction_p_increased')].mean()}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "n_only_acf_change = (df[('acf', 'abstraction_change')] & ~df[('tlcf', 'abstraction_change')]).sum()\n",
    "n_only_tlcf_change = (df[('tlcf', 'abstraction_change')] & ~df[('acf', 'abstraction_change')]).sum()\n",
    "n_both_change = (df[('acf', 'abstraction_change')] & df[('tlcf', 'abstraction_change')]).sum()\n",
    "n_no_change = (~df[('acf', 'abstraction_change')] & ~df[('tlcf', 'abstraction_change')]).sum()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABpAAAAK3CAYAAACCxQxcAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8hTgPZAAAACXBIWXMAAA9hAAAPYQGoP6dpAADr5klEQVR4nOzdd4AU9f3/8ddntl4/kHqKiEpsscWOFSVRbLFFUTR2jcaeRNOMSoqJ0Ygaoyb5Rv1FSLPHKIqKGhUVBUQRgYOjHeXg4PrWmc/vj/M2LHcg5e7mdu/5MBfYmdmZ97ZjP/Oaz+djrLVWAAAAAAAAAAAAwBccvwsAAAAAAAAAAABAz0KABAAAAAAAAAAAgCwESAAAAAAAAAAAAMhCgAQAAAAAAAAAAIAsBEgAAAAAAAAAAADIQoAEAAAAAAAAAACALARIAAAAAAAAAAAAyEKABAAAAAAAAAAAgCwESAAAAAAAAAAAAMhCgATkoJ122kkXXXSR32X0eE1NTbrssss0aNAgGWN0ww03dMp+L7roIhUXF3fKvnqyRYsWyRijxx57zO9SNumNN96QMUZPPvmk36UAAAAAPdJjjz0mY4w+/PBDv0vZJul0WjfffLOGDBkix3F02mmndcp+b7/9dhljtGbNmk7ZX09mjNHtt9/udxmb1NYWvfvuu/0uBQB6PQIk5LxTTz1VhYWFamxs3Og2Y8eOVTgcVm1tbTdWtnmOOeYYGWNkjJHjOCotLdVuu+2mCy64QJMnT/a7vJz2q1/9So899piuuuoq/fWvf9UFF1zwpfdxXVcVFRUyxuill17q8ho/++wz3X777Vq0aFGXH2tjJk6cqPHjx/t2/E154403dMYZZ2jQoEEKh8MaMGCATjnlFD399NN+lwYAAIBeqi2MWf9nwIABGjlyZLe0ITb0zDPPaPTo0erXr5/C4bAqKip09tln6/XXX+/2Wtr84Q9/6JIL0f7yl7/ot7/9rc466yw9/vjjuvHGGzfrfgcffLCMMXrooYc6vaYNLV++XLfffrtmzpzZ5cfamBdffLHHhkQzZ87U+eefryFDhigSiahv374aNWqUHn30Ubmu63d5AIANBP0uANhWY8eO1b///W8988wz+va3v91ufUtLi5577jmdcMIJ2m677Xyo8MvtsMMOuvPOOyVJzc3Nqqys1NNPP60nnnhCZ599tp544gmFQqHM9nPnzpXjkP9+mddff12HHnqobrvtti26z4oVK7TTTjtpwoQJGj16dBdW2Bog3XHHHTrmmGO00047demxNmbixIn69NNP2/XQGjp0qGKxWNZ7rzvddtttGjdunIYPH64rr7xSQ4cOVW1trV588UWdeeaZmjBhgs477zxfagMAAADGjRunYcOGyVqrVatW6bHHHtOJJ56of//73zr55JO7/PjWWl1yySV67LHHtP/+++umm27SoEGDtGLFCj3zzDM67rjj9M4772jEiBFdXsuG/vCHP6hfv36dPnLG66+/ru2331733nvvZt9n/vz5mjZtWqaNd9VVV3VqTRtavny57rjjDu20007ab7/9uvRYG/Piiy/qwQcf7DBEisViCgb9OR345z//Wd/5znc0cOBAXXDBBRo+fLgaGxv12muv6dJLL9WKFSv04x//2JfaAAAdI0BCzjv11FNVUlKiiRMndhggPffcc2pubtbYsWN9qG7zlJWV6fzzz89a9utf/1rXXXed/vCHP2innXbSb37zm8y6SCTS3SVKag3jCgsLfTn21qipqdGee+65Rfd54okn9LWvfU0XXnihfvzjH6u5uVlFRUVdVOGWsdYqHo+roKCgW45njFE0Gu2WY23oySef1Lhx43TWWWdp4sSJWSHWD37wA7388stKpVK+1AYAAABI0ujRo3XggQdmbl966aUaOHCg/va3v3VKgOR5npLJ5Ea/k99zzz167LHHdMMNN+h3v/udjDGZdT/5yU/017/+tduDgq5uM9bU1Ki8vHyL7vPEE09owIABuueee3TWWWdp0aJFvl2815Hubmf71cZ777339J3vfEeHHXaYXnzxRZWUlGTW3XDDDfrwww/16aef+lIbAGDj6MKAnFdQUKAzzjhDr732mmpqatqtnzhxokpKSnTqqadKkurq6nTDDTdkukvvuuuu+s1vfiPP8zL3WX+83T/+8Y/aZZddFIlEdNBBB2natGlZ+2+bD6e6ulqnnXaaiouL1b9/f33/+9/fpu7XgUBA999/v/bcc0/9/ve/V319fWbdhnMgrV27Vt///ve19957q7i4WKWlpRo9erQ+/vjjdvtdvHixTj31VBUVFWnAgAG68cYb9fLLL8sYozfeeCOz3THHHKOvfvWr+uijj3TUUUepsLAwcyXQc889p5NOOkkVFRWKRCLaZZdd9POf/7zd423bx6xZs3T00UersLBQu+66a2aumjfffFOHHHKICgoKtNtuu+nVV1/drOempqYm0ziLRqPad9999fjjj2fWt82JU1VVpf/85z+ZYSW+bJi4WCymZ555RmPGjNHZZ5+tWCym5557bqPbL1y4UMcff7yKiopUUVGhcePGyVqbtc3f//53HXDAASopKVFpaan23ntv3XfffZJah7741re+JUkaOXJkps6212GnnXbSySefrJdfflkHHnigCgoK9Mgjj0iSHn30UR177LEaMGCAIpGI9txzz40Ox/DSSy/p6KOPztRw0EEHaeLEiZJaX6P//Oc/Wrx4ceb4bY2pjc2B9Prrr+vII49UUVGRysvL9c1vflNz5szJ2qZtDPHKykpddNFFKi8vV1lZmS6++GK1tLRs8nWQpFtvvVV9+/bVX/7ylw57QB1//PHtGuWe5+mXv/yldthhB0WjUR133HGqrKzM2ua///2vvvWtb2nHHXdUJBLRkCFDdOONNyoWi2VttyWf69raWl1wwQUqLS1VeXm5LrzwQn388ccdPneff/65zjrrLPXt21fRaFQHHnignn/++S99PgAAANDzlZeXq6CgoF1oc/fdd2vEiBHabrvtVFBQoAMOOKDD+TuNMbrmmms0YcIE7bXXXopEIpo0aVKHx4rFYrrzzju1++676+67784Kj9pccMEFOvjgg7OWJRIJ3XTTTerfv7+Kiop0+umna/Xq1VnbbGl7b8M240477aTZs2frzTffzLQxjjnmmE0+d83Nzfre976XaafvtttuuvvuuzPtq7a2yZQpUzR79ux2badNmThxos466yydfPLJKisry7SFOrJmzRqdffbZKi0t1Xbbbafrr79e8Xg8a5vJkyfriCOOUHl5uYqLi7Xbbrtl2spvvPGGDjroIEnSxRdfnKmzrV3QGe1sSXr//fd14oknqk+fPioqKtI+++yTaWdedNFFevDBByUpa5jFNh3NgTRjxgyNHj1apaWlKi4u1nHHHaf33nsva5u2oRvfeeedL30PdeSOO+6QMUYTJkzICo/aHHjggR32WPuyczKzZs3SRRddpJ133lnRaFSDBg3SJZdc0m4Kgy1po8ZiMV133XXq169f5nxSdXV1h89ddXW1LrnkEg0cOFCRSER77bWX/vKXv3zp8wEAuYIeSMgLY8eO1eOPP65//vOfuuaaazLL165dq5dfflnnnnuuCgoK1NLSoqOPPlrV1dW68sorteOOO+rdd9/Vj370I61YsaLdPDATJ05UY2OjrrzyShljdNddd+mMM87QwoULs05qu66r448/Xocccojuvvtuvfrqq7rnnnu0yy67bFP3+EAgoHPPPVe33nqr3n77bZ100kkdbrdw4UI9++yz+ta3vqVhw4Zp1apVeuSRR3T00Ufrs88+U0VFhaTWL+XHHnusVqxYoeuvv16DBg3SxIkTNWXKlA73W1tbq9GjR2vMmDE6//zzNXDgQEmtXxyLi4t10003qbi4WK+//rp+9rOfqaGhQb/97W+z9rFu3TqdfPLJGjNmjL71rW/poYce0pgxYzRhwgTdcMMN+s53vqPzzjsvM4710qVLO/wy2SYWi+mYY45RZWWlrrnmGg0bNkz/+te/dNFFF6murk7XX3+99thjD/31r3/VjTfeqB122EHf+973JEn9+/ff5PP9/PPPq6mpSWPGjNGgQYN0zDHHbHSYNNd1dcIJJ+jQQw/VXXfdpUmTJum2225TOp3WuHHjJLU2LM4991wdd9xxmR5kc+bM0TvvvKPrr79eRx11lK677jrdf//9+vGPf6w99thDkjJ/Sq3DFZ577rm68sordfnll2u33XaTJD300EPaa6+9dOqppyoYDOrf//63rr76anmep+9+97uZ+z/22GO65JJLtNdee+lHP/qRysvLNWPGDE2aNEnnnXeefvKTn6i+vl7Lli3LDANRXFy80efo1Vdf1ejRo7Xzzjvr9ttvVywW0wMPPKDDDz9c06dPb3cl39lnn61hw4bpzjvv1PTp0/XnP/9ZAwYMyOpRt6H58+fr888/1yWXXLLJ98KGfv3rX8txHH3/+99XfX297rrrLo0dO1bvv/9+Zpt//etfamlp0VVXXaXttttOH3zwgR544AEtW7ZM//rXv7L2tzmfa8/zdMopp+iDDz7QVVddpd13313PPfecLrzwwnb1zZ49W4cffri23357/fCHP1RRUZH++c9/6rTTTtNTTz2l008/fbMfKwAAAPxXX1+vNWvWyFqrmpoaPfDAA2pqamo3usR9992nU089VWPHjlUymdTf//53fetb39ILL7zQro33+uuvZ9q1/fr122hPmbfffltr167VDTfcoEAgsNk1X3vtterTp49uu+02LVq0SOPHj9c111yjf/zjH5lttqS911Gb8ZhjjtG1116r4uJi/eQnP5GkTFuyI9ZanXrqqZoyZYouvfRS7bfffnr55Zf1gx/8QNXV1br33nvVv39//fWvf9Uvf/lLNTU1ZYaAX7/t1JH3339flZWVevTRRxUOh3XGGWdowoQJGx0m7eyzz9ZOO+2kO++8U++9957uv/9+rVu3Tv/v//0/Sa3f6U8++WTts88+GjdunCKRiCorK/XOO+9k6hk3bpx+9rOf6YorrtCRRx4pSVnDCG5rO3vy5Mk6+eSTNXjw4Ey7fs6cOXrhhRd0/fXX68orr9Ty5cs1efJk/fWvf93k89P2mI488kiVlpbq5ptvVigU0iOPPKJjjjkmc9Hn+jbnPbShlpYWvfbaazrqqKO04447fmlNbTbnnMzkyZO1cOFCXXzxxRo0aJBmz56tP/7xj5o9e7bee++9duHq5rRRL7roIv3zn//UBRdcoEMPPVRvvvlmh+djVq1apUMPPTQT/vbv318vvfSSLr30UjU0NLQbJh4AcpIF8kA6nbaDBw+2hx12WNbyhx9+2EqyL7/8srXW2p///Oe2qKjIzps3L2u7H/7whzYQCNglS5ZYa62tqqqykux2221n165dm9nuueees5Lsv//978yyCy+80Eqy48aNy9rn/vvvbw844IAvrf3oo4+2e+2110bXP/PMM1aSve+++zLLhg4dai+88MLM7Xg8bl3XzbpfVVWVjUQiWXXdc889VpJ99tlnM8tisZjdfffdrSQ7ZcqUrLok2YcffrhdTS0tLe2WXXnllbawsNDG4/F2+5g4cWJm2eeff24lWcdx7HvvvZdZ/vLLL1tJ9tFHH93oc2GttePHj7eS7BNPPJFZlkwm7WGHHWaLi4ttQ0NDZvnQoUPtSSedtMn9re/kk0+2hx9+eOb2H//4RxsMBm1NTU3Wdm2v+bXXXptZ5nmePemkk2w4HLarV6+21lp7/fXX29LSUptOpzd6zH/961/tnvv165dkJ02a1G5dR6/B8ccfb3feeefM7bq6OltSUmIPOeQQG4vFsrb1PC/z95NOOskOHTq03f7aPgfrvyb77befHTBggK2trc0s+/jjj63jOPbb3/52Ztltt91mJdlLLrkka5+nn3663W677doda31tn7N77713k9u1mTJlipVk99hjD5tIJDLL77vvPivJfvLJJ5llHT1vd955pzXG2MWLF2eWbe7n+qmnnrKS7Pjx4zPLXNe1xx57bLvn7rjjjrN777131mfE8zw7YsQIO3z48M16rAAAAPDfo48+aiW1+4lEIvaxxx5rt/2G30GTyaT96le/ao899tis5W3tpNmzZ39pDW3fdZ955pktqnnUqFFZbYEbb7zRBgIBW1dXt9F6rd10e6+jNuNee+1ljz766M2q7dlnn7WS7C9+8Yus5WeddZY1xtjKysqsY26q/byha665xg4ZMiTzmF955RUryc6YMSNru7b2y6mnnpq1/Oqrr7aS7Mcff2yttfbee++1kjJtvo5MmzZto23bbW1np9NpO2zYMDt06FC7bt26rG3Xf12/+93v2o2d8pNkb7vttszt0047zYbDYbtgwYLMsuXLl9uSkhJ71FFHZZZtyXtoQx9//LGVZK+//vqNbrO+LTkn09Hz9re//c1Ksm+99VZm2ea2UT/66CMryd5www1Z21100UXtnrtLL73UDh482K5ZsyZr2zFjxtiysrIOawOAXMMQdsgLgUBAY8aM0dSpU7OGKZs4caIGDhyo4447TlJr74MjjzxSffr00Zo1azI/o0aNkuu6euutt7L2e84556hPnz6Z221XDy1cuLBdDd/5zneybh955JEdbrel2nqDNDY2bnSbSCQix2n9OLuuq9ra2kxX+unTp2e2mzRpkrbffvvMcH5S6/jHl19++Ub3e/HFF7dbvv4cPI2NjVqzZo2OPPJItbS06PPPP29X/5gxYzK3d9ttN5WXl2uPPfbIupKp7e9f9py9+OKLGjRokM4999zMslAopOuuu05NTU168803N3n/jamtrc30Vmtz5plnyhijf/7znx3eZ/3ebm1XHCWTycxQfOXl5WpubtbkyZO3qiZJGjZsmI4//vh2y9d/DdqufDz66KO1cOHCzHCHkydPVmNjo374wx+2G+e6oyEuvsyKFSs0c+ZMXXTRRerbt29m+T777KOvf/3revHFF9vdp6PPRW1trRoaGjZ6nLZ1W9L7SGodIiIcDmcdS8p+T63/vDU3N2vNmjUaMWKErLWaMWPGZtW//v4mTZqkUCiU9RlyHCerF5jU2hvy9ddf19lnn535zKxZs0a1tbU6/vjjNX/+fFVXV2/R4wUAAIC/HnzwQU2ePFmTJ0/WE088oZEjR+qyyy7T008/nbXd+t9B161bp/r6eh155JFZbbU2Rx999GbN47q135mvuOKKrLbAkUceKdd1tXjx4g7r/bL23sbajFvixRdfVCAQ0HXXXZe1/Hvf+56stXrppZe2ar/pdFr/+Mc/dM4552Qec9sw4BMmTOjwPht+j7/22mszNUrKzL/03HPPZQ2DvyW2pZ09Y8YMVVVV6YYbbmg3F9TWtPFc19Urr7yi0047TTvvvHNm+eDBg3Xeeefp7bffbtd225z30Ia29v26Oedk1n/e4vG41qxZo0MPPVSSOvyMfVkbtW3YyKuvvjpru7b3QhtrrZ566imdcsopstZmnWM6/vjjVV9f3+HxASDXECAhb4wdO1aSMuMZL1u2TP/97381ZsyYTJf++fPna9KkSerfv3/Wz6hRoySp3RxKG3atbvvism7duqzl0Wi03fBoffr0abfd1mhqapK06S9anufp3nvv1fDhwxWJRNSvXz/1799fs2bNypo7afHixdpll13afbHcddddO9zv9ttvn3VCvs3s2bN1+umnq6ysTKWlperfv39mmIb1jydJO+ywQ7vjlZWVaciQIe2WSe2f2w0tXrxYw4cPzwRmbdqGLtjUl9ZN+cc//qFUKqX9999flZWVqqys1Nq1a3XIIYd02LhwHCfrC7YkfeUrX5GkTIh59dVX6ytf+YpGjx6tHXbYQZdccslGxzDfmGHDhnW4/J133tGoUaMy8xD1798/MwxD22uwYMECSdJXv/rVLTrmxrQ9t23D6K1vjz320Jo1a9Tc3Jy1fHM/Q+srLS2VtOnQtCObc6wlS5ZkArC2eY2OPvpoSe3fu5vzuV68eLEGDx7cbtLbDT9TlZWVstbq1ltvbff757bbbpPU/vcPAAAAeraDDz5Yo0aN0qhRozR27Fj95z//0Z577pm5sKzNCy+8oEMPPVTRaFR9+/ZV//799dBDD7X7/ilt/Pv/hrryO/OWtPc21mbcEosXL1ZFRUW7Nu+2tvFeeeUVrV69WgcffHCmjVdVVaWRI0fqb3/7W4cB0PDhw7Nu77LLLnIcJ9PGO+ecc3T44Yfrsssu08CBAzVmzBj985//3KIwaVva2Z3dxlu9erVaWlo22sbzPE9Lly7NWt7T2nhr167V9ddfr4EDB6qgoED9+/fPfI46+ox92T4XL14sx3HafRY3bOOtXr1adXV1+uMf/9iujdcWENLGA5APmAMJeeOAAw7Q7rvvrr/97W/68Y9/rL/97W+y1maCJak1aPn617+um2++ucN9tAUAbTY2lrT9YiLPL9uuM3z66aeSNh7ySNKvfvUr3Xrrrbrkkkv085//XH379pXjOLrhhhu2+qooKftKnjZ1dXU6+uijVVpaqnHjxmmXXXZRNBrV9OnTdcstt7Q73saem819brtLW0h0+OGHd7h+4cKF7QKjLzNgwADNnDlTL7/8sl566SW99NJLevTRR/Xtb39bjz/++Gbto6PXYMGCBTruuOO0++6763e/+52GDBmicDisF198Uffee+82veadbWte5913312S9Mknn3TqsVzX1de//nWtXbtWt9xyi3bffXcVFRWpurpaF1100Wa/d7dG276///3vd9ijTNr0ZxwAAAA9n+M4GjlypO677z7Nnz9fe+21l/773//q1FNP1VFHHaU//OEPGjx4sEKhkB599NHMxY/r6+j7f0fW/8582mmnbXaNX/adeUvbe5tbrx/a2nhnn312h+vffPNNjRw5cpP72PBiyIKCAr311luaMmWK/vOf/2jSpEn6xz/+oWOPPVavvPLKZrUhOqOd7aetaePtuuuuCgaDnd7Gk1pf33fffVc/+MEPtN9++6m4uFie5+mEE07o8HnrrHMRbfs+//zzO5wDV2odrQMAch0BEvLK2LFjdeutt2rWrFmaOHGihg8froMOOiizfpdddlFTU1Omx1FP57quJk6cqMLCQh1xxBEb3e7JJ5/UyJEj9X//939Zy+vq6tSvX7/M7aFDh+qzzz6TtTbri3BlZeVm1/TGG2+otrZWTz/9tI466qjM8qqqqs3ex7YYOnSoZs2aJc/zsnohtXXpHzp06Bbvs6qqSu+++66uueaaTG+UNp7n6YILLtDEiRP105/+NGv5woULs0LHefPmSVLWRLfhcFinnHKKTjnlFHmep6uvvlqPPPKIbr31Vu26665bNczAv//9byUSCT3//PNZV09NmTIla7tddtlFUmsIualwYnNraHtu586d227d559/rn79+qmoqGiz9rUpX/nKV7Tbbrvpueee03333ZcZxnFbffLJJ5o3b54ef/xxffvb384s35YhBocOHaopU6aopaUlqxfShp+ptvAxFArlzO8fAAAAbLl0Oi3pfyNJPPXUU4pGo3r55ZcViUQy2z366KPbdJwjjjhCffr0yVxA2VkXP3VWe29L2jlDhw7Vq6++qsbGxqxeSNvSxmtubtZzzz2nc845R2eddVa79dddd50mTJjQLkCaP39+Vs+TyspKeZ6X1cZzHEfHHXecjjvuOP3ud7/Tr371K/3kJz/RlClTNGrUqK1q423u875+G29T7YrNraF///4qLCzcaBvPcZx2o4dsjcLCQh177LF6/fXXtXTp0k7Zp9Taa+i1117THXfcoZ/97GeZ5fPnz9/qfQ4dOlSe56mqqiqrR9qGbbz+/furpKREruvSxgOQ1xjCDnmlrbfRz372M82cOTOr95HUemXK1KlT9fLLL7e7b11dXebLfk/guq6uu+46zZkzR9ddd12my3dHAoFAu6tl/vWvf7WbU+X4449XdXW1nn/++cyyeDyuP/3pT5tdV1vDZP3jJZNJ/eEPf9jsfWyLE088UStXrtQ//vGPzLJ0Oq0HHnhAxcXF7QKgzdF2ZdrNN9+ss846K+vn7LPP1tFHH93hMHa///3vM3+31ur3v/+9QqFQZs6t2trarO0dx8lcgZRIJCQpE7jU1dVtdr0dvQb19fXtGqHf+MY3VFJSojvvvFPxeDxr3fr3LSoq6rBr/4YGDx6s/fbbT48//nhWvZ9++qleeeUVnXjiiZv9GL7MHXfcodraWl122WUdfi5feeUVvfDCC1u0z46eN2ut7rvvvq2u8/jjj1cqlcr6DHmepwcffDBruwEDBuiYY47RI488ohUrVrTbz+rVq7e6BgAAAPQMqVRKr7zyisLhcGb4tUAgIGOMXNfNbLdo0SI9++yz23SswsJC3XLLLZozZ45uueWWDntPPPHEE/rggw+2aL+d1d4rKira7DbOiSeeKNd1s9pXknTvvffKGKPRo0dv0bEl6ZlnnlFzc7O++93vtmvjnXXWWTr55JP11FNPZdplbTb8Hv/AAw9IUqaGtWvXtjvWfvvtJ6nz23gdPe9f+9rXNGzYMI0fP77d/jds421ODYFAQN/4xjf03HPPZc0nvWrVKk2cOFFHHHHEJs9FbInbbrtN1lpdcMEFmYB1fR999NFmj9TRpqPnTZLGjx+/1XW2jRix4XPf9l5Y/9hnnnmmnnrqqczIMeujjQcgX9ADCXll2LBhGjFihJ577jlJahcg/eAHP9Dzzz+vk08+WRdddJEOOOAANTc365NPPtGTTz6pRYsWZfXY6S719fV64oknJEktLS2qrKzU008/rQULFmjMmDH6+c9/vsn7n3zyyRo3bpwuvvhijRgxQp988okmTJjQbsi1K6+8Ur///e917rnn6vrrr9fgwYM1YcIERaNRSZt3ldKIESPUp08fXXjhhbruuutkjNFf//rXbht67oorrtAjjzyiiy66SB999JF22mknPfnkk3rnnXc0fvz4LZ6UU2oNkPbbb7+NXgV16qmn6tprr9X06dP1ta99TVLr/DiTJk3ShRdeqEMOOUQvvfSS/vOf/+jHP/5xZt6cyy67TGvXrtWxxx6rHXbYQYsXL9YDDzyg/fbbL9Og3G+//RQIBPSb3/xG9fX1ikQimYldN+Yb3/hGpmfTlVdeqaamJv3pT3/SgAEDssKJ0tJS3Xvvvbrssst00EEH6bzzzlOfPn308ccfq6WlJfPl/IADDtA//vEP3XTTTTrooINUXFysU045pcNj//a3v9Xo0aN12GGH6dJLL1UsFtMDDzygsrIy3X777Vv83G/MOeeco08++US//OUvNWPGDJ177rkaOnSoamtrNWnSJL322msdDvmxKbvvvrt22WUXff/731d1dbVKS0v11FNPbdNcZaeddpoOPvhgfe9731NlZaV23313Pf/885mG5fqfqQcffFBHHHGE9t57b11++eXaeeedtWrVKk2dOlXLli3Txx9/vNV1AAAAoPu99NJLmV4yNTU1mjhxoubPn68f/vCHmZPuJ510kn73u9/phBNO0Hnnnaeamho9+OCD2nXXXTVr1qxtOv4PfvADzZ49W/fcc4+mTJmis846S4MGDdLKlSv17LPP6oMPPtC77767RfvsrPbeAQccoIceeki/+MUvtOuuu2rAgAE69thjO9z2lFNO0ciRI/WTn/xEixYt0r777qtXXnlFzz33nG644YZMr5stMWHCBG233XYaMWJEh+tPPfVU/elPf9J//vMfnXHGGZnlVVVVOvXUU3XCCSdo6tSpeuKJJ3Teeedp3333lSSNGzdOb731lk466SQNHTpUNTU1+sMf/qAddtghM2rILrvsovLycj388MMqKSlRUVGRDjnkkE3Ob7W5z7vjOHrooYd0yimnaL/99tPFF1+swYMH6/PPP9fs2bMzF8secMABklp7Wh1//PEKBAIaM2ZMh8f+xS9+ocmTJ+uII47Q1VdfrWAwqEceeUSJREJ33XXXZj7jX27EiBF68MEHdfXVV2v33XfXBRdcoOHDh6uxsVFvvPGGnn/+ef3iF7/Yon2WlpbqqKOO0l133aVUKqXtt99er7zyyjaNkHLAAQfozDPP1Pjx41VbW6tDDz1Ub775ZmbEkfXbeL/+9a81ZcoUHXLIIbr88su15557au3atZo+fbpeffXVDgNHAMg5FsgzDz74oJVkDz744A7XNzY22h/96Ed21113teFw2Pbr18+OGDHC3n333TaZTFprra2qqrKS7G9/+9t295dkb7vttsztCy+80BYVFbXb7rbbbrOb8xE7+uijraTMT3FxsR0+fLg9//zz7SuvvNLhfYYOHWovvPDCzO14PG6/973v2cGDB9uCggJ7+OGH26lTp9qjjz7aHn300Vn3XbhwoT3ppJNsQUGB7d+/v/3e975nn3rqKSvJvvfee1l17bXXXh0e/5133rGHHnqoLSgosBUVFfbmm2+2L7/8spVkp0yZ8qX7GDp0qD3ppJPaLZdkv/vd727i2Wq1atUqe/HFF9t+/frZcDhs9957b/voo49u9nHW99FHH1lJ9tZbb93oNosWLbKS7I033mit/d9rvmDBAvuNb3zDFhYW2oEDB9rbbrvNuq6bud+TTz5pv/GNb9gBAwbYcDhsd9xxR3vllVfaFStWZO3/T3/6k915551tIBDIeg43Vf/zzz9v99lnHxuNRu1OO+1kf/Ob39i//OUvVpKtqqpqt+2IESNsQUGBLS0ttQcffLD929/+llnf1NRkzzvvPFteXm4l2aFDh1pr//c52PC5ffXVV+3hhx+e2d8pp5xiP/vss6xt2t7/q1evzlr+6KOPdljjxrz22mv2m9/8ph0wYIANBoO2f//+9pRTTrHPPfdcZpspU6ZYSfZf//pX1n07qv+zzz6zo0aNssXFxbZfv3728ssvtx9//HG77bbkc7169Wp73nnn2ZKSEltWVmYvuugi+84771hJ9u9//3vWtgsWLLDf/va37aBBg2woFLLbb7+9Pfnkk+2TTz65Wc8HAAAA/Nf2nXb9n2g0avfbbz/70EMPWc/zsrb/v//7Pzt8+HAbiUTs7rvvbh999NEOv1dubntoQ23tjr59+9pgMGgHDx5szznnHPvGG2+0q3natGlZ9237Lr1+O25b23vWWrty5Up70kkn2ZKSEiup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rm6//XY98cQTWrlypSoqKnTRRRfppz/9aeZ7qrVWt912m/70pz+prq5Ohx9+uB566CENHz680+oAAAAAAHS9PA6QvC96IHXPie1nH75XE+++Qyde9B1d9NNfd8kxjJXEefrN9t689/XQKw/rk8WfaFV9jf7vqj/phP2P73DbW574kZ54a4JuP/tnunzUZd1caW4yjpFJtf7k728S9GSu6+rvv/q73vjHG6pbVae+g/vq2LHH6uybz86cxJz63FRN+sskLZixQI3rGnXvO/dq53129rly9GZGhjmQ0OlmzZql/fbbT5L06aefZq3r7IuPfvOb3+ihhx7S448/rr322ksffvihLr74YpWVlem6666TJN111126//779fjjj2vYsGG69dZbdfzxx+uzzz5TNBrt1HoA5Ib71t3ndwlAluv7XO93CQAA5IS8Pe2b9KysOr/R3JHKWdM1+e+Paujue3XxkZgAaUu0JFq05w57aszh5+iyh67Y6HYvzZik6QtnaFD5wG6sLvc5xshYIyUlFfhdDXqjp3/3tF7680u64ZEbNGSPIaqcUan7r7pfhaWFOuWqUyRJ8Za49jhsDx1++uF68NoHfa4YaOXJ87sE5JkpU6Z027HeffddffOb39RJJ50kSdppp530t7/9TR988IGk1t5H48eP109/+lN985vflCT9v//3/zRw4EA9++yzGjNmTLfVCgAAAADYNvk0wlsW15O6o7tOvLlJD9x0ua785f0qKi3v0mMZzjdtkWP3HqlbTvuBRu9/wka3WbFupX76t5/p95fdp2AgtNHt0J5xHBnvix5IgA8+f/9zHXLSITrwhAM1cOhAHX7a4dr/2P01/6P5mW1GnjtSY344RvuO3NfHSoFslgtCkMNGjBih1157TfPmzZMkffzxx3r77bc1evRoSVJVVZVWrlypUaNGZe5TVlamQw45RFOnTu1wn4lEQg0NDVk/AAAAAAD/5W0PJLve/3elP9/+fe1/zDe0z+HH6OkHf9ulxzJiBLvO5HmervvLDbrq+Cu1W8VufpeTc4zzRQ8kjxOh8Mfuh+yuVx57RdXzq7X98O1V9UmVPpv6mS658xK/SwM2jV+b6GQjR47cZK/7119/vdOO9cMf/lANDQ3afffdFQgE5LqufvnLX2rs2LGSpJUrV0qSBg7M7tk9cODAzLoN3Xnnnbrjjjs6rUYAAAAAQOfI3wDJdn3Y8s4LT6lq9izd+UznNco3iTmQOtWDL/9BQSegS4/lZPO2MJ7hanr44szvnamWxhZ994Dvygk48lxP5//sfB1zzjF+lwZslBG/M9H52uY/apNKpTRz5kx9+umnuvDCCzv1WP/85z81YcIETZw4UXvttZdmzpypG264QRUVFVt9rB/96Ee66aabMrcbGho0ZMiQzioZAAAAALCV8jZA8ro4bVmzfJke+/kP9dPHn1E40j2TARsCpE4za/Es/d9rj2rST//TLfNkAeh8bz/9tt7855u66S83acc9dlTVrCr93y3/p76D++rYscf6XR6wUQRI6Gz33ntvh8tvv/12NTU1deqxfvCDH+iHP/xhZi6jvffeW4sXL9add96pCy+8UIMGDZIkrVq1SoMHD87cb9WqVe2CrjaRSESRSKRT6wQAAAAAbLu8DZAkdWnYsnD2TNXXrtYt3zw6s8xzXc2Z9q4m/fVPmvhZjZxAoOsKwDZ5f/4HWtO4Rgf/8LDMMtdzNe5fv9CfX/uL3r/zXR+ryzGcB4VPHvvpYzrzpjN11FlHSZJ22msnrV66Wk/e8yQBEgBIOv/883XwwQfr7rvv7rR9trS0yHGyp1ENBALyvNbJOocNG6ZBgwbptddeywRGDQ0Nev/993XVVVd1Wh0AAAAAgK6XtwGSkVrHsesiex92tO5+MTtkeOiW76pi5+H65pU3dEl4ZI04Wd9Jzjz0TB25x5FZy8bed77OPPQMnT3ibJ+qylF04IJPki3JdicxHceRZV4u9HCGX5zoJlOnTlU02rk95U855RT98pe/1I477qi99tpLM2bM0O9+9ztdcknrkMDGGN1www36xS9+oeHDh2vYsGG69dZbVVFRodNOO61TawEAAAAAdK38DZC6eFiyguIS7fiVPbOWRQoKVdKnb7vl8EdzvFlVqxdlbi9Zs1SfLp2tPoXl2n677dW3uE/W9sFASP1L+2vXQbt0c6W5zXIeFD45aPRB+tdv/6X+O/TXkD2GaOHHC/Xc75/TqAtGZbZpXNuo1ctWa+2KtZKk6vnVkqQ+A/uoz8A+He4XAHLNGWeckXXbWqsVK1boww8/1K233tqpx3rggQd066236uqrr1ZNTY0qKip05ZVX6mc/+1lmm5tvvlnNzc264oorVFdXpyOOOEKTJk3q9DALAAAAANC18jZAar0mPc/ObNMDaYt8vHiWvnXPOZnbd/xrnCTpW4edpfEX/86vsvKG9ayssZLDmxL+uPzuyzXxFxP18E0Pq351vfoO7qvjLzle5/zwf5/7D178QPdfdX/m9t0XtQ7jNOZHY3Tuj8/t9poBK8vce+h0ZWVlWbcdx9Fuu+2mcePG6Rvf+EanHqukpETjx4/X+PHjN7qNMUbjxo3TuHHjOvXYAAAAAIDulbcBkjHdn7XcPvE/Xbp/z4fHlMtG7HaYqv+4ZLO3Z96jLWPtFwFSyO9K0FsVlhTqst9cpst+c9lGtznu/ON03PnHdWNVwJdjCDt0tkcffdTvEgAAAAAAeShvA6SI09pdx9o8utI3Xx4H8oLneZJjZUNWedfbDwC6EAESuspHH32kOXPmSJL22msv7b///j5XBAAAAADIZfkbIAWMHGPkSQr4XUxn4XwTehDrWXmOlQ3x1gSAzWVlFcifbyboIWpqajRmzBi98cYbKi8vlyTV1dVp5MiR+vvf/67+/fv7WyAAAAAAICc5fhfQVcIBI8dIXh6N+eYGxBh26DHs/2fvvuOkKA8/jn9nZuv1wjXa0ZsUaQJiwYIYW+z+VIyYxER/dmOKib2hiS0xWGMQE4yJ0RijEQvRNDs29AcINix0uH7bZp7fH4QNK+0O7pjbu8/b175wZ2ef/e65c4fzvecZY2Rs04lraABoe8YYBS3W/kTbOu+881RfX6/3339f69ev1/r16/Xee++prq5O559/vt/xAAAAAABZqtOe+g07tmx1rgIpFbJkOtMbQnbzjNyIJ8tm/hEAtJQRBRLa3rx58/T8889r6NCh6W3Dhg3TrFmzdMghh/iYDAAAAACQzTrvDCT7P0vYmc5TuHhBW53o7SDLea6RF3b9jgEAWcXIKNB5f38HPvE8T8HglsVkMBjceM1CAAAAAAB2QqctkIK25NidawaSF7BYwQ4dhvGMEnlJv2MAQFZhBhLaw4EHHqgLLrhAX375ZXrbF198oYsuukgHHXSQj8kAAAAAANms0xZIlmUp4tjqTL9zaQKWDKuFoYPwjKdkPgUSALSGJUsBixlIaFu//OUvVVdXpz59+qh///7q37+/+vbtq7q6Ot1xxx1+xwMAAAAAZKlOfQYj4lja0InWfPOCFkvYocPw5MnNYwk7AGgNS5YcOX7HQCfTq1cvvfnmm3r++ee1ePFiSdLQoUN18MEH+5wMAAAAAJDNOu0MJEkqCNnyOtGUHROgQELH4BlPxhi5OZ1pjh8A7B6ORYGEtvG3v/1Nw4YNU11dnSzL0tSpU3XeeefpvPPO0/jx47XHHnvon//8p98xAQAAAABZqpMXSI46T3208RpIMkae4aQ9/OW5njzbk5fLZxEAWsPIKNC5J4BjN7r99tt15plnqqCgYIvHCgsL9d3vfle33nqrD8kAAAAAAJ1B5y6QgraMJNNJpu2YgCVji1lI8J2bcuU5nrw8PowA0FrMQEJbeeedd3TooYdu8/FDDjlECxYs2I2JAAAAAACdSacukPKDtgKWlOok57hN0JaxLBkuOwOfuSlXXsCTye0kBxcA7AbGmI0zkCxmIKFtrFq1SsFgcJuPBwIBrVmzZjcmAgAAAAB0Jp27QArZCtiWUl7nOMltApKxJI8pSPCZm3AVL4rLCnWmRSIBoH0ZGdmyFbbCfkdBJ9GjRw+9995723z83XffVVVV1W5MBAAAAADoTDp1gRR2bOUE7M4zAylgyVhiBhJ856VcNZXF/I4BAFnFk0eBhDZ12GGH6fLLL1cstuXP5ObmZl155ZU64ogjfEgGAAAAAOgMOv0aKsVhW+vjKb9jtIl0gdRJZlQhO3nGkytXqeLOcVwBwO7iyZNtUSCh7Vx22WV67LHHNGjQIJ177rkaPHiwJGnx4sWaNWuWXNfVT37yE59TAgAAAACyVacvkIrCjix1jmW2THjjNZA8CiT4yPM8eZYnt4ipcADQGp7ZOAMpZIX8joJOoqKiQi+99JLOPvtsXXrppTL/WebYsixNmzZNs2bNUkVFhc8pAQAAAADZqtMXSAUhW0ZGxhhZVnYXSVbQVipoyessa/IhK6USKblBT26x53cUAMgqnjwFrICCCvodBZ1IdXW1/vrXv2rDhg1atmyZjDEaOHCgiouL/Y4GAAAAAMhynb5A6hYJKGhbSnpSyPE7za5L5tgyNcz8gH/cREqpSEomz3Sa2X0AsDt48hS2wln/Cy3omIqLizV+/Hi/YwAAAAAAOhHb7wDtrTBkKxqwlegky77Fcmx5bud4L8hOqURKDd0bZTmcAAWA1vCMp6gV9TsGAAAAAABAi3T6Asm2LFXlBJTsJAVSKmqrk7wVZCHPeHKNq3hl3O8oAJB1PFEgAQAAAACA7NHpCyRJKo8GJFnpCwtnMzfiiCvPwC+pREpuwFWqgmUUAWBnROyI3xEAAAAAAABapEsUSN0ijgKWlMr+/khu1JYxRp6hRsLul4wnlQyn5Jby+QOAnRG2wn5HAAAAAAAAaJEuUSCVhB1FArYSneDaQW7UkmdZ8pgAAh+48ZQaq5pkBbn+EQC0xqZZ0CxhBwAAAAAAskWXKJAc21JF1FGiE0yaMFFHxpHczjCdClnFM55SxlWsKuZ3FADIOp48WbKUY+f4HQUAAAAAAKBFukSBJEkVOQFJJuuvg+RFbXm2JTfVCdowZJVkPKlUIKVEj5TfUQAg67hy5ViOciwKJAAAAAAAkB26TIFUlRNQ0LayfhaSCVlyHclwDh+7WaI5qXh+XF63LD+IAMAHrnHlyGEGEgAAAAAAyBpdpkAqCTsqCjmKZ/l1kCzbVjJiy3M5iY/dK5VMqq5vgyyH6x8BQGu5chWxIgpaQb+jAAAAAAAAtEiXKZAsy1KfgqBco6xfxi6ea8vjGkjYjVKplFwrpUSvhN9RACArucZVnp3ndwwAAAAAAIAW6zIFkiT1yA0qYEvJLJ+8E89xZLL8PSC7xJviSuQklapy/Y4CAFnJk6d8O9/vGAAAAAAAAC3WpQqksoijwpCjWJYvY5fKd+Rm+SwqZJdULKn6Xg2ywixfBwA7w5KlXDvX7xgAAAAAAAAt1qUKJMuy1Cc/KNeYrF7GLpXnyLOkVIppSGh/qVRKSSul5n4xv6MAQFba9HeOHDvH5yQAAAAAAAAt16UKJOk/y9hZlrL5EkJuviPXsZRKZvGbQNaIN8aUyE0o2TvldxQAyEqePNmylWNRIAEAAAAAgOzR5Qqk8qij/JCt5ixukLw8R27AkptgBhLal2c8JWNJ1QyoZfk6ANhJKaXkWA5L2AEAAAAAgKzS5Qok27I0oDCU1cvYWQFbsTxHHgUS2lkqkVIykFJsQNzvKACQtVImpbAVVq5FgQQAAAAAALJHlyuQJKlfQUhhx1bMzc4CSZKaCh25WZwf2SHeGFNzSbPcSspKANhZKZNSoV0oy2ImJwAAAAAAyB5dskAqDDnqlRfI6gIpmR9QFsdHFvCMp2QyqdpB9bIcTnoCwM4yMip2iv2OAQAAAAAA0CpdskCSpIGFYdmWpaSXnS1MMt+WMUaux8wQtI9YY0yJSFLxgQm/owBA1tq0XG6BXeBzEgAAAAAAgNbpsgVSj9yASsKOmlLZWcC4eQG5jqVUIjsLMHRsnvGUaIqrZkCtVOh3GgDIXp482bKVb+f7HQUAAAAAAKBVumyBZFuWBheF5BnJM9lXwngFzn8KpOwswNCxJWMJJQJJNQ1r9jsKAGS1lEkpYAWYgQQAAAAAALJOly2QJKlvQUjRgK3mVPYVSFbQVjzXlpekQELbizXE1VDVILeSzxcA7IqUUopYEUWsiN9RAAAAAAAAWqVLF0g5AVv9CoJKeCZ9jYJs0lToyEtmX250bMlkUkklVTu8XpZt+R0HALJayqRU5BTJsvh+CgAAAAAAskuXLpAkaUhRWCHHUszNviImURCQm4XFFzq2WF2zmoublerr+h0FALKekVGxXex3DAAAAAAAgFbr8gVSaSSg/gUhNbvZNwspWRSQKymVYpkxtI1UKqWEm9T6UTWygvy2PADsik1/r8i3831OAgAAAAAA0HpdvkCSpOElEUUcW81ZNgspWRJQKmApGWemCNpGc12TmoqblBic9DsKAGS9lFIKKKAip8jvKAAAAAAAAK1GgSSpOOxoQEFQsSybhWRybCWitlIxZiBh16VSKSVSCW0YVSMrzOwjANhVSZNUyA6p0C70OwoAAAAAAECrUSD9xx5ZOAvJsm3VdwvKTWZPZnRcTbVNaippVnwIs48AoC0kTVKlTqkcy/E7CgAAAAAAQKtRIP1HUdjRwMKQ4lk2CyleHJDrGXmGWUjYeclkUgkvofVjmH0EAG3FyKjUKfU7BgAAAAAAwE6hQNrMHiVhRRxbTansKZCSJUG5tqUUs5CwC5pqm9RY1qjEIGYfAUBb2PSLHcV2sc9JAAAAAAAAdg4F0mYKQ44GF4UU94y8LJmF5BY7SgUtJbkOEnZSrDmmhJXQ+gk1soLMPgKAtpBUUiErpGKHAgkAAAAAAGQnCqSvGFkaUVHIUUO2zOgJOWoqdOTGKZDQep7x1FzfrJq+tUr1cf2OAwCdRtIkFbWiyrVy/Y4CAAAAAACwUyiQviIasDWmLCIjKeFmR4nUUBqUm0XL7qHjaK5vVjwSV93Eelk2s48AoK2kTEplTpksi++tAAAAAAAgO1EgbUX/gpB65gbUmDIyWbCUXbI4INcYuR6zkNByKddVvDmmtSPXy3CNdwBoM5v+7lDilPicBAAAAAAAYOdRIG2FbVkaXx5VxLHUlAUze5IlAaUClpLxjp8VHUdTTaMaS5oU2zPudxQA6FRcubJlc/0jAAAAAACQ1SiQtqE0EtAexWElPMnt4LOQvHxHybClVIxr2KBlYk0xxRXXugkbpKjfaQCgc0mapEJWiBlIAAAAAAAgq1EgbceI0ohKI44akh27QLIcWw2lQaXiLGGHHXM9V831TVo/cIOSA1N+xwGATidu4ioLlCloBf2OAgAAAAAAsNMokLYj5FgaWxaRLSnmduxypqksKNcz8kzHzgn/NW5oVGNRk+onN8qyubg7ALSlTdc/qnAqfE4CAAAAAACwayiQdqA6L6iBRSE1pUyHXsouUR7aeB2kWMfNCP9tWrpuzd7rpDy/0wBA5+PKlSNHZU6Z31EAAAAAAAB2CQXSDliWpfHlUXWLBFSfMOnfLO5o3GJHsaitRBNLkmHr0kvXDdqg1ACulwUA7SFhEgrbYRU7xX5HAQAAAAAA2CUUSC0QcWztXRlV0JGaUh2zQLJsW7WVIaUSHTMf/OUZTw3rGtRQ0qT6vVm6DgDaS9IkVeFUKGAF/I4CAAAAAACwSyiQWqgqJ6iRJRElPSnpdcySJlYeVMoYuR38ek3Y/ZrrmxQLxrRmylqWrgOAdmKMkZFReaDc7ygAAAAAAAC7jAKpFUaVRtQrL6CGpCevAy5llywLKhW0FW9meTL8VzwWV3M8ptXj18rr3fE+twDQWaSUUkABrn8EAAAAAAA6BQqkVnBsS/tU5aow5Kg+2QGvh5QXUGORo1QTM5Cwkeu6aqpt1IZ+NYrtGfc7DgB0agmTUNSOqsgu8jsKAAAAAADALqNAaqW8oK29K3MUsKTGDng9pPrKkFIpT56hROrqPOOpYX29GkobVTulXlaA6x4BQHtKmqQqA5WyLf56hc7tiy++0PTp01VaWqpoNKoRI0bojTfeSD9ujNEVV1yhqqoqRaNRHXzwwVq6dKmPiQEAAAAAO4MzHDuhV15QY8uico0US3WsoiZeHlTKtuQmO165hd2rsaZRzeGY1hy4juseAUA72/SLG+UO1z9C57ZhwwZNnjxZwWBQTz/9tP7v//5Pt9xyi4qLi9P7/PSnP9UvfvEL3X333Xr11VeVm5uradOmKRaL+ZgcAAAAANBaAb8DZKvhJWE1JD0tXB+TbRmFnI4xuyPVLahkyFKiyVMw5PgdBz5prG9UzDRr1T5r5PWgTASA9pYwCYWskCoDlX5HAdrVTTfdpF69emn27NnpbX379k3/uzFGt99+uy677DJ9/etflyQ9+OCDqqio0OOPP67/+Z//2e2ZAQAAAAA7hxlIO8myLO1VHlXf/JAaUp5cr2OcpLeCturKgkrGXL+jwCex5piaY81aNWatEkOTfscBgC4hbuLq5nRTrp3rdxSgXT3xxBMaN26cTjjhBJWXl2v06NG677770o9//PHHWrlypQ4++OD0tsLCQk2YMEEvv/yyH5EBAAAAADuJAmkXOLalfatyVBUNqC7pyTMdo0Rqqggq5YnrIHVByWRSTXWNWjd4vZr3ismyO8bMOADozIwxMjLqEejhdxSg3X300Ue66667NHDgQD3zzDM6++yzdf7552vOnDmSpJUrV0qSKioqMp5XUVGRfuyr4vG46urqMm4AAAAAAP9RIO2iSMDW/j1yVRRyVJvwZDpAiZSoCCkVkBLN/mfB7pNyXTWsb1BN71rVTWmQ1UGWVQSAzi6ppAJWgOXr0CV4nqcxY8bohhtu0OjRo/Wd73xHZ555pu6+++6dHnPmzJkqLCxM33r16tWGiQEAAAAAO4sCqQ0Uhhzt1z1XOQFbdUnje4nkFjpqKggo0ZjyNQd2H9d11bC2TnXl9Vo/tVZWmPIIAHaXuImrwC5QkV3kdxSg3VVVVWnYsGEZ24YOHarly5dLkiorNxapq1atythn1apV6ce+6tJLL1VtbW369tlnn7VDcgAAAABAa1EgtZHKnIAmV+YoaFuq97lEsmxbNT1DSiY9lrHrAlzPVf26etV1q9faw9ZJ+X4nAoCuwxijlEmpV6CXLIvyHp3f5MmTtWTJkoxtH3zwgaqrqyVJffv2VWVlpebPn59+vK6uTq+++qomTZq01THD4bAKCgoybgAAAAAA/1EgtaG+BSHtW5WjQAcokeLdw0oGLJax6+Rcz1P92nrVF9drzdfWyRT5nQgAuhZXrhw5qghU7HhnoBO46KKL9Morr+iGG27QsmXL9NBDD+nee+/VOeecI0myLEsXXnihrrvuOj3xxBNauHChvvGNb6h79+46+uij/Q0PAAAAAGiVgN8BOpt+BSFJ0j9XNKk+aZQflC+/keyWbFzGLqc+pUiOs9tfH+3PM54a1tWpobBBq7+2TqbU70QA0PXETVw5do7KnDK/owC7xfjx4/WnP/1Jl156qa655hr17dtXt99+u0499dT0Pj/4wQ/U2Nio73znO6qpqdE+++yjefPmKRKJ+JgcAAAAANBaFEjtoCOUSJZtq7ZnSIXvNskznmyLyWadiet5alhbr4aCRq362lqZMmaaAYAfkiapfsF+cix+WQNdxxFHHKEjjjhim49blqVrrrlG11xzzW5MBQAAAABoa7QK7aRfB1jOLtY9rFRASsQoFzoT13VVv7ZO9YUNWnXoGpkK/vsCgB9c48qSpapAld9RAAAAAAAA2hwFUjvavESq86FEckscNeU7SjSkduvrov2kUinVra1TXWmdVh2xRl4V5REA+CVmYoraUQokAAAAAADQKVEgtbN+BSHtV5WjsGOpJuHJ240lkmXbqukVVjJp5Blvt70u2kcymVT9ujrVVtZp9RHrZLpRHgGAn5ImqV6BXgpaQb+jAAAAAAAAtDkKpN2gb0FIU3vmqTDkqDbhyfV234n/WPcQy9h1Aol4QvXr61XTs1Zrj1gvFfmdCAC6tpRJyZKlnoGefkcBAAAAAABoFxRIu0llTkCH9s5TRTSg2qSnhLt7Ch23JMAydlmuqbFZ9bX1Wt9vvdYdXiPl+Z0IABA3ceXauaoIVPgdBQAAAAAAoF1QIO1GhSFH03rlqV9+SI0pT7FU+y8rZ9m2anqyjF028oyn+g0Naow1aNWeq7Xha3VS1O9UAABjjJImqd6B3gpYAb/jAAAAAAAAtAsKpN0sErB1YI9cjSiJKO5JDUlPpp2vixTrHlLKkZIsY5c1XM9T/dp6NToN+nLKSjXu2ywraPkdCwAgKaWUHDnqGWT5OgAAAAAA0HlRIPnAsS1NrIhqQnlUlqTapJHXjiWSWxpQY5GjeD3L2GWDZDKpujW1qi+o15eHrVJyeEqWTXkEAB1FzMRU4BSo3Cn3OwoAAAAAAEC7oUDyiWVZGlEa0UE981QYslWTaL/rIlm2rQ19IkqkPLkey9h1ZE2NzapfX6eaHjVadfQaeb347wUAHYkxRq5x1SfYR7bFX6MAAAAAAEDnxcL9PuuVF1RJOF8vr2rSJ/VJJTyj3IAly2rbGSex3hElFjYpVu8qt5ATXh2N63lq3NCgmBXT2tHr1DipWVaIWUcA0NEklFDQCqpngOXrAAAAAABA50aT0AHkBjdeF2liRVSOZakm4cn12ng2Uq6jDT1CSjS5bTsudlkinti4ZF1Ovb6YumLj9Y4ojwCgQ4p5MZU6pSqyi/yOAgAAAAAA0K6YgdRB2Jal4SURlUcDemllk1Y1p5TjWIoE2q7ja6gOK/lpXImYq1DEabNxsXM846mprkmxREw1fWtVM6VOKpQsUR4BQEfkGU9GRv2D/dt8pjAAAAAAAEBHwwykDqY8GtDXeudpj+Kwkp5Um/DkmraZjZSsCqkp31GsPtUm42HnxWNx1a2uVb1drxX7rNSGw2ulQr9TAQC2p9k0K8fOUa9gL7+jAAAAAAAAtDtmIHVAYcfW5Moc9coL6o01Ma2LuQrZRjm7eG0ky7G1vk9Y+e80yjMeF//2get5aqppVNyNq6ZfrWon18mUMusIADo6Y4wSJqFBwUEKWSG/4wAAAAAAALQ7CqQOyrIsVeeHVJUT1MJ1Mb2/Ia6ahFFuQAo5O182xPpElPi/ZsUaXOXkUyDtTrGmZjXXx9RU0KS1E9YrMSQpaxf+WwIAdp+kkgpaQVWHqv2OAgAAAAAAsFtQIHVwIcfS2PKo+hQE9frqZn3emFLMNcoLWrJ3YjaSyQ+opjKo6BcJ5eQH2yExviqRTKq5pkkJJ671Q2tUP6lBKrCYdQQAWaTZa1ZloFKldqnfUQAAAAAAAHYLCqQsURoJ6JBeeVpWm9Cba2OqSbgK29ZOLWtX3yesbp8nlEy4CoacdkqMlOuqqaZRCS+h+qoG1YyvVaq3K8umOAKAbOIZT0ZG/YL9dmkpWQAAAAAAgGxCgZRFbMvSoKKweuUF9e66mJbUJLQh4SniWIo6LS+Skj3Cas5rVKQ+pWApBVJb84yn5romxeJxNRU3a/249UoMSskKMOsIALJRs2lWrp2rXsFefkcBAAAAAADYbSiQslA0YGtCRY6GFIf1/vq4ltZuLJKijqVIS4qkgK111WHlvdcsz3iyLa6F1BZcz1OsvknxWELx3LjW7b1esRFxKUJxBADZyhijhEloUHCQQlbI7zgAAAAAAAC7DQVSFisMOdq7MkfDisN6b31MH9YlVfOfGUk7KpKa+0QUX9KsWIOrnHwKpF3heq6a65uViCUUy41r/fgNG4ujAkkURwCQ1RJKKGgF1SfUx+8oAAAAAAAAuxUFUidQFHa0T1WuhhW7em99TB/VJVST8BSyLUUDluytFEmmKKiaypAinyeUkx/0IXX2S7kpNdfFlEzEFcuPa/3oDYrtkZDy/E4GAGgrzV6zegR6qMQu8TsKAAAAAADAbkWB1ImURBzt1z1Xw0rCWlIT10d1SdUmjGzLU07AVtDOLJLqBkRU8kVC8WZX4SjXQmoJz3hKxhKKN8aV8JKKF8S1fq8axYfGpVxmGwFAZ5IyKVmyNDA0sMXXGQQAAAAAAOgsKJA6oW6RgLpVBjS6m6eP6hL6oCah9XFXnslc3i5ZFVJ9SUCRDUkKpB1wPVexhpiSzQklgkk1VjWqdli9Uv1SUsQSS9UBQOfT6DWqxClRz0BPv6MAAAAAAADsdhRInVhOwNbwkoiGFYf1eWNKS2vi+rwxpZqEp4BlKRKwtGFARIWvNiiZ9BQMci2kzXnGU7w5rmRjQkmTUiKaUM3IWjUNjcmr8GTZFEcA0Fm5xpWR0aDQINkWPx8BAAAAAEDXQ4HUBdiWpd55QfXOC6om7uqjuoSW1SVUn/DUUBlSeZ6t4IaEisojfkf1nWc8JWIJJZsSSqZSSoaTauzRpIYBDUoMSKaXqbMojgCgU2s2zcqz81QdrPY7CgAAAAAAgC8okLqYorCjMWVRjeoW0aqmlD5rSGrVyHpF3qhVzepmOcGgQtGgguFgl/mNa9dzlWhOKBVLKummlAqm1FTWrPqB9Yr3ScoUGWYbAUAXYoxR0iQ1IjxCISvkdxwAAAAAAABfUCB1UY5lqXtuUN1zg2osrdCL3d+X86ml4k+KFK4LK1DnyLECCoQDCkVDcgJOpymUPOMplUgpEUsolUgpZVJywyk1VTarsbpJ8T4JeaWbSiNmGwFAV9NsmhW1ouoX7Od3FAAAAAAAAN9QIEG5gai69+uud3u8q/jeSdnrLAVXBBT9MqLcL3IVrAvKcR0FLEdOOKBAKKBAKCjHzo5CKeW6SsYTcuOu3KQrVym5AVeJnKTqBjYo3jOuVHdXyv/vcyiNAKBrMsYobuIaFhqmXDvX7zgAAAAAAAC+oUCCJGlgaKA+SHygmGKKlkeVKE8pMapBtckG2Ws2FUpR5ayOKtDsyKlzZMuRYztyQracYEBOwPF1ppJnPLkpV6lESm7SlZd05RpXruXJDaaUKEiqoapRyfKkUmWu3G6erABFEQDgv+ImrpAV0oDQAL+jAAAAAAAA+IoCCZKkPDtPfYJ9tDixWBETkWX9p1gJSl53o3j3pOJjk9qQqpVda8lZ7yiwzlFkTUTR1VEF4o7sJlu2a8u2LNnGke1YsgO2LMeWZVuybVu2s/FmWVaLiibPeJIk4xl5xpOX8uS5m25GxvU2Pma5Gx93jNyAq2RuSrFuzYp1SyjVLSW3zJPJ/e+ydBKzjAAAmYwxipmY+gT7qNgp9jsOAAAAAACAryiQkDYoNEgfJT9S3MQVsSJb3ccKWDKlUqrUVWqgq5gS2uDWymqyZNdbsuttOfWOAnWOwhvCCjUE5cQd2UlLlmfJ8uz//Glp8/5mU2FlSTKSZMx//pSMZSRLMraRZ3syjpEX8JQsSCmZl1QyN6lUgSs335VX4Mkt9KSIMsqijWNTGAEAti2hhAIKaHBosN9RAAAAAAAAfEeBhLRip1jVgWotTS5V2IT/OwtpByzHkvIlL9/I23iFIcUlNapZkmRSRkpIVtySHbdkxSxZ8f+USJ5kefrPn9bG9siSTMDIc4zkbPx3OZIJGXlRI0WNTGjLgiidh6IIANBKxhg1e83qHeytcqfc7zgAAAAAAAC+o0BChqHhoVqeWq6YiSlqRdtkTCtgbfyk5UiejP4zx2hXRqQiAgC0qYQSClgBDQsNa/EvUAAAAAAAAHRmO74IDbqUYqdY1cFqxUxMxuxq0QMAQMe3afZRj0APlTllfscBAAAAAADoECiQsIWhoaEKW2HFTMzvKAAAtLuEYfYRAAAAAADAV1EgYQtFTpH6BvsyCwkA0OkZY9RkmtQj0EPdnG5+xwEAAAAAAOgwKJCwVUNCQ5iFBADo9BImoaAVZPYRAAAAAADAV1AgYasKnUL1C/ZjFhIAoNPaNPuoV6AXs48AAAAAAAC+ggIJ27RpFlKzafY7CgAAbS5u4gpZIQ0JDWH2EQAAAAAAwFdQIGGbCpwC9Q/2V9zEmYUEAOhUjDFqNs3qGeipskCZ33EAAAAAAAA6HAokbNfQ8FDl2DlqMk1+RwEAoM00m2aFrbBGhEf4HQUAAAAAAKBDokDCduXZeRoSGqKkScoznt9xAADYZZ7xFDdxDQwOVJFT5HccAAAAAACADokCCTs0KDRIhXahGrwGv6MAALDLGk2j8uw8DQsP8zsKAAAAAABAh0WBhB0KW2HtEd5DRkYpk/I7DgAAO801rlzjalhomKJ21O84AAAAAAAAHRYFElqkb7CvypwyZiEBALJag9egYqdYA0MD/Y4CAAAAAADQoVEgoUUcy9HIyEg5chQ3cb/jAADQakmTlCSNCI9QwAr4nAYAAAAAAKBjo0BCi1U5VeoV7KUmr0nGGL/jAADQYsYYNXqNqgxUqnegt99xAAAAAAAAOjwKJLSYZVkaER6hsBVWs2n2Ow4AAC0WN3EFrIBGhkfKtvjrDwAAAAAAwI5wBgWtUuwUa2BwoOImLs94fscBAGCHjDFqNs2qDlSr3Cn3Ow4AAAAAAEBWoEDqBGbMmKG8vLzd9nrDwsOUb+erwTTsttcEAGBnNZpG5dq5GhkZKcuy/I4DAAAAAACQFSiQNnPnnXfKsixNmDBhu/utWrVKl1xyiYYMGaKcnBzl5uZq7Nixuu6661RTU5Peb8qUKbIsa6u3xYsX7zBPLBbTbbfdpgkTJqiwsFCRSESDBg3Sueeeqw8++GBX3+5Oi9pRjQyPlDEmfUFyAAA6opRJKWVSGh4arnw73+84AAAAAAAAWSPgd4COZO7cuerTp49ee+01LVu2TAMGDNhin9dff12HHXaYGhoaNH36dI0dO1aS9MYbb+jGG2/UP/7xDz377LPp/Xv27KmZM2duMU737t23m2Xt2rU69NBDtWDBAh1xxBE65ZRTlJeXpyVLlujhhx/Wvffeq0QisYvveOf1C/bTp8lP9XnqcxXZRfxGNwCgwzHGqMFrULlTroGhgX7HAQAAAAAAyCoUSP/x8ccf66WXXtJjjz2m7373u5o7d66uvPLKjH1qamp0zDHHyHEcvfXWWxoyZEjG49dff73uu+++jG2FhYWaPn16q/PMmDFDb731lv74xz/quOOOy3js2muv1U9+8pNWj9mWbMvW6MhorW1cq2bTrBwrx9c8AAB8VczEFLSCGh0ZLcdy/I4DAAAAAACQVVjC7j/mzp2r4uJiHX744Tr++OM1d+7cLfa555579MUXX+jWW2/dojySpIqKCl122WW7nOXVV1/VU089pW9961tblEeSFA6HdfPNN2+x/YsvvtDRRx+tvLw8lZWV6ZJLLpHruhn73Hzzzdp7771VWlqqaDSqsWPH6o9//OMWY1mWpXPPPVePP/64hg8frnA4rD322EPz5s1L71PilGhwaLDe+cc7uni/i3V8t+P13ZHf1bxfz9Pvbvidvp7/9S3GffHhF3XxvhfrhLITdGrvU/WzGT/Tms/X7MyXCQCAbfKMp5iJqX+wvyoCFX7HAQAAAAAAyDoUSP8xd+5cHXvssQqFQjr55JO1dOlSvf766xn7PPHEE4pGozr++ONbPK7rulq7dm3GraGhYbvPeeKJJyRJp512WqteZ9q0aSotLdXNN9+s/fffX7fccovuvffejP1+/vOfa/To0brmmmt0ww03KBAI6IQTTtBTTz21xZj/+te/9L//+7/6n//5H/30pz9VLBbTcccdp3Xr1qX3SfxfQrccf4tq19Xq5B+frINPO1i/v/H3evXJV7cY7w8/+4Nu/87tqupfpW/O/KaO/N8j9e6L7+rHh/5YDTXb/5oAANAaDV6DCuwCjQiP8DsKAAAAAABAVmIJO0kLFizQ4sWLdccdd0iS9tlnH/Xs2VNz587V+PHj0/stWrRIgwYNUigUavHYixcvVllZWca2008/XQ888MA2n7No0SJJ0ogRLT/pFYvFdNJJJ+nyyy+XJJ111lkaM2aM7r//fp199tnp/T744ANFo9H0/XPPPVdjxozRrbfeqsMPP3yLHP/3f/+n/v37S5IOOOAAjRo1Sr/73e907rnnSpKuu+o6BZyArnzmSlX0qFDYCmufY/fROePOyRhr9fLV+t31v9Opl5+qE75/Qnr7pKMm6aLJF+np+57O2A4AwM5KmqSMjEaGRypqR3f8BAAAAAAAAGyBGUjaOPuooqJCBxxwgKSNy7eddNJJevjhhzOWgKurq1N+fn6rxu7Tp4+ee+65jNsPfvCD7T6nrq5Oklr9WmeddVbG/X333VcfffRRxrbNy6MNGzaotrZW++67r958880txjv44IPT5ZEkjRw5UgUFBekxXdfV888/r2OOPkZ79t5TTV6TjDGq6l+lMVPHZIz18hMvy3hG+xy7j+rW1qVvxeXFqupfpYX/XNiq9woAwNYYY9TgNah7oLv6Bvv6HQcAAAAAACBrdfkZSK7r6uGHH9YBBxygjz/+OL19woQJuuWWWzR//nwdcsghkqSCggLV19e3avzc3FwdfPDBrXpOQUGBJKm+vl5FRUUtek4kEtliplNxcbE2bNiQse3JJ5/Uddddp7ffflvxeDy93bKsLcbs3bv3Fts2H3P16tVqbm7WgAEDtGdkT610V6rBNCjfyldVv6qM5634cIWMMTprz7O2GFOSAsEu/1EEALSBJtOkiBXRmMgY2Ra/JwMAAAAAALCzuvxZ+7/97W9asWKFHn74YT388MNbPD537tx0gTRkyBC9/fbbSiQSrVrGrrWGDBkiSVq4cKH23XffFj3HcZwd7vPPf/5TRx11lPbbbz/deeedqqqqUjAY1OzZs/XQQw+1eExjzBbb8uw8jQiP0GvNrylpkls87nmeLMvSFY9dIdvZ8oReNJclhgAAuyZlUkqapMZExqjYKfY7DgAAAAAAQFbr8gXS3LlzVV5erlmzZm3x2GOPPaY//elPuvvuuxWNRnXkkUfq5Zdf1qOPPqqTTz653TIdeeSRmjlzpn7729+2uEBqiUcffVSRSETPPPOMwuFwevvs2bN3arzy8nJFIhEtW7ZMkjQwOFBfpr7U8uRyrfhoRca+lX0rZYxRRXWFegzssfNvAgCArTDGqN6rV1WgSkNDQ/2OAwAAAAAAkPW69Nouzc3Neuyxx3TEEUfo+OOP3+J27rnnqr6+Xk888YSkjdcYqqqq0ve+9z198MEHW4y3evVqXXfddbuca9KkSTr00EP1q1/9So8//vgWjycSCV1yySWtHtdxHFmWlXFdp08++WSrr9HS8Q4++GA9/vjj+vLLL2VbtsZGxqru4zq9+VzmNZUmHTVJtmPr4Rsf3mIGkzFGdevqdioDAACS1GgaFbEiGh8ZL8fa8axcAAAAAAAAbF+XnoH0xBNPqL6+XkcdddRWH584caLKyso0d+5cnXTSSSouLtaf/vQnHXbYYdpzzz01ffp0jR07VpL05ptv6ne/+50mTZrUJtkefPBBHXLIITr22GN15JFH6qCDDlJubq6WLl2qhx9+WCtWrNDNN9/cqjEPP/xw3XrrrTr00EN1yimnaPXq1Zo1a5YGDBigd999d6dyXnXVVXr22Wc1efJknX322XJdVz//5c/VY2gPLV+4PL1fVb8qnXr5qfrNVb/R6k9Xa8IRExTNj2r1J6v1yl9e0SFnHKJjLjhmpzIAALq2pEkqZVLaM7InS9cBAAAAAAC0kS5dIM2dO1eRSERTp07d6uO2bevwww/X3LlztW7dOpWWlmrChAl677339LOf/UxPPfWUfvOb38i2bQ0dOlQ/+tGPdO6557ZJtrKyMr300ku688479fvf/14/+clPlEgkVF1draOOOkoXXHBBq8c88MADdf/99+vGG2/UhRdeqL59++qmm27SJ598stMF0tixY/X000/rkksu0eWXX65evXrpuquv03MLn9OKpSvkGS99EfPjv3e8egzooSdmPaHf3/h7SVK3Ht2050F7aq/D9tqp1wcAdG3GGDV4DeoR6KHBocF+xwEAAAAAAOg0LPPV9cSANnDk14/UG++9oZ+9+TMVOAV+xwEAdFINXoOCVlBTc6aqyCnyOw6ANlBXV6fCwkLV1taqoIC/RwKdwc83/NzvCECGC4pb/0u5ADq+q6++2u8IQIYrr7zS7wjb1NL/7+rS10BC22hubs64v3TpUj3z9DPaf8r+kqS4ifsRCwDQySVNUq5xNSI8gvII8MmNN94oy7J04YUXprfFYjGdc845Ki0tVV5eno477jitWrXKv5AAAAAAgJ3SpZewQ9vo16+fZsyYoX79+unTTz/VXXfdpVAopGt+eI1WB1frw+SHCtrB9FJ2AADsqk1L1/UK9NKg4CC/4wBd0uuvv6577rlHI0eOzNh+0UUX6amnntIjjzyiwsJCnXvuuTr22GP173//26ekAAAAAICdQYGEXXbooYfqd7/7nVauXKlwOKxJkybphhtu0KBBg9TT66m17lrVe/UqdAr9jgoA6CTqTb1y7VyNi4zjFxQAHzQ0NOjUU0/Vfffdp+uuuy69vba2Vvfff78eeughHXjggZKk2bNna+jQoXrllVc0ceJEvyIDAAAAAFqJMy7YZbNnz9Ynn3yiWCym2tpazZs3T2PGjJEk5dg5GhsZK8dy1Ow172AkAAB2LObFZBlLY8JjuM4e4JNzzjlHhx9+uA4++OCM7QsWLFAymczYPmTIEPXu3Vsvv/zyVseKx+Oqq6vLuAEAAAAA/EeBhHbXK9hLQ0NDFTdxpUzK7zgAgCzmGlfNplkDQgPUN9jX7zhAl/Twww/rzTff1MyZM7d4bOXKlQqFQioqKsrYXlFRoZUrV251vJkzZ6qwsDB969WrV3vEBgAAAAC0EgUSdosR4RGqClSp3quXMcbvOACALGSMUb1Xr3KnXKMjo2VZlt+RgC7ns88+0wUXXKC5c+cqEom0yZiXXnqpamtr07fPPvusTcYFAAAAAOwaCiTsFgEroAmRCcqz81Tv1fsdBwCQhRpMgyJWRBOiExSyQn7HAbqkBQsWaPXq1RozZowCgYACgYD+/ve/6xe/+IUCgYAqKiqUSCRUU1OT8bxVq1apsrJyq2OGw2EVFBRk3AAAAAAA/qNAwm5T4BRoXGScLFlcDwkA0CpxE5cxRqMjo1XilPgdB+iyDjroIC1cuFBvv/12+jZu3Dideuqp6X8PBoOaP39++jlLlizR8uXLNWnSJB+TAwAAAABaK+B3AHQtvQO9NTg0WP+X+D8FTVABi48gAGD7XOOqyWvSwOBADQgO8DsO0KXl5+dr+PDhGdtyc3NVWlqa3v6tb31LF198sUpKSlRQUKDzzjtPkyZN0sSJE/2IDAAAAADYSZy9x25lWZZGRUZpnbtOK92VKrKLuIYFAGCbNl33qNQp1djoWH5mAFngtttuk23bOu644xSPxzVt2jTdeeedfscCAAAAALQSBRJ2u6AV1MToRD3X9JzqvXoVOKxzDwDYukbTqLAV1oTIBIWtsN9xAGzFiy++mHE/Eolo1qxZmjVrlj+BAAAAAABtgmsgwReFTqHGRsZyPSQAwDbFvbg842nPyJ4qC5T5HQcAAAAAAKBLoUCCb/oE+mhoaKjiJq6kSfodBwDQgaRMSs2mWQNDAzUoOMjvOAAAAAAAAF0OBRJ8s+l6SL2DvdXgNcg1rt+RAAAdgGc81Xv1qgxUakxkDNc9AgAAAAAA8AEFEnzlWI4mRiaqm9NN9V69jDF+RwIA+MgYs/H6eHaBJkUnKWgF/Y4EAAAAAADQJVEgwXcRO6K9o3srx86hRAKALq7RNCpoBTUxOlH5dr7fcQAAAAAAALosCiR0CMVOsfaK7CXbstVsmv2OAwDwQcyLyTOeRkdGqypQ5XccAAAAAACALo0CCR1G72BvjQiNUNIklTAJv+MAAHajpEkqZmIaFBqkQcFBfscBAAAAAADo8iiQ0KHsEd5DfYN91eg1yjWu33EAALuBZzw1eA3qEeihMZExsizL70gAAAAAAABdHgUSOhTbsjU+Ol7lTrnqvDp5xvM7EgCgHRljVOfVqdQp1aToJAWsgN+RAAAAAAAAIAokdEBhK6x9cvZRkV2kOq9Oxhi/IwEA2sGm8ijfztc+0X2UY+f4HQkAAAAAAAD/QYGEDinfztfknMnKsXMokQCgEzLGqN6rV9gKa+/o3ipyivyOBAAAAAAAgM1QIKHD6uZ006ToJAWtoBpMg99xAABtqMk0ybEcTYhOUEWgwu84AAAAAAAA+AoKJHRoPQI9ND4yXjJSk9fkdxwAQBto9prlGld7hvdUdbDa7zgAAAAAAADYCgokdHj9Q/01KjJKSZNUzIv5HQcAsAsSJqG4iWtoaKiGhIb4HQcAAAAAAADbQIGErLBHaA8NDg1WzMSUMAm/4wAAdkLKpNToNapfsJ9GR0bLsiy/IwEAAAAAAGAbKJCQFSzL0tjIWPUJ9lGj16iUSfkdCQDQCq5xVe/Vq2egpyZEJ8i2+CsIAAAAAABAR8bZG2QNx3I0MTpR3QPdVe/VyzWu35EAAC3gGld1Xp3KnXLtHd1bQSvodyQAAAAAAADsAAUSskrICmmf6D4qd8pV59XJM57fkQAA2+EZT3Venbo53bRfzn6K2lG/IwEAAAAAAKAFKJCQdaJ2VPvl7KdSp1S1Xi0lEgB0UJ7xVOvVqsQu0X45+ynXzvU7EgAAAAAAAFqIAglZKdfO1X45+6nYLmYmEgB0QJtmHhXZRdovZz/l2/l+RwIAAAAAAEArUCAhaxXYBdovZz8V2AXMRAKADsQYozqvTvl2vvbL2U+FTqHfkQAAAAAAANBKFEjIakVOUbpEqvPqZIzxOxIAdGnGGNV6tcqz87Rvzr4qdor9jgQAAAAAAICdQIGErFfibLy2Rp6dp1qvlhIJAHyyaeZRjp2jfaL7qJvTze9IAAAAAAAA2EkUSOgUSp1S7RvdV7l2LiUSAPhgU3kUtsPaJ7qPygPlfkcCAAAAAADALqBAQqdRFijLKJG4JhIA7B6byqOIHdE+0X1UGaj0OxIAAAAAAAB2EQUSOpXyQLn2z9lf+Xa+6rw6SiQAaGebrnmUY+do3+i+6h7o7nckAAAAAAAAtAEKJHQ63ZxumpIzRYV2ITORAKAdecZTrVerPDtP+0X3Y+YRAAAAAABAJ0KBhE6p2CnWlJwpKrFLVOvVyjWu35EAoFPZVB4V2AXaP2d/lQXK/I4EAAAAAACANkSBhE6r0CnUlNwp6uZ0U51XR4kEAG1kU3lUZBdp/5z9VeqU+h0JAAAAAAAAbYwCCZ1avp2vKTlTVO6Uq86rU8qk/I4EAFnNNa5qvVqVOCU6IOcAFTvFfkcCAAAAAABAO6BAQqeXa+dqSs4UVQYqVe/VUyIBwE5yjas6ry59rbkCp8DvSAAAAAAAAGgnFEjoEqJ2VPtH91ePQA/Ve/VKmITfkQAgqyRNUnVenSqcCk3JmaJ8O9/vSAAAAAAAAGhHFEjoMiJ2RPvl7Kd+wX5q8poU82J+RwKArBA3cTV6jaoOVuuA3AOUa+f6HQkAAAAAAADtLOB3AGB3Clkh7R3dW1ErqsWJxXI9VzlWjizL8jsaAHRIzV6zEiahQaFBGhcZp4DFXx0AAAAAAAC6AmYgoctxLEdjI2M1JjJGRkb1pl7GGL9jAUCHYoxRg9eglElpZHik9orsRXkEAAAAAADQhVAgoUuyLEvDwsO0d3RvBRVUnVdHiQQA/2GMUZ1XJ1u29orupZHhkbIt/soAAAAAAADQlfCrxOjS+gT7KGJF9FLzS6r1alVgF3CSFECX5hlPdV6dcuwcTYxMVM9gT78jAQAAAAAAwAecKUeXVxmo1AE5B6jYKVatV6uUSfkdCQB84Ro3XabvH92f8ggAAAAAAKALo0ACJBU7xTow50B1D3RXvVevuIn7HQkAdquESajOq1O5U64Dcw5UWaDM70gAAAAAAADwEQUS8B+5dq6m5EzRoNAgxbyYGr1GrosEoNMzxqjJa1Kz16x+wX46MPdAFTgFfscCAAAAAACAzyiQgM0EraAmRiZqXGScLFmq8+rkGc/vWADQLowxqvfq5cnTnpE9NTk6WWEr7HcsAAAAAAAAdAABvwMAHY1lWRoaHqpCp1CvNr+avh6IYzl+RwOANuMaV/VevXLsHO0V2Uu9g739jgQAAAAAAIAOhBlIwDZ0D3TXQTkHqcKpUJ1Xx3WRAHQaSZNUnVenUqdUB+UcRHkEAAAAAACALVAgAdtR4BTowNwDNTA4kOsiAegUmr1mNXqNqg5W66Ccg1TsFPsdCQAAAAAAAB0QBRKwAyErpEnRSRobGStJXBcJQFYyxqjOrVPKpDQiPEL7RvdVxI74HQsAAAAAAAAdFNdAAlrAsiwNCw9ToV2o12KvqdarVZ6dp6AV9DsaAOxQyqRU79Urz87T2MhYVQeqZVmW37EAAAAAAADQgTEDCWiFHsEempo7Vb0CvdToNarJa2JJOwAdWrPXrAavQd0D3TU1Z6r6BPtQHgEAAAAAAGCHKJCAVsqz87R/zv4aHRktI8OSdgA6JM94qnVr5crViPAIHZBzgAqcAr9jAQAAAAAAIEuwhB2wExzL0YjwCJU5ZXq1+VXVeDXKtXMVskJ+RwMAJU1SDV6DCuwCjYuMU69gL78jAQAAAAAAIMswAwnYBZWBSk3N3bgkVLPXrEavkSXtAPjGGKMmr0mNXqN6BnpuXHKT8ggAAAAAAAA7gQIJ2EU5do72je6rcZFxsmWr1quVa1y/YwHoYjzjqc6rk5HRqPAoTcmZojw7z+9YAAAAAAAAyFIsYQe0AduyNTQ8VN2cbno19qrWuesUsSKKWBEuVg+g3cW8mJpNs4rtYo2LjlP3QHe/IwEAAAAAACDLMQMJaENlgTIdknuI9gjtIVeu6rw6ecbzOxaATsoznmrdWiVNUkNCQ3RI7iGURwAAAAAAAGgTzEAC2ljICm2cARDsrgXNC7TB27BxNpId8TsagE4kbuJq8ppUZBdpTGSMegZ6MuMRAAAAAAAAbYYCCWgn3QPdVZpXqndi72hZYplq3Vrl2/myLSb+Adh5nvFU79XLlq2BwYEaHRmtqB31OxYAAAAAAAA6GQokoB2FrbDGR8arR6CHFsQ2zkaKWlFmIwHYKQmTUKPXqAK7QKMjo1UdqGbWEQAAAAAAANoFBRLQzizLUo9gD5U6pXonvnE2UtyNMxsJQIt5xlOD1yBJ6hfspzGRMcq1c31OBQAAAAAAgM6MAgnYTSJ2RHtF9lL3QHe9GXtTNV6NwlZYUSvKDAIAW2WMUdzE1WyaVWAXaFR4lPoG+/I9AwAAAAAAAO2OAgnYjSzLUq9gL5UHyvV+7H19kPxAtV6tcu1cBa2g3/EAdCCucVXv1StgBTQkNEQjwyO51hEAAAAAAAB2GwokwAdhK6wx0THqHeqtt2JvaWVqpWzLVq6Vy7J2QBdnjFGTaVLSJNXN6abRkdGqClT5HQsAAAAAAABdDAUS4KNuTjcdlHOQPkx+qIXxhar1ahW1ogpbYZaoArqghEmo0WtU1IpqRGSEhoSGKGDxoxoAAAAAAAC7H2elAJ/Zlq2BoYHqEeihd+Pv6qPkR4p5MeXZeZw4BroI17hq8Bpky1afYB+NDo9WgVPgdywAAAAAAAB0YZydBjqIHDtHE6MT1SfYR2/F3tIad40cy2FZO6ATM8ao0TQqZVIqtos1KjJKvQK9mIEIAAAAAAAA33FWGuhgKgOVmpo7VeMj4xWxIqr1atXkNckY43c0AG3EGKNmr1k1Xo1CVkhjI2M1LW+aegd7Ux4B6NBmzpyp8ePHKz8/X+Xl5Tr66KO1ZMmSjH1isZjOOecclZaWKi8vT8cdd5xWrVrlU2IAAAAAwM6iQAI6oIAV0NDwUB2We5hGhEbIkqUar0ZxL06RBGS5hEmoxquRkdGw0DB9Lfdr2iO8h0JWyO9oALBDf//733XOOefolVde0XPPPadkMqlDDjlEjY2N6X0uuugi/eUvf9Ejjzyiv//97/ryyy917LHH+pgaAAAAALAzWMIO6MCidlRjomPUL9RP78Xf0/LUcjV7zcq1cxW0gn7HA9AKKZNSo9coW7aqg9UaGR6pEqfE71gA0Crz5s3LuP/AAw+ovLxcCxYs0H777afa2lrdf//9euihh3TggQdKkmbPnq2hQ4fqlVde0cSJE/2IDQAAAADYCcxAArJAkVOkydHJOjDnQFUFqtTsNavWrZVrXL+jAdgBz3iq8+rU6DWqm9NNU3KmaP/o/pRHADqF2tpaSVJJycbvaQsWLFAymdTBBx+c3mfIkCHq3bu3Xn75ZV8yAgAAAAB2DjOQgCxhWZYqA5Uqd8r1aepTvRd/TxvcDXIsR7lWrmyLPhjoSDzjqck0KWVSKrALtEdkD/UL9pNjOX5HA4A24XmeLrzwQk2ePFnDhw+XJK1cuVKhUEhFRUUZ+1ZUVGjlypVbHScejysej6fv19XVtVtmAAAAAEDLUSABWca2bPUN9lXPQE8tSyzT4sRi1Xq1ClpB5Vg5FEmAzzYvjvLsPA0OD9aA0ACFrbDf0QCgTZ1zzjl677339K9//WuXxpk5c6auvvrqNkoFAAAAAGgrnGkGslTQCmpoeKgOyztM4yLjFLbCqvPq1OA1yDOe3/GALscznhq8BtV6tQpbYY2JjNFhuYdpj/AelEcAOp1zzz1XTz75pF544QX17Nkzvb2yslKJREI1NTUZ+69atUqVlZVbHevSSy9VbW1t+vbZZ5+1Z3QAAAAAQAsxAwnIcmErrD3Ce6h/sL+WJpdqSWIJM5KA3WjzGUe5dq5GhEdoYHCgInbE72gA0OaMMTrvvPP0pz/9SS+++KL69u2b8fjYsWMVDAY1f/58HXfccZKkJUuWaPny5Zo0adJWxwyHwwqHKdoBAAAAoKOhQAI6iYgd0YjwCA0IDtCy5DJ9kPhAdV6dAlaAIgloB57x1GyalTCJdHE0IDhAUTvqdzQAaDfnnHOOHnroIf35z39Wfn5++rpGhYWFikajKiws1Le+9S1dfPHFKikpUUFBgc477zxNmjRJEydO9Dk9AAAAAKA1KJCATiZqR9MzIDYvkmzLVq6VK8dy/I4IZDXXuGoyTXKNqxw7R8NCwzQoNIjiCECXcNddd0mSpkyZkrF99uzZmjFjhiTptttuk23bOu644xSPxzVt2jTdeeeduzkpAAAAAGBXUSABnVTEjmh4eLgGBgfqo+RHWppYqlqvVpKUY+coaAV9Tghkl6RJqslrkiTl2/kaFB6kvsG+FEcAuhRjzA73iUQimjVrlmbNmrUbEgEAAAAA2gsFEtDJhe2whoaHamBooD5LfaYP4h9orbtWjWpUxIoobIVlWZbfMYEOyRijhBJq9pply1Y3p5sGhQapOlitgMWPUAAAAAAAAHRenP0CuoiAFVDfYF/1CfTRSnelPkh8oC9TX6rGq1HYCitqRSmSgP8wxihmYoqZmIJWUD0DPTU4NFhVgSquJwYAAAAAAIAugQIJ6GIsy1JVoEpVgSptcDdoWWKZPk5+rBqvRgEroKgVZWYFuizXuGo2zUqapMJWWINCgzQgOEDdnG4UrAAAAAAAAOhSOEsMdGHFTrHGR8drWHiYPk5+rA8TH6rOq5ORYXk7dBnGGCVMQs2mWZYs5dl52iO0h/qG+qrALvA7HgAAAAAAAOALCiQAyrVzNTw8XENCQ/Rl6kt9nPxYK1IrVOvVyrEcZiWhU9p8tlHICqlXsJf6BfupR6AHn3cAAAAAAAB0eZwhA5AWsALqHeyt3sHeqnPr9GnqU32U+IhZSeg0Ns02ipmYJKVnG1UHq1XkFPkbDgAAAAAAAOhAKJAAbFWBU6ARzggNDQ3NmJW06VpJESuigAKUSejwjDFKKaWYiSllUgpZIXUPdFe/UD/1DPRU0Ar6HREAAAAAAADocCiQAGzXV2clLU8t18fJj1Xn1imllIJWcGOZxJJf6GA2X6IuoIDy7Xz1CfdRr0AvFdlFlJ8AAAAAAADAdnDGF0CLFTgFGu4M17DQMK1z1+mz5Gf6NPWpGr1GuXIVskKKWBE5luN3VHRRnvEUMzElTEKWLOXauRocHKwewR4qd8plW7bfEQEAAAAAAICsQIEEoNVsy1ZZoExlgTKNMqO0yl2lz5Ofa3lquRq8BhmZdJnECXu0N894ipu44iYuS5YidkQDgwPVK9BLlYFKZscBAAAAAAAAO4GzagB2iWM56h7oru6B7hptRmtFaoU+S36mL1JfqM6rkyQFraDCVpgT+WgzrnEVMzElTVKSFLbCqg5Wq3ewt7oHuitshX1OCAAAAAAAAGQ3zuYCaDNBK5i+XlLMi2mVu0orUyv1ReoLNXlN8uTJsRyFrbCCCnINGrSYMUYppRQzMbnGlS1bUTuqPsE+qgpUqdKpVMSO+B0TAAAAAAAA6DQokAC0i4gdUbVdrepgtVImpbXuWq1MrdRnqc9U79WryTTJkqWwFVbICrHUHbbgGU9Jk1TcxDeWj3KUZ+epV7CXKoOVKnfKmdUGAAAAAAAAtBPOvAFodwEroMpApSoDlRplRqnGq9HK1Ep9nvpc69x16aXuHMtRyAoppBCzk7ogY4ySSiphEkqZlCQpZIXUzemmnsGeqgxUqsQuoWwEAAAAAAAAdgMKJAC7lWVZKnaKVewUa2h4qBq9Rq1x12htaq1WuCvU4DWo2TRL2lg8hawQy911UpuWpUuYRPpaRkErqFwrV92D3VUWKFM3p5tyrVz++wMAAAAAAAC7GQUSAF/l2rnKtXPVJ9hHxhjVe/Va667VGneNVqRWqMk0qck0SdpYLgStoAIKMAslC22aYZQ0yXRh5MhR1I6qOlCt8kC5ypwyFdgFFEYAAAAAAACAzyiQAHQYlmWpwClQgVOgfuonz3iq9Wq11l2r1anVWu2uVszE0oWSJSujVKJ06DiMMXLlKmVSSiop17iSNs4qi1gR9Qz0VFmgTGVOmYrtYgpBAAAAANjM0osW+R0ByDDwtqF+RwDgAwokAB2Wbdnp5e4GhgamZyht8Daoxq3RGneN1rvrFfNicuXKyChgBRRUUAErIEcOpdJusHlZlFIqff0iW7aCVlDFdrHKnXKVOCUqcUpUYBdQGAEAAAAAAAAdHAUSgKyx+Qyl6mC1JCllUqrxalTj1mi9u15r3DWq9+rV7DXL1cZZL5YsBayAAgooYAVky6ZY2gnGGHny0iVRyqRkZCRtXIrOsRzlWXkqC5ZtLP7sYhU5RQpbYZ+TAwAAAAAAAGgtCiQAWS1gBdTN6aZuTrf0tpgXU71Xn75t8DZog7tBcRNX3IvLkyfpv8XSpvLDkdPlZ8YYY2S0cUaRa9z0n5u+Zrbs9DJ0RYEiFdvFyrfzVWAXKN/OV9gKU84BAAAAAAAAnQAFEoBOJ2JHFLEjKlNZepsxRjETU51X999iyd2gOq8uXSxtWgbPkiUjI8dyZMtOF0z2f/7J5oJk0ywiT95/CyK58oyX3seSlS7UolZU+U6+ipyijKIox8rJ6q8DAAAAAAAAgO2jQALQJViWpagVVdSOqkIV6e3GGCWVVKPXqCavSU2mSU1ekxq9RtWbejV6jUqapOImLs946Zk46efLbKyVLFub/7OpXLG29s8uFC+bZght9Z/NHnPlpq9NZCnz9TbPG7bCyrVzVWAVKNfJVY6Voxw7J/1nyArtdFYAAAAAAAAA2YsCCUCXZlmWQgop5IRU7BRv8bgxRgklFPNiG2cqmbgSJpHxZ7NpVrPXrJiJKWmS6fJmU6kjKaPoyXj9/5Q7X92+w9yyZGvjcnu2ZafHsWUraAUVsSKKWBHl2DkKW+H0LWSFMu6z5BwAAAAAAACAraFAAoDtsCxLYYUVdsIt2t81brpE2rREXMqktnk/88U2/bFloWPJUkABOZaT/tORk76GU8D67zZHDqUQAAAAAAAAgF1CgQQAbcixNl4vCQAAAAAAAACyme13AAAAAAAAAAAAAHQsFEgAAAAAAAAAAADIQIEEAAAAAAAAAACADBRIAAAAAAAAAAAAyECBBAAAAAAAAAAAgAwUSAAAAAAAAAAAAMhAgQQAAAAAAAAAAIAMFEgAAAAAAAAAAADIQIEEAAAAAAAAAACADBRIAAAAAAAAAAAAyECBBAAAAAAAAAAAgAwUSAAAAAAAAAAAAMhAgQQAAAAAAAAAAIAMFEgAAAAAAAAAAADIQIEEAAAAAAAAAACADBRIAAAAAAAAAAAAyECBBADwxYsvvijLsvTHP/7R7ygAAAAAAAAAvoICCQA6GMuyWnR78cUX9cknn8iyLN188807HNd1Xc2ePVtTpkxRSUmJwuGw+vTpozPOOENvvPFGer8HHnhgm6/5ox/9qEXv4cUXX9Sxxx6ryspKhUIhlZeX68gjj9Rjjz22018XAAAAAAAAALtPwO8AAIBMv/nNbzLuP/jgg3ruuee22D506FA1Nze3aMzm5mYde+yxmjdvnvbbbz/9+Mc/VklJiT755BP94Q9/0Jw5c7R8+XL17Nkz/ZxrrrlGffv2zRhn+PDhO3ytK6+8Utdcc40GDhyo7373u6qurta6dev017/+Vccdd5zmzp2rU045pUW5AQAAAAAAAPiDAgkAOpjp06dn3H/llVf03HPPbbFdkj755JMWjfn9739f8+bN02233aYLL7ww47Err7xSt9122xbP+drXvqZx48a1OLck/fGPf9Q111yj448/Xg899JCCwWBGhmeeeUbJZLJVYwIAAAAAAADY/VjCDgA6uc8//1z33HOPpk6dukV5JEmO4+iSSy7JmH20sy6//HKVlJTo17/+dUZ5tMm0adN0xBFHZGzzPE/XX3+9evbsqUgkooMOOkjLli3L2Oef//ynTjjhBPXu3VvhcFi9evXSRRddtMUMrBkzZigvL09ffPGFjj76aOXl5amsrEyXXHKJXNfN2HfdunU67bTTVFBQoKKiIp1++ul65513ZFmWHnjggYx9Fy9erOOPP14lJSWKRCIaN26cnnjiiV34SgEAAAAAAAAdGzOQAKCTe/rpp5VKpXTaaae16nm1tbVau3ZtxrZu3bptc/+lS5dq8eLF+uY3v6n8/PwWv86NN94o27Z1ySWXqLa2Vj/96U916qmn6tVXX03v88gjj6ipqUlnn322SktL9dprr+mOO+7Q559/rkceeSRjPNd1NW3aNE2YMEE333yznn/+ed1yyy3q37+/zj77bEkbS6sjjzxSr732ms4++2wNGTJEf/7zn3X66advke/999/X5MmT1aNHD/3oRz9Sbm6u/vCHP+joo4/Wo48+qmOOOabF7xUAAAAAAADIFhRIANDJLVq0SJI0YsSIVj3v4IMP3mKbMabNXycWi+ntt99WKBSSJBUXF+uCCy7Qe++9l77m0k033aRoNJp+zne+8x0NGDBAP/7xj7V8+XL17t07Y7yTTjpJl19+uSTprLPO0pgxY3T//fenC6THH39cL7/8sm6//XZdcMEFkqSzzz5bU6dO3SLfBRdcoN69e+v1119XOByWJP3v//6v9tlnH/3whz+kQAIAAAAAAECnxBJ2ANDJ1dXVSVKrZgVJ0qxZs/Tcc89l3Nrjdc4444x0eSRJ++67ryTpo48+Sm/bvDxqbGzU2rVrtffee8sYo7feemuLMc8666yM+/vuu2/GePPmzVMwGNSZZ56Z3mbbts4555yM561fv15/+9vfdOKJJ6q+vl5r167V2rVrtW7dOk2bNk1Lly7VF1980ar3CwAAAAAAAGQDZiABQCdXUFAgSaqvr2/V8/baay+NGzeu3V9n89lD0sYZSJK0YcOG9Lbly5friiuu0BNPPJGxXdq41N7mIpGIysrKthhz8+d9+umnqqqqUk5OTsZ+AwYMyLi/bNkyGWN0+eWXp2c0fdXq1avVo0eP7b1FAAAAAAAAIOtQIAFAJzdkyBBJ0sKFC7XnnnvultdpDcdxtrp903J5rutq6tSpWr9+vX74wx9qyJAhys3N1RdffKEZM2bI87wWjbczNo19ySWXaNq0aVvd56ulEwAAAAAAANAZUCABQCf3ta99TY7j6Le//a1OO+20dnudQYMGafDgwfrzn/+sn//858rLy2uTcRcuXKgPPvhAc+bM0Te+8Y309h0tqbc91dXVeuGFF9TU1JQxC2nZsmUZ+/Xr10+SFAwGt3pNKAAAAAAAAKCz4hpIANDJ9erVS2eeeaaeffZZ3XHHHVs87nmebrnlFn3++ee7/FpXX3211q1bp29/+9tKpVJbPP7ss8/qySefbNWYm2YUbZqRtOnff/7zn+90zmnTpimZTOq+++5Lb/M8T7NmzcrYr7y8XFOmTNE999yjFStWbDHOmjVrdjoDAAAAAAAA0JExAwkAOoH58+crFottsf3oo4/W8OHDdcstt+jDDz/U+eefr8cee0xHHHGEiouLtXz5cj3yyCNavHix/ud//meXc5x00klauHChrr/+er311ls6+eSTVV1drXXr1mnevHmaP3++HnrooVaNOWTIEPXv31+XXHKJvvjiCxUUFOjRRx/d4lpIrXH00Udrr7320ve+9z0tW7ZMQ4YM0RNPPKH169dLkizLSu87a9Ys7bPPPhoxYoTOPPNM9evXT6tWrdLLL7+szz//XO+8885O5wAAZJ8b31rrdwQgw49Gd/M7AgAAADopCiQA6ATmzZunefPmbbG9T58+Gj58uHJycvT000/rgQce0Jw5c3TttdeqqalJ3bt314EHHqi5c+eqR48ebZLluuuu04EHHqhf/OIXuuuuu7R+/XoVFxdr4sSJ+vOf/6yjjjqqVeMFg0H95S9/0fnnn6+ZM2cqEonomGOO0bnnnqtRo0btVEbHcfTUU0/pggsu0Jw5c2Tbto455hhdeeWVmjx5siKRSHrfYcOG6Y033tDVV1+tBx54QOvWrVN5eblGjx6tK664YqdeHwAAAAAAAOjoLLP5mkAAAHRhjz/+uI455hj961//0uTJk/2OAwBdUl1dnQoLC1VbW6uCggK/42yBGUjoaLJhBtLPN+z80sNAe7ig+AK/I+zQ0osW+R0ByDDwtqF+R9ihq6++2u8IQIYrr7zS7wjb1NL/7+IaSACALqm5uTnjvuu6uuOOO1RQUKAxY8b4lAoAAAAAAADoGFjCDgDQJZ133nlqbm7WpEmTFI/H9dhjj+mll17SDTfcoGg06nc8AAAAAAAAwFcUSACALunAAw/ULbfcoieffFKxWEwDBgzQHXfcoXPPPdfvaAAAAAAAAIDvKJAAAF3SKaecolNOOcXvGAAAAAAAAECHxDWQAAAAAAAAAAAAkIECCQAAAAAAAAAAABkokAAAAAAAAAAAAJCBAgkAAAAAAAAAAAAZKJAAAAAAtKlZs2apT58+ikQimjBhgl577TW/IwEAAAAAWokCCQAAAECb+f3vf6+LL75YV155pd58802NGjVK06ZN0+rVq/2OBgAAAABoBQokAAAAAG3m1ltv1ZlnnqkzzjhDw4YN0913362cnBz9+te/9jsaAAAAAKAVAn4HAAAAANA5JBIJLViwQJdeeml6m23bOvjgg/Xyyy9v9TnxeFzxeDx9v7a2VpJUV1fXvmF3Uqyh3u8IQIa6upDfEXYoVhfzOwKQoc7pmD9jNtcQb/A7ApCho/7dbHOxGD9v0LF05ONmUzZjzHb3o0ACAAAA0CbWrl0r13VVUVGRsb2iokKLFy/e6nNmzpypq6++eovtvXr1apeMQGez5dEDYEd+pB/5HQHIPnf5HQDIPjfeeKPfEXaovr5ehYWF23ycAgkAAACAby699FJdfPHF6fue52n9+vUqLS2VZVk+JkN7qqurU69evfTZZ5+poKDA7zhAVuC4AVqP4wZoPY6brsEYo/r6enXv3n27+1EgAQAAAGgT3bp1k+M4WrVqVcb2VatWqbKycqvPCYfDCofDGduKioraKyI6mIKCAk5MAK3EcQO0HscN0HocN53f9mYebWLvhhwAAAAAuoBQKKSxY8dq/vz56W2e52n+/PmaNGmSj8kAAAAAAK3FDCQAAAAAbebiiy/W6aefrnHjxmmvvfbS7bffrsbGRp1xxhl+RwMAAAAAtAIFEgAAAIA2c9JJJ2nNmjW64oortHLlSu25556aN2+eKioq/I6GDiQcDuvKK6/cYvlCANvGcQO0HscN0HocN9icZYwxfocAAAAAAAAAAABAx8E1kAAAAAAAAAAAAJCBAgkAAAAAAAAAAAAZKJAAAAAAAAAAAACQgQIJAAAAADqZTz75RJZl6e233/Y7Sru66qqrtOeee/odA1msqxwr28NxhI6kPY/JF198UZZlqaamps3HBrLdlClTdOGFF/odAx0QBRIAAAAAdBCfffaZvvnNb6p79+4KhUKqrq7WBRdcoHXr1vmW6fPPP1coFNLw4cO3+rgxRvfee68mTJigvLw8FRUVady4cbr99tvV1NQkaeMJasuytrg9//zz233tRx99VFOmTFFhYaHy8vI0cuRIXXPNNVq/fn2bv09kl45yrPTp02ern+1NtxkzZkiSLMvS448/vs1xOI6QTWbMmJHxGSwtLdWhhx6qd999t9XjHH300W2W66233tIJJ5ygiooKRSIRDRw4UGeeeaY++OCDNnsNoD1sOqZuvPHGjO2PP/64LMva5fETiYR++tOfatSoUcrJyVG3bt00efJkzZ49W8lkcpfHR+dGgQQAAAAAHcBHH32kcePGaenSpfrd736nZcuW6e6779b8+fM1adIk3072PvDAAzrxxBNVV1enV199dYvHTzvtNF144YX6+te/rhdeeEFvv/22Lr/8cv35z3/Ws88+m95vjz320IoVKzJu++233zZf9yc/+YlOOukkjR8/Xk8//bTee+893XLLLXrnnXf0m9/8pl3eK7JDRzpWXn/99fTn+dFHH5UkLVmyJL3t5z//eYvG4ThCtjn00EPTn8H58+crEAjoiCOO8C3Pk08+qYkTJyoej2vu3LlatGiRfvvb36qwsFCXX365b7mAlopEIrrpppu0YcOGNh03kUho2rRpuvHGG/Wd73xHL730kl577TWdc845uuOOO/T++++36euhEzIAAAAAAN8deuihpmfPnqapqSlj+4oVK0xOTo4566yz0tuqq6vN9ddfb8444wyTl5dnevXqZe6555704x9//LGRZN566y3jeZ7p37+/+dnPfpYx7ltvvWUkmaVLl24zk+d5pl+/fmbevHnmhz/8oTnzzDMzHv/9739vJJnHH398q8+tqakxxhhz5ZVXmlGjRrX4a/Hqq68aSeb222/f6uMbNmzIGPfBBx801dXVpqCgwJx00kmmrq4uve/TTz9tJk+ebAoLC01JSYk5/PDDzbJly9KPb/paPfroo2bKlCkmGo2akSNHmpdeeinjNe+9917Ts2dPE41GzdFHH21uueUWU1hYmLHP448/bkaPHm3C4bDp27evueqqq0wymWzx+0bLdMRjxRhjXnjhBSMp/fncnCTzpz/9aavP4zgqzNiH46jjO/30083Xv/71jG3//Oc/jSSzevXq9LZ3333XHHDAASYSiZiSkhJz5plnmvr6emPMxs+dpIzbCy+80OLP0uYaGxtNt27dzNFHH73Vxzd91jcdo88//7wZO3asiUajZtKkSWbx4sXpfZctW2aOOuooU15ebnJzc824cePMc889lzHejr6vGGPMv//9bzNq1CgTDofN2LFjzZ/+9Kf095pNFi5caA499FCTm5trysvLzfTp082aNWu2+T7ReZ1++unmiCOOMEOGDDHf//7309s3fW4298c//tEMGzbMhEIhU11dbW6++ebtjn3TTTcZ27bNm2++ucVjiUTCNDQ0GGOM2X///c15551nvv/975vi4mJTUVFhrrzyyoz9b7nlFjN8+HCTk5Njevbsac4+++z0MW2MMbNnzzaFhYVm3rx5ZsiQISY3N9dMmzbNfPnll+l9ksmkOe+889I/T37wgx+Yb3zjGxnfU1zXNTfccIPp06ePiUQiZuTIkeaRRx7Z4dcR7YMCCQAAAAB8tm7dOmNZlrnhhhu2+viZZ55piouLjed5xpiNJ69KSkrMrFmzzNKlS83MmTONbdvpk2CbnxQ3xpjrr7/eDBs2LGPM888/3+y3337bzTV//nxTWVlpUqmUWbhwocnPz0+faDDGmKOOOsoMHjx4h++vtSe+zz//fJOXl2cSicQOx83LyzPHHnusWbhwofnHP/5hKisrzY9//OP0Pn/84x/No48+apYuXWreeustc+SRR5oRI0YY13WNMf/9Wg0ZMsQ8+eSTZsmSJeb444831dXV6ZPW//rXv4xt2+ZnP/uZWbJkiZk1a5YpKSnJOPH9j3/8wxQUFJgHHnjAfPjhh+bZZ581ffr0MVdddVWL3zd2rKMeK8bsfIHEcVSYfh2Oo+zw1QKpvr7efPe73zUDBgxIfyYaGhpMVVVV+nM1f/5807dvX3P66aenn3PiiSeaQw891KxYscKsWLHCxOPxFn2Wvuqxxx4zkrZbMhnz32N0woQJ5sUXXzTvv/++2Xfffc3ee++d3uftt982d999t1m4cKH54IMPzGWXXWYikYj59NNP0/vs6PtKbW2tKSkpMdOnTzfvv/+++etf/2oGDRqU8b1mw4YNpqyszFx66aVm0aJF5s033zRTp041BxxwQGv/c6AT2HRMPfbYYyYSiZjPPvvMGLNlgfTGG28Y27bNNddcY5YsWWJmz55totGomT179jbHHjlypDnkkEN2mGH//fc3BQUF5qqrrjIffPCBmTNnjrEsyzz77LPpfW677Tbzt7/9zXz88cdm/vz5ZvDgwebss89OPz579mwTDAbNwQcfbF5//XWzYMECM3ToUHPKKaek97nuuutMSUmJeeyxx8yiRYvMWWedZQoKCjK+p1x33XVmyJAhZt68eebDDz80s2fPNuFw2Lz44ost+XKijVEgAQAAAIDPXnnlle2eYL711luNJLNq1SpjzMaTV9OnT08/7nmeKS8vN3fddZcxZsuT4l988YVxHMe8+uqrxpiNv3HarVs388ADD2w31ymnnGIuvPDC9P1Ro0ZlnKQYOnSoOeqoo3b4/q688kpj27bJzc1N38aPH7/N/b/2ta+ZkSNHtmjcnJycjJkS3//+982ECRO2+Zw1a9YYSWbhwoXGmP9+rX71q1+l93n//feNJLNo0SJjjDEnnXSSOfzwwzPGOfXUUzNOfB900EFblBq/+c1vTFVV1Q7fB1quox4rxux8gcRxVJi+z3GUHU4//XTjOE76cyjJVFVVmQULFqT3uffee01xcXHGLx089dRTxrZts3LlyvQ4X53J1JLP0lfddNNNRpJZv379dnNvPgNp80ySTHNz8zaft8cee5g77rgjfX9H31fuuusuU1pamjHmfffdl/G95tprr93ipP5nn31mJJklS5Zs932g89n8WJg4caL55je/aYzZskA65ZRTzNSpUzOe+/3vf3+LX3zYXDQaNeeff/4OM+y///5mn332ydg2fvx488Mf/nCbz3nkkUdMaWlp+v7s2bONpIwZqrNmzTIVFRXp+xUVFRkzfVOplOndu3f6/cdiMZOTk7NFIfytb33LnHzyyTt8H2h7XAMJAAAAADoIY0yL9x05cmT63y3LUmVlpVavXr3Vfbt3767DDz9cv/71ryVJf/nLXxSPx3XCCSdsc/yamho99thjmj59enrb9OnTdf/99+9U3sGDB+vtt99O3zZdL2ZrWjNunz59lJ+fn75fVVWV8XVYunSpTj75ZPXr108FBQXq06ePJGn58uUZ42z+9ayqqpKk9DhLlizRXnvtlbH/V++/8847uuaaa5SXl5e+nXnmmVqxYoWamppa/H7QMh3pWNlVHEf/xXGUPQ444ID05/C1117TtGnT9LWvfU2ffvqpJGnRokUaNWqUcnNz08+ZPHmyPM/TkiVLdjj+9j5LX9Waz/qOxm5oaNAll1yioUOHqqioSHl5eVq0aNF2P+tf/b6yZMkSjRw5UpFIJL3P1j7rL7zwQsZnfciQIZKkDz/8sFXvB53LTTfdpDlz5mjRokVbPLZo0SJNnjw5Y9vkyZO1dOlSua671fF29ueltOXPgueff14HHXSQevToofz8fJ122mlat25dxvfnnJwc9e/ff6tj1NbWatWqVRnHg+M4Gjt2bPr+smXL1NTUpKlTp2YcHw8++CDHhk8CfgcAAAAAgK5uwIABsixLixYt0jHHHLPF44sWLVJxcbHKysrS24LBYMY+lmXJ87xtvsa3v/1tnXbaabrttts0e/ZsnXTSScrJydnm/g899JBisZgmTJiQ3maMked5+uCDDzRo0CANGjRIixcvbtF7DIVCGjBgQIv2HTRokP71r38pmUxu8T6/akdfhyOPPFLV1dW677771L17d3mep+HDhyuRSGxzHMuyJGm7X8+vamho0NVXX61jjz12i8c2P4mIXdMRj5VdxXH0XxxH2SM3Nzfjs/irX/1KhYWFuu+++3Tdddft8vit+SwNGjRIkrR48WJNmjRpl8a+5JJL9Nxzz+nmm2/WgAEDFI1Gdfzxx2/3s75pnNZ+1o888kjddNNNWzy2qdRC17Tffvtp2rRpuvTSSzVjxoxdHq81P2O297n+5JNPdMQRR+jss8/W9ddfr5KSEv3rX//St771LSUSifTPya2N0ZoSq6GhQZL01FNPqUePHhmPhcPhFo+DtsMMJAAAAADwWWlpqaZOnao777xTzc3NGY+tXLlSc+fO1UknnZQ+0bUzDjvsMOXm5uquu+7SvHnz9M1vfnO7+99///363ve+lzHb4Z133tG+++6bnp1xyimn6IMPPtCf//znLZ5vjFFtbe1OZT3llFPU0NCgO++8c6uP19TUtGicdevWacmSJbrssst00EEHaejQodqwYUOr8wwePFivv/56xrav3h8zZoyWLFmiAQMGbHGzbf7Xu610xGNlV3Ec/RfHUfayLEu2baePy6FDh+qdd95RY2Njep9///vfsm1bgwcPlrSxEN3WrInWOOSQQ9StWzf99Kc/3erjLf2sb8o4Y8YMHXPMMRoxYoQqKyv1ySeftCrP4MGDtXDhQsXj8fS2rX3W33//ffXp02eLz/rms7bQNd144436y1/+opdffjlj+9ChQ/Xvf/87Y9u///1vDRo0SI7jbHWsU045Rc8//7zeeuutLR5LJpMZx+j2LFiwQJ7n6ZZbbtHEiRM1aNAgffnlly18RxsVFhaqoqIi43hwXVdvvvlm+v6wYcMUDoe1fPnyLY6NXr16ter10Db46QsAAAAAHcAvf/lLxeNxTZs2Tf/4xz/02Wefad68eZo6dap69Oih66+/fpfGdxxHM2bM0KWXXqqBAwdu97e03377bb355pv69re/reHDh2fcTj75ZM2ZM0epVEonnniiTjrpJJ188sm64YYb9MYbb+jTTz/Vk08+qYMPPlgvvPDCTmWdMGGCfvCDH+h73/uefvCDH+jll1/Wp59+qvnz5+uEE07QnDlzWjROcXGxSktLde+992rZsmX629/+posvvrjVec477zz99a9/1a233qqlS5fqnnvu0dNPP51RUlxxxRV68MEHdfXVV+v999/XokWL9PDDD+uyyy5r9eth+zrSsdIaH3/8cUYh+/bbb6uxsZHjiOMoK8Xjca1cuVIrV67UokWLdN5556Vn1UjSqaeeqkgkotNPP13vvfeeXnjhBZ133nk67bTTVFFRIWnj0onvvvuulixZorVr1yqZTO5UltzcXP3qV7/SU089paOOOkrPP/+8PvnkE73xxhv6wQ9+oLPOOqvFYw0cOFCPPfZY+pcmTjnllFbNLJKUfs53vvMdLVq0SM8884xuvvlmSf+d8XTOOedo/fr1Ovnkk/X666/rww8/1DPPPKMzzjijTUo1ZLcRI0bo1FNP1S9+8YuM7d/73vc0f/58XXvttfrggw80Z84c/fKXv9Qll1yyzbEuvPBCTZ48WQcddJBmzZqld955Rx999JH+8Ic/aOLEiVq6dGmLMg0YMEDJZFJ33HGHPvroI/3mN7/R3Xff3er3dt5552nmzJn685//rCVLluiCCy7Qhg0b0sdGfn6+LrnkEl100UWaM2eOPvzwQ7355pu64447WvxzC22LAgkAAAAAOoCBAwfqjTfeUL9+/XTiiSeqf//++s53vqMDDjhAL7/8skpKSnb5NTYtM3LGGWdsd7/7779fw4YNS1+PYXPHHHOMVq9erb/+9a+yLEsPPfSQbr31Vj3++OPaf//9NXLkSF111VX6+te/rmnTpu101ptuukkPPfSQXn31VU2bNk177LGHLr74Yo0cOVKnn356i8awbVsPP/ywFixYoOHDh+uiiy7Sz372s1ZnmTx5su6++27deuutGjVqlObNm6eLLrooY0mtadOm6cknn9Szzz6r8ePHa+LEibrttttUXV3d6tfD9nWkY6U1Lr74Yo0ePTrj9tZbb3EccRxlpXnz5qmqqkpVVVWaMGGCXn/9dT3yyCOaMmWKpI3XQXnmmWe0fv16jR8/Xscff7wOOugg/fKXv0yPceaZZ2rw4MEaN26cysrKtphZ0Rpf//rX9dJLLykYDOqUU07RkCFDdPLJJ6u2trZVS+rdeuutKi4u1t57760jjzxS06ZN05gxY1qVpaCgQH/5y1/09ttva88999RPfvITXXHFFZL+uxRj9+7d9e9//1uu6+qQQw7RiBEjdOGFF6qoqIjZdpAkXXPNNVuUl2PGjNEf/vAHPfzwwxo+fLiuuOIKXXPNNdtd6i4cDuu5557TD37wA91zzz2aOHGixo8fr1/84hc6//zzNXz48BblGTVqlG699VbddNNNGj58uObOnauZM2e2+n398Ic/1Mknn6xvfOMbmjRpkvLy8jRt2rSMnwXXXnutLr/8cs2cOVNDhw7VoYceqqeeekp9+/Zt9eth11mmtVeaAwAAAABkpX/+85866KCD9Nlnn6V/Axw758wzz9TixYv1z3/+0+8oaAccK7sHxxG6irlz5+qMM85QbW2totGo33GADsPzPA0dOlQnnniirr32Wr/jYCsCfgcAAAAAALSveDyuNWvW6KqrrtIJJ5zACfGdcPPNN2vq1KnKzc3V008/rTlz5mzz2jLIXhwr7YvjCF3Fgw8+qH79+qlHjx5655139MMf/lAnnngi5RG6vE8//VTPPvus9t9/f8Xjcf3yl7/Uxx9/rFNOOcXvaNgG5kQCAAAAQCf3u9/9TtXV1aqpqdnmRcaxfa+99pqmTp2qESNG6O6779YvfvELffvb3/Y7FtoYx0r74jhCV7Fy5UpNnz5dQ4cO1UUXXaQTTjhB9957r9+xAN/Ztq0HHnhA48eP1+TJk7Vw4UI9//zzGjp0qN/RsA0sYQcAAAAAAAAAAIAMzEACAAAAAAAAAABABgokAAAAAAAAAAAAZKBAAgAAAAAAAAAAQAYKJAAAAAAAAAAAAGSgQAIAAAAAAAAAAEAGCiQAAAAAAAAAAABkoEACAAAAAAAAAABABgokAAAAAAAAAAAAZKBAAgAAAAAAAAAAQAYKJAAAAAAAAAAAAGSgQAIAAAAAAAAAAEAGCiQAAAAAAAAAAABkoEACAAAAAAAAAABABgokAAAAAAAAAAAAZKBAAgAAAAAAAAAAQAYKJAAAAAAAAAAAAGSgQAIAAAAAAAAAAEAGCiQAAAAAAAAAAABkoEACAAAAAAAAAABABgokAAAAAAAAAAAAZKBAApC1PvnkE1mWpZtvvtnvKAAAAAAAAADQqVAgAdiuBx54QJZlKRKJ6Isvvtji8SlTpmj48OFt/rpvv/22pk+frl69eikcDqukpEQHH3ywZs+eLdd12/z1stFdd92lE044Qb1795ZlWZoxY8ZW99v033Brt5UrV2bs+/vf/17Tp0/XwIEDZVmWpkyZ0v5vBAAAAAAAAECHE/A7AIDsEI/HdeONN+qOO+5o99f61a9+pbPOOksVFRU67bTTNHDgQNXX12v+/Pn61re+pRUrVujHP/5xu+fo6G666SbV19drr7320ooVK3a4/zXXXKO+fftmbCsqKsq4f9ddd2nBggUaP3681q1b15ZxAQAAAAAAAGQRCiQALbLnnnvqvvvu06WXXqru3bu32+u88sorOuusszRp0iT99a9/VX5+fvqxCy+8UG+88Ybee++9dnv9bPL3v/89PfsoLy9vh/t/7Wtf07hx47a7z29+8xv16NFDtm23y8wyAAAAAAAAANmBJewAtMiPf/xjua6rG2+8cYf7plIpXXvtterfv7/C4bD69OmjH//4x4rH4zt87tVXXy3LsjR37tyM8miTcePGbXWptnvvvTf9euPHj9frr7+e8fi7776rGTNmqF+/fopEIqqsrNQ3v/nNLWbZXHXVVbIsS8uWLdOMGTNUVFSkwsJCnXHGGWpqasrYt7m5Weeff766deum/Px8HXXUUfriiy9kWZauuuqqjH2/+OILffOb31RFRYXC4bD22GMP/frXv97ifSxfvlyLFy/e4ddJkqqrq2VZVov23aS+vn67SwD26tVLts2PBgAAAAAAAKCrYwYSgBbp27evvvGNb+i+++7Tj370o+3OQvr2t7+tOXPm6Pjjj9f3vvc9vfrqq5o5c6YWLVqkP/3pT9t8XlNTk+bPn6/99ttPvXv3bnG2hx56SPX19frud78ry7L005/+VMcee6w++ugjBYNBSdJzzz2njz76SGeccYYqKyv1/vvv695779X777+vV155ZYsi5sQTT1Tfvn01c+ZMvfnmm/rVr36l8vJy3XTTTel9ZsyYoT/84Q867bTTNHHiRP3973/X4YcfvkW+VatWaeLEibIsS+eee67Kysr09NNP61vf+pbq6up04YUXpvf9xje+ob///e8yxrT4/bfUAQccoIaGBoVCIU2bNk233HKLBg4c2OavAwAAAAAAACD7USABaLGf/OQnevDBB3XTTTfp5z//+Vb3eeeddzRnzhx9+9vf1n333SdJ+t///V+Vl5fr5ptv1gsvvKADDjhgq89dtmyZksmkRowY0apcy5cv19KlS1VcXCxJGjx4sL7+9a/rmWee0RFHHJHO8L3vfS/jeRMnTtTJJ5+sf/3rX9p3330zHhs9erTuv//+9P1169bp/vvvTxdIb775pv7whz/owgsv1G233ZZ+jTPOOEPvvPNOxlg/+clP5LquFi5cqNLSUknSWWedpZNPPllXXXWVvvvd7yoajbbqPbdGTk6OZsyYoQMOOEAFBQVasGCBbr31Vu29995688031atXr3Z7bQAAAAAAAADZiXWKALRYv379dNppp+nee+/VihUrtrrPX//6V0nSxRdfnLF9U3nz1FNPbXP8uro6Sdrq0nXbc9JJJ6XLI0npMuijjz5Kb9u8oInFYlq7dq0mTpwoaWMZ9FVnnXVWxv19991X69atS2ecN2+epI2l0ebOO++8jPvGGD366KM68sgjZYzR2rVr07dp06aptrY24/VffPHFNp99dOKJJ2r27Nn6xje+oaOPPlrXXnutnnnmGa1bt07XX399m74WAAAAAAAAgM6BAglAq1x22WVKpVLbvBbSp59+Ktu2NWDAgIztlZWVKioq0qeffrrNsQsKCiRtvE5Pa3x1ubtNZdKGDRvS29avX68LLrhAFRUVikajKisrU9++fSVJtbW1rR5z0/vcNMYmX33fa9asUU1Nje69916VlZVl3M444wxJ0urVq1v1ftvCPvvsowkTJuj555/f7a8NAAAAAAAAoONjCTsArdKvXz9Nnz5d9957r370ox9tc7+vXlOoJQYMGKBAIKCFCxe26nmO42x1++YzeU488US99NJL+v73v68999xTeXl58jxPhx56qDzP26kxW2LT2NOnT9fpp5++1X1GjhzZqjHbSq9evbRkyRJfXhsAAAAAAABAx0aBBKDVLrvsMv32t79NXw9oc9XV1fI8T0uXLtXQoUPT21etWqWamhpVV1dvc9ycnBwdeOCB+tvf/qbPPvusza7Ns2HDBs2fP19XX321rrjiivT2pUuX7vSYm97nxx9/rIEDB6a3L1u2LGO/srIy5efny3VdHXzwwTv9eu3ho48+UllZmd8xAAAAAAAAAHRALGEHoNX69++v6dOn65577tHKlSszHjvssMMkSbfffnvG9ltvvVWSdPjhh2937CuvvFLGGJ122mlqaGjY4vEFCxZozpw5rcq7aTbRV2cPfTVja0ybNk2SdOedd2Zsv+OOO7Z47eOOO06PPvqo3nvvvS3GWbNmTcb95cuXa/HixTuda2u++hrSxmtVLViwQP/f3t27ZL2GcQD/HnFoCBsatBcboihyCCtRHJ4QIpoiaGhQazIh6A8wCTEcQghcbIjoxaJoKCGRB0wqHYW0GgJb+gMiEXobHDxDnAd+nM5BH4LwnM9nvLm5fvfvXr9c133ixIlf+i0AAAAA4L9BBxJQlf7+/ty7dy+Li4tpamqqrB88eDDnzp3LjRs3sry8nKNHj2Zubi53797NqVOn0tHR8a9129vbMzo6mgsXLmT//v3p7u7O3r178/nz57x8+TJPnz7N0NDQus5aV1eXUqmU4eHhrKysZMeOHZmamsqHDx+q+vckOXz4cE6fPp2RkZF8+vQpbW1tmZmZyfv375MUR/hdvXo1L168SGtra3p6enLgwIEsLS1lfn4+09PTWVpaquw9e/ZsZmZm1jQqb2JiIm/evEmSrKys5O3bt5W7OXnyZGU0Xnt7e5qbm3PkyJFs2bIl8/PzuXXrVhobG3Pp0qVCzdnZ2czOzib5ETx9/fq1UrNUKqVUKlV7ZQAAAADABiJAAqqyZ8+edHV1/bQb6ObNm9m9e3fu3LmT8fHxNDQ0pK+vLwMDA2uq3dvbm5aWlly7di1jY2P5+PFjNm/enEOHDuX27dvp6upa93kfPHiQixcvZnR0NKurqzl+/HjK5XK2b9++7lp/GRsbS0NDQx4+fJjx8fEcO3Ysjx49yr59+7Jp06bKvvr6+szNzeXKlSt58uRJrl+/nq1bt6apqemnYwDX6vHjx4X7X1hYyMLCQpJk586dlQDpzJkzmZyczNTUVL59+5Zt27alp6cnAwMDqa+vL9R8/vx5BgcHC2uXL19O8qM7TIAEAAAAAP8Pf6yu90V4AP7R69ev09zcnPv376ezs/N3HwcAAAAAoCreQAKo0vfv3/+2NjIykpqaGp06AAAAAMCGZoQdQJWGh4fz6tWrdHR0pLa2NuVyOeVyOefPn09jY+PvPh4AAAAAQNWMsAOo0rNnzzI4OJh3797ly5cv2bVrV7q7u9Pf35/aWvk8AAAAALBxCZAAAAAAAAAo8AYSAAAAAAAABQIkAAAAAAAACgRIAAAAAAAAFAiQAAAAAAAAKBAgAQAAAAAAUCBAAgAAAAAAoECABAAAAAAAQIEACQAAAAAAgAIBEgAAAAAAAAV/AtT3DBCAgg98AAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 1800x700 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "from matplotlib_venn import venn2\n",
    "\n",
    "# Define colors to use for both the Venn diagram and the bar chart.\n",
    "colors = {\n",
    "    \"only_acf\": \"skyblue\",   # for Only ACF Change (left circle only)\n",
    "    \"only_tlcf\": \"lightgreen\",  # for Only TLCF Change (right circle only)\n",
    "    \"both\": \"orchid\",        # for the intersection (both change)\n",
    "    \"no\": \"grey\"             # for the No Change bar\n",
    "}\n",
    "\n",
    "# Create a figure with two subplots side by side.\n",
    "fig, (ax1, ax2) = plt.subplots(1, 2, figsize=(18, 7))\n",
    "\n",
    "### Venn Diagram on ax1 ###\n",
    "venn = venn2(\n",
    "    subsets=(n_only_acf_change, n_only_tlcf_change, n_both_change), \n",
    "    set_labels=('ACF Change', 'TLCF Change'),\n",
    "    ax=ax1\n",
    ")\n",
    "# ax1.set_aspect('auto')   # Allow the axis to stretch (by default, venn2 sets equal aspect).\n",
    "ax1.set_title(\"Venn Diagram of Abstraction Change\")\n",
    "\n",
    "# Set the patch colors for the three regions.\n",
    "patch_left = venn.get_patch_by_id(\"10\")\n",
    "patch_right = venn.get_patch_by_id(\"01\")\n",
    "patch_intersection = venn.get_patch_by_id(\"11\")\n",
    "\n",
    "if patch_left is not None:\n",
    "    patch_left.set_color(colors[\"only_acf\"])\n",
    "    patch_left.set_alpha(0.7)\n",
    "if patch_right is not None:\n",
    "    patch_right.set_color(colors[\"only_tlcf\"])\n",
    "    patch_right.set_alpha(0.7)\n",
    "if patch_intersection is not None:\n",
    "    patch_intersection.set_color(colors[\"both\"])\n",
    "    patch_intersection.set_alpha(0.7)\n",
    "\n",
    "# Optionally display the \"No Change\" count outside the Venn diagram.\n",
    "ax1.text(\n",
    "    0.5, -0.1, f'No Change: {n_no_change}', \n",
    "    horizontalalignment='center', \n",
    "    fontsize=12, \n",
    "    transform=ax1.transAxes\n",
    ")\n",
    "\n",
    "### Bar Chart on ax2 ###\n",
    "labels = ['Only ACF Change', 'Only TLCF Change', 'Both Change', 'No Change']\n",
    "values = [n_only_acf_change, n_only_tlcf_change, n_both_change, n_no_change]\n",
    "bar_colors = [colors[\"only_acf\"], colors[\"only_tlcf\"], colors[\"both\"], colors[\"no\"]]\n",
    "\n",
    "ax2.bar(labels, values, color=bar_colors)\n",
    "ax2.set_title(\"Bar Chart of Abstraction Change\")\n",
    "ax2.set_ylabel(\"Count\")\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Computing Perplexity of generated counterfactuals"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead tr th {\n",
       "        text-align: left;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th colspan=\"8\" halign=\"left\">acf</th>\n",
       "      <th colspan=\"2\" halign=\"left\">prompt</th>\n",
       "      <th>...</th>\n",
       "      <th colspan=\"6\" halign=\"left\">tlcf</th>\n",
       "      <th colspan=\"2\" halign=\"left\">acf</th>\n",
       "      <th colspan=\"2\" halign=\"left\">tlcf</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th>cf_abstraction</th>\n",
       "      <th>cf_abstraction_distribution</th>\n",
       "      <th>cf_abstraction_id</th>\n",
       "      <th>cf_text</th>\n",
       "      <th>factual_abstraction</th>\n",
       "      <th>factual_abstraction_distribution</th>\n",
       "      <th>factual_abstraction_id</th>\n",
       "      <th>factual_text</th>\n",
       "      <th>cf_prompt</th>\n",
       "      <th>factual_prompt</th>\n",
       "      <th>...</th>\n",
       "      <th>cf_abstraction_id</th>\n",
       "      <th>cf_text</th>\n",
       "      <th>factual_abstraction</th>\n",
       "      <th>factual_abstraction_distribution</th>\n",
       "      <th>factual_abstraction_id</th>\n",
       "      <th>factual_text</th>\n",
       "      <th>abstraction_change</th>\n",
       "      <th>abstraction_p_increased</th>\n",
       "      <th>abstraction_change</th>\n",
       "      <th>abstraction_p_increased</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>3687</th>\n",
       "      <td>love</td>\n",
       "      <td>[0.031963773, 0.002379056, 0.0020912625, 0.005...</td>\n",
       "      <td>18</td>\n",
       "      <td>[I'm 39 and still love being a painter,\" she e...</td>\n",
       "      <td>love</td>\n",
       "      <td>[0.027502172, 0.00645427, 0.0062332232, 0.0338...</td>\n",
       "      <td>18</td>\n",
       "      <td>[I'm 39 and still love being given the time of...</td>\n",
       "      <td>I'm 39 and still love being a</td>\n",
       "      <td>I'm 39 and still love being given</td>\n",
       "      <td>...</td>\n",
       "      <td>18</td>\n",
       "      <td>[I'm 39 and still love being a ghost.I don't n...</td>\n",
       "      <td>love</td>\n",
       "      <td>[0.0072898837, 0.00431205, 0.005212173, 0.0159...</td>\n",
       "      <td>18</td>\n",
       "      <td>I'm 39 and still love being given the time of ...</td>\n",
       "      <td>False</td>\n",
       "      <td>True</td>\n",
       "      <td>False</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5167</th>\n",
       "      <td>neutral</td>\n",
       "      <td>[0.011735451, 0.0050212676, 0.011357892, 0.034...</td>\n",
       "      <td>20</td>\n",
       "      <td>[Now I can’t unpack you like this,\" he added, ...</td>\n",
       "      <td>surprise</td>\n",
       "      <td>[0.04082695, 0.011286443, 0.022810955, 0.06648...</td>\n",
       "      <td>27</td>\n",
       "      <td>[Now I can’t unhear the steady, soothing sound...</td>\n",
       "      <td>Now I can’t unpack</td>\n",
       "      <td>Now I can’t unhe</td>\n",
       "      <td>...</td>\n",
       "      <td>20</td>\n",
       "      <td>[Now I can’t unpack the knowledge I got for it...</td>\n",
       "      <td>sadness</td>\n",
       "      <td>[0.005518393, 0.006473891, 0.012378504, 0.0220...</td>\n",
       "      <td>26</td>\n",
       "      <td>Now I can’t unhear the sound of my voice\\n\\nTh...</td>\n",
       "      <td>True</td>\n",
       "      <td>False</td>\n",
       "      <td>True</td>\n",
       "      <td>False</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3129</th>\n",
       "      <td>neutral</td>\n",
       "      <td>[0.009871497, 0.0016246348, 0.0034111058, 0.01...</td>\n",
       "      <td>20</td>\n",
       "      <td>[No disadvantages in stereotypes\\n\\nDisadvanta...</td>\n",
       "      <td>surprise</td>\n",
       "      <td>[0.03453425, 0.015363309, 0.0069924644, 0.0461...</td>\n",
       "      <td>27</td>\n",
       "      <td>[No disadvantages in stereotypes. He's been ab...</td>\n",
       "      <td>No disadvantages in stereotypes\\n</td>\n",
       "      <td>No disadvantages in stereotypes.</td>\n",
       "      <td>...</td>\n",
       "      <td>20</td>\n",
       "      <td>[No disadvantages in stereotypes\\n\\nNothing is...</td>\n",
       "      <td>neutral</td>\n",
       "      <td>[0.023964822, 0.023042116, 0.011957536, 0.0852...</td>\n",
       "      <td>20</td>\n",
       "      <td>No disadvantages in stereotypes.\\n\\n\\nCan be u...</td>\n",
       "      <td>True</td>\n",
       "      <td>False</td>\n",
       "      <td>False</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>359</th>\n",
       "      <td>neutral</td>\n",
       "      <td>[0.05616486, 0.0022262137, 0.004238532, 0.0190...</td>\n",
       "      <td>20</td>\n",
       "      <td>[Very little, and yet, some of their best acti...</td>\n",
       "      <td>surprise</td>\n",
       "      <td>[0.07218294, 0.002217058, 0.003235798, 0.02005...</td>\n",
       "      <td>27</td>\n",
       "      <td>[Very little, and yet, some days, good ol' Jef...</td>\n",
       "      <td>Very little, and yet, some of</td>\n",
       "      <td>Very little, and yet, some days</td>\n",
       "      <td>...</td>\n",
       "      <td>20</td>\n",
       "      <td>[Very little, and yet, some of those little th...</td>\n",
       "      <td>neutral</td>\n",
       "      <td>[0.012486543, 0.027007772, 0.002327915, 0.0136...</td>\n",
       "      <td>20</td>\n",
       "      <td>Very little, and yet, some days of the week I ...</td>\n",
       "      <td>True</td>\n",
       "      <td>False</td>\n",
       "      <td>False</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4345</th>\n",
       "      <td>anger</td>\n",
       "      <td>[0.028027648, 0.020095436, 0.5121869, 0.150957...</td>\n",
       "      <td>2</td>\n",
       "      <td>[The fuck is a fortnight? Like, what the fuck ...</td>\n",
       "      <td>anger</td>\n",
       "      <td>[0.006209381, 0.039235707, 0.35787648, 0.29543...</td>\n",
       "      <td>2</td>\n",
       "      <td>[The fuck is a fortnight? Like the days, like ...</td>\n",
       "      <td>The fuck is a fortnight? Like,</td>\n",
       "      <td>The fuck is a fortnight? Like the</td>\n",
       "      <td>...</td>\n",
       "      <td>2</td>\n",
       "      <td>[The fuck is a fortnight? Like, what's a fortn...</td>\n",
       "      <td>anger</td>\n",
       "      <td>[0.003338068, 0.0035662758, 0.38989776, 0.2073...</td>\n",
       "      <td>2</td>\n",
       "      <td>The fuck is a fortnight? Like the weekend, lik...</td>\n",
       "      <td>False</td>\n",
       "      <td>True</td>\n",
       "      <td>False</td>\n",
       "      <td>False</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>5 rows × 22 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "                acf                                                     \\\n",
       "     cf_abstraction                        cf_abstraction_distribution   \n",
       "3687           love  [0.031963773, 0.002379056, 0.0020912625, 0.005...   \n",
       "5167        neutral  [0.011735451, 0.0050212676, 0.011357892, 0.034...   \n",
       "3129        neutral  [0.009871497, 0.0016246348, 0.0034111058, 0.01...   \n",
       "359         neutral  [0.05616486, 0.0022262137, 0.004238532, 0.0190...   \n",
       "4345          anger  [0.028027648, 0.020095436, 0.5121869, 0.150957...   \n",
       "\n",
       "                                                                           \\\n",
       "     cf_abstraction_id                                            cf_text   \n",
       "3687                18  [I'm 39 and still love being a painter,\" she e...   \n",
       "5167                20  [Now I can’t unpack you like this,\" he added, ...   \n",
       "3129                20  [No disadvantages in stereotypes\\n\\nDisadvanta...   \n",
       "359                 20  [Very little, and yet, some of their best acti...   \n",
       "4345                 2  [The fuck is a fortnight? Like, what the fuck ...   \n",
       "\n",
       "                                                                             \\\n",
       "     factual_abstraction                   factual_abstraction_distribution   \n",
       "3687                love  [0.027502172, 0.00645427, 0.0062332232, 0.0338...   \n",
       "5167            surprise  [0.04082695, 0.011286443, 0.022810955, 0.06648...   \n",
       "3129            surprise  [0.03453425, 0.015363309, 0.0069924644, 0.0461...   \n",
       "359             surprise  [0.07218294, 0.002217058, 0.003235798, 0.02005...   \n",
       "4345               anger  [0.006209381, 0.039235707, 0.35787648, 0.29543...   \n",
       "\n",
       "                             \\\n",
       "     factual_abstraction_id   \n",
       "3687                     18   \n",
       "5167                     27   \n",
       "3129                     27   \n",
       "359                      27   \n",
       "4345                      2   \n",
       "\n",
       "                                                         \\\n",
       "                                           factual_text   \n",
       "3687  [I'm 39 and still love being given the time of...   \n",
       "5167  [Now I can’t unhear the steady, soothing sound...   \n",
       "3129  [No disadvantages in stereotypes. He's been ab...   \n",
       "359   [Very little, and yet, some days, good ol' Jef...   \n",
       "4345  [The fuck is a fortnight? Like the days, like ...   \n",
       "\n",
       "                                 prompt                                     \\\n",
       "                              cf_prompt                     factual_prompt   \n",
       "3687      I'm 39 and still love being a  I'm 39 and still love being given   \n",
       "5167                 Now I can’t unpack                   Now I can’t unhe   \n",
       "3129  No disadvantages in stereotypes\\n   No disadvantages in stereotypes.   \n",
       "359       Very little, and yet, some of    Very little, and yet, some days   \n",
       "4345     The fuck is a fortnight? Like,  The fuck is a fortnight? Like the   \n",
       "\n",
       "      ...              tlcf  \\\n",
       "      ... cf_abstraction_id   \n",
       "3687  ...                18   \n",
       "5167  ...                20   \n",
       "3129  ...                20   \n",
       "359   ...                20   \n",
       "4345  ...                 2   \n",
       "\n",
       "                                                                             \\\n",
       "                                                cf_text factual_abstraction   \n",
       "3687  [I'm 39 and still love being a ghost.I don't n...                love   \n",
       "5167  [Now I can’t unpack the knowledge I got for it...             sadness   \n",
       "3129  [No disadvantages in stereotypes\\n\\nNothing is...             neutral   \n",
       "359   [Very little, and yet, some of those little th...             neutral   \n",
       "4345  [The fuck is a fortnight? Like, what's a fortn...               anger   \n",
       "\n",
       "                                                         \\\n",
       "                       factual_abstraction_distribution   \n",
       "3687  [0.0072898837, 0.00431205, 0.005212173, 0.0159...   \n",
       "5167  [0.005518393, 0.006473891, 0.012378504, 0.0220...   \n",
       "3129  [0.023964822, 0.023042116, 0.011957536, 0.0852...   \n",
       "359   [0.012486543, 0.027007772, 0.002327915, 0.0136...   \n",
       "4345  [0.003338068, 0.0035662758, 0.38989776, 0.2073...   \n",
       "\n",
       "                             \\\n",
       "     factual_abstraction_id   \n",
       "3687                     18   \n",
       "5167                     26   \n",
       "3129                     20   \n",
       "359                      20   \n",
       "4345                      2   \n",
       "\n",
       "                                                                       acf  \\\n",
       "                                           factual_text abstraction_change   \n",
       "3687  I'm 39 and still love being given the time of ...              False   \n",
       "5167  Now I can’t unhear the sound of my voice\\n\\nTh...               True   \n",
       "3129  No disadvantages in stereotypes.\\n\\n\\nCan be u...               True   \n",
       "359   Very little, and yet, some days of the week I ...               True   \n",
       "4345  The fuck is a fortnight? Like the weekend, lik...              False   \n",
       "\n",
       "                                           tlcf                          \n",
       "     abstraction_p_increased abstraction_change abstraction_p_increased  \n",
       "3687                    True              False                    True  \n",
       "5167                   False               True                   False  \n",
       "3129                   False              False                    True  \n",
       "359                    False              False                    True  \n",
       "4345                    True              False                   False  \n",
       "\n",
       "[5 rows x 22 columns]"
      ]
     },
     "execution_count": 20,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import pandas as pd \n",
    "\n",
    "df = pd.read_pickle('token_replacement_analysis_dataframe.pkl')\n",
    "df.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "metadata": {},
   "outputs": [],
   "source": [
    "from transformers import AutoTokenizer, AutoModelForCausalLM\n",
    "\n",
    "model_name = 'openai-community/gpt2-xl'\n",
    "tokenizer = AutoTokenizer.from_pretrained(model_name)\n",
    "model = AutoModelForCausalLM.from_pretrained(model_name).to(device)\n",
    "tokenizer.pad_token = tokenizer.eos_token"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 107,
   "metadata": {},
   "outputs": [],
   "source": [
    "# inspired by XXXX\n",
    "\n",
    "import torch\n",
    "import torch.nn.functional as F\n",
    "import tqdm\n",
    "from typing import Union, List\n",
    "from transformers import AutoModelForCausalLM, AutoTokenizer\n",
    "\n",
    "def compute_perplexity(\n",
    "    texts: Union[str, List[str]], \n",
    "    model: AutoModelForCausalLM, \n",
    "    tokenizer: AutoTokenizer,\n",
    "    stride: int = 128,\n",
    "    show_pbar: bool = False\n",
    ") -> torch.Tensor:\n",
    "    \"\"\"\n",
    "    Computes per-example perplexity for a batch of texts using a sliding window,\n",
    "    matching the internal label-shift used by the model.\n",
    "\n",
    "    Args:\n",
    "        texts (str or List[str]): A single text or a list of texts.\n",
    "        model (AutoModelForCausalLM): The causal language model.\n",
    "        tokenizer (AutoTokenizer): The tokenizer corresponding to the model.\n",
    "        stride (int): The stride used in the sliding window.\n",
    "        device (torch.device): The device to run the model on.\n",
    "        show_pbar (bool): If True, display a progress bar; otherwise, disable it.\n",
    "        \n",
    "    Returns:\n",
    "        A 1D tensor of perplexities (one per input text).\n",
    "    \"\"\"\n",
    "    # Ensure texts is a list.\n",
    "    if isinstance(texts, str):\n",
    "        texts = [texts]\n",
    "    \n",
    "    # Batch tokenization with padding.\n",
    "    encodings = tokenizer(texts, padding=True, return_tensors='pt')\n",
    "    input_ids = encodings.input_ids.to(device)         # shape: (B, L)\n",
    "    attention_mask = encodings.attention_mask.to(device)   # shape: (B, L)\n",
    "    B, L = input_ids.size()\n",
    "    max_model_length = model.config.n_positions  # maximum window size\n",
    "    \n",
    "    # Effective lengths (non-padding tokens) per example.\n",
    "    lengths = attention_mask.sum(dim=1)  # shape: (B,)\n",
    "    \n",
    "    # Initialize accumulators per example.\n",
    "    nll_sum = torch.zeros(B, device=device)\n",
    "    token_count = torch.zeros(B, device=device)\n",
    "    \n",
    "    # Track how many tokens have been scored for each example.\n",
    "    prev_end = torch.zeros(B, dtype=torch.long, device=device)\n",
    "    \n",
    "    # Use tqdm with the disable flag set to the inverse of show_pbar.\n",
    "    for begin_loc in tqdm.tqdm(range(0, L, stride), disable=not show_pbar):\n",
    "        end_loc = min(begin_loc + max_model_length, L)\n",
    "        window_size = end_loc - begin_loc\n",
    "        \n",
    "        # Get current window.\n",
    "        window_input_ids = input_ids[:, begin_loc:end_loc]\n",
    "        window_attention_mask = attention_mask[:, begin_loc:end_loc]\n",
    "        \n",
    "        # For each example, determine the effective end (if text ended before end_loc).\n",
    "        current_end = torch.minimum(torch.full((B,), end_loc, device=device), lengths)\n",
    "        # Number of new tokens for each example in this window.\n",
    "        valid_len = current_end - prev_end  # shape: (B,)\n",
    "        \n",
    "        # Prepare target_ids: start as a clone of the window.\n",
    "        target_ids = window_input_ids.clone()\n",
    "        # For each example, mask out tokens that have been scored before.\n",
    "        for i in range(B):\n",
    "            if valid_len[i] <= 0:\n",
    "                target_ids[i, :] = -100\n",
    "            else:\n",
    "                num_to_mask = window_size - valid_len[i]\n",
    "                if num_to_mask > 0:\n",
    "                    target_ids[i, :num_to_mask] = -100\n",
    "        \n",
    "        # If no example has any new token in this window, skip.\n",
    "        if (valid_len <= 0).all():\n",
    "            continue\n",
    "\n",
    "        # Forward pass to get logits.\n",
    "        with torch.no_grad():\n",
    "            outputs = model(window_input_ids, attention_mask=window_attention_mask)\n",
    "            logits = outputs.logits  # shape: (B, window_size, vocab_size)\n",
    "        \n",
    "        # ---- Apply label shifting to match internal loss computation ----\n",
    "        # The model's loss is computed on positions 1...window_size (using targets from 1...window_size)\n",
    "        # compared to logits for positions 0...window_size-1.\n",
    "        if window_size < 2:\n",
    "            # Not enough tokens to shift; skip this window.\n",
    "            continue\n",
    "        shift_logits = logits[:, :-1, :].contiguous()    # shape: (B, window_size-1, vocab_size)\n",
    "        shift_targets = target_ids[:, 1:].contiguous()     # shape: (B, window_size-1)\n",
    "        \n",
    "        # Compute per-token loss (no reduction)\n",
    "        loss_vals = F.cross_entropy(\n",
    "            shift_logits.view(-1, shift_logits.size(-1)),\n",
    "            shift_targets.view(-1),\n",
    "            reduction='none'\n",
    "        ).view(B, shift_logits.size(1))  # shape: (B, window_size-1)\n",
    "        \n",
    "        # Create mask for valid positions (where target != -100)\n",
    "        mask = shift_targets != -100  # shape: (B, window_size-1)\n",
    "        loss_sum = (loss_vals * mask.float()).sum(dim=1)  # per-example sum over window\n",
    "        num_tokens = mask.sum(dim=1).float()  # per-example count of tokens in this window\n",
    "        \n",
    "        # Accumulate losses and token counts.\n",
    "        nll_sum += loss_sum\n",
    "        token_count += num_tokens\n",
    "        \n",
    "        # Update pointer: all tokens in window have now been scored.\n",
    "        prev_end = current_end.clone()\n",
    "        if torch.all(prev_end >= lengths):\n",
    "            break\n",
    "\n",
    "    # Compute average negative log-likelihood per token per example.\n",
    "    avg_nll = nll_sum / token_count\n",
    "    ppl = torch.exp(avg_nll)\n",
    "    return ppl\n",
    "\n",
    "def batched_compute_perplexity(\n",
    "    texts: List[str],\n",
    "    model: AutoModelForCausalLM,\n",
    "    tokenizer: AutoTokenizer,\n",
    "    stride: int = 128,\n",
    "    batch_size: int = 64\n",
    ") -> torch.Tensor:\n",
    "    ppls = []\n",
    "    for i in tqdm.trange(0, len(texts), batch_size):\n",
    "        ppls.append(\n",
    "            compute_perplexity(\n",
    "                texts[i:i+batch_size], model, tokenizer, stride=stride)\n",
    "        )\n",
    "    return torch.cat(ppls)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 119,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead tr th {\n",
       "        text-align: left;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th colspan=\"8\" halign=\"left\">acf</th>\n",
       "      <th colspan=\"2\" halign=\"left\">prompt</th>\n",
       "      <th>...</th>\n",
       "      <th colspan=\"6\" halign=\"left\">tlcf</th>\n",
       "      <th colspan=\"2\" halign=\"left\">acf</th>\n",
       "      <th colspan=\"2\" halign=\"left\">tlcf</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th></th>\n",
       "      <th>cf_abstraction</th>\n",
       "      <th>cf_abstraction_distribution</th>\n",
       "      <th>cf_abstraction_id</th>\n",
       "      <th>cf_text</th>\n",
       "      <th>factual_abstraction</th>\n",
       "      <th>factual_abstraction_distribution</th>\n",
       "      <th>factual_abstraction_id</th>\n",
       "      <th>factual_text</th>\n",
       "      <th>cf_prompt</th>\n",
       "      <th>factual_prompt</th>\n",
       "      <th>...</th>\n",
       "      <th>cf_abstraction_id</th>\n",
       "      <th>cf_text</th>\n",
       "      <th>factual_abstraction</th>\n",
       "      <th>factual_abstraction_distribution</th>\n",
       "      <th>factual_abstraction_id</th>\n",
       "      <th>factual_text</th>\n",
       "      <th>abstraction_change</th>\n",
       "      <th>abstraction_p_increased</th>\n",
       "      <th>abstraction_change</th>\n",
       "      <th>abstraction_p_increased</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>3687</th>\n",
       "      <td>love</td>\n",
       "      <td>[0.011075822, 0.0012299945, 0.00060553127, 0.0...</td>\n",
       "      <td>18</td>\n",
       "      <td>[I'm 39 and still love being a painter,\" she e...</td>\n",
       "      <td>love</td>\n",
       "      <td>[0.027502172, 0.00645427, 0.0062332232, 0.0338...</td>\n",
       "      <td>18</td>\n",
       "      <td>[I'm 39 and still love being given the time of...</td>\n",
       "      <td>I'm 39 and still love being a</td>\n",
       "      <td>I'm 39 and still love being given</td>\n",
       "      <td>...</td>\n",
       "      <td>18</td>\n",
       "      <td>[I'm 39 and still love being a ghost.I don't n...</td>\n",
       "      <td>neutral</td>\n",
       "      <td>[0.0023383307, 0.0026369456, 0.014076343, 0.08...</td>\n",
       "      <td>27</td>\n",
       "      <td>I'm 39 and still love being given the time of ...</td>\n",
       "      <td>False</td>\n",
       "      <td>True</td>\n",
       "      <td>True</td>\n",
       "      <td>False</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5167</th>\n",
       "      <td>neutral</td>\n",
       "      <td>[0.007528358, 0.0017489385, 0.0064586983, 0.04...</td>\n",
       "      <td>27</td>\n",
       "      <td>[Now I can’t unpack you like this,\" he added, ...</td>\n",
       "      <td>neutral</td>\n",
       "      <td>[0.04082695, 0.011286443, 0.022810955, 0.06648...</td>\n",
       "      <td>27</td>\n",
       "      <td>[Now I can’t unhear the steady, soothing sound...</td>\n",
       "      <td>Now I can’t unpack</td>\n",
       "      <td>Now I can’t unhe</td>\n",
       "      <td>...</td>\n",
       "      <td>27</td>\n",
       "      <td>[Now I can’t unpack the knowledge I got for it...</td>\n",
       "      <td>sadness</td>\n",
       "      <td>[0.0007323831, 0.0023145257, 0.005041193, 0.02...</td>\n",
       "      <td>25</td>\n",
       "      <td>Now I can’t unhear the sound of my voice\\n\\nTh...</td>\n",
       "      <td>False</td>\n",
       "      <td>True</td>\n",
       "      <td>True</td>\n",
       "      <td>False</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3129</th>\n",
       "      <td>neutral</td>\n",
       "      <td>[0.009510105, 0.0006139145, 0.0008801412, 0.01...</td>\n",
       "      <td>27</td>\n",
       "      <td>[No disadvantages in stereotypes\\n\\nDisadvanta...</td>\n",
       "      <td>neutral</td>\n",
       "      <td>[0.03453425, 0.015363309, 0.0069924644, 0.0461...</td>\n",
       "      <td>27</td>\n",
       "      <td>[No disadvantages in stereotypes. He's been ab...</td>\n",
       "      <td>No disadvantages in stereotypes\\n</td>\n",
       "      <td>No disadvantages in stereotypes.</td>\n",
       "      <td>...</td>\n",
       "      <td>27</td>\n",
       "      <td>[No disadvantages in stereotypes\\n\\nNothing is...</td>\n",
       "      <td>neutral</td>\n",
       "      <td>[0.0042812102, 0.011158562, 0.004974131, 0.114...</td>\n",
       "      <td>27</td>\n",
       "      <td>No disadvantages in stereotypes.\\n\\n\\nCan be u...</td>\n",
       "      <td>False</td>\n",
       "      <td>True</td>\n",
       "      <td>False</td>\n",
       "      <td>True</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>359</th>\n",
       "      <td>neutral</td>\n",
       "      <td>[0.04535892, 0.0011685372, 0.001830566, 0.0127...</td>\n",
       "      <td>27</td>\n",
       "      <td>[Very little, and yet, some of their best acti...</td>\n",
       "      <td>neutral</td>\n",
       "      <td>[0.07218294, 0.002217058, 0.003235798, 0.02005...</td>\n",
       "      <td>27</td>\n",
       "      <td>[Very little, and yet, some days, good ol' Jef...</td>\n",
       "      <td>Very little, and yet, some of</td>\n",
       "      <td>Very little, and yet, some days</td>\n",
       "      <td>...</td>\n",
       "      <td>27</td>\n",
       "      <td>[Very little, and yet, some of those little th...</td>\n",
       "      <td>approval</td>\n",
       "      <td>[0.009655895, 0.037750673, 0.00079858844, 0.00...</td>\n",
       "      <td>4</td>\n",
       "      <td>Very little, and yet, some days of the week I ...</td>\n",
       "      <td>False</td>\n",
       "      <td>True</td>\n",
       "      <td>True</td>\n",
       "      <td>False</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4345</th>\n",
       "      <td>anger</td>\n",
       "      <td>[0.027632747, 0.009616762, 0.54481435, 0.26420...</td>\n",
       "      <td>2</td>\n",
       "      <td>[The fuck is a fortnight? Like, what the fuck ...</td>\n",
       "      <td>anger</td>\n",
       "      <td>[0.006209381, 0.039235707, 0.35787648, 0.29543...</td>\n",
       "      <td>2</td>\n",
       "      <td>[The fuck is a fortnight? Like the days, like ...</td>\n",
       "      <td>The fuck is a fortnight? Like,</td>\n",
       "      <td>The fuck is a fortnight? Like the</td>\n",
       "      <td>...</td>\n",
       "      <td>3</td>\n",
       "      <td>[The fuck is a fortnight? Like, what's a fortn...</td>\n",
       "      <td>anger</td>\n",
       "      <td>[0.0010770368, 0.0010117039, 0.45792034, 0.324...</td>\n",
       "      <td>2</td>\n",
       "      <td>The fuck is a fortnight? Like the weekend, lik...</td>\n",
       "      <td>False</td>\n",
       "      <td>True</td>\n",
       "      <td>True</td>\n",
       "      <td>False</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>5 rows × 22 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "                acf                                                     \\\n",
       "     cf_abstraction                        cf_abstraction_distribution   \n",
       "3687           love  [0.011075822, 0.0012299945, 0.00060553127, 0.0...   \n",
       "5167        neutral  [0.007528358, 0.0017489385, 0.0064586983, 0.04...   \n",
       "3129        neutral  [0.009510105, 0.0006139145, 0.0008801412, 0.01...   \n",
       "359         neutral  [0.04535892, 0.0011685372, 0.001830566, 0.0127...   \n",
       "4345          anger  [0.027632747, 0.009616762, 0.54481435, 0.26420...   \n",
       "\n",
       "                                                                           \\\n",
       "     cf_abstraction_id                                            cf_text   \n",
       "3687                18  [I'm 39 and still love being a painter,\" she e...   \n",
       "5167                27  [Now I can’t unpack you like this,\" he added, ...   \n",
       "3129                27  [No disadvantages in stereotypes\\n\\nDisadvanta...   \n",
       "359                 27  [Very little, and yet, some of their best acti...   \n",
       "4345                 2  [The fuck is a fortnight? Like, what the fuck ...   \n",
       "\n",
       "                                                                             \\\n",
       "     factual_abstraction                   factual_abstraction_distribution   \n",
       "3687                love  [0.027502172, 0.00645427, 0.0062332232, 0.0338...   \n",
       "5167             neutral  [0.04082695, 0.011286443, 0.022810955, 0.06648...   \n",
       "3129             neutral  [0.03453425, 0.015363309, 0.0069924644, 0.0461...   \n",
       "359              neutral  [0.07218294, 0.002217058, 0.003235798, 0.02005...   \n",
       "4345               anger  [0.006209381, 0.039235707, 0.35787648, 0.29543...   \n",
       "\n",
       "                             \\\n",
       "     factual_abstraction_id   \n",
       "3687                     18   \n",
       "5167                     27   \n",
       "3129                     27   \n",
       "359                      27   \n",
       "4345                      2   \n",
       "\n",
       "                                                         \\\n",
       "                                           factual_text   \n",
       "3687  [I'm 39 and still love being given the time of...   \n",
       "5167  [Now I can’t unhear the steady, soothing sound...   \n",
       "3129  [No disadvantages in stereotypes. He's been ab...   \n",
       "359   [Very little, and yet, some days, good ol' Jef...   \n",
       "4345  [The fuck is a fortnight? Like the days, like ...   \n",
       "\n",
       "                                 prompt                                     \\\n",
       "                              cf_prompt                     factual_prompt   \n",
       "3687      I'm 39 and still love being a  I'm 39 and still love being given   \n",
       "5167                 Now I can’t unpack                   Now I can’t unhe   \n",
       "3129  No disadvantages in stereotypes\\n   No disadvantages in stereotypes.   \n",
       "359       Very little, and yet, some of    Very little, and yet, some days   \n",
       "4345     The fuck is a fortnight? Like,  The fuck is a fortnight? Like the   \n",
       "\n",
       "      ...              tlcf  \\\n",
       "      ... cf_abstraction_id   \n",
       "3687  ...                18   \n",
       "5167  ...                27   \n",
       "3129  ...                27   \n",
       "359   ...                27   \n",
       "4345  ...                 3   \n",
       "\n",
       "                                                                             \\\n",
       "                                                cf_text factual_abstraction   \n",
       "3687  [I'm 39 and still love being a ghost.I don't n...             neutral   \n",
       "5167  [Now I can’t unpack the knowledge I got for it...             sadness   \n",
       "3129  [No disadvantages in stereotypes\\n\\nNothing is...             neutral   \n",
       "359   [Very little, and yet, some of those little th...            approval   \n",
       "4345  [The fuck is a fortnight? Like, what's a fortn...               anger   \n",
       "\n",
       "                                                         \\\n",
       "                       factual_abstraction_distribution   \n",
       "3687  [0.0023383307, 0.0026369456, 0.014076343, 0.08...   \n",
       "5167  [0.0007323831, 0.0023145257, 0.005041193, 0.02...   \n",
       "3129  [0.0042812102, 0.011158562, 0.004974131, 0.114...   \n",
       "359   [0.009655895, 0.037750673, 0.00079858844, 0.00...   \n",
       "4345  [0.0010770368, 0.0010117039, 0.45792034, 0.324...   \n",
       "\n",
       "                             \\\n",
       "     factual_abstraction_id   \n",
       "3687                     27   \n",
       "5167                     25   \n",
       "3129                     27   \n",
       "359                       4   \n",
       "4345                      2   \n",
       "\n",
       "                                                                       acf  \\\n",
       "                                           factual_text abstraction_change   \n",
       "3687  I'm 39 and still love being given the time of ...              False   \n",
       "5167  Now I can’t unhear the sound of my voice\\n\\nTh...              False   \n",
       "3129  No disadvantages in stereotypes.\\n\\n\\nCan be u...              False   \n",
       "359   Very little, and yet, some days of the week I ...              False   \n",
       "4345  The fuck is a fortnight? Like the weekend, lik...              False   \n",
       "\n",
       "                                           tlcf                          \n",
       "     abstraction_p_increased abstraction_change abstraction_p_increased  \n",
       "3687                    True               True                   False  \n",
       "5167                    True               True                   False  \n",
       "3129                    True              False                    True  \n",
       "359                     True               True                   False  \n",
       "4345                    True               True                   False  \n",
       "\n",
       "[5 rows x 22 columns]"
      ]
     },
     "execution_count": 119,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df.head()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "group = 'tlcf'\n",
    "ppls = []\n",
    "for cf_samples in tqdm.tqdm(df[(group, 'cf_text')].tolist()):\n",
    "    ppls.append(\n",
    "        compute_perplexity(cf_samples, model, tokenizer, stride=2).sum().cpu().item()\n",
    "    )\n",
    "df[(group, 'cf_text_ppl')] = ppls\n",
    "df[(group, 'cf_text_ppl')].describe()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 133,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 250/250 [06:55<00:00,  1.66s/it]\n"
     ]
    }
   ],
   "source": [
    "group = 'acf'\n",
    "ppls = []\n",
    "for cf_samples in tqdm.tqdm(df[(group, 'cf_text')].tolist()):\n",
    "    ppls.append(\n",
    "        compute_perplexity(cf_samples, model, tokenizer, stride=2).sum().cpu().item()\n",
    "    )\n",
    "df[(group, 'cf_text_ppl')] = ppls\n",
    "df[(group, 'cf_text_ppl')].describe()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 140,
   "metadata": {},
   "outputs": [],
   "source": [
    "# df[('acf', 'cf_text_ppl')] = df[('acf', 'cf_text_ppl')].apply(lambda x: sum(x))\n",
    "# df[('tlcf', 'cf_text_ppl')] = df[('tlcf', 'cf_text_ppl')].apply(lambda x: sum(x))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 147,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "count       250.000000\n",
       "mean     111236.820755\n",
       "std      137299.481232\n",
       "min         421.839950\n",
       "25%         930.726788\n",
       "50%       86298.502544\n",
       "75%      161584.720733\n",
       "max      900593.216788\n",
       "Name: (acf, cf_text_ppl), dtype: float64"
      ]
     },
     "execution_count": 147,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df[('acf', 'cf_text_ppl')].describe()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 148,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "count       250.000000\n",
       "mean     136589.725069\n",
       "std      145795.007704\n",
       "min         603.783047\n",
       "25%        3181.261127\n",
       "50%      101433.825531\n",
       "75%      201552.378000\n",
       "max      932871.122273\n",
       "Name: (tlcf, cf_text_ppl), dtype: float64"
      ]
     },
     "execution_count": 148,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df[('tlcf', 'cf_text_ppl')].describe()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 152,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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ji5dukRdXV2sWrUq9SgAAADQ5pKH9u233x5Tp06NH/zgB/Hyyy/H7bffHnfccUfcfffduTV33HFHTJ48OaZNmxaLFi2Kbt26xdChQ2Pz5s2pxwEAAIA2VZL6gL///e/j/PPPj/POOy8iIg477LB46KGH4plnnomIv1zNnjRpUtx4441x/vnnR0TEAw88EJWVlfH444/H8OHDU48EAAAAbSb5Fe0zzjgj5s6dGytXroyIiOXLl8fTTz8d55xzTkRErF69Ourr66Ouri73mvLy8hg4cGAsWLBgl8fcsmVLNDU15T0AAABgX5T8ivYNN9wQTU1N0a9fv+jQoUNs3749br311hgxYkRERNTX10dERGVlZd7rKisrc/v+3sSJE+Ob3/xm6lEBAAAgueRXtB955JGYOXNmPPjgg/Hss8/G/fffH3feeWfcf//97/uY48ePj8bGxtxj7dq1CScGAACAdJJf0b722mvjhhtuyN1rfcIJJ8Trr78eEydOjJEjR0ZVVVVERDQ0NETv3r1zr2toaIiTTjppl8csLS2N0tLS1KMCAABAcsmvaL/77rtRXJx/2A4dOkRLS0tERNTU1ERVVVXMnTs3t7+pqSkWLVoUtbW1qccBAACANpX8ivanPvWpuPXWW6Nv375x3HHHxXPPPRff+9734otf/GJERBQVFcXYsWPjW9/6Vhx55JFRU1MTEyZMiOrq6rjgggtSjwMAAABtKnlo33333TFhwoT42te+FuvWrYvq6ur48pe/HDfddFNuzXXXXRebNm2KUaNGxYYNG+LMM8+M2bNnR+fOnVOPAwAAAG2qKMuyrNBD7K2mpqYoLy+PxsbGKCsrK/Q47+muOSvj9DX3FnqMdq/28J5/fTJ4fOEGAQAADkh706HJ79EGAACAA5nQBgAAgISENgAAACQktAEAACAhoQ0AAAAJCW0AAABISGgDAABAQkIbAAAAEhLaAAAAkJDQBgAAgISENgAAACQktAEAACAhoQ0AAAAJCW0AAABISGgDAABAQkIbAAAAEhLaAAAAkJDQBgAAgISENgAAACQktAEAACAhoQ0AAAAJCW0AAABISGgDAABAQkIbAAAAEhLaAAAAkJDQBgAAgISENgAAACQktAEAACAhoQ0AAAAJCW0AAABISGgDAABAQkIbAAAAEhLaAAAAkJDQBgAAgISENgAAACQktAEAACAhoQ0AAAAJCW0AAABISGgDAABAQkIbAAAAEhLaAAAAkJDQBgAAgISENgAAACQktAEAACAhoQ0AAAAJCW0AAABISGgDAABAQkIbAAAAEhLaAAAAkJDQBgAAgISENgAAACQktAEAACAhoQ0AAAAJCW0AAABIqKTQA8CeWPDan3J/XrhtZQEnad+u+cRRhR4BAAD2e65oAwAAQEJCGwAAABIS2gAAAJCQ0AYAAICEhDYAAAAkJLQBAAAgIaENAAAACfkebdqd09fcW+gR2q8ne+56++DxbTsHAADsx1zRBgAAgISENgAAACTUKqH9xhtvxMUXXxw9e/aMLl26xAknnBBLlizJ7c+yLG666abo3bt3dOnSJerq6mLVqlWtMQoAAAC0qeSh/fbbb8egQYOiY8eO8atf/Speeuml+O53vxsHH3xwbs0dd9wRkydPjmnTpsWiRYuiW7duMXTo0Ni8eXPqcQAAAKBNJf8wtNtvvz369OkTM2bMyG2rqanJ/TnLspg0aVLceOONcf7550dExAMPPBCVlZXx+OOPx/Dhw1OPBAAAAG0m+RXtn//85zFgwIC46KKLolevXtG/f//40Y9+lNu/evXqqK+vj7q6uty28vLyGDhwYCxYsGCXx9yyZUs0NTXlPQAAAGBflDy0X3vttZg6dWoceeSR8etf/zq++tWvxlVXXRX3339/RETU19dHRERlZWXe6yorK3P7/t7EiROjvLw89+jTp0/qsQEAACCJ5KHd0tISJ598cnz729+O/v37x6hRo+KKK66IadOmve9jjh8/PhobG3OPtWvXJpwYAAAA0kke2r17945jjz02b9sxxxwTa9asiYiIqqqqiIhoaGjIW9PQ0JDb9/dKS0ujrKws7wEAAAD7ouShPWjQoFixYkXetpUrV8ZHPvKRiPjLB6NVVVXF3Llzc/ubmppi0aJFUVtbm3ocAAAAaFPJP3X8mmuuiTPOOCO+/e1vx2c/+9l45pln4t5774177703IiKKiopi7Nix8a1vfSuOPPLIqKmpiQkTJkR1dXVccMEFqccBAACANpU8tE899dR47LHHYvz48fGf//mfUVNTE5MmTYoRI0bk1lx33XWxadOmGDVqVGzYsCHOPPPMmD17dnTu3Dn1OAAAANCmirIsywo9xN5qamqK8vLyaGxs3Ofv175rzso4fc29hR4DIiKi9vCeu94xeHzbDgIAAO3M3nRo8nu0AQAA4EAmtAEAACAhoQ0AAAAJCW0AAABISGgDAABAQkIbAAAAEhLaAAAAkJDQBgAAgISENgAAACQktAEAACAhoQ0AAAAJCW0AAABISGgDAABAQkIbAAAAEhLaAAAAkJDQBgAAgISENgAAACQktAEAACAhoQ0AAAAJCW0AAABISGgDAABAQkIbAAAAEhLaAAAAkJDQBgAAgISENgAAACQktAEAACAhoQ0AAAAJCW0AAABISGgDAABAQkIbAAAAEhLaAAAAkJDQBgAAgISENgAAACQktAEAACAhoQ0AAAAJCW0AAABISGgDAABAQkIbAAAAEhLaAAAAkJDQBgAAgISENgAAACQktAEAACAhoQ0AAAAJCW0AAABISGgDAABAQkIbAAAAEhLaAAAAkJDQBgAAgISENgAAACQktAEAACAhoQ0AAAAJCW0AAABISGgDAABAQkIbAAAAEhLaAAAAkJDQBgAAgISENgAAACQktAEAACAhoQ0AAAAJCW0AAABISGgDAABAQkIbAAAAEhLaAAAAkJDQBgAAgISENgAAACQktAEAACChVg/t2267LYqKimLs2LG5bZs3b47Ro0dHz549o3v37jFs2LBoaGho7VEAAACg1bVqaC9evDjuueee+NjHPpa3/ZprroknnngiHn300XjqqafizTffjAsvvLA1RwEAAIA20WqhvXHjxhgxYkT86Ec/ioMPPji3vbGxMaZPnx7f+9734uMf/3iccsopMWPGjPj9738fCxcubK1xAAAAoE20WmiPHj06zjvvvKirq8vbvnTp0mhubs7b3q9fv+jbt28sWLBgl8fasmVLNDU15T0AAABgX1TSGgd9+OGH49lnn43FixfvtK++vj46deoUFRUVedsrKyujvr5+l8ebOHFifPOb32yNUQEAACCp5Fe0165dG1dffXXMnDkzOnfunOSY48ePj8bGxtxj7dq1SY4LAAAAqSUP7aVLl8a6devi5JNPjpKSkigpKYmnnnoqJk+eHCUlJVFZWRlbt26NDRs25L2uoaEhqqqqdnnM0tLSKCsry3sAAADAvij5W8eHDBkSzz//fN62yy67LPr16xfXX3999OnTJzp27Bhz586NYcOGRUTEihUrYs2aNVFbW5t6HAAAAGhTyUP7oIMOiuOPPz5vW7du3aJnz565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5ZezKVOm7PKrkHb372B3s8Cu/O2njmeZc5r255lnnslKSkqyW2+9NVu1alU2c+bMrGvXrtl//dd/5dbcdtttWUVFRfazn/0s+8Mf/pCdf/75u/wqpP79+2eLFi3Knn766ezII4/M+yqkDRs2ZJWVldkll1ySvfDCC9nDDz+cde3adaevQiopKcnuvPPO7OWXX85uvvnmXX4V0u5m4cA2cuTI7MMf/nDu671++tOfZoccckh23XXX5dY4pznQCO1Wcvfdd2d9+/bNOnXqlJ122mnZwoULCz0SB4CI2OVjxowZuTV//vOfs6997WvZwQcfnHXt2jX7zGc+k7311lt5x/mf//mf7Jxzzsm6dOmSHXLIIdnXv/71rLm5OW/Nk08+mZ100klZp06dssMPPzzvZ+ywu38HezIL/L2/D23nNO3RE088kR1//PFZaWlp1q9fv+zee+/N29/S0pJNmDAhq6yszEpLS7MhQ4ZkK1asyFvzpz/9Kfv85z+fde/ePSsrK8suu+yy7J133slbs3z58uzMM8/MSktLsw9/+MPZbbfdttMsjzzySHbUUUdlnTp1yo477rjsF7/4xV7PwoGtqakpu/rqq7O+fftmnTt3zg4//PDs3//93/O+hss5zYGmKMuyrJBX1AEAAGB/4h5tAAAASEhoAwAAQEJCGwAAABIS2gAAAJCQ0AYAAICEhDYAAAAkJLQBAAAgIaENAAAACQltAAAASEhoAwAAQEJCGwAAABL6/41PUrxfDapsAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 1200x700 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# plot two histograms showing the two distributions of ppl values\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "\n",
    "plt.figure(figsize=(12, 7))\n",
    "_ = plt.hist(\n",
    "    df[('acf', 'cf_text_ppl')],\n",
    "    alpha=0.5,\n",
    "    label='ACF'\n",
    ")\n",
    "_ = plt.hist(\n",
    "    df[('tlcf', 'cf_text_ppl')],\n",
    "    alpha=0.5,\n",
    "    label='TLCF'\n",
    ")\n",
    "plt.legend()\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 153,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/var/folders/zp/5fd9lh0x5tgcx_03zmfmm2sm0000gn/T/ipykernel_61864/2828876340.py:15: FutureWarning:\n",
      "\n",
      "\n",
      "\n",
      "Passing `palette` without assigning `hue` is deprecated and will be removed in v0.14.0. Assign the `x` variable to `hue` and set `legend=False` for the same effect.\n",
      "\n",
      "\n"
     ]
    },
    {
     "data": {
      "image/png": "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eTyeMvv5vv5bt27VxRdfrJiYGLVp00YvvPDCUcfcu3evrr32WjVq1EhJSUkaNWpUjV2mUhl79+7VlClTdMkllxwV0KWDH1Y++OCDFfp3A4BgRCcdAEw2bNgwTZ8+XXPmzCkzfDcvL0/ffvutbrrpJkVHRx/z+U8++aTGjx+vgQMH6q677tL27dv11ltv6ZdfftGqVasUHh5e6ZqGDBmiDh06aMKECfr111/13nvvKSkpSRMnTqzSa9y9e7ckqVmzZsfc584779T06dN1/fXX6z//+Y9+/vlnTZgwQX/88YfmzZsnSZo8ebLuu+8+xcbG+juSLVq0OOYxDcPQNddco6VLl+qOO+5Qz5499e233+qhhx7Svn37NGnSJCUmJurDDz/Us88+q5KSEk2YMEHSwaG5x/LBBx/o9ttvV7du3TRmzBg1btxYGzZs0KJFizR06FBNnjxZM2bM0Lx58/xDmc8888wTfp0GDx6sHTt2aNasWZo0aZK/u+oL1M8++6z++9//asiQIbrzzjuVnZ2t1157TQMGDNCGDRvUuHFjjRgxQp9//rlGjx6tSy65RG3bttXmzZs1fvx43XHHHbryyitltVr11ltv6a677tJ1112nwYMHS1KFajzSs88+K4vFokceeURZWVmaPHmyBg4cqI0bN5b5P5ufn68rr7xSQ4YM0U033aQ5c+borrvuUkREhG6//fYKn2/w4MFq3LixRo0apZtuuklXXnmlf5j477//rgsuuEDx8fF6+OGHFR4erilTpuiiiy7S8uXLjxo+fvfddysxMVFPPPGErFbrCc/98ccfq1OnTurbt6+6d++umJgYzZo1y/+hiiR9+eWXkqRbbrmlwq9JOvi9fqTQ0FA1adLkuM/54IMPFBsbq9GjRys2NlY//PCDnnjiCRUVFenFF18ss29+fr4uv/xyDR48WEOGDNHcuXP1yCOP6IwzztAVV1wh6eDw8r/+9a9KS0vT/fffr9atW+vDDz/UDz/8UKnXUhO++eYbud3uSn8dCwsLlZOTU2ZbMI9QANCAGQAAU7ndbqNVq1ZG//79y2x/++23DUnGt99+6982bdo0Q5KRkpJiGIZhZGVlGREREcall15qeDwe/36vv/66IcmYOnWqf9utt95qtGvXrsw5JBnjxo3z3x83bpwhybj99tvL7HfdddcZzZo1O+FrufXWW41G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r3Xr1po4caL27NmjU089VbNnz9bGjRv1zjvvVGmJwPI888wz+u6773T++efr7rvvVlhYmKZMmSKHw1HumuAVsX//fi1duvSoiQd9IiMjddlll+nTTz/V//73P4WHh2vGjBm69NJLNXjwYA0aNEh//etf1ahRI+3cuVOffPKJDhw4UO210s8991w1adJEt956q+6//35ZLBZ9+OGH1fqQaOTIkXr99dc1fPhwrV+/Xq1atdKHH37o/zCnpi1ZsuSoD7kk6dprr1X37t318ssva/fu3br//vv1+eef6+qrr1aTJk2UlpamTz/9VNu2bdONN95YK7UBgOlMmFE+IEky5s2b57//1VdfGZKMRo0albmFhYUZQ4YMMQzDMEaOHGlIMrZv3+5/3vr16w1JxrZt2+r6JQCoB9544w1DknH22WeX+/ifl2Dzef31140uXboY4eHhRosWLYy77rrrqGWgKrME25+XDTvWef/MtwTbifx5CTbDMAyXy2WMHz/e6NChgxEeHm60bdvWGDNmTJnlpAzDMDIyMoyrrrrKiIuLMySdcDm24uJiY9SoUUbr1q2N8PBw45RTTjFefPHFMsulGUbFl2Dz+fLLL41zzz3XiI6ONuLj442zzz7bmDVr1lGvsbJLsBmGYTz99NNGmzZtjJCQkKO+7p999plx/vnn+38vdenSxbjnnnv8v4sGDx5sxMXFGXv27ClzzPnz5xuSjIkTJ/q3rV692ujdu7cRERFRqeXYfEuwzZo1yxgzZoyRlJRkREdHG1dddZWRmppaZl/f13XdunVG//79jaioKKNdu3bG66+/Xma/6i7BZhiG8euvvxqXXXaZERsba8TExBgXX3yxsXr16jL7+P4v//LLLyd8nS+//LIhyViyZMkx9/nggw8MScb8+fP922w2m/HSSy8Zffv2NWJjY42IiAjjlFNOMe67774yy/5V5//IqlWrjHPOOceIjo42WrdubTz88MPGt99+e9Ryacf6f13ez4PU1FTjmmuuMWJiYozmzZsbDzzwgLFo0aJaWYLtWLcPP/zQv6/b7Tbee+8944ILLjASEhKM8PBwo127dsaIESPKLM9WmX9TAAgGFsMI0FlD6pjFYtG8efN07bXXSpJmz56tYcOG6ffffz9qwpXY2Fi1bNlS48aN03PPPSeXy+V/rLS0VDExMVq8eLEuueSSunwJ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9u3bfyiYH3z34XI1kWGEE9IBAA2e1WqV1WpT02pejy5JIRapcZRLWVl00oFAFVbRHf/3v/9V+KD3339/lYoB0DDl5ubK4bD7u+cHhchuT9TevftkGIYs1W0dAAAQpHxd76bR1bse3adZjFM7c/PlcrkUHh5eI8cEUHMqHNInTZpUof0sFgshHUCl7N27V5L+FNIP3i8t3a+8vDw1a9bMjNIAADBddna2JNVIJ12SmsQ4ZeQYysnJUatWrWrkmABqToVDekpKSm3WAaABS01NlSTZ7a3LbHc4WknaqLS0NEI6AKDB8nXSm1RzjXSfptEu/3EJ6UDgqfY16YZhyDCMmqgFQAOVlpYmSbLby75R8IV23+MAADREubm5kqQmUTXTSW98KKT7jgsgsFQ5pL///vvq3r27oqKiFBUVpe7du+u9996rydoANBCpqakyjDA5nc3LbPeFdl+nHQCAhignJ0fS4XBdXb7j+I4LILBUeLj7kZ544gm98soruu+++9S/f39J0po1azRq1CilpaXpqaeeqtEiAdRfXq9XaWlpsttbSAot85jT2VyGEUZIBwA0aDk5OQqxGIqPctfI8ZrQSQcCWpVC+ltvvaV3331XN910k3/bNddcozPPPFP33XcfIR1AhWVlZclutx811P2gENntLZWamiaPx6PQ0NBy9gEAoH7LzclRQpRbITW00EnjKEI6EMiqNNzd5XKpT58+R23v3bu33O6a+YQPQMPgm5TSbm9T7uOlpW3kdDqUkZFRl2UBABAQDMNQbl6uEmroenRJigr3KirMy3B3IEBVKaTfcssteuutt47a/s4772jYsGHVLgpAw3GikO6bPI4VJgAADVFJSYlcLneNhnRJio9yKj8vr0aPCaBmVGm4u3Rw4rjFixfrnHPOkST9/PPPSktL0/DhwzV69Gj/fq+88kr1qwRQb/nCd2npsUL6Sf79zj///DqrCwCAQJCfny9Jious2dGq8VFuJecWcjkZEICqFNK3bNmis846S5K0e/duSVLz5s3VvHlzbdmyxb+fxVJDF84AqLdSUlLkdsfL44kr93FfeKeTDgBoiPIOdbtrupOeEOmW1zBUWFiopk2b1uixAVRPlUL60qVLa7oOAA1QSUmJsrKyVFp6+jH38Xpj5HI1IaQDABokXye9pmZ294k7dLz8/HxCOhBgqrxOuk96errS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6t1335XD4TC7NACocwsXLtTrr7+u2Ai37jtvt9rQQUcAOaNlse48e488LoeefuopbdiwweyS0IAQ0oEAt3LlSt1zz71as2aNSko6a8eOR1VQcLYki9mloUpClZV1uXbvHqXS0hZasGCB7r//Aa57A9CgzJ8/X2+//bbiow4G9NbxfFiJwNO1RYn+r1+KDK9TTz/9NMuzoc4Q0oEAVVRUpBdeeEEvvPCCiors2rfveqWk3CuXq5nZpaEGlJa2065dDykra6D27z+gMWPGaOrUqXTVAdRrXq9X06ZN0/vvv6/G0W7df95utYzj5x4C12lJVv3rnBSFyKnnnn1WixcvNrskNACEdCAArVmzRnfffY9Wrlwpq7WTdux4RHl5A8S3bP1iGOHKzLxGu3f/W3Z7or744gs98MC/tW3bNrNLA4Aa53K5NGnSJM2bN08t4+wadcEuZnFHUDiluVX3n5usRhFuvf766/rkk09YqQW1KszsAgAcVlhYqHfffVcrVqyQYYTrwIHBys0lnNd3paUdtHPnw2rRYqEMY6keeeRRXXvt3zR06FBFRkaaXR4AVJvNZtOECRP022+/qWNTq0b2S1WjCI/ZZQEVdnKTUv37gl16a00HzZw5Uzk5ObrrrrsUGsrqOqh5vPMHAoBhGFq2bJnuuuturVixQlZrB+3Y8Yhycy8S36YNg2FEKCPjWiUnPyC7vZnmzZun++67X5s3bza7NAColvz8fD322GP67bffdGarQt19bgoBHUEpsZFToy7YpZMb27R48WJNmDCBy9RQK3j3D5gsOztbTz/9tF555RUVFTm0f//1Sk5+QE5nktmlwQQ2W0ft3PmIsrIG6sCBTI0dO1avv/4666oDCEppaWl6+OGHlJycrPPb5+r2vmmKCGWYMIJXXKRH952XotOTirV27Vo9/vjjys/PN7ss1DMBEdLfeOMNtW/fXlFRUerXr99xZ0589913dcEFF6hJkyZq0qSJBg4cyEyLCEper1dff/217r77Hq1bt07Fxadrx47HGN4OGUaEMjOv0a5d/1FpaRstXrxYd999j3766SezSwOACvv555/14IP/UWZmlq7qkqF/nLlfISxMUuMm/HCKxi7qorGLumh/UZQkaX9RlMYu6qIJP5xicnX1U2SYV//st0f92uZp+/btGj16lHbt2mV2WahHTE8Cs2fP1ujRozVu3Dj9+uuv6tGjhy677DJlZWWVu/+yZct00003aenSpVqzZo3atm2rSy+9VPv27avjyoGq27t3r8aMGaMpU6bIZgtVevot2rPnX3K5mppdGgKI3d5Wu3Y9qIyMQcrPL9Zzzz2niRMn8ok9gIBmGIbmzJmj5557Tl6XXbf3TdVlp2XLQkCvFSXOUBU7wlXsCJfXOPhF9hoWFTvCVeLkeunaEhoiDe21T3/rdkB5ebl69JFHtHz5crPLQj1hMUyemrBfv37q27evXn/9dUkHu4tt27bVfffdp0cfffSEz/d4PGrSpIlef/11DR8+/IT7FxUVKSEhQYWFhYqPj692/UBluFwuzZ07V59++qncbrcKCnpr//7B8njizC4tYHTu/IKio/eqtPQk7dr1sNnlBIyIiCy1aTNLsbG71ahRrEaMuE0DBw5USIjpn7UCgJ/dbterr76qVatWqWmMUyPPTlWbBLvZZdVrYxd1UbEjvNzH4iJdevZyVgypbVszYzV9fTuVukL097//XTfffDMTyuEolcmhpr67czqdWr9+vQYOHOjfFhISooEDB2rNmjUVOobNZpPL5VLTpuV3IB0Oh4qKisrcADNs2rRJ9913n2bNmqXS0jjt2fNPpaffSkBHhTidSUpJuU/79t2g4mKPXn/9dY0ZM0ZpaWlmlwYAkqSsrCw98vDDWrVqlTo3L9GDA3YR0NEgdG1Rov8M2KmkWIc+++wzPfvss7JarWaXhSBmakjPycmRx+NRixYtymxv0aKFMjIyKnSMRx55RK1bty4T9I80YcIEJSQk+G9t27atdt1AZRQWFmrSpEl6/PHHtW9fhrKzL9aOHY+puLi72aUh6IQoL+88bd8+VgUFZ+mPP/7Q/fc/oOnTpzO7LABTbdiwQaNHjVLKnj0a0CFH9/RPUWwkM7ij4UiKdeo/A3apW4sirVu3Tg8++B+lpKSYXRaCVFCPk3z++ef1ySefaN68eYqKiip3nzFjxqiwsNB/S09Pr+Mq0VB5vV4tXrxY//rXXVq6dKlstnaHri++Tl4va1+j6tzueKWn36aUlLtktzfWZ599pnvuuVfr1683uzQADYzb7db06dM1btw42axFurHHXl1/5gGFBvU7TKBqosO9GtkvVZeckqV9+/broQcf1DfffCOTry5GEAoz8+TNmzdXaGioMjMzy2zPzMxUy5Ytj/vcl156Sc8//7y+//57nXnmmcfcLzIyUpGRBCLUrbS0NL355pvaunWrvN4oHThwvfLyzleQfy6GAFNScrp27BijpKRvZRhLNH78eJ1//vm68847j3kJEADUlMzMTL300kvavn27Ehs5dFufNLVtzPB2NGwhFmlQ10x1bGbTx7+21VtvvaXffvtN9957r2JjY80uD0HC1MQQERGh3r17a8mSJf5tXq9XS5YsUf/+/Y/5vBdeeEFPP/20Fi1apD59+tRFqUCF2Gw2TZ06Vfff/4C2bt2qgoJe2r59rPLyWFYNtePgcm2DtHPnI7JaO2rlypX617/u0rx58+R2u80uD0A9tXr1av373w9o+/btOrttvh66cBcBHThCtxbFeuSiHTqleYlWr16tBx54QNu2MYkfKsbUTrokjR49Wrfeeqv69Omjs88+W5MnT5bVatWIESMkScOHD1ebNm00YcIESdLEiRP1xBNPaObMmWrfvr3/2vXY2Fg+nYJpDMPQsmXLNG3aByooyJfTmah9+/6ukpKuZpeGBsLhaKXk5PvVpMnPatVqgaZNm6bFi7/TP/85Ur169TK7PAD1hMPh0NSpU/XNN98oIsyrm3vt09knF5hdFhCQEqLduufcFC3ekaRvthsaM+ZR3XzzLbruuutYnQXHZXpIv+GGG5Sdna0nnnhCGRkZ6tmzpxYtWuSfTC4tLa3Mf+K33npLTqdT119/fZnjjBs3Tk8++WRdlg5Iknbv3q0pU6Zo27Zth7qaVysn52IZRvnLoQC1J0T5+f1VWNhDLVoslGH8qHHjxql///664447lJSUZHaBAILYrl279OrkyUpNS1ObhFKN6JOmpFin2WUBAS3EIl1+WpZOaV6i6etP1vTp07Vx40bdd999/F7GMZm+TnpdY5101JSioiJ99NFH+vbbb2UYhgoKzlJGxt/kcjUxu7SgxjrpNScqap9atZqr2NjdCg+P0D/+cb2uu+465ukAUCkul0uzZs3S559/Lq/XqwEdcvS3bhkKD21QbyEDFuukBw+rM1QzN7TR5owERUVF6rbbRujyyy+nq95AVCaHmt5JB4KNx+PRt99+qw8//EhWa4ns9lbav/96Wa2nmF0aUIbd3kYpKfcrIeFXtW79hWbOnKnvv1+iO+64Xeecc44sFovZJQIIcNu3b9err76qvXv3qlkjp4b23KtTmrP+M1AVjSI8uvPsNK3b21ifbWmtt99+WytXrtT9999/wkmz0bAQ0oEKMgxD69at07Rp07R37155vdHKyPi7cnPPlxRqdnnAMVhUWNhbxcXdlZj4rQxjqSZMmKCuXbvq9ttv16mnnmp2gQACkMPh0MyZM/XFF19IhlcXdszV1adnKDKM7jlQHRaL1LdtgU5LLNGnm1rrty1bdN999+qWW4br6quvpqsOSYR0oEJ2796tqVOnavPmzTKMEOXlna/MzCvk8cSZXRpQIV5vpDIzr1F+/jlq2XKBtm79TQ8++KAGDBigW265xT8PCABs3bpV/3v1Ve0/cEBJsQ4N7blXHZvZzC4LqFfio9y64+w0bdgXr083n6T33ntPq1at0v333682bdqYXR5MRkgHjiM7O1sffvihli1bJkkqKuqujIy/yeEg0CA4OZ1JSku7QzExyWrVap5WrFih1atXa9CgQfrHP/7BKhlAA3bkXCuSV3/tnKMrumQqgmvPgVrTq02ROjffrs83t9b6P/7QA/ffr+v/8Q8NHjxYERERZpcHkxDSgXJYrVbNnTtX8+d/KbfbJZvtZGVk/I3rzlFv2GwdtXv3aCUkbFDLlgs0b948LV78nW666UZdccUVCg9ndQKgofB4PPruu+80Y8Z0lZRY1Srerpt67FX7pqVmlwY0CHGRHt3aJ1292hTo000naebMmVqyZIlGjhyps88+2+zyYAJCOnAEp9OpRYsWafbsOSouLpLL1UQHDgxSYeFZkrhGCPWNRYWFZ6mo6Aw1bbpSLVp8q/fee08LFnylm28epgsuuIBr44B6btu2bZoyZYp2796tqHCvBnfP0AUdchXKtz5Q585sVazTErfr2+2JWpps6JlnnlGfPn105513qnXr1maXhzrEEmyADi4v8/3332v27DnKy8uV1xutzMxLlJt7Ieud14FTTpmg0NASSVJYmFUWi1eGESK3u5E8nljt3DnG5AobhtBQqxITF6t58x9lsbh18sntNGzYUGaCB+qhgoICTZ8+XUuWLJEk9Wubp0FdMxUf5Ta5MlQWS7DVT5nFEfpsc2tty45TWFiYBg8erOuvv15RUVFml4YqYgk2oII8Ho+WLVummTNnKTs7S15vhHJyLlVOzsXyeBqZXV6DERpaovDw4jLbLBbvUdtQuzyeRsrIuE65uRcqKelbGcbPmjBh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Cum8phL5P053J6JR8eabbyInJwc6nQ4/+tGP8Ne//hWiKAIA/vnPf2L+/PlDbiYGBAcHQ6vVjna5REREfonXVCL/x5BORKNi06ZN+NGPfgTAM72ut7cXn3/+OQCgpqYGOTk55/U527ZtQ0hIiPd18803j1jNRERE/obXVCL/x+nuRDTiqqursX//frz77rsAALlcjh/84AfYtGkT5s6d6x1RPx/f+ta38OKLL3r/nSMCREREg3hNJfJ/DOlENOI2bdoEp9PpbRQHeG4ilEolNmzYgAkTJqCqquq8Pkur1SIrK2ukSiUiIvJrvKYS+T9OdyeiEeV0OvHaa6/hueeew+HDh72vI0eOICEhAZs3b8att96KTz75BKWlpWd8vcPhgMlkkqByIiIi/8NrKpH/40g6EY2obdu2obu7G3feeSfCw8OHnPvud7+LTZs24YsvvsD27dtx3XXXYeXKlbjqqqsQGhqKkpISPPvss9i0aZN3uxgiIiLCkK3ZBuTn5+O+++7jNZXIzzGkE9GI2rRpE+bPn39GQAc8IX316tWorq7Gzp07sW7dOrz00kt44IEHoNFokJubi1/+8peYOHGiBJUTERH5rltuueWMY83NzUhKSuI1lcjPCeKFdJcgIiIiIiIiohHDNelEREREREREPoIhnYiIiIiIiMhHMKQTERERERER+QiGdCIiIiIiIiIfwZBORERERERE5CMY0omIiIiIiIh8BEM6ERERERERkY9gSCciIiIiIiLyEQzpRERERERERD6CIZ2IiCgAtLW1Yfny5cjKyoJKpUJcXBzmzJmDF198EWazWeryiIiIqJ9c6gKIiIhoZOn1esyZMwcRERF4+umnMWnSJCiVSpSVleHPf/4zEhMTcf3115/xdQ6HA8HBwRJUTEREFLg4kk5ERDTG3X333ZDL5SgpKcH3v/995ObmIiMjAzfccAO2b9+OpUuXAgAEQcCLL76I66+/HlqtFr/73e8AAC+++CIyMzOhUCig0+nw97//3fvZDQ0NEAQBhw8f9h7r6emBIAjYtWsXAGDXrl0QBAHbt2/H5MmToVKpMGvWLJSXl4/anwEREZG/YEgnIiIawzo7O7Fjxw784he/gFarPet7BEHw/vrJJ5/EjTfeiLKyMtxxxx149913sXz5cvzv//4vysvLcdddd+H222/HZ599dsG1rFixAs899xwOHDiA2NhYLF26FA6H46K/NyIiorGIIZ2IiGgMq62thSiK0Ol0Q47HxMQgJCQEISEhePDBB73Hb731Vtx+++3IyMhASkoK1q5di9tuuw133303JkyYgPvvvx833XQT1q5de8G1PPHEE1iwYAEmTZqEv/3tb2hvb8e77757yd8jERHRWMKQTkREFID279+Pw4cPIz8/HzabzXt8+vTpQ95XWVmJOXPmDDk2Z84cVFZWXvDveeWVV3p/HRUVBZ1Od1GfQ0RENJaxcRwREdEYlpWVBUEQUF1dPeR4RkYGAECtVg85fq4p8ecik3me94ui6D3GKexEREQXjyPpREREY1h0dDQWLFiADRs2wGQyXfDX5+bmYu/evUOO7d27F3l5eQCA2NhYAMCJEye8509vIne64uJi76+7u7tx7Ngx5ObmXnBNREREYxlH0omIiMa4F154AXPmzMH06dPx5JNPYvLkyZDJZDhw4ACqqqpwxRVXnPNrV6xYge9///soKCjA/PnzsXXrVrzzzjv45JNPAHhG4mfNmoVVq1YhPT0dJ0+exKOPPnrWz3rqqacQHR2NuLg4PPLII4iJicGyZctG4lsmIiLyWwzpREREY1xmZiZKS0vx9NNP46GHHkJLSwuUSiXy8vLwwAMP4O677z7n1y5btgzPP/881q5di+XLlyM9PR2vvPIK5s6d633PX//6V9x555244ooroNPpsHr1anz7298+47NWrVqF5cuXo6amBlOnTsXWrVuhUChG4lsmIiLyW4J4+iIyIiIiosts165d+Na3voXu7m5ERERIXQ4REZFP45p0IiIiIiIiIh/BkE5ERERERETkIzjdnYiIiIiIiMhHcCSdiIiIiIiIyEcwpBMRERERERH5CIZ0IiIiIiIiIh/BkE5ERERERETkIxjSiYiIiIiIiHwEQzoRERERERGRj2BIJyIiIiIiIvIRDOlEREREREREPuL/A9AiY2t11pe8AAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 1200x700 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "import pandas as pd\n",
    "\n",
    "# Create a new DataFrame with two columns: one for the values and one for the group labels.\n",
    "acf_values = df[('acf', 'cf_text_ppl')]\n",
    "tlcf_values = df[('tlcf', 'cf_text_ppl')]\n",
    "\n",
    "data = pd.DataFrame({\n",
    "    'cf_text_ppl': pd.concat([acf_values, tlcf_values], ignore_index=True),\n",
    "    'Group': ['ACF'] * len(acf_values) + ['TLCF'] * len(tlcf_values)\n",
    "})\n",
    "\n",
    "plt.figure(figsize=(12, 7))\n",
    "sns.violinplot(x='Group', y='cf_text_ppl', data=data, palette={'ACF': 'blue', 'TLCF': 'orange'})\n",
    "plt.title(\"Violin Plot of cf_text_ppl for ACF and TLCF\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Finding Interesting Case studies"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "only_acf_change = df[df[('acf', 'abstraction_change')] & ~df[('tlcf', 'abstraction_change')]]\n",
    "only_tlcf_change = df[df[('tlcf', 'abstraction_change')] & ~df[('acf', 'abstraction_change')]]\n",
    "both_change = df[df[('acf', 'abstraction_change')] & df[('tlcf', 'abstraction_change')]]\n",
    "no_change = ~df[('acf', 'abstraction_change')] & ~df[('tlcf', 'abstraction_change')]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {},
   "outputs": [],
   "source": [
    "# TODO should we condition on the same observation? probably not, otherwise the sampling on acf makes less sense"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [],
   "source": [
    "example = only_tlcf_change.iloc[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "MultiIndex([(   'acf',                   'cf_abstraction'),\n",
       "            (   'acf',      'cf_abstraction_distribution'),\n",
       "            (   'acf',                'cf_abstraction_id'),\n",
       "            (   'acf',                          'cf_text'),\n",
       "            (   'acf',              'factual_abstraction'),\n",
       "            (   'acf', 'factual_abstraction_distribution'),\n",
       "            (   'acf',           'factual_abstraction_id'),\n",
       "            (   'acf',                     'factual_text'),\n",
       "            ('prompt',                        'cf_prompt'),\n",
       "            ('prompt',                   'factual_prompt'),\n",
       "            (  'tlcf',                   'cf_abstraction'),\n",
       "            (  'tlcf',      'cf_abstraction_distribution'),\n",
       "            (  'tlcf',                'cf_abstraction_id'),\n",
       "            (  'tlcf',                          'cf_text'),\n",
       "            (  'tlcf',              'factual_abstraction'),\n",
       "            (  'tlcf', 'factual_abstraction_distribution'),\n",
       "            (  'tlcf',           'factual_abstraction_id'),\n",
       "            (  'tlcf',                     'factual_text'),\n",
       "            (   'acf',               'abstraction_change'),\n",
       "            (   'acf',          'abstraction_p_increased'),\n",
       "            (  'tlcf',               'abstraction_change'),\n",
       "            (  'tlcf',          'abstraction_p_increased')],\n",
       "           )"
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "example.keys()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "<|begin_of_text|>I'm 39 and still love\n",
      "I'm 39 and still single\n"
     ]
    }
   ],
   "source": [
    "# print all the prompts \n",
    "print(example[('prompt', 'factual_prompt')])\n",
    "print(example[('prompt', 'cf_prompt')])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "TLCF\n",
      "\n",
      "tlcf factual text:\n",
      "<|begin_of_text|>I'm 39 and still love my life in the middle west but I've had feelings about this country that are getting stronger. I've decided to live in the mid-south but I don't know how to tell the people that I live with. I need some advice about how and where to start this conversation. I need someone who has been through this before.\n",
      "I was trying to work on how to bring up a conversation with\n",
      "\n",
      "tlcf factual abstraction:\n",
      "love\n",
      "\n",
      "\n",
      "tlcf counterfactual text:\n",
      "[\"I'm 39 and still single, you're the first Person to write to me, otherwise this letter will never reach. Serious Man - Desert Storm Description : Nick Khanji Admitted To Hospital - Veradyu | Natash - Intimate Stories 2017-04-22, 14:21\\nDefinitely I'm putting every thing in my Erotica Essay, I'll put music so that the people can enjoy\", \"I'm 39 and still single. Know why... we have to hold our marriage session and completion right on 30th October this year in Norfolk.\\nNot the easiest since we live almost 300 miles apart, but I love him, I love Emma (Emma Bickley) and I know she loves him...and I love the male lead. Hmmm!\\nSo, we are trying to communicate better during the session, before\", \"I'm 39 and still single. I don't get too concerned about my relationship status until I'm married. I don't mind living with my girlfriend and sharing an apartment. I'm looking for a man who is not jealous. I'm also looking for a hot boyfriend. I want this hook-up to be casual so I can have fun. I'm interested in meeting you at your place. I'm waiting for a date without\", \"I'm 39 and still single, and in the middle of maternity leave. My younger brothers are married with families of their own, and we were together all the way up until they got married: my very first marriage.\\nWhen we eventually called it off for a good long-time there was no talk of children, no talk of settling down. Education was very important to us. I had spent 20 years in an authoritarian part of\", \"I'm 39 and still single.\\nDescribe the ideal guy: passionate, thinks outside the box, respects me...\\nFavorite movie: Wo hu cang long\\nIf you're the cowboy princess. So here is a video of me rapping about my dirty cowboy lifestyle.\", \"I'm 39 and still single. Yes single. I have been going around the town and trying to meet a nice guy ( WHO WANTS ME) or start afresh (SMH). Maybe sharing Disney (AW) with the boys and girls ( AWW)-Goosebumps is silly.\\nThis April, I am travelling out to Singapore. (I will tell more of my amazing journey including story why foreigner can love\", \"I'm 39 and still single. I'm very reliable, but a bit shy.\\nRebekkahsUtitatus. well I have hot very feminine curvaceous bodyneeding your body, i am aware of my body and how to please a man.thats about all and more im looking to navigate the rough sea of dating.\", \"I'm 39 and still single? Have I been good to myself? I assert I haven't. Have you had a similarly difficult time?\", \"I'm 39 and still single. And I am the best possible guy. I'm about 6 feet, like 210 pounds, really good stamina, very romantic.\\nWell, so as I said, Melanie wasn't sure - and now with your penis, I wouldn't pronounce and get it in bed. The morning I was bringing - I was given a penis, my wife, and - to Mario, he was going to\", \"I'm 39 and still single...At almost the beginning of my career I had a boyfriend but he kinda deserted me so i went my own way trying to get my designs noticed but nothing was happening...Now, suddenly, The Muse has arrived, and I need to trust her.There's no problem situations or any problems...but, strangely, I'm unable to make her look anything like Baby Doll again...Sallum, I\", \"I'm 39 and still single. I have a thing for strong, silent type men. And I'm originally psychiatric social worker who does not trust people or talk to random strangers :) Due to a hectic life, I miss my friendliness and also my straight- personality trait. Please dont be offended or anything ;) I just need someone who can occupy my attention whilst our started chats. I just dealt how much unpleasant experience a man deserves\", 'I\\'m 39 and still single but I\\'m busy taking down my boyfriend and my mistakes will be...just as painful as what I\\'ve done to them. Stay away from this world..Stay away..\"', \"I'm 39 and still single. My brother, Sam, and I are hotshot engineers hired to fix the broken marriage of my father, a major in the Squadrons. No one knows why isn't he on the front lines yet. We get the hotbed of a mishmash of a house just as I get the offer to test synphonic implants into some brainstorms. Now I'm pregnant and we're married\", \"I'm 39 and still single...@melissa dyers\\n30. matt schultz/wafering kids. @mathewj schultz\\nWhen I first realised the extent of the funding for Muslim immigrants to stock North Kilburn High with the best and the brightest, and the cultural riches from sharia, it did not surprise me, quite the opposite in fact. And it was not unlike Steve King's statement that\", \"I'm 39 and still single, 24 yrs like that but happier now(please feel welcome to inbox or message me on that).\\nStop littering the streets with all these 'advertisements' /pleasure merry-go-rounds and stop wasting water via these gazebos and showering devils(in cave) and bathrooms. Make water costs high and stick to plastic altogether. Shorter.println.MIA 10% water\", \"I'm 39 and still single. Matrimony is within my range for this month. I need a man with a big romance, who can live in the beautiful city of Maricarmo. I am looking for a man who is non-judgmental with a large and very windy play, well-endowed and with lengthy sexerches moments. In order to reach communication with me, just use the hookup site and\", 'I\\'m 39 and still single who loves to go partying and discovering new restaurants. If you\\'re looking for an adventurous person you won\\'t find anything more than what you can find. I don\\'t care about any felony \"\\nKeywords: 40s woman, partying, single and looking\\nJudy C. I need someone who loves London but has a taste for roaming the world.\\nMore than a DBO a true gentleman', \"I'm 39 and still single. I'm a provider, but I don't want anyhow else to make me obligated. I am spontaneous, and I want sex the entire week. I want you to leave a message with the message that I have your eyes open. I'm here and ready to receive your expectations. I hope you can meet me for a encounter.\\nLooking for a comforting guy on Bartlett\\nFirst name: Mar\", 'I\\'m 39 and still single. Part of the problem is there is no one else I\\'m interested in romancing. Thank you for the comment.\\n\"Like CookiePedia\\'s shared bedroom. If you take them to try your hand at packing, then break out your Sigg and tell them how solo travel had improved their game.\" yum', \"I'm 39 and still single. Hi, my name is Steve and I live in New York City. My girlfriend, Lisa Jones, and I live together. She's Mexican and I'm white. We live in Astoria, Queens. My sister lives in Litttle Rock, Arkansas with her family. She is 27 years old and is married. We emailed her, expecting a date.\\nI thought there'd be one\", \"I'm 39 and still single, have in the past 2 years a good relationship with a guy that i tell all about my BaCon Afr.The problem is you dont understand the difference between the hype and how 40 yr olds ( me ) have a harder time understanding the hype!\\nHi there...I'm married. Last year my husband and I went to New Orleans trying to get another angle but it didn't work...\", \"I'm 39 and still single.\\n_COPY AND PASTE_ ONLY.\\nA woman can be so easy to spot.\\nMany say that meeting someone through Skype\\nis the pinnacle of dating apps.\\nJust like that, sparks fly and time flies.\\n'Will I need to block him out of my head,\\nto make it seem like someone else?\\nwill I have to look the other way when he asks for cash?\\nWill I have to\", \"I'm 39 and still single. Obviously my go to's are tremendous. I'm told that's not true and sometimes I think that's okay and sometimes I think it's not true and it's starting to scare me. What do you think I really need to do about this? I'm already a pretty happy person and I just want to be as happy as I can be. I don't hate my life but there are\", \"I'm 39 and still single. life has a way of letting you down. I believe this is God's roadmap to perfection. He is my excuse, I am his witness, my remorse will lead me to perfection. peace ml\\n  3. W18,,I believe the process of filialation is recognition of conviction and/or agreeing to fix the situation. Two down-three to go. Thanks, I will plow\", \"I'm 39 and still single (active in the dating scene but not going too far or anything), freakishly handsome and I wanna tell you why.\\nThe sickness you’re going through right now makes you realize just how good you’ve got it. About as good as it gets, and I use that term literally, I mean, you’re looking pretty damn good.\\nYou must have experienced some pain, something very painful, but nothing\", \"I'm 39 and still single! Want to be married tonight! I've had fun fantasies about marriage, am trying to find the real thing... and I'm totally open to doing whatever it takes! sexyslarter56@hotmail.com\\n~ Honeys\\nThey say you can never find the real thing over the internet. Well I found the real thing at Fool's Glass. I'm in need of a bondage lesson so\", \"I'm 39 and still single. I think the main reason was that I had feelings for my cousins that I was either too afraid to act on, or too scared they'd find out about the situation. The last 2 guys trusted me and asked me to give them a go and once they saw me it was 'over.'\\nI then moved to Courtenay, and the thought of a relationship was something I just swore I\", \"I'm 39 and still single so bored with the dating scene here. I enjoy sewing and crafts, that are all the rage these days, and enjoy the mental gymnastics it sometimes requires. I'm creative, funny and smart. I live in Oakland with my rescue goldendoodle and hang out a lot in watsons. For hobbies, I'm a fan of finishing things: socks, ties, my clothes, etc.\", 'I\\'m 39 and still single.\" At that time, he could not marry because feelings were still too narcissistic. He still lives alone and still cannot marry.\\n5. According to the narcissism literature review, the following is the theory of narcissistic tendencies:\\nA. Paradoxical neurosis theory\\nB. Horney method theory\\nC. Schutz method theory\\nD. Fragmented ego theory\\nE. Object-rel', \"I'm 39 and still single, enjoying my life and focusing on pure fun. My dreams have taken me from my native village of Tampa, Florida to the mountains of Spain and now I live in Aix-en-Provence, France. Although I'm now living in the most picturesque place on Earth, I still live not far from my native city. I'm a self taught musician and writer but also an accountant, so if\"]\n",
      "\n",
      "tlcf counterfactual abstraction:\n",
      "neutral\n",
      "ACF\n",
      "\n",
      "acf factual text:\n",
      "[\"I'm 39 and still love girls.\\nI have had no prior relations.\\nIn the past i used to think that girls are always perfect and that the ideal girl is the type of girl who is a lot of fun, but as i grew older i have found out otherwise.\", \"I'm 39 and still love my wife. She's 50 and likes me.\\nI just bought myself a wife. I would be interested in a wife to start off the relationship. My wife is 49 and has done great. She likes me and I like her.\\nMy name is Mike. I’m 36 years old and I’m from New Jersey. I’m from the Tri\", \"I'm 39 and still love doing what I love. When I'm not teaching (the best job ever!), I'm playing bass in a couple of rock bands, tending bar, running marathons, and writing and posting on TheWriteOut. I live in St. Petersburg, FL with my lovely wife and my handsome hound.\", \"I'm 39 and still love and care for my firstborn, who's 27, a terrific young man. His wife just had a baby in December, who is also a terrific young man, and we are both very close to him. However, even though he's still in high school, and as I explained to his wife, a very responsible young man who keeps his grades up\", \"I'm 39 and still love dancing with people.\\nWe had fun every Sunday at the studio, playing and rehearsing our choreographies. And of course the guys were too crazy to stay away from the girls. I can't remember the first one that I met but it was a woman.\\nYes. Not a little one but very tall.\\nAny kind of dance is great. I only started\", 'I\\'m 39 and still love my job. I think a lot about how lucky I am. I\\'ll never forget a young, white male student came up to me and said, \"You have the strangest eyes.\" I\\'m white, but this kid was Asian, so I didn\\'t take offense. I realized afterwards, I had a Japanese-looking face.\\nI had several female students say', \"I'm 39 and still love reading the New York Times on my iPhone. There are a few online sources I like to use to find articles for reference. But in the past I've been using the Apple News app for reading articles online. But I didn't like it, mostly because I didn't like using an app just for reading things. So I decided to try a new service from\", 'I\\'m 39 and still love a lot of \"boy\\'s\" stuffs. I just dont think thats the path I\\'m supposed to go. I loved the drama of the boy\\'s I used to be able to talk to about life and my feelings. I also liked the intimacy of their private conversations about things like, \"What do I want to do this summer?\" I guess they don', \"I'm 39 and still love my job in a law firm. At least I guess I do. I make the right decisions and meet the right people and feel good about it. Except I think some of the people in the Firm should be doing other jobs, like having a happy family.\\nEvery single day I see people being unhappy at work. So unhappy that they have to hide their stress\", \"I'm 39 and still love flowers.\\nI know my flowers!\\nI love all types of flowers...lilies, daisies, orchids, etc. I love all colors and just can't get enough of them...and I love to decorate with them...all year long...they add a bit of spring to the dreary winter months.\\nHere's to always loving them...fl\", \"I'm 39 and still love my job as a full time schoolteacher. I'm in a great position at my school, teaching and tutoring students in Math, Spanish, English, and Science. I am also a teacher and trainer for a non-profit organization, helping under-privileged children in Peru learn English. I believe I am an excellent teacher. My goal is to help my students have\", \"I'm 39 and still love to see and feel.\\nYes I am, and so is he. Just looking for someone to spend quality time with and just have some fun.\\nI am a 39 yr old retired Army nurse. I love to read, hike, sing and spend time with my grandkids.\\n40 now, been widowed 8 years, enjoying life and making more memories\", \"I'm 39 and still love my boy.\\nI have always been a one-woman band - a bit of a loner, and not overly social. I love to paint and drink coffee but for some reason find my life boring, so I do not make a lot of friends. There's an opening in the creative department.\\nI've been looking for a partner to spend more of my\", \"I'm 39 and still love to rock! For my birthday last year, my boyfriend bought me this awesome Guitar (the Ovation USA V4). It's been an awesome experience and just one of the reasons I love guitar! One of my favorite things to do, other than playing guitar, is to put on a show. I perform in local bars around town, and on the weekends\", \"I'm 39 and still love my 25-year-old body. At my age, women start to get more sensitive to chemicals. I'm a beauty guru and beauty editor, and I have a beauty company. I started a natural hair company.\\nWhat is a body lotion made of?\\nIt's mostly mineral oil and fragrances that can cause irritation, so look for lotion that is without the\", 'I\\'m 39 and still love \"sex work.\" This is something I can\\'t help but be passionate about. Here are 10 reasons why!\\nI can\\'t help but be passionate about \"sex work.\" I like the idea of doing it from an empowered and knowledgeable standpoint. I still consider myself a sex worker even though I work at a spa. This is an issue of ethics and values', \"I'm 39 and still love the concept of the game.\\nThe reason I said that, is because when I first played in middle school, my mom thought it would be fun for me, so she played too, and I think she just wanted to play something with me. I was then 8, and now I'm 39.\\nAt first I had problems with my hands, since\", \"I'm 39 and still love to read. I have many friends who love to read too and we have started a Facebook group where we share our favorites. We hope to continue doing so. If you'd like to join, just send me an email.\", \"I'm 39 and still love my life. Married with two beautiful kids. I love travel and outdoor activities. I'm looking for someone who's like minded and will make me happy.\\nYes, i can be more specific please let me know.\\nI love to hear about the people and places that I haven't seen, and to share new experiences with those I love. A person who is\", \"I'm 39 and still love me some men!\\nI don't know what to think about me.\\nThe reason I'm here is so i can feel normal again. I was very alone in my early 20s. Then I got pregnant. The man I fell for and married didn't accept my baby, not with his life. I started my journey of healing. I met some men\", \"I'm 39 and still love to travel. 3 and a half weeks from now, I'm heading to Japan to stay with family. I'm going to Tokyo, Kyoto, Nara, Osaka, Osaka JR, Osaka Airport, Hiroshima, Kyoto, Gion, Kyoto JR and Kyoto Nijo Castle. During these 3 weeks, I want to do something different every day.\\n\", 'I\\'m 39 and still love it: Meghan McCain on why she\\'s still riding the rails 30 years after her father\\'s death\\n\"Coming from one of the first generations of women who were able to attend college, I think this whole notion of feeling like you have to prove yourself over and over is very important,\" McCain said.\\nMeghan McCain, the daughter of late Republican Sen.', \"I'm 39 and still love it, don't judge me!\\nPosted: Mon Nov 28, 2016 1:45 am Post subject: I'm 39 and still love it, don't judge me!\\nI'm 39 and I've been dating this guy for a year and half. I was 40 (nearly 41) in March and I still haven\", \"I'm 39 and still love a good smoothie. They're simple and quick to whip up and great to boost your day.\\nI usually make them vegan (I’m a massive lover of green smoothies) but if I’m craving something indulgent I’ll whip up a treat! And this one is pure heaven!\\nFor this recipe, you will need a blender, some ice cubes,\", \"I'm 39 and still love to ski. I'm in fairly decent shape, but could use a little advice. I started skiing when I was 14 and skied competitively for 6 years, so I've been in good shape. I've been taking a month off and taking care of my 4 year old son, but am slowly getting back into skiing. I love it\", \"I'm 39 and still love reading. I'm interested in literary fiction and horror/creepy things in general.\\nYou should be reading right now... just have to figure out how to find it.\\nHow long do you get for a visit?\\nThis one is for the older members. Does anyone in the DC area have some nice Victorian homes for a 50s Halloween? Any details would\", \"I'm 39 and still love running. My two kids are 6 and 3, which have prompted me to look into running with a toddler in a stroller. The idea of running with an infant in a stroller is somewhat intimidating but I know I can do it. I want to get to a point where I can do this. I've been running for 7 years and\", 'I\\'m 39 and still love to try new things but I don\\'t know if I should cut out the \"extra\" things I eat in order to live healthy. My husband and I (married 10 years) can go for 4-5 months without any trouble if I don\\'t eat foods like ice cream, cookies, or french fries. However, I do like to have a', \"I'm 39 and still love to eat out, but I'm not the type to dine in once every few months, when I had $500,000 saved up.\\nI have some amazing restaurants in my town, like the K-Town ramen place, Rasa, where you sit in booths to eat a four-course meal, and then an entire server goes through the station, and bring\", \"I'm 39 and still love clothes. I've got a great relationship with my wardrobe and am always on the look out for a good piece. My wardrobe has always been full of casual wear for any occasion, from a daily outfit to more formal events. And a great handbag is always a must.\", \"I'm 39 and still love the feeling of being in the great outdoors. I recently had a job promotion and new office. As I was moving all my gear and set up my work desk, it dawned on me that I hadn't yet unpacked my stuff in our basement storage room. In the last few months, I've been planning my next adventure and figured I would write a\", \"I'm 39 and still love working in a shop... I'm the customer service manager, running the day to day, and have been for over 3 years. I grew up in Hockley and have just finished a full time course at Bolton College. This was a tough one but very rewarding and I really enjoyed the learning and experience. This is the 2nd time I have\", \"I'm 39 and still love to ride! It's time for an update! My son is doing great, doing most of the driving now. The ride is good, good water and good people. I love that I am able to help our sons with life skills and help them grow! Being older and wiser makes you more aware of our world and it's needs, and being able\", \"I'm 39 and still love my job in a stressful and demanding environment. I enjoy pushing myself in order to meet challenges head-on and always look for ways to be more efficient. As a person with many interests, I have always been good at doing many things well and at learning new skills, which allows me to keep up with change. I am a great team player, communicative and\", \"I'm 39 and still love men.\\nThe secret? I didn't feel that way in my twenties or early thirties.\\nIf I weren't 39, I wouldn't be looking for a man, but I feel like 39 is my time to open up my life to love.\\nBefore I was 29, I'd had my share of failed love stories. And if I\", \"I'm 39 and still love the outdoors. I love hiking, biking, canoeing and more. What I love even more, is helping others with outdoor pursuits. I have lived in the North Country my entire life, so it's no wonder that I feel comfortable living here. I love the fact that there is so much to see and do in the area, including plenty of hidden gems\", \"I'm 39 and still love, enjoy my independence and look forward to it. I have been in this industry since I was 16, I love meeting new people, great conversation and people. As for now I work with young men and women. I enjoy seeing them in a new way every day. I find it very exciting.\\nI love to dance and if I had to choose I\", \"I'm 39 and still love writing stories about female main characters! I also write dark humor and a little bit of paranormal. If you like it, please leave a review!\\nDo you like writing? Want to support me? How about supporting two other female writers?\\nWhy not a triple-threat?\", \"I'm 39 and still love it!\\nI just bought a new 2017 Ford Escape with the 4cyl. 1.5L turbo.\\nWhile the 1.6L is a nice truck and we've been driving it for almost a week, we haven't tried it out on the road yet.\\nAny suggestions to help me make a more informed decision? We've\", \"I'm 39 and still love doing it - how old is your youngest child? We're looking at a 3rd and a 2nd...we just started the 2nd!\\n@BeckyS @BrendaB @PatW\\nI'm sorry I got the wrong thread. This one is too new.\\nYay! For the 3rd and second! (\", \"I'm 39 and still love cats. My name is Emily and I'm 39 years old and from Missouri. I love cats and was never sure if they were dogs. I grew up in a cat-only house and most of the cats I had at that age weren't affectionate with humans or especially friendly with one another. So I didn't get a dog until I was 32\", \"I'm 39 and still love chocolate. That's just a fact. I don't think I'll ever grow out of it.\\nYou know what the craziest thing about being a mother is? The truth is that even when you're an adult, there's no getting rid of the fact that you've got a child who's always going to be a kid.\\nOn Motherhood,\", \"I'm 39 and still love this blog.\\nI'm still excited when I learn something new about my blog.\\nWe were invited to our neighbors house for a birthday celebration.\\nI met up with my friend, Stacy, and we had so much fun at her house.\\nWe are friends with the rest of the new girl.\\nI like Stacy so much, she's a great friend and I hope\", \"I'm 39 and still love sex. A very little.\\nBy: Laura Ann\\nWanna try the hard way? Yes!\\nBy: Angela Stacey\\nBy: Katie L.\\nBy: Racheal H\\nBy: Leilani G\\nBy: Angela P.\\nBy: Heather D\\nBy: Jennifer S\\nBy: Melinda P\\nBy: Lauren A\\nBy\", \"I'm 39 and still love to get creative. I've always been the creative type. The love for anything which has to do with art has always been part of my life. And I've managed to pick up a little bit of 'new' (the right term here) since I was 21 years old. I do understand what I have to do with all of it. If\", \"I'm 39 and still love music, though I don't get to listen to it as much as I would like. But what the hell I'd still say that rock'n'roll is the greatest genre, and this video is of such a genre. I've never heard of Rival Sons, I suppose I can't even say if it's really rock'n'roll. I also\", \"I'm 39 and still love my man. But he's tired of trying to figure out what's next. We've been married for 12 years, have three kids, and I have no idea what we want for our future. Any advice? I'm a homemaker at heart, but also want to go to school and get my doctorate. I'm not going to college to\", \"I'm 39 and still love this type of wedding. I have done a number of weddings for my daughter's friends. It was a really nice day and I loved that the wedding party got to enjoy the big day. The food was awesome as well.\", \"I'm 39 and still love nature... and books. When I'm not busy as a mad scientist, I'm usually finding inspiration for the projects that I make and read from the book shelf and by visiting with friends who share my interests. Since both of my kids have left the nest, I've been able to do a lot more things and enjoy them more!\\nI have had a long\", \"I'm 39 and still love my job and career.\\nBut as I'm getting older, my professional, organizational skills are a lot of work. As a result, I'm looking for a way to get more of them out of my system.\\nThe good news is, I can get them out more! Since I'm still in the field, I'm looking for ways to use them,\", \"I'm 39 and still love to be able to wear long skirts. I'm trying to figure out how to make them longer with out changing the seam height. I don't think I will need to cut off the excess, but I just can't figure out the proper way to increase the length without a decrease in the rise.\\nIf you use a muslin template cut a long top shape\", \"I'm 39 and still love the 3 I have. They give me a feeling of complete self satisfaction and security. When I look into the eyes of my wives it's a feeling that keeps you going and looking back at the past keeps you coming back to the present. I'm not very good at explaining how I feel about my wives but I'm not gonna take your time to try\", \"I'm 39 and still love it, I know it can get expensive, but I just want to try to do it without relying on my mom every other week. What kind of clothes would you recommend?\\nThanks for any recommendations!\\nThere are so many factors, but here are some things to consider.\\n1. Brand. I would find a brand that doesn't use really expensive fabrics, or\", \"I'm 39 and still love the ride\\nRides My Motorbike with my Girlfriend\\nJust joined 4 years ago but 6 year old from the time she was 14 and I've been a member for 1 year\\nby Rednexx (93.7) 1 year ago\\nJust joined 4 years ago but 6 year old from the time she was \", \"I'm 39 and still love my job at the Ritz Carlton in Dubai. If you do, too, the sky's the limit. Once you get into the big time (that's when it really comes into your blood), you have no idea how hard it was, just like my co-worker who's working in the Bahamas and loves it. But she's paying her bills and paying\", \"I'm 39 and still love going to a nightclub and meeting new people. Don't know how I got this bad habit? And it's very addictive. After spending the evening there I come home to write a novel, meet up with a friend or go out for dinner.\\nThe first is my first drink of the night, a tipple that goes down well on a cold evening with a\", \"I'm 39 and still love sex, but I've noticed that I have to be with someone at least once every 2 weeks to get the release I need. I've talked to guys before who are very receptive to sex and they said they can be with someone any number of times a week or even a couple of times a week, and they still get the same release from sex with\", \"I'm 39 and still love to hit the gym. For the first time since I was 17 I am getting back into shape. I had tried various exercise programs in the past but I am going to try this program. I am using this for 90 days and am hoping for some quick results. I know some people don't like to use supplements but I am just using this to\", \"I'm 39 and still love being a man (even though I am gay), but I am beginning to experience a lot of negative feelings.\\nI feel that I am worthless, that I am not attractive, that I don't make good money and that there is not a woman who could love and want me. I have a family, but I feel like I have no responsibility to them.\\n\", \"I'm 39 and still love animals. I have many chickens, guinea hens, cats, a few hamsters, and my first rabbit. They all do well together, and make a wonderful pet for someone.\\nI grew up on a farm in Indiana. It is still home, but I am not a farmer. I have always been around animals, from before I can remember.\", \"I'm 39 and still love to read. I have three children (all still babies) and still love to read bedtime stories to my children. They are my greatest joy and my highest priority. I will gladly read anything at least once. Any book I am interested in reading I am most definitely going to read.\", \"I'm 39 and still love reading newspapers. I'm on a month long diet to give my metabolism a hit.\\nI have a number of problems with my feet. I wear shoes that require a high arch but as I have been told my foot problems make me extremely vulnerable to damage in the arch.\\nAny help, advice and help for me.\\nI am currently 37 years old, and\", \"I'm 39 and still love the older men... that being said, I really need some advice on how to treat them. I want to be honest, I feel like I'm all out of love and life experience. A new job has come up that is right on my career track and I want to make sure I land it. I've had the opportunity to speak to two of the\", \"I'm 39 and still love the way I look. I'm very adventurous and would be a good sport as well. I can drive but I'd be looking for someone who can help me learn how to drive in an adult safe environment and can get a license as well. I'm also looking for a good man to teach me how to cook and talk and laugh and have fun. I\", \"I'm 39 and still love the taste of ice cream as I was in my childhood. I would love to try all the ice cream flavour combinations out there. Have a great day dear. Thank you for sharing this amazing post.\\nMilkshakes are a favorite among kids and grown-ups. The taste will surely get you in a craving for another one and the creamy texture makes it all\", 'I\\'m 39 and still love reading. I read 30 to 40 books each year. But sometimes they are \"just not what I need right now\". When I was 35 I picked up \"Love and Theft\" and it changed my life. The new book has made me feel like I was born again. And I\\'ve still got this book in my hands.\\nHow\\'s it', \"I'm 39 and still love going out. And I still love trying new restaurants, even if I only get to try one thing on a menu. But it gets harder and harder to keep track of where all my new favorite restaurants are.\\nThat's why I decided to make a list of the best restaurants in New York City, the restaurant that made me fall in love with the city in\", \"I'm 39 and still love to shop online for clothes and shoes. And I love how you can try things on before you buy them. However, I'm also realistic and the price tag (and size) of the item can affect my decision to buy. With that said, if I see something that really catches my eye, I will always go for the pair.\\nI've been on\", \"I'm 39 and still love what I do for a living\\nAt the age of 22, I started my first job as a hairdresser. I have been passionate about my job ever since, and am lucky to have had some really awesome clients who have supported me and continue to support me and my career. My long term clients give me valuable feedback about my work and help me\", \"I'm 39 and still love a good kiss. Do you like kissing? Do you want to kiss?\", \"I'm 39 and still love making my own clothes. I can't get the fabrics or the patterns in stores that work for me. I need a steady supply and also to be able to buy certain kinds of fabrics at a discount. Can you help?\\nI have discovered that you can buy fabrics at a discount from various online vendors. I purchased a fabric from a store in St. Louis\", \"I'm 39 and still love to have a boyfriend (well maybe not the last one). So, I'm looking for someone to do some photography and help me out at parties. You could be just a friend for all I care... if you don't mind..!\", \"I'm 39 and still love to do it all at once!\\nI am so glad to be a member of this site, I can't wait to try the exercises and maybe join in with the others. I don't think I can physically do the sit ups and leg lifts. I have read that people of my age are at higher risk of injuries because of poor muscle tone. It would\", \"I'm 39 and still love to dance. My hobby is to walk in the park in the evening and sing in the streets or wherever I feel like and enjoy the sweet smell of flowers, green grass, trees, hear the birds singing, smell the fresh air, feel the coolness of the evening air and the sun light shining down on me and I could sing the songs I love to\", \"I'm 39 and still love to cook but am starting to feel a bit intimidated in the kitchen and am wondering if anyone can share some tips and recipes for those of you out there who are looking to develop some of your cooking skills and learn new things to feed the family.\\nI really do love to cook but am not motivated at the moment.\\nI hope that someone on this forum can help\", \"I'm 39 and still love to read, still watch movies, still dream to one day actually get married.\\nI have a very busy life with my own kids. I have 2 daughters and one son. The kids and I have all kinds of fun together.\\nI'm trying to get back into reading and writing again. I've only written one book and I still have it sitting on\", \"I'm 39 and still love to have sex.. it is the single most fulfilling thing i do. I believe the relationship needs to be equal though, and this is mostly a difficult issue. When we're in love we get into a relationship to the point of feeling we've no choice. I am sure this isn't a new thing, but I believe it's how most relationships start anyway\", \"I'm 39 and still love this game!\\nI love this game. It's getting to be difficult but I keep at it and keep playing. This is my best friend.\", \"I'm 39 and still love reading romance novels. I have read 4 or 5 romance novels, and love romance novels. However, I have had my fair share of rejections, and a few flat turns of the page when trying to keep myself from crying.\\nAnd of course I feel it's important to admit that I have watched the majority of romantic comedies. I even laugh\", \"I'm 39 and still love to read. I've read a lot of books over the years and like to get book recommendations. Thanks in advance!\\nI will never tell you to read this book. It's a book by Tom Clancy. Read other books and ignore it. I'll never read it or watch the TV show.\\nPercy Jackson and the Olympians\\nCatching\", \"I'm 39 and still love my job. The reason I love it is not because of the job itself but rather because of the people I work with and the community I work in.\\nAs a young executive I worked for the city of Austin, Texas as a deputy city manager for over 5 years. I was in charge of budgeting, planning, and business development in the 3\", \"I'm 39 and still love my '09 car as much as the day it rolled off the lot. Like I said above - no problems. Very quiet, great performance. The only reason I'm selling is I'm about to move to the suburbs - my son just graduated from High School, and I need to unload this thing to make room for our future. I'm a '67\", \"I'm 39 and still love to bake!\\nFruit and Chocolate Cake!\\nI have to confess - I am not a big cake person.\\xa0 When I was younger, my mom used to make a really good chocolate cake with a peanut butter frosting and it was pretty easy to make.\\xa0 But as I got older, I think I got tired of the PB frosting.\\nSo today, I\", \"I'm 39 and still love it (even though we're getting married on May 11th this year!) The dress is in stock. I'll contact you once we have a booking date.\", \"I'm 39 and still love going to a regular job (it pays the bills) every day. What's the best way to enjoy this working life without being unhappy about it? I've always been too shy or too lazy to pursue my own happiness but am willing to give a regular life a try.\\nI believe that happiness is a choice, and that we can only have it if we\", \"I'm 39 and still love to be surprised\\nA little while ago I gave my name and number out, on an invite only list. It was to be sent out after the Summer 2012 AGM, and it was due to expire in September. I was going to fill in my details again and again (the letter arrived with the data I put in the first time) until\", \"I'm 39 and still love being in the game of sports.\\nI like to keep moving, and i want to see if you guys want to go out for some bowling. I'm not great at bowling, but I like to go out and help someone else have a great time, i enjoy that aspect.\\nI'm a simple man, good lookin women, i'm athletic, i\", \"I'm 39 and still love playing Scrabble.\\nI'm very impressed by the depth of information you have about Scrabble and provide the most fun. You can be better! I love this site!\\nA really nice Scrabble page, please tell me how I can contact the author, so we can all have a chat.\\nHave you found this Scrabble forum useful? Please contact me as\", \"I'm 39 and still love music, still have the same heart for it, still travel and still spend time writing and recording. And still try and give back to it through music. I can be a great song writer if you just give me the time. I'm not saying my songs are better than anyones or their any better than mine but when I play them or hear them back\", \"I'm 39 and still love to cook. My favorite dish is a thick eggless chocolate cake with pistachios. Since I lost my sight 6 years ago I no longer go to restaurants or bakeries but make everything from scratch. I'm looking to make my own balsamic vinegar. I've been to many bakeries and bakers in the city to try different recipes.\", \"I'm 39 and still love it like never before.\\nI love my husband, but we have a love-hate relationship.\\nIs your lover a man or a woman?\\nI get too much mail and only have one email address to reply to.\\nMy family and friends are an important part of my life.\\nHave you ever heard of your lover's parents?\\nI don't know who your lover\", \"I'm 39 and still love wine in the same way I did as a teenager - but it's not what I'm drinking. In fact, I'm drinking less wine because it's now starting to taste flat, sour and uninspiring. I have had so much wine that I am becoming immune and have developed a good repertoire of cocktails, spirits, beers and teas. Although my regular tip\", \"I'm 39 and still love dancing.\\n...and it's been a wonderful dance. I've found a place and a partner who love to dance, a place to dance and a place to express love. In this city the place to dance has found me. This is the city that I have danced with and learned to love and the city that loves me as much as I love it.\", 'I\\'m 39 and still love my job.\\nby Anna Sorensen | 5 min read | 11.11.2022\\nWith a great reputation for service and performance, a great compensation package, and a commitment to work life balance, the communications and marketing professional may have a difficult time saying \"no\" to a demanding and high-pressure job. However, if you\\'re', \"I'm 39 and still love making my dolls so much. Still work on a few things and do the odd doll once a year. I also love having fun and have even bought a few other people dolls, sheesh!\\nHer name is Ava Mae... she's amazing!! And her collection of babies (the Kona dolls), can be a pain to put together!\", 'I\\'m 39 and still love the romance movies I used to hate as a kid! 3.5 stars for the romance but will go down in my review as 3 stars for all the others!\\n\"I have such a hard time writing this review.\"\\nThis movie is one of the few examples of a romance movie that does not ruin the plot for me. The romance between the two main', \"I'm 39 and still love that I can fit into my old size. I'm in love with that size.\\nFits well and looks good on.\\nThey look good but I was hoping they would stretch, though I do love the feel and fit.\\nVery happy with my purchase, so happy I found you guys, also I will be purchasing more from this store, thanks again!\\nOrdered\", \"I'm 39 and still love music like this. Very unique song. Perfect for the setting, too. Very much a mood piece. I'm surprised no one has seen the movie by the way.\", \"I'm 39 and still love to run. I love to run marathons in cities but also love to hit trails and do events such as the Rogue 50K.\", \"I'm 39 and still love men. Men can be kind and they are so intelligent. For me this person is more than an occasional experience, I'm looking for something long term. When i think about him I can feel my heart beating. He is the best man I have ever known and it is great to be able to go through my life with him, I am thankful for that\", \"I'm 39 and still love to do everything! Today we took our bikes on a short ride. Both bikes were in perfect condition and I thought we would have a great time! We went to a trail ride we know. It was just enough of a challenge to make it interesting. We have a 4wd capable truck so we had that for our friends to drive. We had \", \"I'm 39 and still love to eat a lot, I love to have a good food and enjoy all the flavors of the world. Food is everything. I like to cook simple meals and I love to eat in front of the fire. I have a passion for cooking and love to spend hours on my craft. I love the attention I get from people and love sharing my passion with the\", \"I'm 39 and still love coffee. Yes, it's that old! But I also like to read and I love working on my computer. I can be found in my house in the Netherlands, working on writing.\", \"I'm 39 and still love my job, but I am currently considering leaving to pursue other things, such as photography or blogging. I have more creative ambitions than the two occupations I've been trying to make a living out of for a while now. I've also been thinking about trading photography for a business degree and turning my photography into a career, but I'm a little concerned about taking\", \"I'm 39 and still love my body\\nI’m 39 and I love my body. I don’t care for the age factor that keeps rearing it’s ugly head to the point where I get self conscious about things. I have had multiple health concerns that need attention, but I don’t let them keep me from living. Sure, I’ve had bad days, but I’m\", \"I'm 39 and still love my country. I appreciate the wonderful foods that country is known for: bbq, burgers, good beer, fresh homemade cheese and soups, pies, mac and cheese, good hotdogs, mexican food, pizza, and of course ice cream. I wish every country had the same.\\nThe US is very beautiful, has unique sights and friendly people.\", \"I'm 39 and still love going to the Gym to work out!\\nI'm very passionate about people. I really care about people and I know that everyone deserves love and happiness.\", \"I'm 39 and still love shopping for clothes. I love finding cool new brands at secondhand stores. Finding amazing brands like Urban Outfitters is kind of exciting. Of course, I don't go into the stores full of ideas and hope to get something great. But I'm willing to give any stores a chance.\\nI've been to The Outlets at Columbia Mall in Columbia,\", \"I'm 39 and still love to see an inbred hog trotting around the yard for its daily exercise. When I hear of the success of those 18 year olds running around campus, it makes me nostalgic for those days. My best years are ahead of me.\\nOne thing that people seem to forget is that a few years ago, many 18 year olds were still in high school\", 'I\\'m 39 and still love animals, but I found that with many of the shelters I visited they still have dogs with 15 years on them. And the fact that they say they \"rescued\" the dog. If you have found a dog you want to adopt, please go to the local shelters. Do your research online, get to know the animals, bring in friends who', \"I'm 39 and still love my job. I love my job.\\nI'm in a long term relationship, and he's great too.\", \"I'm 39 and still love life!\\nI'm a 39 year old guy, single mother of a daughter.\\n- (G) I think I am in love with a woman, she is younger, has a dog, and she doesn't know it.\\n- (G) I've been thinking about marrying my current girlfriend but when she asks me how long i would want to wait,\", \"I'm 39 and still love fashion, but more so, I've gotten a lot better with shopping. I actually used to think I knew how to shop, but as I have become more of an older style, I've begun to realize that my ideas for clothing don't really make any sense when I am that age. I started a Pinterest board for dressier outfits. I'm the\", \"I'm 39 and still love shopping online as much as I did 6 years ago. I'm a proud wife, mother, and stay-at-home mom of three great kids. I also love to help others with all of the details of their home decor, especially how to manage a large home. I do this by writing home decor blog posts and then helping others with my resources for home\", \"I'm 39 and still love cats! I was an Air Force spouse and served 2 years overseas. My husband is in the Army and we are now stationed in Alaska. I had a lot of pets growing up including dogs, birds and mice. I am hoping to be the mom to two cats and if we can have a bird in the mix too, that would be amazing.\", \"I'm 39 and still love shopping for my daughters. The last few months I've been going a lot more because of these challenges. Is there an advantage to purchasing gifts for my daughter over the adults? What types of gifts are considered the best when going to a younger teen? What is the best way to give them? I also find myself buying so much for my son when he is\", \"I'm 39 and still love it\\nMammoth Mountain Ski Area just celebrated its 50th anniversary, with 30,000 first-time visitors expected on Opening Day. The resort also continues to attract skiers from around the world.\\nBy Nell Redmond • Sep 3, 2012\\nMammoth Mountain Ski Area in California is the oldest continuous ski area in the\", \"I'm 39 and still love my 7 year old 22wtt\\nPostby Old Squire » Fri Jan 24, 2020 3:38 am\\nI love my 22wtt and it is the only 22wtt I own. Its the first one i bought and I have a 1968 4Sgt with a 62k miles\", \"I'm 39 and still love life. In my eyes - things have just slowed down.\\nLoving you more and more every day.\\nThere is always another challenge in life but you must keep going.\\nLet the best years begin!\\nLife is good and still just about exciting.\\nNo new pictures are planned at the moment, but some day soon I'll be putting up pictures of my grandchildren and\", \"I'm 39 and still love dating women! I'm shy, timid and nice but at the same time I can give you what you need!\\nam thinking about seeing this again i'm getting a little bored with everything we did the first time.\\nHello. Looking for a great relationship, just because I miss the good old days and I really miss the thrill and adventure you can feel. It\", \"I'm 39 and still love sex. (Men, it's always your fault).\\nNow, I know I sound selfish because I love sex so much. But, sometimes when men cheat, or they cheat and they tell me, sometimes that shit is my fault. In these situations I feel like I've let them down because I'm still in love with them and so I feel like the\", \"I'm 39 and still love it but it could be you. I do find most men attractive, especially when they wear what they call shorts.\\nI am a teacher in the primary school, so would have a very long way to go to be a member of this club. I hope you find what you are looking for.\\nIs it really 2018 and we are still talking about the\", 'I\\'m 39 and still love to go out to bars in London, find new clubs that are not as \"typical\". The most of the new clubs here on this site are on this list. Have fun and have a great night!!', 'I\\'m 39 and still love this hairstyle. I am an easy one to style and like to keep it easy. I\\'m not a \"pretty\" person but a pretty person. I was born with a crazy \"real\" personality, and that\\'s never changed. My hair is curly so I am always seeking new looks, but my hair is very low-maintenance. And I am not', 'I\\'m 39 and still love doing my nails! I\\'m looking for the perfect polish... with a splash of sparkle. I love these nail art photos, but this isn\\'t one of them! However, it does take me about a week to get used to what I\\'m doing, because it is more \"done on a natural finger\" than on my nails. So, I haven\\'t', 'I\\'m 39 and still love to dress up. I have been to the airport a couple of times recently to pick up my son from a soccer game.\\nThe game was over and we were in the parking lot but in one of the parking lots they still have those \"playground\" games. I felt I would be over dressed. I bought a dress and put on sandals and thought that', 'I\\'m 39 and still love to shop. I don\\'t really need anything new; I already have every item I need and would never consider upgrading for anything. I get all my clothing and other basic items from Target, Old Navy and Payless. The only real \"deals\" I have looked for are coupons. This one that I received the other day will be the first to hit', \"I'm 39 and still love to run and play football!\\nI'm a personal trainer by day and just love to play!\\nHey how's things coming along?\\nI'm just about done with my gym certification.\\nIt was actually quite the shock when I realized that I was going to graduate with 2 kids from the same family!\\nCongrats on your new addition! I'm hoping my kids\", \"I'm 39 and still love my 3rd grade self. It's not just because I have 3 amazing kids, but also because I was able to have a lot of time with my first 2.\\nThey were little, and we were in the same place: I'm 39 and still love my 3rd grade self. It's not just because I have 3\", \"I'm 39 and still love baking bread! Do you think we can use the machine you used in the above video or do we need to bake it in the conventional way?\\nWe need to bake it in the conventional way, you can also use the machine you mentioned for this purpose.\\nYou might also like to have a look at our video on how to bake bread in the conventional way.\", \"I'm 39 and still love my job. Why? Because of my employer, my boss, and the co-workers I work with.\\nSo, I thought the Best Employers Of 2018 might not even be an option.\\nHere are 15 places I love working and the biggest reason why.\\nI love my job because of my team.\\nNot only do they create a culture of happiness\", \"I'm 39 and still love the beach...not to mention the sun...but also very happy with winter clothes. Love all of these cozy (and on the cheap) pieces, love the lightness of the pieces, love the casual look, love the fact that you can actually use them in the summer and not have to find another pair of jeans or blazer!\\nI love this combination\", \"I'm 39 and still love coffee and drinking it daily! Here are some great recipes you may like!\\nI’m 37, married, live in a big city, and just can’t get over how much I love coffee. I drink at least four cups a day, I have a new brewer that keeps me caffeinated with three delicious brews. While I’ve lost the hair\", \"I'm 39 and still love shopping. It's not as fun as it used to be though.\\nI have a problem that I have struggled with for years. I'm not a big guy, but I know I am a fatty.\\nI started using a scale at work, and I started losing weight. I can't believe how good it feels.\\nI feel like I have lost myself.\", \"I'm 39 and still love my job, but no more. The only way I see myself being able to afford a house in the future is if I can either start a new career or quit my current one and try to start a different career with a different salary. I've tried taking time off work, but just ended up paying the bills and was unable to really go on a vacation\", 'I\\'m 39 and still love reading the BDN\\'s Bookshelf column and looking at all the new book covers. Not sure how much time I can devote to reading them, but the column has inspired me to try some books I\\'d considered, though it\\'s hard to get into a book once you\\'ve picked it up. I recently checked out \"The Kite Runner\" by Khaled', \"I'm 39 and still love living on my own. My cat, my dogs and my house are all mine, I have no responsibilities of any kind whatsoever. Not to be confused with those guys who love to drive around in a car all the time and never have time to leave the house for something that's considered as normal life.\\nWhy am I still single after 35 years of age\", \"I'm 39 and still love my wife and children, although I know this is a distant dream. I love art in general and have been making models since 1997, with a keen interest in 1/72 scale modelling. I have an artistic flair but lack the knowledge of modelling to add quality to my work. I have learnt enough about modern technology to understand the benefits of paint\", \"I'm 39 and still love to travel. I'm not going to lie, the idea of getting on a plane, even if it's just for the sheer excitement of flying, can give me a jolt. If I'm traveling for work, I can stay on the train, use public transit or jump in a cab. If I'm traveling by car, I know to drive slower\", 'I\\'m 39 and still love to eat and cook. Sometimes you just need to sit down and share the great meals with your friends. My husband and I travel often and we like to share good meals with friends. It\\'s not just a simple buffet or take out food. It\\'s more like \"gourmet\" food! Enjoy!\\nA few of my favorites.\\nWhen I was a kid', \"I'm 39 and still love you\\nI'm 39 and still love you The following statement by one of the editors of a conservative news service I once used to read suggests to me that something terrible has happened to women in this country.\\xa0 And I think it's a terrible comment on behalf of a group of people that I respect.\\xa0 They say:\\xa0 “We're still \", \"I'm 39 and still love it. I've had three other boyfriends (now broken up). My dad is an Air Force Colonel and I have an awesome job.\\nI'm a college professor and teach 18+ students. We have 3 children: ages 6, 4, 1. My daughter is an artist and she sells her work.\\nI love my family,\", \"I'm 39 and still love to cook, even if it is just in the occasional pan of stew or pasta on the weeknights (though not as often as I used to).\\nYou have done so much already!\\nWhen do you move to Toronto?\\nYou have so much already?\\nWhen will you move to Toronto?\\nWe'll be able to pay for a better quality of life. We\", \"I'm 39 and still love reading ( I am not married )! I like playing video games ( I am a veteran, I have been gaming for 14 years ) and playing the piano ( I am a piano player but don't have my fingers crossed up, I just wanted to make my point! ) I have had the pleasure of being friends with many people on this website ( just\", 'I\\'m 39 and still love being a bridezilla. When I get a \"date\" set, I always expect and hope for the best and my mind will process the whole situation as if I\\'m taking a math test with no other knowledge on the subject. I think I just want to scream at some point and leave the whole thing to the Lord.\\nI do think sometimes God has a', \"I'm 39 and still love cooking for my family. I just made up a new favorite recipe that is gluten free and also vegan...even though it's one of the recipes I am making this Thanksgiving, I think it will be one of the best. I wish I was making it for the whole family...the recipe will make 12 servings but I don't think we'll be eating\", \"I'm 39 and still love to go out clubbing.\\nRecently I'm not attending a lot of clubs. And I miss this so much, especially when we're on holidays.\\nThere's no good answer for it.\\nBut I need a club scene in Prague.\\nA club scene with real people, not gay guys just hanging out together.\\nI know that for a fact.\\nSomeone to share\", \"I'm 39 and still love my 26 year old husband. He's the best thing that's ever happened to me. He's the one that brought me back to the Lord. I've never known another man who loves me and has a deeper respect for me than he does. We really get along well. He always supports me and is there for me. When I get into any\", \"I'm 39 and still love to ski, the excitement of the powder and the big days. I've skied from a young age and have always loved the rush of a slope, a turn and a run in the powder or on a gladed run. My friend and I will often go to Aspen at the end of January and enjoy 6 days of skiing, starting on Friday with\", \"I'm 39 and still love the process of being creative. I've always been a passionate person with an eye for detail. In the last few years I've decided to expand my artistic interest to digital creation and web design.\\nI began learning about web development in the late 90s and began working with PHP, MySQL, Apache, WordPress, and a number of CMS tools. I was\"]\n",
      "\n",
      "acf factual abstraction:\n",
      "love\n",
      "\n",
      "\n",
      "acf counterfactual text:\n",
      "[\"I'm 39 and still single, and I have been for over a year now. Its such a beautiful time of year in our part of the country right now, with the first crocus of the season starting to bloom. I went out on a walk this morning to photograph the first leaves on the crocus, and I saw a few other beautiful flowers in the daffodil\", \"I'm 39 and still single.\\nI'm a Canadian writer, but I was born and grew up in Australia and am now semi-retired and live in the Hudson Valley, New York.\\nMy writing has included a short story in the Sudden Denouement series of murder mysteries, a humorous fantasy short in a short story anthology series, and several poems. I like to write the\", \"I'm 39 and still single and in no rush. Married to a wonderful lady (still awesome) who's great with a knife, a crafty woodworker, and great in bed too. I think she'd make a good wife for me... I'd love to see her with a knife too. We've had one serious discussion on it, but she'd do it.\\nIf\", \"I'm 39 and still single. Where in Canada are you from?\\nPlease keep your posts personal. Do not use your real name as I cannot moderate these posts and have no authority to moderate such posts.\\nDo you prefer white guys or black guys?\\nIf you're married (or ever will be) what are you and your significant other's ethnicities?\\nWhat country do you come from\", \"I'm 39 and still single.. not that I would ever go there... :oh: but I'm afraid I can't find my future partner either...I don't want to be a spinster...or an old maid...that would give me a bad reputation. What if my kids and grandchildren have none of my bloodline.\\nI got the impression that in this time and age\", \"I'm 39 and still single, and here's the deal: I love to read books, I love to write, I love to cook, and I love to shop. Some days it's easy to love all three at once! So, my goal is to write the best novel, a cookbook, a business plan, a recipe blog, and a blog about shopping. And I\", 'I\\'m 39 and still single, and I\\'m a bit sad - I have no desire to be a \"nice girl\" and I\\'m at the point where I\\'m losing my passion. Now I just like to make friends and have fun, but I just can\\'t bring myself to have any type of relationship at the moment. I\\'d love to find a nice guy and live with', \"I'm 39 and still single, very happy and content, but not yet settled down. Always busy looking for something to make me smile.\\nI'm just wanting to find out if any of the rest of you are looking for something more, and maybe we can see if we have something in common.\\nAm interested in a good-looking man and well-groomed man.\\nBtw I\", \"I'm 39 and still single? Who are you kidding! Don't believe it? You may be surprised how I come up with this stuff but if you don't understand it, it will just confuse you more. For me, it's simple. When you're ready, the Universe conspires to bring you your match. I don't say it's easy, but it is.\", \"I'm 39 and still single, why so many guys don't believe in me? What do you do?\\nI am a wonderful and single guy that is very honest with who I am. I'm 39 years old and I live in the Northwest, (Seattle) Washington.\\nI enjoy everything that the outdoors has to offer and love to travel the world. I have a great life\", \"I'm 39 and still single. I love being around other single women but I'm not willing to put out in front of just anyone. I'm not into blowjobs but if you're willing to do a S and M then I'm all for it. Not into S & M at all, and only a man that I trust would get any kind of thing from me.\\nHi\", \"I'm 39 and still single\\nI haven't dated much over the past few years. Now I'm 39. The way I see it, it was like this a lot of years ago in my 30's and it was a miserable time in my life. I started with a one night stand and a weekend tryst with some guy. Then I had the other situation,\", \"I'm 39 and still single I've spent the last 12 months dating a girl I met online. She said it's because I'm not looking for something serious. I'm very picky.\\nI like to be around people who know how to get along with me, and not get mad when I change my mind.\\nI'm from Pennsylvania but I love to travel. I've\", \"I'm 39 and still single, and I'm all about the romance and love! I have the perfect boyfriend. We'll always be a couple but we will always talk about different things and get along.\\nNights out. I love it when he's up at 5am getting ready for work and I'm out the door with all the clothes on.\\nHe never gives up and\", \"I'm 39 and still single. It's time for me to move on, no more long term relationships that are taking up my time. At my age, I need to get back into the dating scene. I'm no longer as pretty as I was. I need a fun person, someone to go out and have fun with. I'm looking for a laid back woman, \", \"I'm 39 and still single as you all know I'm still single and still a virgin! I've never made a post before because I thought everyone here was well aware of my history. I've always been like a big groupie for musicals, musical theatre, movie songs. I watch the music videos for my favorites and i just listen and fantasize about the scenes and everything\", \"I'm 39 and still single. I think I'm pretty close to 45 before I start getting older (my husband's dad was 52 at the time of his wedding, and he died 11 months after I got married), but I don't like the idea of being older alone.\\nIf I do end up having kids, I'd like to make sure they're as close\", \"I'm 39 and still single. I have a good income, good health and am not looking for a committed relationship at this time. I like people but find them very difficult and often not good enough to go out on a date. Why can 't I meet someone and not fall in love?\\nA. I am shy.\\nB. I don 't like to socialize.\\n\", \"I'm 39 and still single. Im soooo lost. Im working hard and I have a great job but I have no where to call home. I'm lonely and I get very easily hurt. I would love to find the best thing that ever happened to me. Someone who I can share the best years of my life with. I love fashion and style. If you have been\", \"I'm 39 and still single...or was single, until I found the love of my life. I'm a 39-year-old man seeking a good woman who's looking for a serious relationship. I'm a 5'4 female seeking 5'8 - 5'10. Seeking women who are mature, outgoing, ambitious and have a high self-worth.\", \"I'm 39 and still single. Have a degree in psychology and minored in art. I have a lot of interests, I love photography, reading, playing the ukulele, baking, gardening, camping, and love to help people. I'm pretty social and would love to meet people who share my interests! I can be pretty spontaneous and enjoy life to the fullest.\\nLooking\", \"I'm 39 and still single. But I don't mind. I find that I can get off with someone else if they're attractive and willing. Don't mind if they're not attractive and willing, either. Just curious what you'd be into.\\nI'm 39 and still single. I don't mind.\\nFind me on Facey, if you are single, too.\\n\", \"I'm 39 and still single. I have been dating about 4 times. So far the best date was the girl I am engaged too, but there's been some great dates. My life is fine though I have issues with the way things are and will continue to have issues with that for as long as I live.\\nI don't know what to do. I want to be\", \"I'm 39 and still single! I have 2 lovely daughters that are 11 and 13. I'm a stay at home mom to my 2 daughters. I'm a very creative person who is easily influenced by people, music, and art. I love new technologies and computers. I'm in school for Electrical Engineering and I hope to one day get my masters in IT\", 'I\\'m 39 and still single. I\\'ve only been a full-time student in college for about 1 year and I don\\'t know if I want to get a job out of college to support myself until I get married or start a family.\\nMy parents think my decision is based on \"spending\" rather than something else.\\nSo if I go out of college, I could work', \"I'm 39 and still single. I'm an amazing cook. My name is Erica. I like to paint and dance.\\nI can dance salsa and bachata.\\nHi, I'm from Uruguay.\\nI'm a travel loving person who loves to see other countries and get to know the culture. Love to learn and speak Spanish! I love going to dance and going out with friends.\", \"I'm 39 and still single...with a really weird problem...if any?\\nI'm 39, with no family, but I have a very young daughter 6 years old and I'm in a relationship for 10 years. And I would really love to meet someone.\\nWe are sooooo far apart in so many ways that I don't know if I could ever build a\", \"I'm 39 and still single? Need to find a friend to date: I don't drink, smoke, or go out and am just a normal, kind, polite, clean cut 39 year old man who likes to cook and play video games with friends. I'm not the most handsome man, so I'm working on building muscle and growing my beard as that's a sign\", \"I'm 39 and still single and don't know what to do. I'll share the details of who I am and how I am living and how you are welcome to write any comments of messages. I have a 5 year old daughter who is my joy.\\nGlad you are interested in finding love.\\nYou have not disclosed where you are from or what you do. Sounds like\", \"I'm 39 and still single... and loving it\\nI'm 39, and I'm single, living in Germany. So how can I be in love with people who also have kids and say they are in love with me? I am aware of the problem. I do have two daughters, who are 18 and 12 years old. All my friends' marriages, including\"]\n",
      "\n",
      "acf counterfactual abstraction:\n",
      "love\n"
     ]
    }
   ],
   "source": [
    "# token level factual continuation and abstraction \n",
    "print(\"TLCF\")\n",
    "print('\\ntlcf factual text:')\n",
    "print(example[('tlcf', 'factual_text')])\n",
    "\n",
    "print('\\ntlcf factual abstraction:')\n",
    "print(example[('tlcf', 'factual_abstraction')])\n",
    "\n",
    "print('\\n\\ntlcf counterfactual text:')\n",
    "print(example[('tlcf', 'cf_text')])\n",
    "\n",
    "print('\\ntlcf counterfactual abstraction:')\n",
    "print(example[('tlcf', 'cf_abstraction')])\n",
    "\n",
    "\n",
    "print(\"ACF\")\n",
    "print('\\nacf factual text:')\n",
    "print(example[('acf', 'factual_text')])\n",
    "\n",
    "print('\\nacf factual abstraction:')\n",
    "print(example[('acf', 'factual_abstraction')])\n",
    "\n",
    "print('\\n\\nacf counterfactual text:')\n",
    "print(example[('acf', 'cf_text')])\n",
    "\n",
    "print('\\nacf counterfactual abstraction:')\n",
    "print(example[('acf', 'cf_abstraction')])\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "venv",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.10.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
