{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "d454c0dd-66df-4e07-aa3f-6e6cdf21ce98",
   "metadata": {},
   "outputs": [],
   "source": [
    "import json\n",
    "import numpy as np\n",
    "import math\n",
    "import matplotlib.pyplot as plt\n",
    "import re\n",
    "import string"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "936d9f29-2709-434c-85b9-3a866e120637",
   "metadata": {},
   "outputs": [],
   "source": [
    "from conformal_generation.sequence_selector import RunningMaxSequenceSelector, RunningSmallestSubsetSumSequenceSelector, PostprocessedSequenceSelector\n",
    "#from conformal_generation.sequence_selector import SequenceSelectorFromScore\n",
    "from conformal_generation.calibration_dataset import ManualCalibrationDataset\n",
    "from conformal_generation.conformal_generation import ConformalGeneration"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "26134513-fa21-48d9-bcd2-b50c2e0e8fb4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2000\n",
      "15944\n",
      "{'name': '10458', 'success': [1, 0, 1, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], 'interactions': [{'completion': 0.7154925499329796, 'probability': 0.7154925499329796, 'confidence': 0.7154925499329796, 'idx': 0}, {'completion': 0.417514242697702, 'probability': 0.417514242697702, 'confidence': 0.417514242697702, 'idx': 1}, {'completion': 0.149690994163353, 'probability': 0.149690994163353, 'confidence': 0.149690994163353, 'idx': 2}, {'completion': 0.3342096564603057, 'probability': 0.3342096564603057, 'confidence': 0.3342096564603057, 'idx': 3}, {'completion': 0.27541727308903297, 'probability': 0.27541727308903297, 'confidence': 0.27541727308903297, 'idx': 4}, {'completion': 0.04814430795684208, 'probability': 0.04814430795684208, 'confidence': 0.04814430795684208, 'idx': 5}, {'completion': 0.21255285165862106, 'probability': 0.21255285165862106, 'confidence': 0.21255285165862106, 'idx': 6}, {'completion': 0.41531164609688725, 'probability': 0.41531164609688725, 'confidence': 0.41531164609688725, 'idx': 7}, {'completion': 0.25851988095931583, 'probability': 0.25851988095931583, 'confidence': 0.25851988095931583, 'idx': 8}, {'completion': 0.16331002399598488, 'probability': 0.16331002399598488, 'confidence': 0.16331002399598488, 'idx': 9}, {'completion': 0.39216628812179355, 'probability': 0.39216628812179355, 'confidence': 0.39216628812179355, 'idx': 10}, {'completion': 0.6957879197181561, 'probability': 0.6957879197181561, 'confidence': 0.6957879197181561, 'idx': 11}, {'completion': 0.30868471412245907, 'probability': 0.30868471412245907, 'confidence': 0.30868471412245907, 'idx': 12}, {'completion': 0.13299763888931174, 'probability': 0.13299763888931174, 'confidence': 0.13299763888931174, 'idx': 13}, {'completion': 0.034201178443145616, 'probability': 0.034201178443145616, 'confidence': 0.034201178443145616, 'idx': 14}, {'completion': 0.16534292788151092, 'probability': 0.16534292788151092, 'confidence': 0.16534292788151092, 'idx': 15}, {'completion': 0.41933670557763714, 'probability': 0.41933670557763714, 'confidence': 0.41933670557763714, 'idx': 16}, {'completion': 0.021007360586568286, 'probability': 0.021007360586568286, 'confidence': 0.021007360586568286, 'idx': 17}, {'completion': 0.05718449019765577, 'probability': 0.05718449019765577, 'confidence': 0.05718449019765577, 'idx': 18}, {'completion': 0.16534292788151092, 'probability': 0.16534292788151092, 'confidence': 0.16534292788151092, 'idx': 19}]}\n",
      "{'name': '9792', 'success': [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0], 'interactions': [{'completion': 0.8233320913979503, 'probability': 0.8233320913979503, 'confidence': 0.8233320913979503, 'idx': 0}, {'completion': 0.23189271618283847, 'probability': 0.23189271618283847, 'confidence': 0.23189271618283847, 'idx': 1}, {'completion': 0.17661833855002526, 'probability': 0.17661833855002526, 'confidence': 0.17661833855002526, 'idx': 2}, {'completion': 0.11845638440574267, 'probability': 0.11845638440574267, 'confidence': 0.11845638440574267, 'idx': 3}, {'completion': 0.05643159642437378, 'probability': 0.05643159642437378, 'confidence': 0.05643159642437378, 'idx': 4}, {'completion': 0.0067909809999839935, 'probability': 0.0067909809999839935, 'confidence': 0.0067909809999839935, 'idx': 5}, {'completion': 0.3579658480269895, 'probability': 0.3579658480269895, 'confidence': 0.3579658480269895, 'idx': 6}, {'completion': 0.05512931727233941, 'probability': 0.05512931727233941, 'confidence': 0.05512931727233941, 'idx': 7}, {'completion': 0.07379773123902732, 'probability': 0.07379773123902732, 'confidence': 0.07379773123902732, 'idx': 8}, {'completion': 0.2703282052361722, 'probability': 0.2703282052361722, 'confidence': 0.2703282052361722, 'idx': 9}, {'completion': 0.12220079667797162, 'probability': 0.12220079667797162, 'confidence': 0.12220079667797162, 'idx': 10}, {'completion': 0.0151357729782535, 'probability': 0.0151357729782535, 'confidence': 0.0151357729782535, 'idx': 11}, {'completion': 0.13150091423749877, 'probability': 0.13150091423749877, 'confidence': 0.13150091423749877, 'idx': 12}, {'completion': 0.27233627684959955, 'probability': 0.27233627684959955, 'confidence': 0.27233627684959955, 'idx': 13}, {'completion': 0.09888648654780073, 'probability': 0.09888648654780073, 'confidence': 0.09888648654780073, 'idx': 14}, {'completion': 0.20257772823658782, 'probability': 0.20257772823658782, 'confidence': 0.20257772823658782, 'idx': 15}, {'completion': 0.03205465507857659, 'probability': 0.03205465507857659, 'confidence': 0.03205465507857659, 'idx': 16}, {'completion': 0.23997941641070422, 'probability': 0.23997941641070422, 'confidence': 0.23997941641070422, 'idx': 17}, {'completion': 0.11070919987015605, 'probability': 0.11070919987015605, 'confidence': 0.11070919987015605, 'idx': 18}, {'completion': 0.2355173472168504, 'probability': 0.2355173472168504, 'confidence': 0.2355173472168504, 'idx': 19}]}\n"
     ]
    }
   ],
   "source": [
    "#x_train = np.load('/home/path/Data/triviaqa/train/idx.npy', allow_pickle=True)\n",
    "#x_test = np.load('/home/path/Data/triviaqa/test/idx.npy', allow_pickle=True)\n",
    "data = []\n",
    "for t in [\"train\", \"test\"]:\n",
    "#for t in ['train']:\n",
    "    x = np.load('./data/triviaqa/%s/idx.npy' % t, allow_pickle=True)\n",
    "    success = (np.load('./data/triviaqa/%s/labels.npy' % t, allow_pickle=True) > 0.5).tolist()\n",
    "    score = np.load('./data/triviaqa/%s/probs.npy' % t, allow_pickle=True)\n",
    "    #evaluation = np.load('/home/path/Data/triviaqa/%s/self_eval.npy' % t, allow_pickle=True)\n",
    "\n",
    "    \n",
    "    for i in range(x.shape[0]):\n",
    "        #print(i)\n",
    "        dict_element = {}\n",
    "        dict_element[\"name\"] = str(int(x[i]))\n",
    "        successi = [int(a) for a in success[i]]\n",
    "        \n",
    "        dict_element[\"success\"] = successi\n",
    "        l = []\n",
    "        for j in range(20):\n",
    "            answer = {}\n",
    "            answer[\"completion\"] = float(score[i,j]) #float(successi[j])\n",
    "            answer[\"probability\"] = float(score[i,j])\n",
    "            answer[\"confidence\"] = float(score[i,j])\n",
    "            answer[\"idx\"] = j\n",
    "            l.append(answer)        \n",
    "        dict_element[\"interactions\"] = l\n",
    "        data.append(dict_element)\n",
    "        if t == \"train\":\n",
    "            idx = int(x.shape[0])\n",
    "print(idx)\n",
    "print(len(data))\n",
    "print(data[0])\n",
    "print(data[1])\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "ba9871be",
   "metadata": {},
   "outputs": [],
   "source": [
    "# load ground truth\n",
    "truth = {}\n",
    "# with open('../../data/dev_sample_self_eval.jsonl', 'r') as f:\n",
    "with open('data/output.jsonl', 'r') as f:\n",
    "    i = 0\n",
    "    for line in f:\n",
    "        item = json.loads(line)\n",
    "        truth[str(i)] = item.copy()\n",
    "        i += 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "099681b4",
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_question_data(idx):\n",
    "    if not isinstance(idx, str):\n",
    "        idx = str(idx)\n",
    "    return truth[idx]\n",
    "\n",
    "def get_generated_answers(idx):\n",
    "    if not isinstance(idx, str):\n",
    "        idx = str(idx)\n",
    "    return [generate[\"decoded\"] for generate in truth[idx][\"generations\"]]\n",
    "\n",
    "def get_unique_answers_idx(idx):\n",
    "    if not isinstance(idx, str):\n",
    "        idx = str(idx)\n",
    "    gens = get_generated_answers(idx)\n",
    "    uniq_gens = list(set(gens))\n",
    "    return [gens.index(ug) for ug in uniq_gens]\n",
    "\n",
    "def process_method(instance, outputs):\n",
    "    unique_idx = get_unique_answers_idx(instance)\n",
    "    process_outputs = [outputs[i] for i in unique_idx if i < len(outputs)]\n",
    "    return process_outputs\n",
    "\n",
    "def normalize_text(s):\n",
    "    \"\"\"Lower text and remove punctuation, articles and extra whitespace.\"\"\"\n",
    "\n",
    "    def remove_articles(text):\n",
    "        return re.sub(r\"\\b(a|an|the)\\b\", \" \", text)\n",
    "\n",
    "    def white_space_fix(text):\n",
    "        return \" \".join(text.split())\n",
    "\n",
    "    def remove_punc(text):\n",
    "        exclude = set(string.punctuation)\n",
    "        return \"\".join(ch for ch in text if ch not in exclude)\n",
    "\n",
    "    def lower(text):\n",
    "        return text.lower()\n",
    "\n",
    "    return white_space_fix(remove_articles(remove_punc(lower(s))))\n",
    "\n",
    "def exact_match(prediction, answers):\n",
    "    \"\"\"True if prediction matches any answer.\"\"\"\n",
    "    prediction = normalize_text(prediction)\n",
    "    answers = [normalize_text(a) for a in answers]\n",
    "    return float(any([prediction == a for a in answers]))\n",
    "\n",
    "def admissibility_check(instance, outputs):\n",
    "    data = get_question_data(instance)\n",
    "    generated_answers = get_generated_answers(instance)\n",
    "    answers = data[\"answer\"][\"normalized_aliases\"]\n",
    "    predictions = [generated_answers[output[\"idx\"]] for output in outputs]\n",
    "    return max([exact_match(prediction, answers) for prediction in predictions])\n",
    "\n",
    "def admissibility_list(instance, outputs):\n",
    "    data = get_question_data(instance)\n",
    "    generated_answers = get_generated_answers(instance)\n",
    "    answers = data[\"answer\"][\"normalized_aliases\"]\n",
    "    predictions = [generated_answers[output[\"idx\"]] for output in outputs]\n",
    "    return [exact_match(prediction, answers) for prediction in predictions]\n",
    "\n",
    "def admissibility_check_mock(instance, outputs):\n",
    "    return max(float(item['success']) for item in outputs)\n",
    "\n",
    "def admissibility_list_mock(instance, outputs):\n",
    "    return [float(item['success']) for item in outputs]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "ea40a871",
   "metadata": {},
   "outputs": [],
   "source": [
    "# admissibility_aggregation = lambda a_list: max(a_list) if len(a_list) > 0 else 1\n",
    "score_fn = lambda x, y: y.get(\"completion\", 0)\n",
    "# score_fn = lambda x, y: np.mean([step[\"probability\"] for step in y]) if len(y) > 0 else 0\n",
    "sequence_selector = PostprocessedSequenceSelector(\n",
    "    base_selector=RunningMaxSequenceSelector(score_fn=score_fn),\n",
    "    process_method=process_method,\n",
    "    returns_subsequence=True,\n",
    ")\n",
    "x = [(row[\"name\"]) for row in data]\n",
    "y = [row[\"interactions\"] for row in data]\n",
    "# print(y[0])\n",
    "for row_data, row_y in zip(data, y):\n",
    "    for j, seq in enumerate(row_y):\n",
    "        seq[\"success\"] = row_data[\"success\"][j]\n",
    "        #for step in seq:\n",
    "        #    step[\"success\"] = row_data[\"success\"][j]\n",
    "#idx = int(0.8 * len(x))\n",
    "x_train, x_test = x[:idx], x[idx:]\n",
    "y_train, y_test = y[:idx], y[idx:]\n",
    "#print(len(x_train))\n",
    "a_data = [row[\"success\"] for row in data]\n",
    "a_train, a_test = a_data[:idx], a_data[idx:]\n",
    "n = len(x_train)\n",
    "calibration_ds = ManualCalibrationDataset(\n",
    "    sequence_selector=sequence_selector,\n",
    "    input_dataset=x_train,\n",
    "    raw_generated_dataset=y_train,\n",
    ")\n",
    "a_func = admissibility_check_mock"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "2ac7fb79",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Custom Admissibility Actual Admissibility     Generated Answer\n",
      "                 0.0                    0               8-ball\n",
      "                 0.0                    0               8-Ball\n",
      "                 0.0                    0              8-Balls\n",
      "                 0.0                    0               8-BALL\n",
      "                 0.0                    0             8-Balled\n",
      "                 0.0                    0            8-Balling\n",
      "                 1.0                    1               8-Bell\n",
      "                 0.0                    0              8-Baulk\n",
      "                 0.0                    0                 8-Ba\n",
      "                 0.0                    0                  8-B\n",
      "                 0.0                    0              8- Ball\n",
      "                 0.0                    0              8- ball\n",
      "                 0.0                    0                 8-80\n",
      "                 0.0                    0                  8-8\n",
      "                 0.0                    0             8-balled\n",
      "                 0.0                    0           8-ballyard\n",
      "                 0.0                    0              8-bally\n",
      "                 0.0                    0               8-blll\n",
      "                 1.0                    1                8-bll\n",
      "                 0.0                    0               8-balk\n",
      "True Answers: ['nine ball', '9 ball pool', '9 ball', 'nineball', '9ball', 'six ball']\n"
     ]
    }
   ],
   "source": [
    "test_idx = 9\n",
    "computed = admissibility_list_mock(x_train[test_idx], y_train[test_idx])\n",
    "actual = [item['success'] for item in y_train[test_idx]]\n",
    "generated_answers = get_generated_answers(x_train[test_idx])\n",
    "true_answers = get_question_data(x_train[test_idx])[\"answer\"][\"normalized_aliases\"]\n",
    "# print table header\n",
    "print(f\"{'Custom Admissibility':>20} {'Actual Admissibility':>20} {'Generated Answer':>20}\")\n",
    "# format and print each row\n",
    "for c, a, ans in zip(computed, actual, generated_answers):\n",
    "    print(f\"{c:>20} {a:>20} {ans:>20}\")\n",
    "print(f\"True Answers: {true_answers}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "866dabd7",
   "metadata": {},
   "outputs": [],
   "source": [
    "eval_dict = calibration_ds.get_dict_for_evaluating_admissibilities()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "68d09045",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'lambda': 0.021007360586568286,\n",
       " 'instance_index': 0,\n",
       " 'instance': '10458',\n",
       " 'raw_output': [{'completion': 0.7154925499329796,\n",
       "   'probability': 0.7154925499329796,\n",
       "   'confidence': 0.7154925499329796,\n",
       "   'idx': 0,\n",
       "   'success': 1},\n",
       "  {'completion': 0.417514242697702,\n",
       "   'probability': 0.417514242697702,\n",
       "   'confidence': 0.417514242697702,\n",
       "   'idx': 1,\n",
       "   'success': 0},\n",
       "  {'completion': 0.149690994163353,\n",
       "   'probability': 0.149690994163353,\n",
       "   'confidence': 0.149690994163353,\n",
       "   'idx': 2,\n",
       "   'success': 1},\n",
       "  {'completion': 0.3342096564603057,\n",
       "   'probability': 0.3342096564603057,\n",
       "   'confidence': 0.3342096564603057,\n",
       "   'idx': 3,\n",
       "   'success': 0},\n",
       "  {'completion': 0.27541727308903297,\n",
       "   'probability': 0.27541727308903297,\n",
       "   'confidence': 0.27541727308903297,\n",
       "   'idx': 4,\n",
       "   'success': 1},\n",
       "  {'completion': 0.04814430795684208,\n",
       "   'probability': 0.04814430795684208,\n",
       "   'confidence': 0.04814430795684208,\n",
       "   'idx': 5,\n",
       "   'success': 0},\n",
       "  {'completion': 0.21255285165862106,\n",
       "   'probability': 0.21255285165862106,\n",
       "   'confidence': 0.21255285165862106,\n",
       "   'idx': 6,\n",
       "   'success': 0},\n",
       "  {'completion': 0.41531164609688725,\n",
       "   'probability': 0.41531164609688725,\n",
       "   'confidence': 0.41531164609688725,\n",
       "   'idx': 7,\n",
       "   'success': 0},\n",
       "  {'completion': 0.25851988095931583,\n",
       "   'probability': 0.25851988095931583,\n",
       "   'confidence': 0.25851988095931583,\n",
       "   'idx': 8,\n",
       "   'success': 0},\n",
       "  {'completion': 0.16331002399598488,\n",
       "   'probability': 0.16331002399598488,\n",
       "   'confidence': 0.16331002399598488,\n",
       "   'idx': 9,\n",
       "   'success': 0},\n",
       "  {'completion': 0.39216628812179355,\n",
       "   'probability': 0.39216628812179355,\n",
       "   'confidence': 0.39216628812179355,\n",
       "   'idx': 10,\n",
       "   'success': 0},\n",
       "  {'completion': 0.6957879197181561,\n",
       "   'probability': 0.6957879197181561,\n",
       "   'confidence': 0.6957879197181561,\n",
       "   'idx': 11,\n",
       "   'success': 0},\n",
       "  {'completion': 0.30868471412245907,\n",
       "   'probability': 0.30868471412245907,\n",
       "   'confidence': 0.30868471412245907,\n",
       "   'idx': 12,\n",
       "   'success': 0},\n",
       "  {'completion': 0.13299763888931174,\n",
       "   'probability': 0.13299763888931174,\n",
       "   'confidence': 0.13299763888931174,\n",
       "   'idx': 13,\n",
       "   'success': 0},\n",
       "  {'completion': 0.034201178443145616,\n",
       "   'probability': 0.034201178443145616,\n",
       "   'confidence': 0.034201178443145616,\n",
       "   'idx': 14,\n",
       "   'success': 0},\n",
       "  {'completion': 0.16534292788151092,\n",
       "   'probability': 0.16534292788151092,\n",
       "   'confidence': 0.16534292788151092,\n",
       "   'idx': 15,\n",
       "   'success': 0},\n",
       "  {'completion': 0.41933670557763714,\n",
       "   'probability': 0.41933670557763714,\n",
       "   'confidence': 0.41933670557763714,\n",
       "   'idx': 16,\n",
       "   'success': 0},\n",
       "  {'completion': 0.021007360586568286,\n",
       "   'probability': 0.021007360586568286,\n",
       "   'confidence': 0.021007360586568286,\n",
       "   'idx': 17,\n",
       "   'success': 0},\n",
       "  {'completion': 0.05718449019765577,\n",
       "   'probability': 0.05718449019765577,\n",
       "   'confidence': 0.05718449019765577,\n",
       "   'idx': 18,\n",
       "   'success': 0},\n",
       "  {'completion': 0.16534292788151092,\n",
       "   'probability': 0.16534292788151092,\n",
       "   'confidence': 0.16534292788151092,\n",
       "   'idx': 19,\n",
       "   'success': 0}],\n",
       " 'selected_sequence': [{'completion': 0.7154925499329796,\n",
       "   'probability': 0.7154925499329796,\n",
       "   'confidence': 0.7154925499329796,\n",
       "   'idx': 0,\n",
       "   'success': 1}]}"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "list(eval_dict.items())[1][1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "609b104e",
   "metadata": {},
   "outputs": [],
   "source": [
    "a_dict = {}\n",
    "for key, out_dict in eval_dict.items():\n",
    "    lambda_ = float(out_dict['lambda'])\n",
    "    instance = out_dict['instance']\n",
    "    a_dict[key] = a_func(instance, out_dict['selected_sequence'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "482ea04c",
   "metadata": {},
   "outputs": [],
   "source": [
    "calibration_ds.register_admissibilities(a_dict, reregister=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "01391f8a-afbb-4b43-8fcf-348fb8bf6b3e",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.578770361417283\n",
      "0.7005\n",
      "0.7003499999999999\n"
     ]
    }
   ],
   "source": [
    "CG = ConformalGeneration(\n",
    "    sequence_selector=sequence_selector,\n",
    "    calibration_dataset=calibration_ds,\n",
    ")\n",
    "gamma0 = 0.7\n",
    "CG.calibrate(gamma=gamma0, recalibrate=True)\n",
    "# selected= CG.select(instance=x_train[0], raw_generated_sequence=y_train[0])\n",
    "print(CG._conformal_threshold)\n",
    "print(sum(a_func(x, selected) for x, selected in zip(x_train, [CG.select(instance=x, raw_generated_sequence=y) for x, y in zip(x_train, y_train)])) / len(x_train))\n",
    "print((len(x_train) + 1 ) * gamma0 / len(x_train))\n",
    "# print(x_train)\n",
    "# print(y_train)\n",
    "# print([[step[-1]['completion'] for step in y] for y in y_train])\n",
    "# print(a_train)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "b404fbab-c1cf-4d01-a01a-1bcfadfde087",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjcAAAHHCAYAAABDUnkqAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjcsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvTLEjVAAAAAlwSFlzAAAPYQAAD2EBqD+naQAAbntJREFUeJzt3Qd4FFUXBuATAqH33ntvISAIiEjvHeRXQEQpCgiCiqIiIArYKCKCooid3kE6iAiIVJFepffeEhLmf74TJ26WTbKbbN/vfZ4l7GR3dnJndubMLecGGYZhCBEREZGfSObpDSAiIiJyJgY3RERE5FcY3BAREZFfYXBDREREfoXBDREREfkVBjdERETkVxjcEBERkV9hcENERER+hcENERER+RUGNz7m0KFD0rBhQ8mYMaMEBQXJ/PnzxZesW7dOtxs/yX4os2HDhvlkkWG7sf3O9Oyzz0qhQoXEHduK53379k3wvdOmTdPXHj9+PGbZE088oQ8TfofX4LXk37Zs2SIhISHyzz//SKC7fPmypE2bVpYuXeq2z2RwkwhHjhyRXr16SZEiRSRVqlSSIUMGqVmzpowfP17u3r0rrtS1a1fZvXu3vP/++/L9999LlSpVxJ8dO3ZMLywlSpSQNGnS6KNMmTLSp08f+euvv8Sf4IvvzQHMoEGD9MLcsWNHT2+KX/H2/R6f8PBwmTBhgjz22GOSOXNmvZjnyZNHWrZsKT///LNERUVJoHrrrbfkqaeekoIFC8Ys+/zzz10e2O7du1ePJ8sg29PHctasWaV79+4yZMgQ920M5pYi+y1evNhInTq1kSlTJqNfv37Gl19+aXz22WfG//73PyNFihRGjx49XFacd+7cwTxgxltvveWzu2zt2rX6N+BnQhYtWmSkSZPGyJAhg/Hiiy8akydP1vIeOHCgUahQISMoKMg4fvy44S/69OmjZWPL3bt3jfv37xue8uDBAyNfvnxa7jj+b9y4Yfd7hw4dGufflVgRERHGvXv3DGdDGaOsLWHbsW8SEhkZqe9FWZlq166tDxN+h9fgtfbsd2924cIFo3LlyrrtjRo1Mj7++GNj6tSpxsiRI426devq8nfffdcIRDt27NC/f+PGjbGWly1bNtbx4AqzZs2y+xzrbPEdy3v37tXfrV692i3bktx9YZR/1CL873//00h8zZo1kjt37pjfoSbh8OHDsmTJEpd9/sWLF/VnpkyZnLbO27dva3WhN9aOmWW9evXqWGUNH3zwgd4FJUvmvZWPzixb1BB6EpoRT506pcd9o0aNZO7cuVqL6CkpUqRwyXqTJ0+uj8QIDg7WR3xQ8+XpfeksXbp0kR07dsicOXOkbdu2sX43ePBg2bp1qxw4cEAC0TfffCMFChSQRx991NOb4jVKly4t5cqV05qrunXruv4D3RJC+YkXXnhBI8/ff//d7rtA3LkUKVLECAkJMQoWLGgMHjz4oTtOLG/WrJnx22+/GY888oiRMmVKo3Dhwsa333770N2v5QPvM23fvt1o3LixkT59eiNt2rR657Rp06ZYn/PNN9/o+9atW6c1IdmzZ9caKMDdBO4qdu3aZTz++ON6d160aFG9CwC8p2rVqkaqVKmMEiVKGCtXroy1btSgYJ34HV6TJUsWo3379saxY8cSVXPTs2dPfd3mzZsNR+zbt89o166dkTlzZi1H3FkuWLDAZjls2LDBGDBggJEtWzatIWrdurXejVpbunSp8dhjj+lr0qVLZzRt2tT4+++/Y72ma9euWu6HDx82mjRpoq9r1aqV/m79+vVaFvnz59fjADUgL7/8stbEWb7fev9afj3xfxwDlhzZ5/b+rXF5/vnnjTJlyuj/8fc1aNDA5utwDFepUkXLHsc9atts1dyYtSEzZ840SpcurcfMo48+avz111/6e7wPxx/Wg2PT+jhCeVke//Dzzz8bYWFhWvYok3Llyhnjxo2LVdszbNgwo1ixYrpeHKM1a9Y0VqxYEfOa+Lb1hx9+0OMb78Xn/PrrrzbL2nJbrWtu8Du8Bq+Nb7+jhgd/X8uWLR8qY9T8oDYT35G44Lv8xBNPPLQ8KirKyJMnj35H7C03W1Ajge3EOdFe4eHhxpAhQ/SzsP04DvG9WrNmTazXmWX00Ucfaa04zoU4H+GYO3HihJYNzqt58+bV4wZldPnyZZvnVJxncA7A6/B3meedOXPm6HNzX+K7ZAnnQewbfDZekzNnTqNbt27GpUuX7PpbCxQoYDz77LMPbZP1frY8Nq5evWr0799fzw84T+D4Hz16tO4zS/HtL/MYFKtHfOfbs2fP6raiPPG5uXLl0jK1/s4ldB5M6BwGOAfhmmNZu+kqDG4cgJ2PE7a9zJ2NC9vEiRONZ555Rp/jwmJ90JcsWVK/QG+++aZ+oXHwotnFPHjwZRs7dqy+/6mnnjK+//57Y968efo7vAYXt9y5cxsjRozQL4T5pbQMDswDHxcpfKkmTJigrwU8x0kPF+DXXntNf4fXBQcHG9OnT9cDHhcGfIlQDhkzZozVNIEgqGLFisY777yjTUf4OxBg4G+7ffu2w8ENtgUXIUegHLBd2O4PPvhAyxGBGspx7ty5D5VDpUqVNCDA3/rKK6/o3/rkk0/GWud3332n70cQgddhvWiawRfU8suPfY3yxgkJ/8fFGe+Fl156SU8EqK7/4osvNFDAZ+G4sLxY4OSN7cK+NR9xBTeO7nN7/ta4IBjH34vPMcsE78dJ0RICE1yEcGIfNWqUvh7HdIUKFWwGDFiO4w3bjgf2Hd6L/YZ9+Mknnxhvv/22nnDr1KkTb3CDAAXrrFevnn7X8Ojbt6/RoUOHmNfgmMS+RNPxlClTdP34LpnfgfiCG1xAEBjioopjAJ+Nv3X37t1JCm7i2+9ofkZTt/WFGwEhXo+gOS7YzmTJkj20jxCQ4b3mTYs95WYLbtLMoNleFy9e1OMVzcqTJk0yPvzwQz3v4W9EM451GYWGhupxMGbMmJjjAAEw9mONGjWMTz/9VLsGYJ8i8LB1TsXn4byFcyfOW7goI0jFcWZ53OFcYxlEoImtVq1aWo44nyHowP7GDV5CF+ZTp07p9mP7LOF8jcClVKlSMfvZDKxxjsT3IWvWrPr34fyB6wX+Nny2KaH9deTIES0TEdH1mJ9z7ty5OLcXZYkyQBl/9dVXep7C980yeLfnPJjQOQxQ9vi95ffGVRjc2On69eu6U8y78YTs3LlTX9+9e/dYy1999VVdbnm3Ykb0licr3FXjQoULka07GksIlvDFx4FtOnPmjEb1uLhbn3wRfVu2+QNOwPjdTz/9FLNs//79ugwnScsL5vLly2OdoMGyFsKEWgS8zrzI2xvcmGVtHQSadzc4SZoPy8/FF758+fKxasZwIsKXt3jx4g+VQ/369WOdqHBXgYv2tWvX9PnNmzf1y2vdjwonCpwMLJebgewbb7zx0DbbKhtc/HGy+Oeff+xqr7YObhzd5wn9rfGZPXu2ruPQoUP6HEEt7oRxwbCEbcJyy78J7ez4HFsBA45vy0AAgR+WI5C2DJzNC6l1MGkZ3OACgNoA6+PaEoJv3M3HJ67gBo+tW7fGLMPfiL+1TZs2SQpu4tvvBw4c0OUIBCzhrhoXlvgusuZ7cSGy1Lt3b73Am8ekPeVmC/5urN/6+EGtkuX3E99XEz4DtTeW8HsEwM8999xDZYSaZcv1m8cB9qNl/zMEqPguWH7vzXOqZZ8X87yFIMXyGDWPO8tzkq3vLGpMEgoqYdWqVfo69Bm0FlefG9wI4Gbl4MGDsZbjfILvD2qs7N1fjvS5uXr1qs1riiVHzoMJ9R8za/xmzJhhuJr3dljwMjdu3NCf6dOnt+v15pC3gQMHxlr+yiuv6E/rvjkYAVSrVq2Y59mzZ5eSJUvK0aNH4/0cjEZYsWKFtG7dWkdvmdBH5emnn5YNGzbEbLupR48eNvsGpEuXTvu5mPD56N+DttJq1arFLDf/b7ltqVOnjvn//fv3dehfsWLF9P3bt28XR5jbi+2xhmG1KBvzMXHiRF1+5coV7Q/y5JNPys2bN+XSpUv6wHagjwiG0J8+fTrWunr27Blr2C/KH+VpDt1cuXKlXLt2TUc8mOvDA2WHMli7du1D2/fiiy8+tMyybNAPB+uoUaMGzgDaZ8FRidnnCf2t8fnxxx91VB72p/kdaNasmS633Kbly5frNqGvgQnHDsrflnr16sUazm0eV+3atYv1PbN1vFnDcYayxT6L7zV79uzRY8FR1atXl8qVK8c8x9/YqlUr/ZtdNSIIIwTxt1uWM47zX375RTp16hTv8Hq8NzQ0VGbMmBGzDNs5e/ZsadGiRcwxaU+5OfIdnTx5cqzvJ0ZRmfC9wWgqePDggf4tkZGRemzZOkd06NBBU15YHwedO3eO1S8KyyMiIh76fuOciv1m/X7097A8RhM6n927d0+/s2b/mYTOZzjnAEaP2WvWrFn6ncR7LM819evX1/22fv36JO2vuODvxD5Bn7qrV6/afE1izoNxMcsE73c1Bjd2wnBvwIXTHrhooLOreUEw5cqVSw9Q64uK5ZfN8kCI64Cz7GR8584dDUSs4cKCk8jJkydjLS9cuLDNdeXLl++hEyZOLvnz539oGVhuG4bAv/POO/ralClTSrZs2fTkhi/F9evXxRHmhe3WrVsP/e6LL77QL9sPP/wQazk6cyNYwFBDy5MrHkOHDtXXXLhwId4yN7945t9lXgRxMrReJ4IL6/XhhIsytHbixAnNy5IlSxa9GOD9tWvX1t85WjaJ3ecJ/a1xwf5DoI7tRRmbD6Q+QIfRgwcPxmwTjoHixYs/tA5b22lrm8zjyp7jzVrv3r31gt6kSRPdB88995wsW7Ys1mveffdd/XvwuvLly8trr71mdzoBW38X1oP9YHb0d4VnnnlGfv/995jzBS6CuHlAZ96EYMg+3mte9HEBwzFrOZTfnnJz5DuKwBTfTzwqVKjw0Pu+/fZbXY5O1RgejO8CbvRsfQ+Senwk5f0IvPr37y85c+bUAADbaZ437f3ORlf62QfnGpS79XkGwQ2Y55rE7q+44FyNwRkImPG3Pv744/Lhhx/KuXPnYl7j6HnQnjJxdt4rWzhayoHgBvkb/v77b4cK2N6dGNcoC0e+IPayvCuxZxvs2baXXnpJRwi8/PLLerdkJhlETRAuto7Ae1ELYauszbss6xwO5me8+uqrcdYUWAeaCf1d5jqRTwhBqTXrUTU4UViP3sJdV4MGDfRk+frrr0upUqV0BBUuOAh4HC2bxErs8YWLKXKZfPLJJ/qwhlqF4cOHO3WbErOtOXLkkJ07d2pNCk7UeOB4RHCACyrgxI1ReAsWLNCT8ldffSVjx47V2gbk4PBG+P4MGDBAy/nNN9/UoB41HXEFjJYQxGDUEvYhvpczZ87U71bjxo0dKjdbcBwDvqMIdE0IHMzgwayFMGHbccyjdg+BJT4b+3rUqFG6X5x9fCTl/agB3rhxo24nasBwU4LvKsouoe8sgjZ7bhwsYZ04TyCXlC0IaJKyv+KDYwO1eUgIi/XiBhH7BDXhlSpVcvg8GB+zTHDz62oMbhzQvHlz+fLLL2XTpk2xqjttwRBmHBSIenE3bTp//rzePVomdkoKRM9IbGdryOX+/fv1Ymt9p+IKqO7G0GDLCyCqc/G3JgaaPXDxQZbPqlWrJvh6s3kGQ4TNu52kKlq0aMwJJbHrRMJF1G7gxIMTkMlWtbK9gbA79zkuqhi+adZ+Wdei/fTTTxrcYJsQNNtq8nHXcGBUr+MkjQe+e7jLxTbiZG0Gtqg969atmz5Q64CAB0nHEgpubP1d2K/YD/jbkyK+/Y7tNZsA0RSFmphx48bZtV7UNOC7g6YpJMLE8H0EFgjCHS03W+fC0aNH63ZZBjcJnSPwPcV2WP7Nto4tT8IFGOkncFyjNtpkb3OmGfghdYi9+xrnGhyP9pxnEtpfiakVKVq0qHaZwAN/JwI6nMsRkDpyHkzos80ysbwmugqbpRyAqBp33TgRIkixhrsPZCmGpk2b6k/rE9GYMWP0J05YzoC7EEzHgLtRy9oMbB8uPGjzNpvUXAnbYX3nhMylie2PgLLGhQPVrrbK2vqz8MVDfxx8yc+ePfvQ6xPTdIAaIJTdyJEjtSkgMes07xIttxf/N48TS2ZOnIQCQnftczRtoa0fd7Ht27d/6IEAAU1Uf/zxh24Tygt3f2iGM+3bt0/vBl3N7OdgQoBnNoug5snWa3A3jouB+fv44IbGsq8Fygblj/2QUG6bhCS039EEhayzqEXAZ1n2i7On9mbz5s0ydepUrUWxzi5tT7nZgoAGNQ242UM5OFKTYrkcxw7K1pvY2k6wN6jMmzev3lyg2dbWvra1n/EdQznY+q7g9eibZO/+svc8AmhWxU2oJQQzaHY01+fIeTChz962bZvWHpYtW1ZcjTU3DsBOx8UDJwhEnrgTx10tOrOhChPVv6h2hYoVK2pNBr782NHos4BaCNzB4+6pTp06TtuJ7733ntYE4KKGKB7VhLjI4+BE+6k74E4O1ZY4cNGRD1/UVatWxVTROgp9HFDW6MSGKnjctaJMccJB9I/f4Ytt2ccFnYtRBuhPgU7TuEvEBR/bggR0u3btcmgb8IWeNGmSXlzCwsL0ooK7dFy80U8AJ/jPPvsswbs4HDdoLkNTFNaJpGe2qqzNDqv9+vXTE0p8FzJ37HOUMcobqfRtQQCPz8XdO5oLcaeL9n90jMQ24YSMABcnMldPlYEbDjT9oV8Ajgn0UcFn4w7UvEvEcYkAGOWMGhFcfFCbYM+8UfieY59g36DmAwkkIbFNco7sd9wI4XuE8wv6WiCQtxcumjj28MDfbH3nbU+5xQV39WimwfkM24V1oykK/TXw3UdgjOWW5wjU2rRp00b/JnyP0SSI/WKrf52n4Dtq9j3BxRzBCpoxbdXExAWdzefNm6ffH8vaDOxrnFPw/UVgjX2JskfgunDhQi0jXEPwOnQcRs0vjlHcxKApx579hf8HBwdrXxr0D8LxitfbOm5Q+4iO/ThOsB/wfcZ247xpHoOOnAcTOpZxzkKNkzv63HAoeCJguB6Gv2E4JoYgYvgtkoFh2KXlcEQMVxw+fLjmH0EuB+T0iC+Jn7W4hpHaGraHJFRIgY5hnkiyhDwF1qm/zaGqf/75p83PwjBFa3Ftm5nYzHJIIXJNIBcItgHbgqHkeD+G7SZm+gVAUjwkB0QeCgy9xTBO5IlA8jAMt7eGodHID4HhxChz5LZo3ry5DmdOqBzi2jY8x9+DYY/YBuSyQdIry6HBZhI/WzAcGkOxUS4oHxw7yFtkPSQYwzuREwdDYDFM3J4kfond5/bsBwyrRz6Q+CBRXI4cOWKG5iI3BpKm4XthTxI/S3Ed3+a2mrlZbA0Fx/5t2LChbgs+G9vdq1evWHle3nvvPc1TgmGt5nH0/vvva3I/e5P4IaUAhrAjb5B12SV2KHh8+91yCLd1qgZ74dxkKy2FveUWHwz9Ru6r6tWr6xDl5MmT63cP37kff/wx1pBlDF1HDhXsN7MMMZ2N9b505DiI6xi397wV1+chVw2Gu+NYwfceeWSQasHW99AWfDfxWiS1tB4+je3CNcM6iR+GXOP6gHMd9gXOFUhjgZw75jFq7/6aMmWKfv/MNAxxfc+RlBDlge8Czl/4W6tVq6a5lKzZcx6M71hGglU8x1B5dwjCP64PoYiIKLHQqfjrr7/WWhE015L3Q40IBqGgRptEOy6jNg9NU+6ouWFwQ0TkxdAnAn040GSBkTHkG9CfCE206KDrrAEkvury5ctaBhixZ/ZHdTUGN0REXgj5Q9B3BX0u0FEbHZrRn4KIEsYOxUREXggjpNCRHh1BP/30UwY2RA5gzQ0RERH5Fea5ISIiIr/C4IaIiIj8SsD1uUG66jNnzmgGRrckEiIiIqIkQ+YaTF6NIfbW8/hJoAc3CGzcMdcSEREROR+mP7HMTm9LwAU3qLExC8fZcy4hVTfSdGO+GUzgSK7BcnYPljPL2d/wmPbtcr5x44ZWTpjX8fgEXHBjNkUhsHFFcIPsoVgvgxvXYTm7B8uZ5exveEz7Rznb06WEHYqJiIjIrzC4ISIiIr/C4IaIiIj8SsD1ubFXVFSUths6Aq9Pnjy5TnSH95NreEM5ox05ODjYI59NRETxY3BjYxz9uXPn5Nq1a5KY9+bKlUtHYjGHjut4SzlnypRJt4P7mojIuzC4sWIGNpisDr29HblwIUHgrVu3JF26dAkmGKLE83Q5I7i6c+eOztoMuXPndvs2EBFR3BjcWEAThxnYZM2aVRJz0Y2IiJBUqVIxuHEhbyjn1KlT608EODhe2ERFROQ9WL1gwexjgxobooSYx4mjfbOIiMi1GNzYwD4UZA8eJ0Q+ICIiab9393pdue4IH9zmRGJw46euXr0qw4cPl7Nnz3p6U4iIPGPGDJHy5THfju3fYzl+j9d5w3q5zf4R3Kxfv15atGihM3ziLnj+/PkJvmfdunUSFhYmKVOmlGLFism0adPcsq2+pn///rJlyxZ58cUXPb0pRETuh5qCd94ROXhQ5IknHg5E8BzL8Xu8zt6aBVetl9vsP8HN7du3pWLFijJx4kS7Xn/s2DFp1qyZ1KlTR3bu3Ckvv/yydO/eXZYvX+7ybfUlS5Ys0Wnh8RPDlX/88UdPbxIRkXuFhIisWiVSpIjI0aPRAcfp09G/w088x3L8Hq/D6xO7XjPAMQObxKzXlesOcfM2O6OcfXm0VJMmTfRhr8mTJ0vhwoXlk08+0eelS5eWDRs2yNixY6VRo0Yu3FLfggAQD2DNFhEFrPz5Ud0fc4G91PBpufDaMPmnQXdJcTRSJP9jIj/MEHmQR+Qfh1Ys8sNvIh07ihw9IVLzaZFx40ReflnkZFLW68p153fbNt9v0F2uvvWqSNOm/wU22A/YH27iU0PBN23aJPXr14+1DEENanDiEh4erg/LKdPNES7Wo1zwHDlMMNQYD0fhvebPxLyffKuc8dnYBhw3/jgU3Px+cDQYy9mn5colsnq1zHlsnDx1aJxITyxsGP07VF7USOyK84jIb/+tp53Efp7o9bpy3Xncs82HRUqOviJPXjyPWgiRpUuj90MSR5Y6ci5K7msJ9nLmzBlrGZ4jYLl7925M7hFLo0aN0o611lasWPHQkG+k9EfGWSSIQx6VxEKTELmep8sZxwiOO/Qdi4yMFH+1cuVKT29CQGA5u9bYvK+LnBYJDn4gwcHRN0jkPKlT35GgICQ4TavPkyd/ICunTo3+5a5d0Y8kQvJUvwxuEmPw4MEycODAmOcIhPLnzy8NGzaUDBkyxHot5ipCSn9kvkWCOEfhLh4X3PTp03tsmDD+3nHjxknbtm39tq+NN5SzebwgoH788ccTdbx4O9wl4YLboEEDnUuLWM6+6v7x0/LM1nT6/w8++E1eHNlWUuBGGTUKefMmfsXoU4Kml+PH/1tWqFDS1+vKdZ92/npPnDihA4KypU8v/xs/XqLOnZOV70+VBs8955xytmp58bvgBrUq58+fj7UMzxGk2Kq1AYyqwsMaTtbWJ2xkKMbFEllvE5P51mwiMdfhCW+++aYGby+99JKMGDFCR5T5G28oZ8BnYxtsHUv+xN//Pm/BcnaRkydlyxOD5MaDmZI1+KoULnxNL7gp9u0TqVcv8X1B0BEX7zf7lHz/vUiXLiJJXa8r133SuevFjeZvv/2mo5jx/1SnTknEiROS6t91OKWcLThyHvKpPDfVq1eX1atXx1qGO0ssp2gZM2aU559/Xi+8u3fvTlKeHDTPERH5rH9HAq08U0af1mkcIto9DjUJtkYOObjeWJ1la9SI/pmU9bpy3Sedu15cH3744QdZu3atBjYVjxyRHp9/Lulz5IguX3FCOSeBR4MbFA6GdONhDvXG/1HFZTaxPPPMMzGvf+GFF+To0aMyaNAg2b9/v3z++ecyc+ZMGTBggMf+Bm+E/h/oT/T33387/D4MH+/QoYNOBnnkyBGXbSMRkUuh3yQGoBw9KitTttBF9Vv8W4uPJhLLizpe50iem3/X+9AoIHN0VmLW68p1Rzh3vbhWf/HFF3o9Rm1Kq02bpPX330tIvnzR6zKboJJSzr4c3GzdulUqVaqkD0DfGPz/HSQ+EtHsumagAxgGjosvamuQHwdDwr/66iuvGwaOCo8RI6KPGdwl4Ceeu6si5O2339bA0d7gBjU8r7zyiuTLl0+DyezZs2s0jjK2ZciQIVKyZEnp0qWLtoEuWLBAKlSooH1Pdjmh0xgRUZIhn8q778r1omHyR2SYLqpXz6IjsXlRL1FCX+dQzhi8Hu+z1dSS2PW6ct0hzlsvugUsXbpUrzG4VvTo0UNCu3VzTXkkhRFgrl+/jqNbf1q7e/eusXfvXv2ZGFFRUcbJk1eNsLAHRrJkGK/83wPPw8IM4+ZNw6W2bt1qhISEGM2aNTPKlCkT5+suXbpkjBs3zqhUqZK+vnXr1sacOXOM8PDweNf/yy+/GH369DFu3LhhjBgxwqhfv74RFhZmHDp0yDhw4IBRr149w9VQzlevXtWfnpTU48XbRUREGPPnz9efxHL2VfNmRug5uESJOI7pBM55cUrofYldryvXHe6c9Z49e9ZYtGhRnOXo1HK28/ptzaf63PiCSZNSClrZrNOv4DmWjx3rus9GRN2rVy/p27ev1sAcOnQozrwAEyZM0PxAGBl2+PBhmTdvno6wCkkgqt6xY4d07dpVRyqhhujKlSvaTIiOyyVKlJCsWbMmaRg9EZEzrVwX3Qm1QYM4XpDYmoSE3peUGgpXrTskcetFF4Vt27bFGtzTvHnz2B18XVkeicDgxsmmTUspDx7YHp6MAOfLL8VlELBcunRJ3n33XSlfvrwGNuibZEvPnj11NBVyB5UtW1a6desma9asSTApHpqjli1bpv9H8yBGC40ePVo/99q1azp6LaEAiYjIXVasiP7Z8N+8fWQ/XA8wiAcdh9EU5UsTMTO4cbJz5+LPu3LmjLjE6dOntS8M5ulKmzatFC9eXIfAx9XvBpOVoubl4MGDGqwgIEHNTcGCBeWNN96QPXv22HxfmzZttB9UgQIF9PPQ3waTc6J/TpUqVXQoOhGRNzh2TOTw4ei+jxisQ/ZDf8pvv/1WpzgC9IdFHxtf4VN5bnxBrlyGnDkTd4CTBxmqXaBfv346T5c5pxSyLWPuLXs6FdeoUUMf48eP10RMmI/q448/1iYo1ABZQk3NlClTHqoFQqcyTybUIyKyZibXRrYQ5GxNYvb/gHHo0CHtqoAM7Ljxbdmypdbw+xIGN0727LPhMnp0KptNU8g311PnNXGuxYsXa5PSPiRLsoDAxJHh4Miy+7///U8fZ86c0f449mJgQ0TeGtzE2d+GHoJmKLO2BilB2rdvL1myZBFfw+DGyV58MVyWLUv1UKdiBDahoSKuSMmDjl1Iumftu+++S/Q60WxFROSroqJ0vkzF4MZ+Zrb/qlWr6tQraAXwRb651V4MlR1r1xoyfnyQdh5GHxvECaixQWDjQGUIERElEgb34J4vY0aRRx5hMcYHI1zNgSDI+I+cZ+hX6csY3LgAApghQ6IfRETkuSapunXRB5F7wBbMp4hRrxjqjX6TCHDQxcDXAxvgLiciIr/D/jbxQ1eG2bNna/9KOHDgwEMDSHwZgxsiIvIrmOpm48bo/zO/zcP27t0rCxculPDwcB1I0rp1a81h5k8Y3BARkV/59dfoYd+FC4sULerprfEekZGRsmLFCvnzzz/1OfrWYDRURnRM8jMMboiIyK8wK7FtloFNzZo1pU6dOhKMDId+iMENERH5Ffa3se3xxx+Xf/75R4d4Yz5Af8bpF4iIyG+cOiWCfKbILYaRUoHs/v37snv37pjnSMz6wgsv+H1gA6y5ISIiv6u1QW6bzJklYF26dElmzZolFy5ckGTJksVMnxAo2eRZc+PHw/yGDx/uU7O4EhElFZukRHbt2iVffvmlBjaYSNnMOhxIWHPjp/r37y+XL1/WyS8xGSYRkb/DlDerVgXulAvINPzLL7/ITsz/IxgtVljatGkj6dOnl0DDmhs/tGTJErl586b+zJQpk/z444+e3iQiIpfbtUvk4sXoLPGPPhpYBY5amq+++koDm6CgIHniiSekc+fOARnYAGtu/FCzZs30AdOmTfP05hARubVJ6oknRP6dKimguiJcvHhROw23a9dOChUqJIGMwQ0REfmFQOtvYxhGTAdhZBhu0aKF/kybNq0EOjZLERGRz7t7V+S33wJnyoVz587JN998I9evX49ZFhYWxsDmXwxu/Mwbb7whKVOmlKefftrTm0JE5DYIbMLDMaUAajH8u7Zm69at2r/m5MmTmnWYHsbgxs8MHjxYPvnkE/n555/l8OHDnt4cIiK3T7ngr6lcMNHlnDlzdLBIVFSUFC9ePKZ/JcXG4MbZIiKS9vskwgRozz//vCZtssxMSUTkz/y9vw1yliF3zZ49e/T8jikUnnrqKUmTJo2nN80rMbhxphkzJH3NmiInT9r+PZaXL6+vc/XMrzjg//77b5d+DhGRNzh3TuSvv6L/X6+e+J1jx47J119/LVeuXNEb2G7dukmNGjUCJttwYjC4cZaICAkaNkyCDx+WIExoYh3g4DnGJx48KPLOOy6twXn77bfl1q1b8QY3I0eO1CGD8T1OnDhh871DhgzRHvldunSRGzduyIIFC6RChQo6KRsyYxIRuZOZuC8sTCR7dv8r+3z58knWrFn1vNurVy99TvHjUHBnCQkRY8UKefDEExJ89Gh0ILNunUj+/P8FNlhepEj0N9FFSRi2bdsmkydP1nbY+IIbTJ725JNPxruuPHnyPLRs2bJlmk8BHdrGjx+v+RRwNzF37lx58OCB9O7dW1aZZxoiIjfwxyYpJOXLli2bNkGlSJFCunbtqtMosLbGPgxunCl/frm1aJFkaNVKgswA5/vvRbp0+S+wMQMeF0Bwgai+b9++Uq1aNc1OiVlh8cWwliVLFn04CtM54EuGrJeoIZo3b54MGjQoZpZZ3F0gBXhIoGXQIiKPMAz/Cm4wGmrz5s16k1i7dm2tEQf2rXEMm6WczMiXT4w1a6IDGQQ06IPjhsAGJkyYoDPBvvvuu1K+fHkNbPbv3+/UZilUi6L2BlauXKl3EaNHj9bPvXbtmpw/f56BDRG5zZ496Gwrgrkhcbr1ZXfv3pXp06fr8G7crKL2BsEOOY41N66AAAY1NpbfNDx3YWBz+vRp7QuDIeDITokhgsh3g6YpBDrOapbCJGyYmK1AgQL6e/S3wbDEihUrapXp559/7tS/i4goPmatDSo4UqXy3bJCzprZs2drP8bg4GBp1KiRVKlShc1QicTgxhXQxwZNUZbw3IU1N/369ZMmTZrE5DxInjy5lC5dOs5+N4ltlkJNzZQpU2It69mzp/To0YNfQiLyWH4bX22SQs3Mxo0bZfXq1fp/nJfbt28vuXPn9vSm+TQGN04WdOqUBLVq9V9TlGWfG8tOxk60ePFiWbNmjezbty/WctTYuGs4ODu5EZG7ISPxr7/69pQLGJCxdu1aDWzKlSsnzZs311p3ShoGN8508qSka9FCgo4fj93HBj/N0VIuCHDwZcAIJmvfffed0z6DiMjbbNwYPadUrlwi5cqJT8IgjKZNm2pwg7mheKPoHOxQ7Mw8Nw0bSvDx42JYdx42Axyzk3H9+i7PVExEFEhNUr6Szw5BzG+//ab9JE0IaipXrszAxokY3Dgzz82wYRJVrFj0aCnrmhkzwClRQuTdd12W54aIKFD42hBwJFf94YcftBsBOg8jbQa5BpulnKljR7lZr55kyJbN9u8R4GC+JwY2RERJcumSyPbt0f9HZbgvTKGAZKcIcDDgAzlsmA/MdRjcOFtCgQsDGyKiJFu9OjqBHzJdePPAIuSrWb9+vfz6b8/n7NmzS4cOHfQnuQ6DGyIi8jm+0CQVHh6uSfmOY5CJiISGhmrnYVtZ48m5GNwQEZFPQY2NL+S3QbMTAhk8MKoVEwyTezC4ISIin3LwYHSuVLTy/zv1klc1Q0VFRWlAg2HdrVu3ljt37ugkmOQ+HC1FREQ+2ST12GOYUFK8BqZO+Pbbb3VKGhMmvGRg434MboiIyKd4Y5PUoUOHZPLkyTrhMLLFYyJh8hw2SxERkc+4fz86ZZi3TLmAJijkrcH8UIA5oTA3VKZMmTy9aQGNNTfkUU888YS8/PLLXrsXChUqJOPGjfP0ZhDRv/74Q+TmTRF0YQkN9WyxXL9+XaZNmxYT2FStWlWee+65RE1KTM7Fmhs/8eyzz2o16Pz58z29KURELm+SQuK+ZMk8O40Csg1funRJJ7ps2bKllClTxnMbRLEwuCG3QJpxZuMkIn/Jb4ORUI0bN5Z169ZJ27ZtJXPmzJ7dIIqFzVIBAtkxUWWKOwy0Cb/xxhsSGRmpv1u8eLG2D6PtGHbu3KlfXLzG1L17d+ncuXPM8w0bNkitWrUkderUkj9/funXr5/cvn07VnPOiBEj5JlnnpEMGTJIz54949w2bEffvn0lY8aMOqpgyJAheldkwoznWA9OHhh5gCRYR44cifn9sGHDNDmWJTQlYRssa7YwJPPjjz/Wvx8z8fbp00fuowH/XxcuXJAWLVro31S4cGH58ccfE1XWROQa6KO7ZYvnghuciyzPPUWLFtVmKAY23ofBjQM1D3E9zCDBntdaXkzje60zYfZZBASPPPKI7Nq1SyZNmiRff/21vPfee/p7BCk3b96UHTt2xARCCDJwR2LCMvSPAXy5ccfSrl07+euvv2TGjBka7CBAsYRAomLFirpeBCxxwdBJzLWyZcsWGT9+vIwZM0a++uqrWIHJ1q1bZeHChbJp0yYNfJ588smHyjIha9eu1W3HT3wm2srxsPyckydP6u8xqd3nn3+uAQ8ReQfMSfzggUipUg/PTexqe/fulS+++EJmzZolV65ciVmOG0HyPmyWstOoUaPi/F3x4sXl6aefjnmOi3NcF96CBQvqRdSEizkSPFkbOnSoOAsu0qhd+eyzz/SLWKpUKTlz5oy8/vrr8s4772iNCWo+EMxUqVJFfw4YMECGDx+uk7yh09zhw4d1ojezLDp16hTTERh//6effqq/R+CUKlUqXV63bl155ZVXEtw+bNvYsWN120qWLCm7d+/W5z169NDhlQhqfv/9d6lRo4a+Hu3cKEf0L+rYsaPd5YC7K5RBcHCwlkGzZs1k9erV+jkHDx6UX375RQMsBIGAALB06dKJKnMi8o8mKdy8rlixQv788099ni9fPj2HkHdjzU0AQM6F6tWrx7rDqFmzpgYup06d0ucITBDUoFbkt99+0zZkXNhRI4Namzx58mgQA6j9QY1HunTpYh6NGjXSzJyY+daEQMkejz76aKxtw7YiqEEzGbYdtTrVqlWL+T2alIoVKyb79+93qBzKli0b66SE5imzZsb8nMqVK8f8HgEQh3MSBW5+m8uXL+tNjhnY4AYLN6e4ISTvxpobOw0ePDjO3yWz6rI/cODAh5bFVYXZv39/8QZocpo6daoGLkgbjgs7liHgQTuzWWsDCIp69eql/WysFShQIOb/adOmdcu2o6wt++iArZoz68nqsC8QkBGR9zt6NPqRPDnOV67/vL///lsWLVqk3QTQD69NmzYxN3jk/Rjc2MmRkT54bVzBTVLWm1iogZkzZ44GAGZwhWae9OnTaxWrZb8bNAeZgQyCm9GjR2twY9m8FBYWpu3PqD1xhj+QuMLC5s2b9SSCWhZsO6qF8RqzWQp3U2gmM5uMsmfPLufOnYv196FTtCMQzOFztm3bFtMsdeDAAWYZJfKyJqnq1UXSp3f956FWG4ENbtjQvxADI8h3sFnKj6BvDC7qlg90kO3du7f+fOmll7QpZ8GCBdqnx7KGCf1RMGMtRgiZHYcff/xx2b59u/ZHsay5QV8dJK1CB2J8BpqQsE7rDsX2QrpybAuCiZ9//lkmTJgQU6OFIKdVq1baLwZNZKhZ6tKlizYpYTlgey9evCgffvihdhieOHGi9p9xBPr6oJM0aqQQSCHIwQgx3LERUWA0SVnWADdo0ECaNGkiXbt2ZWDjgxjc+BE0IVWqVCnWA52C8+bNK0uXLtXOshi99MILL8jzzz8vb7/9dqz3I4BBPxczuEGWTSSlypUrl178TQiC0A8HQQ9qfPA56JiMfjmJgWHed+/e1aHqGJ6NwMZy6Pg333yjfWGaN2+u/XFwApo5c2ZMMxNqcNBpGkEN/j78na+++qrD24HPwd+AckCfI2xDjhw5EvU3EZHzIEsFRkq5csoFjPz86aefYpqqUXOMc5K9tfDkXYIM684Kfg6ztqIzGGo5rKsZ7927px1ikePEHPHjCHwpsH6sl18I1/GWck7q8eLt0G8JQTHSCFj3VyKWszuh5frRR0UwXdOlSwg8nHdMo+kJNb1mUzZuoiwHFpD3nDviu35bY58bIiLyiSapevUSH9jYgtGSyGmFZm1ArS1qosn3eby+DU0JyCSLO18M90WTQnyQeRZNJGZmXORjwR00ERH5J2fnt0GDBZKLTpkyRQMbpLNA8zia5Fnr7h88WnODzLboSDp58mQNbBC4IF8KOpba6uuA9lBMCYAhyxg5gz4fyDmAETJInEdERP4FM4Bv2uTc4Aa5vDBAAYoUKaJ97NyVuoICoOYGAQlGwXTr1k07riLIwdxBCF5swQgdJJ9DNmDU9jRs2FCeeuqpBGt7iIjIN2EWGMxwU7QoAhHnrBPXG8yzhyzqmDOPgY3/8VjNDTpxYbitZXI8VAfWr19f5w+yBbU1SL2PYAa92I8ePaqdljA0OC7h4eH6sOyQZHZ4sk70hueorkSH1cQkdzP7ZpvrINfwlnLGZ2MbcNz4Yzp28/vh6BxexHJ2puXLcQ8eLPXqRcn9+4n7vuN7iv41GAEK6JSKFBno3mA9NyB577nDkfV5LLi5dOmSDjvOmTNnrOV4HldafdTY4H2PPfaYHqw4KDGs+c0334zzczAPEoZDW8NcIaglsoT0+xj2jGR2SZm8Eu8n1/N0OSNoxhD29evX+/UJcqXZ4YFYzh4wf35dEUkvmTNvk6VLzzr8flxnkOfr2rVrmngU/Wt4TLuHs8vZ1jyMfjFaCnlcRo4cqTlN0EcHWWqRE2XEiBFxzjqNmiH067GsuUFHZDRpWQ8lw5cAtUGoQUpMNkoEXLjgIvMvZ4p1HW8pZ2RKxp1fvXr1/LbmBicnJDPjUHCWsyecPCly+nQKSZbMkFdeqSSZMjk2kgmZy+fNm6eBDc4V6F+DGhwe07557jBbXrw6uMmWLZteEM6fPx9rOZ6j9sQWBDBogkLmWChfvrzcvn1bk6299dZbNnu5o10VD2socOtCx3Nk6kXtENaFmh1HLp5opkCND+7o2ePedTxdzgiucAeB4wTHiz/muEnou0IsZ3f1t4GqVYMke/YUDn1HMdklauhx04pmKEyhgGsLujLwmHYPZ5ezI+vyWHCDOZWQKGn16tXSunXrmIsWnseVxh8XFOuLmXnH7KxchGZgZc4W7QhsA5opcDfPmhvX8ZZyxozhcQXiROSZKReQGmThwoWyb98+fY7UIZiqBecL9h8LHB5tlkJzEebtqFKlinYQxlBw1MRg9BQg7wCmDkC/GWjRooWOsEKSJbNZCrU5WO6sZgFcLDFvEYaiO/pFwOvR/wJzMvFO13W8oZzxuf7YFEXkLTBWYPVqx6dcQJ9NBDa4EUazCK4VvNkMPB4Nbjp27KgJlDAvEdpGQ0NDZdmyZTGdjDGhomVNDeZCwkGKn6dPn9bZoBHYvP/++07fNly4HL144fXoWIpmCgY3rsNyJvJ/mA0BUy1gBvBq1ex/H+aXQ/eGcuXK6c0xBSaPdyhGE1RczVDoQGw9mgmzWeNBRET+3yRVpw5qSuN+HZqo16xZox37cWOJG2Akg6XA5vHghoiIKDFTLmCI95w5c3QiRQwwQKZhImBwQ0REXgXpTP6dHcFmcINBBchYjxobDETBqMXq1au7fTvJezG4ISIir7J+PbLYixQoIFKixMOjZufPny+HDh3S52XLltW+l7ZSflDgYnBDRERe2yRlme0BA08wgTKSeGJgQZMmTSQsLIyjoeghDG6IiMgn8tuYmeOzZs0qHTp0eGj6HiITgxsiIvK4W7dExo4VmTRJ5Oy/U0jt2CFSv364ZM0a3eSErPGYxRsJNJEIliguDG6IiMjjgU3t2tG5bZC8zzRr1jEJCporrVvXk2rVQnUZEqwSJcT9E/MQERFZQI2NZWATFPRAatdeJ507fy+pUt2SZcv+dNoUOxQYGNwQEZFHffnlf4FNunQ3pUuXH6ROnV91NvAdO0Jl2rSu7DRMDmGzFBERedSZM9E/ixQ5Km3bzpV06W5LREQKWby4mfz1V0Wxmi+ZKEEMboiIyGPQ2oRBUEFBV6Vz5x+0tub8+Rwya1YHuXQpm74mTx7uIHIMgxsiIvKIe/dEevcWuXYNzzLLhg01JU2au7JsWSOJjIyeUAq1Nj17cgeRYxjcEBGR2508KdKr1yHZvDmbJEuWWXLnFlm7tq4Yxn9Z+xDYhIaKDBjAHUSOYUsmERG51dq1UdK370qpVu0n6dhxtixdGiX794sMHx4k+fJFBzX4OWyYyK+/opMxdxA5hjU3RETktv4148dfl7//ni1hYad0We3aeaVePUOSJxcZMiT6QZRUDG6IiMjl7t5F89IByZRpvuTPf0+iolJKmzYtpVKlMix9cjoGN0RE5FJHj0bJsGGrpGjRzfo8WbI88tJL7SVLlswseXIJ9rkhIiKXWbtWpHp1Q1Kn/kef58lTTd588zkGNuRSrLkhIiKX9K8ZO9aQQYOCJCoquezd20E6dz4vtWqVYmmTyzG4ISIip7pxI1LeeWeF/PVXKomKqitduoh88UVmSZ2azVDkHgxuiIjIaXbtuiLTps2WzJnPSq1aQdKiRai8/HIWCfovfQ2RyzG4ISIip5g+fY/s3r1QMmWKkLt3U0vVqq2lbdssLF1yOwY3RESUJBER9+Wjj5ZLZOQ2CQkRuXy5gPTu3U5KlcrAkiWPYHBDRER2uXULnYRFvvwyeiZvTGj57LOGhId/L2nTntROxNevPyajR9eRNGk4GJc8h8ENERHZFdjUri2yc6fIgwfRy06dEnnvvSAJDQ2TBg0uS548bWXo0KLsX0Mex9CaiIgShBobM7BJkeK+ZMt2MeZ3O3eGypUrfeXllxnYkHdgcENERAlCUxQCm+zZL0qPHlOkS5cfJHXqOzG/X748NUuRvAabpYiIKEFnzhgSGrpTmjVbKilSRMrNm+kkU6Zrcvdumn9/z0Ik78HghoiI4hURESFPPrlESpX6S58fOVJE5s5tI7dvp4t5DToXE3kLBjdERBSnc+fOy5Qps6VUqUvy4EGQrF37hGzYUEsM47+sfMmSifTsyUIk78HghoiIbLpxQ+SDD36XTJkuyY0b6WX58nayd29BHfJtGdiEhooMGMBCJO/BDsVERPSQ3btFqlQRmTSpqezYUUny5eslmzYVlOHDRfLliw5q8HPYMJFffxVJ918LFZHHseaGiIhinD17VqZP3y1vvdVA7t4Nknz5Usnrr7eU6tWjfz9kSPSDyJsxuCEiIjEMQzZt2iorViyXoKAoKVkyu+TMWUl++EEkWzYWEPkWBjdERAHu3r178tNPi+Tkyb2aXfjAgRLStm0peeut6OYnIl/D4IaIKICdPn1avv12tty/f02iopLJpk315fXXH5X69f8bDUXkaxjcEBEFqD//3CFLliyWoKAHcvVqJjl0qL18+21e5qwhn8cKRyKiAHTypMjQoVm0r83evaUlJKSXzJ/PwIb8A2tuiIgCrH/NunWppHNnkcuXC8qRI93lww9zS6tWbIYi/8HghogoAKCG5vffN8mqVb/JxInPy+XL2SQsTGTWrDxSpIint47IuRjcEBH5mVu3RMaOjZ7JGxNaFi58R55+er4EBx/S0VAVKuySEiXq6WtSpfL01hI5H4MbIiI/C2xq1xbZuVPkwQORAgVOSKtWsyU4+KZERgbL6tWNpU+fytKpk6e3lMh1GNwQEfkR1MYgsEEz1GOPbZC6dddKsmSGXLqUVWbNai8dOuRiYEN+j6OliIj8CJqiUGMTGrpD6tdfo4HNrl0V5Msve8r587lk/nxPbyGR67HmhojIj6CPDezaFSrlyu2Rv/8uJzt2hIpIUKzfE/kzBjdERH7gwYMH8scfOyRt2lC5eTNYHjxIJt9/3zkmqDHlyeOxTSRyGwY3REQ+7tatWzJt2ly5fPmY1KhxSZYvb/Tvb2IHNpgnqmdPj2wikVsxuCEi8mGHDh2Vn36aKyK3JSIihdy7l0uKFRM5ejS6741lYBMaKjJggCe3lsg9GNwQEfloM9Tcuevk779/09w158/nkFu3OsjcudkkJCR2nhs0RaHGBoFNunSe3nIi12NwQ0TkY65fvyGffz5XIiL+0cBm9+4wad26sXTqlEKfw5Ah0Q+iQMTghojIh5w/L9KnT6SUKHFWRELkyJHmMmZMeSlQwNNbRuQ9GNwQEfkAJOVbtChIuncXuXgxi5Qq1UGeey6z/PxzVu1PQ0T/cfgrsXbtWkffQkRESXDmzHV5661pMmDAUbl4UaR8eZGZM4vJa68xsCFySs1N48aNJV++fNKtWzfp2rWr5M+f39FVEBGRnRYsOCB//LFAUqa8K02bLpVUqXrLe+8lk5QpWYRETqu5OX36tPTt21dmz54tRYoUkUaNGsnMmTMlIiLC0VUREVEc7t2LkqFDl8vOndM1sLl4MY80bdpJPvqIgQ2R04ObbNmyyYABA2Tnzp3yxx9/SIkSJaR3796SJ08e6devn+zatcvRVRIRkYVt267JG298I8mSbdbn165Vk2HDukmTJplZTkR2SFI3tLCwMBk8eLDW5CBD5tSpU6Vy5cpSq1Yt2bNnj13rmDhxohQqVEhSpUol1apVky1btsT7+mvXrkmfPn0kd+7ckjJlSg2uli5dmpQ/g4jI7W7dEhkxQqRMmejn+PnuuyIff3xdZs/+QjJnPi337qWSfPk6ytixjSVbNo7/IHJpcHP//n1tlmratKkULFhQli9fLp999pmcP39eDh8+rMs6dOiQ4HpmzJghAwcOlKFDh8r27dulYsWK2sx14cIFm69H01eDBg3k+PHj+vkHDhyQKVOmSN68ecXbTlJ4juXOWC+6NQUHR/90xnpduW53bLOzy9nXy8NV28xydl054721a4sMG4am/uhlp06JDB0q8tprGeTAgRJy40Y+6dq1lzz/fKmk7VCiQGQ4qG/fvkbWrFmNLFmyGP379zd279790GvOnj1rBAUFJbiuqlWrGn369Il5HhUVZeTJk8cYNWqUzddPmjTJKFKkiBEREWEk1vXr1w382fjpDDdvGkZYmGEkS2YYqVNHGPPnz9efeI7l+H1S14u9ZD6Sul5Xrttd2+zMcnbldvv6PmQ5u66c3333v3WinF9/fY2ROvWtmPU3bx5hREREJm7lFCdcO3DuSMo1hDxXzo5cvx2u59y7d69MmDBB2rZtq81CcfXLSWjIOGphtm3bps1apmTJkkn9+vVl06ZNNt+zcOFCqV69ujZLLViwQLJnzy5PP/20vP766xKMWyobwsPD9WG6ceNGTO0THkk1frzIgQOiIxdSp45en/kTy/H7QYOStl5rSVmvK9ftrm12Zjm7crt9fR+ynOMuZ4Qg+/dH17w8/bTI7dtBcvNmdI1M9M+gmP/fvo2fQRb/F9m6NUjXAUWKHNC+Na1bn5Pp0ztKSEiUrlvkgdy/bzE5FCWZec53xrmf3F/OjqxPq1ccWfn69eulRo0akjx57LgoMjJSNm7cKI8//rhd6zlz5ow2J+E9CFhMgwYNkl9//VU7K1srVaqUNkl16tRJOzGjCQw/0ZEZTVu2DBs2TIYPH/7Q8p9++knSpEkjznLkSEYZObKa09ZHRN4FZ8qIiGC5dy+5REYmPWte8uSR0qjRMnnkkW36/Pbt7FK5cm5JlYoZ+YhsuXPnjlZoXL9+XTJkyCBODW5QQ3L27FnJkSNHrOWXL1/WZVFRUS4LbtB5+N69e3Ls2LGYmpoxY8bIRx99pNtkb80NcvNcunQpwcKxR+bM0TPvPngQJOHh7PBHFFgMyZ5dJH366Akp06Uz9P9p05rLDF1u+Xv8HD78sjzxxFzJmTO6f2GWLLlk+PBOcudOdBURuhHu3evhP80P4c5/5cqV2nczRYoUnt4cv3XfReWM6zdahuwJbhy+GiMWCjJnZrMKbtLiG20nbCACFHRCtoTnuXLlsvkejJBCQVk2QZUuXVrOnTunzVwhmArXCprObDWfYT3OKHQEN+gIGP1Z92XUqN9l8OCaEh4evW7EgMuWOb7exo1F4uhXnaT1unLd7tpmZ5az9bp9sTycuW6Ws2PlnC9fkJw8abnk4XOjtb/++ks6dlyMS4Dcvp1GlixpKSNH7tfA5u7dFDqVwjPP4Bzl+P4j+zjr/E/uLWdH1mV3cIM+NoDA5tlnn40VMKC2Bl9YNFfZC4EIho2vXr1aWrdurcsePHigzzG03JaaNWtqcxJeh/45cPDgQQ16bAU27tCzZ3S7O2pvsElFilyPmecFP/GnVKrk+HrxPnO91pKyXleu213b7MxyduV2+/o+ZDknXM74/jt6RxvdH/G+XLpUSL77rq3cv59KRPbHrDM0VGTAAMf3HRFZsLeX8rPPPqsPjILq2LFjzHM8evbsaYwcOdK4ePGiQz2fp0+fbqRMmdKYNm2asXfvXl1PpkyZjHPnzunvu3TpYrzxxhsxrz9x4oSRPn16HbF14MABY/HixUaOHDmM9957z+7P5Ggp3x8dxFE8HC3liePOWes+deqUsXbtWuP69SgdNVWsWPTIEvzE86RsL8WPo6UCZ7SUw0PBhw0bZty6dctwlgkTJhgFChQwQkJCdGj45s2bY35Xu3Zto2vXrrFev3HjRqNatWoaFGFY+Pvvv29ERkZ6LLgBnIxccZIy15svX/TJFD+ddfJz1brdsc2uuBj4cnm4aptZzs4p5x07dhjbt2+P8/e84LoPyzpwghuHOxT7OnRIypgxo10dkhyFKmdkS0ZyQ7bnug7L2T1YzkmDfoA4H2BKGvQTfPHFFyVr1qwsZw/iMe3b5ezI9Tu5vdMsoC9M5syZpVKlSjY7FJuQaZiIKJBhYASyqGNUJs6XSJGB8ycRuYddwU2rVq1iOhCbnX+JiCg2VITv2LFDfvnlF839lT59eh2MgfnziMjLghvLBHlxJcsjIgr0wGb+/Pk6chSKFSumN4OOpMggIudg1jkiIidA81OWLFn0Z926dTV1RXxN+ETk4eAGbcX2fkmvXLmS1G0iIvKZ2hpkTU+dOrU+r1WrlpQsWTLORKRE5EXBzbhx41y/JUREPgRBzaJFizQ7+/PPP6+jQpBclIENkY8EN127dnX9lhAR+QjMjYfRUFevXtWA5uTJk1KkSBFPbxYRORLcYGy5OaYc/4+Ps3PHEBF5UzPUli1bZMWKFToNDHJutG/fXvLly+fpTSOixPS5MWcCz5Qpk83+N+aEmvbOCk5E5Evu3r0rCxculP37o+eBKlWqlLRs2TKmvw0R+Vhws2bNGh0FANGTvhERBRZkXEVgg2zDDRo0kKpVq3I0FJEvBze1a9e2+X8iokBRv359HQ3arFkzyZMnj6c3h4icnecGnei+/vpr2bdvnz4vU6aMdOvWLaZ2h4jI1925c0cOHjwooaGh+hz9a7p3787aGiIfkMzRN6xfv15TiX/66aca5OCB/xcuXFh/R0Tk606cOCFffPGFLFiwQA4cOBCznEn5iPy05qZPnz7SsWNHmTRpkrY9AzoR9+7dW3+3e/duV2wnEZHLYWDE77//rv0M8X/URqPGhoj8PLg5fPiw5ncwAxvA/wcOHCjfffeds7ePiMgtbt++LfPmzZMjR47o8/Lly2v/GnPSYCLy4+AmLCxM+9ogxbglLKtYsaIzt42IyC2OHz8uc+bMkVu3bkny5MmlSZMmUqlSJTZDEflzcGPOcgv9+vWT/v37aw3Oo48+qss2b94sEydOlNGjR7tuS4mIXARBDR7ZsmWTDh06aE4vIvLz4AajBdCRDm3QpkGDBj30uqefflr74xAReTsz8SiUK1dO+w6WLl1aQkJCPL1pROSO4ObYsWNJ/RwiIq9x9OhRWblypXTq1EnSpUuny9isThRgwU3BggVdvyVERC6G+aB+/fXXmLQV69atk+bNm7PciQIxuMF8KuhglyJFCv1/fDDXChGRt7l586Z2Gv7nn3/0OToMN2rUyNObRUSeCm5at24t586d0052+H9cOHEmEXkjDIDAMG9kHUafGtTWYKg3EQVwcIOqXFv/JyLydnv27NHcXJAzZ04dDZU1a1ZPbxYRedvcUtauXbsmmTJlcsaqiIicqlixYhrMYIoYNEMhjw0R+TeH55b64IMPZMaMGTHPcReEFOV58+aVXbt2OXv7iIgcdurUqZjUFcgw3KNHD802zMCGKDA4HNxMnjxZ8ufPr//HUMpVq1bJsmXLtMPxa6+95optJCKyC3LVLF++XL7++mtNLmriFApEgcXh+ll0LDaDm8WLF8uTTz4pDRs21JnCq1Wr5optJCKyq3kcfWtOnz4dMzqKiAKTwzU3mTNnlpMnT+r/UWNTv359/T+qgHHXRETkbvv375cvvvhCA5tUqVJppnTcdBFRYHK45qZt27Y6zULx4sXl8uXL2hwFO3bs0I57RETuEhkZqc3jW7Zs0efo+9e+fXsOcCAKcA4HN2PHjtUmKNTefPjhhzGpy8+ePSu9e/d2xTYSEdl08eJF2bp1q/6/evXqUq9ePQkODmZpEQU4h4MbZCl+9dVXH1o+YMAAZ20TEZFdcufOrbXHGTJkkBIlSrDUiChxfW6+/fZbWbJkSazZwZHjpkaNGjFpzYmIXNUM9csvv8j58+djllWpUoWBDRElLbgZOXKkpE6dWv+/adMmmThxojZPZcuWjbU3ROQy6OP31Vdfaf8ajIpitnQiclqzFPramB2H58+fL+3atZOePXtKzZo15YknnnB0dURECdq9e7emnoiIiJA0adJopuFkyRy+NyOiAOFwcIMOxLiDKlCggKxYsUIGDhyoyzH88u7du67YRiIKUPfv39dmKIzGhIIFC+oNVfr06T29aUTkT8FNgwYNpHv37lKpUiU5ePCgNG3aNGZyOoyiIiJyhlu3bsn3338vFy5c0OePP/641K5dmzU2RJQgh+t10ccGQy4xBHPOnDkxs+tu27ZNnnrqKUdXR0RkE5qf0qZNq48uXbpInTp1GNgQkWtqbjAy6rPPPnto+fDhwx1dFRFRLOhTg740mOASP5E0FMx8WkRETgtu/vrrLylXrpyebPD/+FSoUMGuDyYisoTmp1mzZmm/mubNm+syBjVE5LLgJjQ0VCfMzJEjh/4/KChI55Iymc/xk/NLEZEjcO5Ah2F0HEYem/DwcLlz5442SxERuSy4OXbsmGTPnj3m/0REzoBABklBMdQbihYtKm3atGFgQ0SuD25QTWzr/0REiYXaYCTjQ2oJ1PrWrVtX82Xh/0REbu1QDGfOnJENGzZoG7l1ltB+/folaYOIyP+h+emnn36Smzdv6rxQyF2D3FlERB4JbqZNmya9evWSkJAQHQZueZeF/zO4IaIETzzJk0uzZs1k+/bt0qpVKzZDEZFng5shQ4bIO++8I4MHD2bOCSJyqMb33r17UqRIEX1esmRJnfCSzVBE5PHgBqMY/ve//zGwISK7R0NhssuVK1dqjS9qfjNmzKi/Y2BDRF6Rofj555/XXBRERAnBfHMzZ86UZcuWaZoIDEhAgENE5FU1N6NGjdIEWzhZlS9fXlKkSBHr92PGjHHm9hGRjzp16pRO0XLt2jUJDg7WeemqVq3K2hoi8s7gZvny5dpeDtYdiokosKEZavPmzbJq1SodTZk5c2Zp37695MmTx9ObRkQBwuHg5pNPPpGpU6fKs88+65otIiKfhpucS5cuaWBTpkwZadGihaRKlcrTm0VEAcTh4CZlypSaaIuIyJI5BQs0btxY+9eg6Zo1ukTk9R2K+/fvLxMmTHDN1hCRTwY1SOqJpHzmnHPoi4dJdBnYEJFP1NxgSOeaNWtk8eLFUrZs2Yc6FM+dO9eZ20dEXuz27dsyf/58OXz4sD7fv3+/lC5d2tObRUQBzuHgJlOmTNK2bVvXbA0R+Yx//vlHR0NhCgVkHG7SpImUKlXK05tFROR4cPPNN9+w2IgCGDoKoxlq3bp12gyVLVs26dChg+TIkcPTm0ZElPiJM4kocC1ZskTnhILQ0FCtsWFiPiLyueCmUqVKdncMNE96jpg4caJ89NFHcu7cOalYsaJ2WEayr4RMnz5dnnrqKZ14D+3+ROR6jzzyiOzbt08aNWqk31ciIp8Mblq3bh3zf0x89/nnn2v+iurVq+syJOzas2eP9O7d2+ENmDFjhgwcOFAmT54s1apVk3HjxulJ88CBA/FWcx8/flxeffVVqVWrlsOfSUSONUOdPHlS8ufPr89z5colL7/8MmtriMi3g5uhQ4fG/L979+7Sr18/GTFixEOvwQnQUZiuoUePHtKtWzd9jiAH1d5IFPjGG2/YfA/mqOnUqZMMHz5cfvvtN03vTkTOd//+fR3ijakUnnvuOcmbN68uZzMUEflVnhtMmvnMM888tLxz5846csIRERERsm3bNqlfv/5/G5QsmT7ftGlTnO979913tVYHk3gSkWscPXpUh3afOHFCR0NhVBQRkV92KE6dOrX8/vvvUrx48VjLsczRFOtI0Y5amJw5c8Zajuc4qdqCURpff/217Ny5067PCA8P14fpxo0bMXekeDiTuT5nr5dYzu5uhvr1119jbjCyZ8+u6R+yZs3KY9sFeN5wH5a1b5ezI+tzOLhBW/uLL76oHYfNTr9//PGHBhzvvPOOuBLuHLt06SJTpkzR4af2TvSJ5itrK1askDRp0rhgK0VWrlzpkvUSy9nVUJuK/DVIzgf4nuXOnVu/4+RaPG+4D8vaN8v5zp07dr82yDDzpTtg5syZMn78eB0xAehcjGkZkJm0XLlyDp1IEWDMnj07Vqflrl27aj+aBQsWxHo9amswcis4ODjWXabZnIVOyEWLFk2w5gYdI1FrlCFDBnF2VImd2aBBg4cyNxPL2RcgAzlm88YccujYjyYpHs+uxfOG+7Csfbuccf3GDdf169cTvH4nKs/Nk08+qQ/zw37++Wcdyo3+M2hmshc6JVauXFlWr14dE9wgWMHzvn37PvR6ZD/dvXt3rGVvv/221ugg2DJHc1jCSRoPayhwVwUgrlw3sZxdqUaNGnp3hO9l+vTpNbjh8eweLGf3YVn7Zjk7sq5EJ/Fbv369NkWhE3GePHm0TR75ahyFYeCoqalSpYo2c2EoOKrEzdFT6LyMERpoXkKfHuuaIUwHAY7UGBFRNNSQrl27Vpo1a6Y3G8hnhbstYN8xIvJVDgU3SLI3bdo0DWpQY4PaGzT5IIEemqYSo2PHjnLx4kXtr4P1I+PpsmXLYjoZ484RTU5E5FzotI+mX+SuQmCDAIeIKKCCmxYtWmhtDU6AqF1p3Lix9n1BXpqkQhOUrWYowPw18UGwRUT2Q9Mx2sPNTsKoGa1ZsyaLkIgCL7j55ZdfNHkfRkpZDwMnIt9w9epV7cB/5swZfY4s4/Xq1YvVSZ+IyNfZ3d6D/DLouIuOhpgm4bPPPtMRR0TkGzBlyRdffKGBDfJVYV62hg0bMrAhosANbh599FHNL3P27Fnp1auXTlqJjsQY3YQqbmYvJfJuSMKHTMMYVYjvcIkSJTy9SURELuFwT920adPqHDOoycGw7FdeeUVGjx6t0yG0bNnSNVtJRElOeoWh3c8++6yOTsyYMSNLlIj8VpKGIZUsWVI+/PBDnVQPuW6IyHvg5gP5n/bu3RuzDAmw2L+GiPydU8ZY42SJJHwLFy50xuqIKAmQn2bRokUyd+5czQK+a9culicRBZREJ/EjIu+DTv6zZs2SCxcu6PPHH39cateu7enNIiJyKwY3RH4CNTRLlizRmhv0jUPW8CJFinh6s4iI3I7BDZEfwChGZAqHwoULa2CTLl06T28WEZFHMLgh8gO5c+fWhHyYJLZWrVqcsoSIAhqDGyIfZBiGNkOh2SlDhgy6DAn5iIjISaOliMh9MFntvHnzdNLLOXPmaCJNIiL6D2tuiHzIuXPndG6oy5cvS1BQkM7zhp9ERPQfBjdEPtIMtW3bNlm2bJnO6o2mqHbt2kmBAgU8vWlERF6HwQ2RDzRDISnfnj179DnmhGrVqpWkSZPG05tGROSVGNwQeblkyZLJxYsX9We9evV0VBSbooiI4sbghshLm6EAQUyKFCmkffv2WoOTL18+T28aEZHXY3BD5GXu3bun87Qhdw1y1kD27Nk9vVlERD6DwQ2RFzl9+rSOhrp27ZocOnRIKlWqxEzDREQOYnBD5CXNUJs3b5ZVq1Zp3prMmTNrUxSnUCAichyDGyIPu3v3rs4LdfDgQX1epkwZadGihaRKlcrTm0ZE5JMY3BB5EHLWfPXVV3LlyhUJDg6WRo0aSZUqVTgaiogoCRjcEHkQAppHH31Um6Q6dOgguXLl4v4gIkoiBjdEbnbnzh25fft2zAgo1NSEhobqkG8iIko6BjdEbvTPP//oZJfJkyeXnj17ar8aM5cNERE5B4MbIjeNhvrtt99k3bp1+v9s2bJpDQ47DRMROR+DGyIXu3XrlsybN0+OHj2qzytWrChNmzaVkJAQlj0RkQswuCFyoWPHjsncuXM1wEFTVLNmzbR/DRERuQ6DGyIXwigoBDboPIzRUJxGgYjI9RjcELlQq1atZMOGDVKnTh12GiYicpNk7vogokBw5MgRWbFiRczzNGnSSMOGDRnYEBG5EWtuiJwA80GtXbtWa2kgf/78Urp0aZYtEZEHMLghSqIbN25o7poTJ07o88qVK0uxYsVYrkREHsLghigJDh06pMO8Mfklhna3bNlSypYtyzIlIvIgBjdEiYSkfGvWrNH/586dW9q3by9ZsmRheRIReRiDG6JEQkADVatWlQYNGmgeGyIi8jyejYkcgAkv06ZNq/9Hv5revXszdw0RkZfhUHAiO0RFRcmyZcvks88+k6tXr8YsZ1I+IiLvw+CGKAEIZqZOnSp//PGH3Lt3TzsRExGR92KzFFE89u7dKwsXLpTw8HBJnTq1ZhwuWbIky4yIyIsxuCGyITIyUjMN//nnnzFJ+dq1aycZM2ZkeREReTkGN0Q2oAnKDGxq1qypc0MFBwezrIiIfACDGyIbqlWrJsePH9dh3sWLF2cZERH5EHYoJhKR+/fvy8aNG3WOKEDOmk6dOjGwISLyQay5oYB36dIlmTVrlly4cEFHQ9WtWzfgy4SIyJcxuKGAtmvXLlmyZInW3CA5X6FChTy9SURElEQMbiggRUREyC+//CI7d+7U54ULF5a2bdtKunTpPL1pRESURAxuKOBcvHhRm6HwMygoSGrXri21atWSZMnYBY2IyB8wuKGAYxiGZh1GLQ1y17ApiojIvzC4oYCAUVBmzUyOHDmkY8eOOqu3OQkmERH5D9bDk987d+6cTJ48WU6cOBGzDDN6M7AhIvJPDG7Ir5uftm7dKl999ZX2r1m5cqUuIyIi/8ZmKfJLmOhy0aJFsmfPHn2OLMOtW7fWDsREROTfGNyQ3zl79qzMnj1brly5ov1s6tWrJ9WrV2dgQ0QUIBjckF9BluGvv/5aoqKidAZvjIbCjN5ERBQ4GNyQX8mePbuUKFFCR0e1atVKUqdO7elNIiKiQOxQPHHiRM01kipVKp2NecuWLXG+dsqUKZpwLXPmzPqoX79+vK8n/3fmzBmdEwrQp6ZNmzY61JuBDRFRYPJ4cDNjxgwZOHCgDB06VLZv3y4VK1aURo0aafOCLevWrZOnnnpK1q5dK5s2bdImh4YNG8rp06fdvu3kWRj5hGMAzVCLFy+OGQmVIkUK9q8hIgpgHg9uxowZIz169JBu3bpJmTJlNB9JmjRpZOrUqTZf/+OPP0rv3r0lNDRUSpUqpcN80QSxevVqt287eU5kZKR2Gl6xYoXufwQ26GdDRESU3NOTF27btk0GDx4cswyjW9DUhDtye9y5c0dndM6SJYsLt5S8yalTp+TAgQO634ODg7Wmr0qVKqytISIizwc3ly5d0rvtnDlzxlqO5/v377drHa+//rrkyZNHA6K48p3gYbpx44b+xIURD2cy1+fs9VI01M5s3rxZmybx/0yZMulM3rly5dKaHHIuHs/uwXJ2H5a1b5ezI+vz6dFSo0ePlunTp+vFDp2RbRk1apQMHz78oeVozkDzlysgEy45HwIY1NiYgQ36W6GfFrkWj2f3YDm7D8vaN8sZLTU+Edxky5ZNmxXOnz8fazme4248Ph9//LEGN6tWrZIKFSrE+To0eaHDsmXNjdkJOUOGDOLsqBI7s0GDBtqplZwP80OhszmOEexDlrPr8Hh2D5az+7CsfbuczZYXrw9uQkJCpHLlytoZGKnxwewc3Ldv3zjf9+GHH8r7778vy5cv174W8UmZMqU+rKHAXXVhdOW6AwlqaH777TetpTED2KJFi0qBAgVk6dKlLGc34fHMcvY3PKZ9s5wdWZfHm6VQq9K1a1cNUqpWrSrjxo2T27dv6+gpeOaZZyRv3rzavAQffPCBvPPOO/LTTz9pbhzM+Azp0qXTB/mHW7duybx58+To0aN6QGNfO7umjYiI/JPHgxskW8OMzQhYEKhgiPeyZctiOhmjGQIjqEyTJk3SUVbt27ePtR7kyRk2bJjbt5+c79ixYzJ37lwNcJInTy5NmjSR9OnTs6iJiMg3ghtAE1RczVDoLGzp+PHjbtoqcjc0Sa5fv14faJLCVAodOnTQn0RERD4V3BAhsPnhhx+01gYqVaqkNTbsu0RERI5icENeAU2PyFeEBH3NmzePdwQcERFRfBjckEdra+7evStp06bV53Xq1JGwsDBmmyYiIt+eW4oCE/IVfPvttzrqzZwTCjmPOI0GERElFWtuyO0OHTqkw7xRa4NcR0jKlzt3bu4JIiJyCgY35DaooVmzZo1s3LhRnyOgwZB+1tYQEZEzMbght7h27ZrMmTNHOwwDEjYiNTfy2BARETkTryzkFosWLdLABlNhtGrVSkqXLs2SJyIil2BwQ27RrFkzWbJkiQ7zzpw5M0udiIhchqOlyCWuXr0q27dvj3mOfjVdunRhYENERC7Hmhtyun379smCBQskPDxcZ/QuUqQIS5mIiNyGwQ05TWRkpKxYsUL+/PNPfZ4vXz6OhCIiIrdjcENOceXKFZk1a5bO7A41atSQunXramI+IiIid2JwQ0m2Z88eWbhwoUREREiaNGmkdevWUrx4cZYsERF5BIMbSjIENXgUKFBA2rVrJxkyZGCpEhGRxzC4oURPeomZvCE0NFSnUUDuGnMZERGRp/BKRA7btWuXTJo0Se7cuaPPg4KCpGzZsgxsiIjIKzC4Ibuh6QlDvOfPny+XLl2SP/74g6VHREReh81SZBfM3D179my5ePGiPq9du7Y8/vjjLD0iIvI6DG4oXoZhyM6dO2Xp0qWaxyZdunTStm1bKVy4MEuOiIi8EoMbihcS8v3yyy/6f2QabtOmjQY4RERE3orBDcWrQoUK2rcGI6Iee+wx7TxMRETkzRjc0EPNUEePHtVaGgQyqVKlkhdffFGSJ+ehQkREvoGjpSgGJrqcO3eu/PDDD7Fm9GZgQ0REvoS346TOnj2ro6EwRxQS8d2/f58lQ0REPonBTYBDMxQ6DWM276ioKMmYMaNOoZA/f35PbxoREVGiMLgJYPfu3ZNFixbJ3r179XnJkiWlVatWkjp1ak9vGhERUaIxuAlg58+fl3379mkzVIMGDaRatWocDUVERD6PwU0AK1iwoDRp0kTy5MkjefPm9fTmEBEROQVHSwWQu3fvypw5c3ReKNMjjzzCwIaIiPwKa24CxMmTJzWwuX79uo6I6t69O5ugiIjILzG4CYDRUBs3bpQ1a9bIgwcPJHPmzNK8eXMGNkRE5LcY3PixO3fuyPz58+XQoUP6vGzZstKiRQtJmTKlpzeNiIjIZRjc+Ck0PU2bNk1u3rypGYYbN24sYWFhrLEhIiK/x+DGTyEZX6ZMmSQkJEQ6dOggOXPm9PQmERERuQWDGz9y+/ZtnegyODhYHwhq0ASFAIeIiChQcCi4nzh27JhMnjxZVq9eHbMsffr0DGyIiCjgMLjxcRgBtW7dOvn+++/l1q1bcvjwYU56SUREAY3NUj4MnYXnzZuntTYQGhoqTZs2lRQpUnh604iIiDyGwY2POnLkiAY26GeDYKZZs2ZSsWJFT28WERGRxzG48dHZvGfNmiXh4eGSI0cO7TicLVs2T28WERGRV2Bw44MwIgpZhtEchfw1bIYiIiL6D4MbH4Esw0jGV7hwYX1erlw5fRAREVFsDG68XFRUlM4Lhfmh0qZNKy+88IKkS5fO05tFRETktRjceDHM4D179mw5deqUPi9Tpow2SREREVHcGNx4qQMHDuikl+g8jCzDLVu21OCGiIiI4sfgxguT8q1cuVI2b96sz/PkySPt27eXzJkze3rTiIiIfAKDGy8TFBSkuWugWrVq0qBBA50nioiIiOzD4MaLamySJUumwQ0S8pUvX16KFy/u6c0iIiLyOZxbysMiIyNl6dKlMnPmTDEMQ5ehjw0DGyIiosRhzY0HXblyRUdDnT17Vp+fOHFCChYs6MlNIiIi8nkMbjzk77//lkWLFklERISkTp1aWrduzcCGiIjICRjcuNn9+/dl+fLlsm3bNn1eoEABadeunWTIkMHdm0JEROSXGNy42Zw5czSHDTz22GNSp04d7UhMREREzsHgxs0Q0Jw5c0ZatWolRYsWdffHExER+T0GN25ohjp9+rQUKlRIn+fLl0/69eunk2ASERGR87E9xIUuXrwoU6ZMkR9//FHOnz8fs5yBDRERkZ8HNxMnTtSaDUwKiay8W7Zsiff1s2bNklKlSunrkewOeWK8CfLV7NixQ7788ksNcLCd4eHhnt4sIiKigODx4GbGjBkycOBAGTp0qGzfvl0qVqwojRo1kgsXLth8/caNG+Wpp56S559/XgMIDKHGA0OrvUFUVJQO8V64cKEm6CtSpIj06tVLR0URERFRAAQ3Y8aMkR49eki3bt101uvJkydLmjRpZOrUqTZfP378eGncuLG89tprUrp0aRkxYoSEhYXJZ599Jp6GgOzgwYMaaGEaBYyE6ty5s6RLl87Tm0ZERBQwPNqrFQnskO9l8ODBMcswLLp+/fqyadMmm+/BctT0WEJNz/z5822+Hs1Blk1CN27ciOnoi4cz7du3Tz8LwQxqk1Bbg9obci5zvzl7/xHL2RN4PLOs/c19F52jHVmfR4ObS5cuaTNOzpw5Yy3H8/3799t8z7lz52y+HsttGTVqlAwfPvyh5StWrNAaImf3tcG2ZM+eXWtvvKWpzF+tXLnS05sQEFjOLGd/w2PaN8v5zp07dr/W78cjo1bIsqYHNTf58+eXhg0bOj0rMKJK7MwGDRpIihQpnLpuYjm7G49nlrO/4THt2+Vstrx4fXCTLVs2CQ4OjjVMGvA8V65cNt+D5Y68HjNs42ENBe6qAMSV6yaWs7vxeGY5+xse075Zzo6sy6MdikNCQqRy5cqyevXqmGUPHjzQ59WrV7f5Hiy3fD0gQozr9URERBRYPN4shSajrl27SpUqVaRq1aoybtw4uX37to6egmeeeUby5s2rfWegf//+Urt2bfnkk0+kWbNmMn36dNm6davmlCEiIiLyeHDTsWNHTXT3zjvvaKfg0NBQWbZsWUyn4RMnTsSaWLJGjRry008/ydtvvy1vvvmmFC9eXEdKlStXzoN/BREREXkLjwc30LdvX33Ysm7duoeWdejQQR9EREREXpfEj4iIiMiZGNwQERGRX2FwQ0RERH6FwQ0RERH5FQY3RERE5FcY3BAREZFfYXBDREREfoXBDREREfkVBjdERETkV7wiQ7E7GYbh8NTpjkzzfufOHV03ZwV3HZaze7CcWc7+hse0b5ezed02r+PxCbjg5ubNm/ozf/78nt4UIiIiSsR1PGPGjPG+JsiwJwTyIw8ePJAzZ85I+vTpJSgoyKnrRlSJoOnkyZOSIUMGp66bWM7uxuOZ5exveEz7djkjXEFgkydPnlgTatsScDU3KJB8+fK59DOwMxncuB7L2T1Yzixnf8Nj2nfLOaEaGxM7FBMREZFfYXBDREREfoXBjROlTJlShg4dqj/JdVjO7sFyZjn7Gx7TgVPOAdehmIiIiPwba26IiIjIrzC4ISIiIr/C4IaIiIj8CoMbIiIi8isMbhw0ceJEKVSokKRKlUqqVasmW7Zsiff1s2bNklKlSunry5cvL0uXLk3K/goYjpTzlClTpFatWpI5c2Z91K9fP8H9Qo6Xs6Xp06drhu/WrVuzKJ18PMO1a9ekT58+kjt3bh1xUqJECZ47XFDO48aNk5IlS0rq1Kk1o+6AAQPk3r17PKbjsX79emnRooVmCcY5YP78+ZKQdevWSVhYmB7LxYoVk2nTponLYbQU2Wf69OlGSEiIMXXqVGPPnj1Gjx49jEyZMhnnz5+3+frff//dCA4ONj788ENj7969xttvv22kSJHC2L17N4vcieX89NNPGxMnTjR27Nhh7Nu3z3j22WeNjBkzGqdOnWI5O7GcTceOHTPy5s1r1KpVy2jVqhXL2MnlHB4eblSpUsVo2rSpsWHDBi3vdevWGTt37mRZO7Gcf/zxRyNlypT6E2W8fPlyI3fu3MaAAQNYzvFYunSp8dZbbxlz587FSGtj3rx58b3cOHr0qJEmTRpj4MCBeh2cMGGCXheXLVtmuBKDGwdUrVrV6NOnT8zzqKgoI0+ePMaoUaNsvv7JJ580mjVrFmtZtWrVjF69eiV2fwUER8vZWmRkpJE+fXrj22+/deFWBmY5o2xr1KhhfPXVV0bXrl0Z3LignCdNmmQUKVLEiIiIcGyHBjhHyxmvrVu3bqxluADXrFnT5dvqL8SO4GbQoEFG2bJlYy3r2LGj0ahRI5duG5ul7BQRESHbtm3TJg/LearwfNOmTTbfg+WWr4dGjRrF+XpKXDlbu3Pnjty/f1+yZMnCInXi8Qzvvvuu5MiRQ55//nmWrYvKeeHChVK9enVtlsqZM6eUK1dORo4cKVFRUSxzJ5ZzjRo19D1m09XRo0e16a9p06YsZyfy1HUw4CbOTKxLly7pyQUnG0t4vn//fpvvOXfunM3XYzk5r5ytvf7669oebP2FoqSV84YNG+Trr7+WnTt3sihdWM64yK5Zs0Y6deqkF9vDhw9L7969NWBH1ldyTjk//fTT+r7HHntMZ5uOjIyUF154Qd58800WsRPFdR3EzOF3797V/k6uwJob8iujR4/Wzq7z5s3TToXkHDdv3pQuXbpo5+1s2bKxWF3owYMHWjv25ZdfSuXKlaVjx47y1ltvyeTJk1nuToROrqgR+/zzz2X79u0yd+5cWbJkiYwYMYLl7AdYc2MnnNCDg4Pl/PnzsZbjea5cuWy+B8sdeT0lrpxNH3/8sQY3q1atkgoVKrA4nXg8HzlyRI4fP66jJCwvwpA8eXI5cOCAFC1alGWexHIGjJBKkSKFvs9UunRpvQNG80tISAjL2QnlPGTIEA3Yu3fvrs8xmvX27dvSs2dPDSbRrEVJF9d1MEOGDC6rtQHuPTvhhIK7qNWrV8c6ueM52sdtwXLL18PKlSvjfD0lrpzhww8/1DuuZcuWSZUqVViUTj6ekc5g9+7d2iRlPlq2bCl16tTR/2MYLSW9nKFmzZraFGUGj3Dw4EENehjYOOd4NvvmWQcwZkDJKRedx2PXQZd2V/bDoYYYOjht2jQd0tazZ08danju3Dn9fZcuXYw33ngj1lDw5MmTGx9//LEOUR46dCiHgrugnEePHq1DQGfPnm2cPXs25nHz5k3nHwQBXM7WOFrKNeV84sQJHe3Xt29f48CBA8bixYuNHDlyGO+9914S97h/c7SccT5GOf/88886XHnFihVG0aJFdZQrxQ3nVaTdwAMhxJgxY/T///zzj/4eZYyyth4K/tprr+l1EGk7OBTcC2GMfoECBfRiiqGHmzdvjvld7dq19YRvaebMmUaJEiX09RgOt2TJEg9stX+Xc8GCBfVLZv3AyYucV87WGNy45niGjRs3atoIXKwxLPz999/XYfjkvHK+f/++MWzYMA1oUqVKZeTPn9/o3bu3cfXqVRZzPNauXWvzfGuWLX6irK3fExoaqvsFx/M333xjuFoQ/nFt3RARERGR+7DPDREREfkVBjdERETkVxjcEBERkV9hcENERER+hcENERER+RUGN0RERORXGNwQERGRX2FwQ0RERH6FwQ0RuRUmgOzfv78UK1ZMZ27PmTOnzqc0adIkne+HiCipOCs4EbnN0aNHNZDJlCmTjBw5UmdiTpkypU7K+eWXX0revHl1Qk4ioqRgzQ0RuU3v3r0lefLksnXrVnnyySeldOnSUqRIEWnVqpUsWbJEWrRooa8bM2aMBj5p06bVGcfxvlu3bsWsZ9q0aRogLV68WEqWLClp0qSR9u3ba83Pt99+K4UKFZLMmTNLv379JCoqKuZ9WP7ee+/JM888I+nSpZOCBQvKwoUL5eLFi7oNWFahQgXdPtPly5flqaee0sALn4Pt+vnnn3nUEHkxBjdE5BYIElasWCF9+vTRoMWWoKCg6BNTsmTy6aefyp49ezRYWbNmjQwaNCjWaxHI4DXTp0+XZcuWybp166RNmzaydOlSfXz//ffyxRdfyOzZs2O9b+zYsVp7tGPHDmnWrJl06dJFg53OnTvL9u3bpWjRovrcnHbv3r17UrlyZQ2+/v77b+nZs6e+Z8uWLS4rKyJKIpdPzUlEZBg6QzNOOXPnzo1VHlmzZjXSpk2rj0GDBtksq1mzZunrTJhVGOs6fPhwzLJevXoZadKkMW7evBmzrFGjRrrccgb5zp07xzw/e/asrmfIkCExyzZt2qTL8Lu4NGvWzHjllVe4X4m8FPvcEJFHoQbkwYMH0qlTJwkPD9dlq1atklGjRsn+/fvlxo0bEhkZqTUoqK1B0xDgJ2pZTOiYjGYnNC1ZLrtw4UKsz0Ozk+XvAU1N1svwvly5cmmzFvoHzZw5U06fPi0RERG6neZ2EJH3YbMUEbkFRkeh2enAgQOxlqPPDX6XOnVqfX78+HFp3ry5BiFz5syRbdu2ycSJE/V3CCxMKVKkiLUerNvWMgROlixfYzaD2Vpmvu+jjz6S8ePHy+uvvy5r166VnTt3SqNGjWJtCxF5FwY3ROQWWbNmlQYNGshnn30mt2/fjvN1CGYQWHzyySfy6KOPSokSJeTMmTMe20u///67djZGn5yKFStqMHbw4EGPbQ8RJYzBDRG5zeeff65NTFWqVJEZM2bIvn37tCbnhx9+0Cao4OBgrcW5f/++TJgwQYeOo2Pw5MmTPbaXihcvLitXrpSNGzfq9vbq1UvOnz/vse0hooQxuCEit0EfGYxSql+/vgwePFhrQhDoIJB59dVXZcSIEboMQ8E/+OADKVeunPz444/a/8ZT3n77bQkLC9OmqCeeeEL74bRu3dpj20NECQtCr2I7XkdERETkE1hzQ0RERH6FwQ0RERH5FQY3RERE5FcY3BAREZFfYXBDREREfoXBDREREfkVBjdERETkVxjcEBERkV9hcENERER+hcENERER+RUGN0RERORXGNwQERGR+JP/A7LT1y4+ckIFAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "gamma_list = np.linspace(0, 1, 21).tolist()\n",
    "results = {gamma: [] for gamma in gamma_list}\n",
    "is_gamma_inf = {gamma: False for gamma in gamma_list}\n",
    "seq_length = {gamma: [] for gamma in gamma_list}\n",
    "for gamma in gamma_list:\n",
    "    CG.calibrate(gamma=gamma, recalibrate=True)\n",
    "    if CG._conformal_threshold == math.inf:\n",
    "        is_gamma_inf[gamma] = True\n",
    "        results[gamma] = [1 for _ in range(len(x_test))]\n",
    "        seq_length[gamma] = [len(y_tmp) for y_tmp in y_test]\n",
    "        continue\n",
    "    for i in range(len(x_test)):\n",
    "        selected = CG.select(instance=x_test[i], raw_generated_sequence=y_test[i])\n",
    "        results[gamma].append(a_func(x_test[i], selected))\n",
    "        seq_length[gamma].append(len(selected))\n",
    "est = [np.mean(results[gamma]) for gamma in gamma_list]\n",
    "for gamma, y_val in zip(gamma_list, est):\n",
    "    if is_gamma_inf[gamma]:\n",
    "        plt.scatter(gamma, y_val, marker=\"x\", color=\"red\", s=50)\n",
    "    else:\n",
    "        plt.scatter(gamma, y_val, marker=\"o\", color=\"blue\", s=30)\n",
    "\n",
    "#n_test = len(x_test)\n",
    "# Add legend entries\n",
    "plt.scatter([], [], marker=\"o\", color=\"blue\", label=r\"$\\hat{\\lambda} < \\infty$\", s=30)\n",
    "plt.scatter([], [], marker=\"x\", color=\"red\", label=r\"$\\hat{\\lambda} = \\infty$\", s=50)\n",
    "plt.plot(gamma_list, est, color=\"blue\")\n",
    "#plt.plot(gamma_list, gamma_list, linestyle=\"--\", color=\"gray\", label=\"Lower bound\")\n",
    "plt.plot(gamma_list, gamma_list, linestyle=\"--\", color=\"gray\", label=\"Lower bound\")\n",
    "plt.xlabel(\"Gamma\")\n",
    "plt.ylabel(\"Admissibility\")\n",
    "plt.title(\"Conformal Generation Admissibility vs Gamma (test set)\")\n",
    "plt.legend()\n",
    "plt.grid()\n",
    "plt.savefig(\"triviaqa_conformal_generation_admissibility_test_iid.pdf\", format=\"pdf\",bbox_inches='tight')\n",
    "plt.show()\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "9b289de1-cf5f-4990-9bc8-a92a5303c6b1",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# plot average sequence length vs gamma\n",
    "avg_seq_length = [np.mean(seq_length[gamma]) for gamma in gamma_list]\n",
    "for gamma, val in zip(gamma_list, avg_seq_length):\n",
    "    if is_gamma_inf[gamma]:\n",
    "        plt.scatter(gamma, val, marker=\"x\", color=\"red\", s=50)\n",
    "    else:\n",
    "        plt.scatter(gamma, val, marker=\"o\", color=\"blue\", s=30)\n",
    "plt.scatter([], [], marker=\"o\", color=\"blue\", label=r\"$\\hat{\\lambda} < \\infty$\", s=30)\n",
    "plt.scatter([], [], marker=\"x\", color=\"red\", label=r\"$\\hat{\\lambda} = \\infty$\", s=50)\n",
    "plt.plot(gamma_list, avg_seq_length, color=\"blue\")\n",
    "plt.xlabel(\"Gamma\")\n",
    "plt.ylabel(\"Average Sequence Length\")\n",
    "plt.title(\"Average Sequence Length vs Gamma (test set)\")\n",
    "plt.legend()\n",
    "plt.grid()\n",
    "plt.savefig(\"triviaqa_average_sequence_length_test_iid.pdf\", format=\"pdf\",bbox_inches='tight')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "4d43f892-7d8c-45bb-88e5-67ab9eb5fbb6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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9erVVVOUHjzC2bNnVdDDwMY2+7PeN880gNEDSk65aDtOOw/atbuyBw41xNDBefPmqSFtffr0UUMNg4OD1eNdu3bVPvroo1hDwZMnT6599dVXaojyyJEjORTcDuU8YcIENQR06dKl2s2bNw23x48f234n8OJyNsXRUvYp5ytXrqjRfgMGDNDOnDmjrV27VsuaNas2duzYJH7jns3acsbxGOX822+/qeHKmzdv1goVKqRGuVLccFxF2g3cEEJMmjRJ/f/ff/9Vj6OMUdamQ8E/+OADdR5E2g4OBXdBGKOfN29edTLF0MP9+/cbHqtdu7Y64BtbvHixVrRoUfV8DIdbt26dE7bas8s5X7586kdmesPBi2xXzqYY3Nhnf4a9e/eqtBE4WWNY+Oeff66G4ZPtyjkyMlIbNWqUCmhSpkyp5cmTR+vXr592//59FnM8duzYYfZ4q5ct/qKsTV8TFBSkvhfszz/++KNmbz74x751Q0RERESOwz43RERE5FEY3BAREZFHYXBDREREHoXBDREREXkUBjdERETkURjcEBERkUdhcENEREQehcENEREReRQGN0TkUJgActCgQVK4cGE1c3u2bNnUfEozZsxQ8/0QESUVZwUnIoe5ePGiCmTSp08v48aNUzMxp0iRQk3K+f3330uuXLnUhJxEREnBmhsicph+/fpJ8uTJ5eDBg/LKK69IiRIlpGDBgtK6dWtZt26dtGzZUj1v0qRJKvBJnTq1mnEcr3vy5IlhPfPmzVMB0tq1a6VYsWKSKlUq6dChg6r5+emnnyR//vySIUMGGThwoERHRxteh+Vjx46VN954QwIDAyVfvnyyevVquXPnjtoGLCtbtqzaPt3du3elc+fOKvDC+2C7fvvtN+41RC6MwQ0ROQSChM2bN0v//v1V0GKOj49PzIEpWTL59ttv5cSJEypY2b59uwwdOjTWcxHI4DkLFy6UjRs3ys6dO6Vt27ayfv16dZs/f77MmjVLli5dGut133zzjao9OnLkiDRv3ly6du2qgp3XX39dDh8+LIUKFVL39Wn3nj17JhUrVlTB1z///CN9+vRRrzlw4IDdyoqIksjuU3MSEWmamqEZh5zly5fHKo9MmTJpqVOnVrehQ4eaLaslS5ao5+kwqzDWdf78ecOyvn37aqlSpdIeP35sWNa4cWO13HgG+ddff91w/+bNm2o9w4cPNyzbt2+fWobH4tK8eXPtvffe4/dK5KLY54aInAo1IM+fP5cuXbpIeHi4WrZ161YZP368nD59Wh49eiRRUVGqBgW1NWgaAvxFLYsOHZPR7ISmJeNlt2/fjvV+aHYyfhzQ1GS6DK/Lnj27atZC/6DFixfL9evXJSIiQm2nvh1E5HrYLEVEDoHRUWh2OnPmTKzl6HODxwICAtT9y5cvS4sWLVQQsmzZMjl06JBMnz5dPYbAQufn5xdrPVi3uWUInIwZP0dvBjO3TH/dl19+KVOmTJEPP/xQduzYIUePHpXGjRvH2hYici0MbojIITJlyiQNGzaUadOmSWhoaJzPQzCDwOLrr7+Wl19+WYoWLSo3btxw2re0Z88e1dkYfXLKlSungrGzZ886bXuIKGEMbojIYb777jvVxFSpUiVZtGiRnDp1StXk/PLLL6oJytfXV9XiREZGytSpU9XQcXQMnjlzptO+pSJFisiWLVtk7969anv79u0rt27dctr2EFHCGNwQkcOgjwxGKTVo0ECGDRumakIQ6CCQef/992XMmDFqGYaCf/HFF1K6dGlZsGCB6n/jLJ9++qlUqFBBNUXVqVNH9cNp06aN07aHiBLmg17FFjyPiIiIyC2w5oaIiIg8CoMbIiIi8igMboiIiMijMLghIiIij8LghoiIiDwKgxsiIiLyKAxuiIiIyKMwuCEiIiKPwuCGiIiIPAqDGyIiIvIoDG6IiIjIozC4ISIiIvEk/wPsCtxcp0QJ5QAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "gamma_list = np.linspace(0, 1, 21).tolist()\n",
    "results = {gamma: [] for gamma in gamma_list}\n",
    "is_gamma_inf = {gamma: False for gamma in gamma_list}\n",
    "seq_length = {gamma: [] for gamma in gamma_list}\n",
    "for gamma in gamma_list:\n",
    "    CG.calibrate(gamma=gamma, recalibrate=True)\n",
    "    if CG._conformal_threshold == math.inf:\n",
    "        is_gamma_inf[gamma] = True\n",
    "        results[gamma] = [1 for _ in range(len(x_train))]\n",
    "        seq_length[gamma] = [len(y_tmp) for y_tmp in y_train]\n",
    "        continue\n",
    "    for i in range(len(x_train)):\n",
    "        selected = CG.select(instance=x_train[i], raw_generated_sequence=y_train[i])\n",
    "        results[gamma].append(a_func(x_train[i], selected))\n",
    "        seq_length[gamma].append(len(selected))\n",
    "est = [np.mean(results[gamma]) for gamma in gamma_list]\n",
    "for gamma, y_val in zip(gamma_list, est):\n",
    "    if is_gamma_inf[gamma]:\n",
    "        plt.scatter(gamma, y_val, marker=\"x\", color=\"red\", s=50)\n",
    "    else:\n",
    "        plt.scatter(gamma, y_val, marker=\"o\", color=\"blue\", s=30)\n",
    "\n",
    "# Add legend entries\n",
    "plt.scatter([], [], marker=\"o\", color=\"blue\", label=r\"$\\hat{\\lambda} < \\infty$\", s=30)\n",
    "plt.scatter([], [], marker=\"x\", color=\"red\", label=r\"$\\hat{\\lambda} = \\infty$\", s=50)\n",
    "plt.plot(gamma_list, est, color=\"blue\")\n",
    "plt.plot(gamma_list, [g * (len(x_train) + 1) / len(x_train) for g in gamma_list], linestyle=\"--\", color=\"gray\", label=\"Lower bound\")\n",
    "plt.xlabel(\"Gamma\")\n",
    "plt.ylabel(\"Admissibility\")\n",
    "plt.title(\"Conformal Generation Admissibility vs Gamma (train set)\")\n",
    "plt.legend()\n",
    "plt.grid()\n",
    "plt.savefig(\"triviaqa_conformal_generation_admissibility_train_iid.pdf\", format=\"pdf\",bbox_inches='tight')\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "382c5b23-6c79-4336-a9e9-fbfeecf07da4",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "avg_seq_length = [np.mean(seq_length[gamma]) for gamma in gamma_list]\n",
    "for gamma, val in zip(gamma_list, avg_seq_length):\n",
    "    if is_gamma_inf[gamma]:\n",
    "        plt.scatter(gamma, val, marker=\"x\", color=\"red\", s=50)\n",
    "    else:\n",
    "        plt.scatter(gamma, val, marker=\"o\", color=\"blue\", s=30)\n",
    "plt.scatter([], [], marker=\"o\", color=\"blue\", label=r\"$\\hat{\\lambda} < \\infty$\", s=30)\n",
    "plt.scatter([], [], marker=\"x\", color=\"red\", label=r\"$\\hat{\\lambda} = \\infty$\", s=50)\n",
    "plt.plot(gamma_list, avg_seq_length, color=\"blue\")\n",
    "plt.xlabel(\"Gamma\")\n",
    "plt.ylabel(\"Average Sequence Length\")\n",
    "plt.title(\"Average Sequence Length vs Gamma (train set)\")\n",
    "plt.legend()\n",
    "plt.grid()\n",
    "plt.savefig(\"triviaqa_average_sequence_length_train_iid.pdf\", format=\"pdf\",bbox_inches='tight')\n",
    "plt.show()"
   ]
  }
 ],
 "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.12.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
