{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "22da9941-1c6c-4f28-b9af-46bc17c10c72",
   "metadata": {},
   "outputs": [],
   "source": [
    "# file_path = 'paper_review_results_04_07/paper_review_final_labels_04_07.json'\n",
    "file_path = 'paper_review_final_labels_05_12.json'\n",
    "data = []\n",
    "with open(file_path, 'r') as file:\n",
    "    for line in file:\n",
    "        data.append(json.loads(line.strip()))\n",
    "\n",
    "categories = data[0]['human'][0].keys()\n",
    "\n",
    "def generating_pairs(list_of_vecs):\n",
    "    samples = []\n",
    "    for j in range(len(list_of_vecs)):\n",
    "        gpt3_vec_list = list_of_vecs[j]['gpt-3.5-turbo']\n",
    "        gpt4_vec_list = list_of_vecs[j]['gpt-4o-mini']\n",
    "        phi_vec_list = list_of_vecs[j]['Phi-3.5-mini-instruct']\n",
    "        mistral_vec_list = list_of_vecs[j]['Mistral-7B-Instruct-v0.3']\n",
    "        gemma_vec_list = list_of_vecs[j]['gemma-2-2b-it']\n",
    "        human_vec_list = list_of_vecs[j]['human']\n",
    "        vec_list = []\n",
    "        for i in range(3):\n",
    "            if human_vec_list[i] != None:\n",
    "                vec = [human_vec_list[i][key] for key in categories]\n",
    "                vec_list.append(vec)\n",
    "            else:\n",
    "                vec_list.append([])\n",
    "        # print(list_of_vecs[j]['paper_id'], vec_list)\n",
    "            # else:\n",
    "            #     vec_list.append(None)\n",
    "        for i in range(3):\n",
    "            if gpt3_vec_list[i] != None:\n",
    "                vec = [gpt3_vec_list[i][key] for key in categories]\n",
    "                vec_list.append(vec)\n",
    "            else:\n",
    "                vec_list.append([])\n",
    "        for i in range(3):\n",
    "            if gpt4_vec_list[i] != None:\n",
    "                vec = [gpt4_vec_list[i][key] for key in categories]\n",
    "                vec_list.append(vec)\n",
    "            else:\n",
    "                vec_list.append([])\n",
    "        for i in range(3):\n",
    "            if phi_vec_list[i] != None:\n",
    "                vec = [phi_vec_list[i][key] for key in categories]\n",
    "                vec_list.append(vec)\n",
    "            else:\n",
    "                vec_list.append([])\n",
    "        for i in range(3):\n",
    "            if mistral_vec_list[i] != None:\n",
    "                vec = [mistral_vec_list[i][key] for key in categories]\n",
    "                vec_list.append(vec)\n",
    "            else:\n",
    "                vec_list.append([])\n",
    "        for i in range(3):\n",
    "            if gemma_vec_list[i] != None:\n",
    "                vec = [gemma_vec_list[i][key] for key in categories]\n",
    "                vec_list.append(vec)\n",
    "            else:\n",
    "                vec_list.append([])\n",
    "        samples.append(vec_list)\n",
    "    return samples\n",
    "\n",
    "pairs = generating_pairs(data)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "a8b4eb9d-693d-4425-b567-d5be3e213246",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "\n",
    "def conditioned_cosine_similarity(X, Y, Z):\n",
    "    # Step 1: Normalize Z\n",
    "    Z_norm = Z / np.linalg.norm(Z)\n",
    "\n",
    "    # Step 2: Project X and Y onto Z\n",
    "    X_Z = np.dot(Z_norm, X) * Z_norm\n",
    "    Y_Z = np.dot(Z_norm, Y) * Z_norm\n",
    "\n",
    "    # Step 3: Get the orthogonal components of X and Y\n",
    "    X_orth = X - X_Z\n",
    "    # print(X_orth)\n",
    "    Y_orth = Y - Y_Z\n",
    "    # print(Y_orth)\n",
    "\n",
    "    # Step 4: Compute cosine similarity between the orthogonal components\n",
    "    if np.linalg.norm(X_orth) == 0 or np.linalg.norm(Y_orth) == 0:\n",
    "        return 0\n",
    "    similarity = np.dot(X_orth, Y_orth) / (np.linalg.norm(X_orth) * np.linalg.norm(Y_orth))\n",
    "    return similarity\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "8c4f658f-19c6-4553-a01c-6b6a267280ad",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Signal prior of each dimension [[0.21609604 0.59915518 0.18474878]\n",
      " [0.30691418 0.29913295 0.39395287]\n",
      " [0.55980436 0.27667852 0.16351712]\n",
      " [0.02278791 0.89684304 0.08036905]\n",
      " [0.01445087 0.96576256 0.01978657]\n",
      " [0.04290796 0.94430858 0.01278346]\n",
      " [0.27523344 0.35660293 0.36816363]\n",
      " [0.41462872 0.14606492 0.43930636]\n",
      " [0.0655847  0.47076478 0.46365051]\n",
      " [0.06936416 0.0560249  0.87461094]\n",
      " [0.15807025 0.45675856 0.38517119]\n",
      " [0.22543353 0.47876834 0.29579813]\n",
      " [0.3963984  0.40618052 0.19742108]\n",
      " [0.00822588 0.9006225  0.09115162]\n",
      " [0.22787906 0.70753668 0.06458426]\n",
      " [0.5819253  0.34470876 0.07336594]\n",
      " [0.0047799  0.17507781 0.82014229]\n",
      " [0.28234771 0.41518453 0.30246776]\n",
      " [0.06991996 0.55302357 0.37705647]]\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "\n",
    "def compute_dimension_probabilities(data, possible_values=(-1, 0, 1), dimension_size=len(categories)):\n",
    "    \"\"\"\n",
    "    Compute the probability of each possible value appearing at each dimension index,\n",
    "    after mapping -2 to -1 and 2 to 1.\n",
    "\n",
    "    Args:\n",
    "        data (list): A nested list of lists of vectors (ragged 3D array).\n",
    "        possible_values (tuple): Values to consider for counting probabilities.\n",
    "        dimension_size (int): The number of dimensions in each vector.\n",
    "\n",
    "    Returns:\n",
    "        np.ndarray: A (dimension_size x len(possible_values)) array of probabilities.\n",
    "    \"\"\"\n",
    "    # Initialize count matrix\n",
    "    counts = np.zeros((dimension_size, len(possible_values)))\n",
    "\n",
    "    # Iterate through all vectors\n",
    "    for outer in data:\n",
    "        for vec in outer:\n",
    "            if len(vec) == 0:\n",
    "                continue  # skip empty vectors\n",
    "            for i, val in enumerate(vec):\n",
    "                # Map -2 -> -1 and 2 -> 1\n",
    "                if val == -2:\n",
    "                    val = -1\n",
    "                elif val == 2:\n",
    "                    val = 1\n",
    "\n",
    "                if val in possible_values:\n",
    "                    index = possible_values.index(val)\n",
    "                    counts[i, index] += 1\n",
    "\n",
    "    # Compute probabilities\n",
    "    probabilities = np.zeros_like(counts)\n",
    "    for i in range(dimension_size):\n",
    "        total = counts[i].sum()\n",
    "        if total > 0:\n",
    "            probabilities[i] = counts[i] / total\n",
    "\n",
    "    return probabilities\n",
    "\n",
    "\n",
    "prior_matrix = compute_dimension_probabilities(pairs)\n",
    "print('Signal prior of each dimension', prior_matrix)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "0f20dd77-dc9a-48bd-a8e8-f28504aee85d",
   "metadata": {},
   "outputs": [],
   "source": [
    "import random\n",
    "import copy\n",
    "m = 8\n",
    "alpha_llm = 0.05\n",
    "alpha_prior = 0.05\n",
    "n_human = int(1500/m*(1-alpha_llm-alpha_prior))+1\n",
    "n_llm = int(1500/m*alpha_llm)+1\n",
    "n_prior = int(1500/m*alpha_prior)+1\n",
    "cheater_llm = 'GPT-4'\n",
    "values = np.array([-1, 0, 1])\n",
    "\n",
    "def simulate_review(n_human, n_llm, n_prior, n_random, llm_index):\n",
    "    review_simulated = np.ones((n_human+n_llm+n_prior+n_random, len(data), len(categories)))*np.nan\n",
    "    remaining_review = copy.deepcopy(pairs)\n",
    "    remaining_index = list(range(len(data)))\n",
    "    \n",
    "    for i in range(n_human):\n",
    "        if len(remaining_index) >= m:\n",
    "            index = random.sample(remaining_index, k=m)\n",
    "        else:\n",
    "            index = remaining_index\n",
    "            remaining_index = list(range(len(data)))\n",
    "            tmp = [x for x in remaining_index if x not in index]\n",
    "            index += random.sample(tmp, k=(m-len(index)))\n",
    "        for j in index:\n",
    "            for l in [0,1,2]:\n",
    "                if len(remaining_review[j][l]) != 0:\n",
    "                    review_simulated[i,j] = np.array(remaining_review[j][l])\n",
    "                    remaining_review[j][l] = []\n",
    "                    break\n",
    "            # if len(remaining_review[j][0]) + len(remaining_review[j][1]) + len(remaining_review[j][2]) == 0:\n",
    "            remaining_index.remove(j)\n",
    "    \n",
    "    \n",
    "    for i in range(n_llm):\n",
    "        if len(remaining_index) >= m:\n",
    "            index = random.sample(remaining_index, k=m)\n",
    "        else:\n",
    "            index = remaining_index\n",
    "            remaining_index = list(range(len(data)))\n",
    "            tmp = [x for x in remaining_index if x not in index]\n",
    "            index += random.sample(tmp, k=(m-len(index)))\n",
    "        for j in index:\n",
    "            for l in llm_index:\n",
    "                if len(remaining_review[j][l]) != 0:\n",
    "                    review_simulated[n_human+i,j] = np.array(remaining_review[j][l])\n",
    "                    remaining_review[j][l] = []\n",
    "                    break\n",
    "            # if len(remaining_review[j][begin_index]) + len(remaining_review[j][begin_index+1]) == 0:\n",
    "            remaining_index.remove(j)\n",
    "\n",
    "    for i in range(n_prior):\n",
    "        if len(remaining_index) >= m:\n",
    "            index = random.sample(remaining_index, k=m)\n",
    "        else:\n",
    "            index = remaining_index\n",
    "            remaining_index = list(range(len(data)))\n",
    "            tmp = [x for x in remaining_index if x not in index]\n",
    "            index += random.sample(tmp, k=(m-len(index)))\n",
    "        for j in index:\n",
    "            sampled_vector = np.array([\n",
    "                np.random.choice(values, p=prior_matrix[i])\n",
    "                for i in range(prior_matrix.shape[0])\n",
    "            ])\n",
    "            review_simulated[n_human+n_llm+i,j] = sampled_vector\n",
    "    for i in range(n_random):\n",
    "        if len(remaining_index) >= m:\n",
    "            index = random.sample(remaining_index, k=m)\n",
    "        else:\n",
    "            index = remaining_index\n",
    "            remaining_index = list(range(len(data)))\n",
    "            tmp = [x for x in remaining_index if x not in index]\n",
    "            index += random.sample(tmp, k=(m-len(index)))\n",
    "        for j in index:\n",
    "            sampled_vector = np.array([\n",
    "                np.random.choice(values, p=[1/3,1/3,1/3])\n",
    "                for i in range(prior_matrix.shape[0])\n",
    "            ])\n",
    "            review_simulated[n_human+n_llm+n_prior+i,j] = sampled_vector\n",
    "    return review_simulated\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 896,
   "id": "1e68d82a-cf71-4b8c-a5f8-f399887e319f",
   "metadata": {},
   "outputs": [],
   "source": [
    "from sklearn.metrics import roc_auc_score\n",
    "def compute_similarity_score(review_simulated, llm_conditioned):\n",
    "    n, m_total, k = review_simulated.shape\n",
    "    scores = np.zeros(n)\n",
    "    scores_cond = np.zeros(n)\n",
    "    scores_dist = np.zeros(n)\n",
    "    for i in range(n):\n",
    "        ct_ii = 0\n",
    "        ct_i = 0\n",
    "        valid_tasks = ~np.isnan(review_simulated[i, :, 0])\n",
    "        for j in np.where(valid_tasks == True)[0]:\n",
    "            valid_agents = ~np.isnan(review_simulated[:, j, 0])\n",
    "            xi = review_simulated[i,j]\n",
    "            s3 = cosine_similarity(xi,llm_conditioned[j])\n",
    "            scores_dist[i] -= s3\n",
    "            ct_i += 1\n",
    "            for ii in np.where(valid_agents == True)[0]:\n",
    "                if ii != i:\n",
    "                    yi = review_simulated[ii,j]\n",
    "                    # s = - cosine_similarity(xi,llm_conditioned[j])\n",
    "                    s1 = conditioned_cosine_similarity(xi, yi, llm_conditioned[j])\n",
    "                    s2 = cosine_similarity(xi,yi)\n",
    "                    ct_ii += 1\n",
    "                    scores[i] += s2\n",
    "                    scores_cond[i] += s1\n",
    "        if ct_ii > 0:\n",
    "            scores[i] /= ct_ii\n",
    "            scores_cond[i] /= ct_ii\n",
    "            scores_dist[i] /= ct_i\n",
    "        else:\n",
    "            print('no valid peers')\n",
    "    return scores, scores_cond, scores_dist"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "709ed9bf-2017-4d44-bfd5-ae2475a057e3",
   "metadata": {},
   "outputs": [],
   "source": [
    "import warnings\n",
    "warnings.filterwarnings('ignore')\n",
    "\n",
    "m = 5 # number of reviews per reviewer\n",
    "values = np.array([-1, 0, 1])\n",
    "llm_conditioned = np.zeros((len(data), len(categories)))\n",
    "\n",
    "T = 100\n",
    "\n",
    "AUC_scores = np.zeros((5, T*3)) # direct cosine similarity\n",
    "AUC_scores_cond = np.zeros((5, T*3)) # cosine similarity after projecting on the space orthogonal to Z\n",
    "AUC_scores_dist = np.zeros((5, T*3)) # negative distance to Z\n",
    "\n",
    "for ll in range(5):\n",
    "    for t in range(T):\n",
    "        \n",
    "        r1 = np.random.rand()\n",
    "        r2 = np.random.rand()\n",
    "        r3 = np.random.rand()\n",
    "        alpha_llm = 0.1*r1\n",
    "        alpha_prior = 0.1*r2\n",
    "        alpha_random = 0.1*r3\n",
    "        n_human = int(1500/m*(1-alpha_llm-alpha_prior-alpha_random))+1\n",
    "        n_llm = int(1500/m*alpha_llm)+1\n",
    "        n_prior = int(1500/m*alpha_prior)+1\n",
    "        n_random = int(1500/m*alpha_random)\n",
    "        identity = np.zeros(n_human+n_llm+n_prior+n_random)\n",
    "        identity[:n_human] = 1\n",
    "        for b in range(3):\n",
    "            \n",
    "            cond_index = (ll+1)*3+b\n",
    "            llm_index = [(ll+1)*3, (ll+1)*3+1, (ll+1)*3+2]\n",
    "            llm_index.remove(cond_index)\n",
    "            for j in range(len(data)):\n",
    "                if len(pairs[j][cond_index]) > 0:\n",
    "                    llm_conditioned[j] = pairs[j][cond_index]\n",
    "                else:\n",
    "                    llm_conditioned[j] = np.ones(len(categories))*np.nan\n",
    "        \n",
    "            \n",
    "            review_simulated = simulate_review(n_human, n_llm, n_prior, n_random, llm_index)\n",
    "            scores, scores_cond, scores_dist = compute_similarity_score(review_simulated, llm_conditioned)\n",
    "            mask = ~np.isnan(scores)\n",
    "            auc = roc_auc_score(identity[mask], scores[mask])\n",
    "            AUC_scores[ll,b*T+t] = auc\n",
    "            \n",
    "            mask = ~np.isnan(scores_cond)\n",
    "            auc = roc_auc_score(identity[mask], scores_cond[mask])\n",
    "            AUC_scores_cond[ll,b*T+t] = auc\n",
    "\n",
    "            mask = ~np.isnan(scores_dist)\n",
    "            auc = roc_auc_score(identity[mask], scores_dist[mask])\n",
    "            AUC_scores_dist[ll,b*T+t] = auc"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 968,
   "id": "78514b83-d9d5-4c1b-889e-a176d1410b0e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAxYAAAJNCAYAAACsgOMnAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8hTgPZAAAACXBIWXMAAA9hAAAPYQGoP6dpAACb1ElEQVR4nOzdd1yV5f/H8ddRZA8HLhQHiKvCNCkH7nLvHKmVppUNK7Pft9I00Ur7NqwcZd/MmXvvmRNxi5rlREFUHKiAiCDq+f1BkMRhHpBz8P3scR7pfV33dV03XML9ue9rGIxGoxEREREREREzFMrvBoiIiIiIiPVTYCEiIiIiImZTYCEiIiIiImZTYCEiIiIiImZTYCEiIiIiImZTYCEiIiIiImZTYCEiIiIiImZTYCEiIiIiImZTYCEiIiIiImazqsAiPj6ekSNHUrVqVezt7fHw8KB///6cP38+22WtW7eONm3a4O7uTpEiRShVqhTt27fn999/z4OWi4iIiIgUbAaj0WjM70ZkRXx8PC1atCAoKIiyZcvSqFEjQkND2bt3LyVLlmTXrl14e3tnqaxx48bxwQcfYDAYaNiwIeXKlePMmTPs27cPgJ9++ok33ngjLy9HRERERKRAsZrA4tNPP+Wzzz6jfv36bNiwAWdnZ+CfIKFx48Zs27Yt03KuXr1K+fLlAfj999/x9/dPSVu8eDHdu3fHwcGBy5cvp9QhIiIiIiIZs4rAIjExkVKlShEVFcXBgwepXbt2qvRatWpx5MgR9u/fz1NPPZVhWatWraJDhw60bt2atWvXpkl/8sknOXz4MHv27OHpp5/O1esQERERESmorGKORWBgIFFRUXh7e6cJKgC6desGwMqVKzMty87OLkt1Fi9ePHuNFBERERF5hFlFYHH48GEA6tSpYzI9+Xhyvoz4+fnh5ubG5s2bCQwMTJW2ZMkSjhw5QoMGDahSpYqZrRYREREReXTY5HcDsuLcuXMAKXMj/i35eHK+jBQtWpQpU6bQp08fGjdunDJ5++zZs+zbt4/WrVszffr0DMtISEggISEh5e/379/n+vXrlChRAoPBkMWrEhERERGxbEajkZs3b+Lh4UGhQhm/k7CKwCI2NhYAR0dHk+lOTk6p8mWmW7duFC9enJ49e6Z6a1G6dGmaN29OiRIlMjx/7NixjBo1Kkt1iYiIiIhYu/Dw8HQf8iezisAieX55em8Dsjv//Ntvv+XDDz+kc+fOBAQE4OXlxZkzZ/j000/5z3/+w+7du1m0aFG65w8dOpQhQ4ak/D06OpoKFSoQHh6Oq6trttoiIiIiImKpYmJi8PT0xMXFJdO8VhFYJF/IrVu3TKbHxcUBZGl52G3btvF///d/1KlTh4ULF6a80nniiSdYtGgRfn5+LF68mA0bNtCyZUuTZdjZ2ZmcBO7q6qrAQkREREQKnKwM97eKydsVKlQASHeH7eTjyfkyMnPmTAC6du2aZpxY4cKF6dq1KwBbt27NaXNFRERERB45VhFY1KpVC4CDBw+aTE8+7uvrm2lZyUFIem8Wko9fv3492+0UEREREXlUWUVg0bBhQ9zc3AgJCSE4ODhNevJ8iPbt22daVpkyZQDYv3+/yfR9+/YBUKlSpRy2VkRERETk0WMVgYWtrS2DBg0CYNCgQanmWowbN44jR47g7++Pn59fyvGJEydSvXp1hg4dmqqszp07AzB79uw0G+otX76cOXPmUKhQIbp06ZJHVyMiIiIiUvBYxeRtgOHDh7Np0yaCgoLw8fGhUaNGhIWFsWfPHkqUKMG0adNS5Y+MjOTEiRNERESkOt65c2e6d+/OwoUL6dixI3Xr1qVy5cqcPXs25S3GF198QbVq1R7atYmIiIiIWDureGMBYG9vz5YtWxgxYgSOjo4sW7aM0NBQ+vbtS3BwcJZ3yjYYDMyfP59ff/2Vxo0bc/r0aZYuXUpoaCht27Zl7dq1DBs2LI+vRkRERESkYDEYs7sJhKQRExODm5sb0dHRWm5WRERERAqM7NznWs0bCxERERERsVwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGw2+d0AERERSxYREUFERES2zytbtixly5bNgxaJiFgmBRYiIiIZ+Pnnnxk1alS2zxs5ciQBAQG53yAREQulwEJERCQDAwcOpGPHjqmO3b59G39/fwACAwNxcHBIc57eVojIo0aBhYiISAZMDWm6detWyp+ffPJJnJycHnazREQsjiZvi4iIiIiI2RRYiIiIiIiI2RRYiIiIiIiI2RRYiIiIiIiI2RRYiIiIiIiI2RRYiIiIiIiI2RRYiIiIiIiI2RRYiIiIiIiI2RRYiIiIiIiI2bTztojI3yIiIoiIiMj2eaZ2ZhaRgks/K0RMU2AhIvK3n3/+mVGjRmX7vJEjRxIQEJD7DRIRi6SfFSKmGYxGozG/G2HtYmJicHNzIzo6GldX1/xujojkkKmnkLdv38bf3x+AwMBAHBwc0pynp5CPnlu3buHs7AxAbGwsTk5O+dwieZj0s0IeJdm5z9UbCxGxCJYwtMBUWbdu3Ur585NPPqkbSBHRzwqRdCiwEBGLoKEFIiIi1k2BxSPGEp4Ki5gycOBAOnbsmOpYVocWiMijQ7/HRCyXAotHjCU8FdYvBTFFQwtEJCss4feYiJimwOIRYwlPhfVLQUTE+ljKQyFL+D0mIqYpsHjEWMJTYf1SsCyWcrMgIpbNUh4KWcLvMRExTYGFPHT6pWBZLOVmQeTfFPRaFj0UElP071QepMBC5BGnmwWxVAp6LYseCokplvDvVMGN5bCqwCI+Pp6xY8cyd+5czp07R/HixWndujWjR4+mfPnyWSpj+vTpvPLKK5nmmzFjBi+//LK5TRaxeLpZEEuloFfE8lnCv1NLCG4kidUEFvHx8bRo0YKgoCDKli1Lp06dCA0NZdq0aaxatYpdu3bh7e2daTlVqlShb9++JtOio6NZtmwZQMo/CBGRR5ElPAFU0Cti+Szh36klBDeSxGoCizFjxhAUFET9+vXZsGEDzs7OAIwbN44PPviA/v37s23btkzL8ff3Tzdo+Omnn1i2bBkNGzbEy8srV9svlscSbpxELJWeAIqItbCE4EaSWEVgkZiYyIQJEwCYNGlSSlABMGTIEGbMmMH27ds5cOAATz31VI7r+e233wB46aWXzGuwWAXdOImkT08ARUQku6wisAgMDCQqKgpvb29q166dJr1bt24cOXKElStX5jiwOHv2LEFBQdja2tKjRw9zmyxWQDdOIunTE0AREckuqwgsDh8+DECdOnVMpicfT86XE8lvK9q1a0exYsVyXI5YD904iYiIiOQeqwgszp07B5Duyk/Jx5Pz5cTs2bOBrA2DSkhIICEhIeXvMTExOa5XRERERKQgKJTfDciK2NhYABwdHU2mJz9VTs6XXXv37uXEiRMUK1aMdu3aZZp/7NixuLm5pXw8PT1zVK+IiIiISEFhFYGF0WgEwGAwZJieU8nDoHr27ImtrW2m+YcOHUp0dHTKJzw83Kz6RURERESsnVUMhXJxcQFSj39/UFxcHECq1aKy6u7du8yfPx/I+mpQdnZ22NnZZbsuERERESmYtIy9lQQWFSpUAOD8+fMm05OPJ+fLjg0bNnDlyhW8vLxo0KBBzhspIiIiIo8sLWNvJYFFrVq1ADh48KDJ9OTjvr6+2S47eRjUiy++mMPWiYiIiMijTsvYW0lg0bBhQ9zc3AgJCSE4ODjNXhaLFi0CoH379tkqNzY2luXLlwMKLEREREQk57SMvZVM3ra1tWXQoEEADBo0KNU3ady4cRw5cgR/f3/8/PxSjk+cOJHq1aszdOjQdMtdsmQJcXFx1KtXDx8fn7y7ABERERGRAs4q3lgADB8+nE2bNhEUFISPjw+NGjUiLCyMPXv2UKJECaZNm5Yqf2RkJCdOnMhwEk3yMKisTtoWERERERHTrOKNBYC9vT1btmxhxIgRODo6smzZMkJDQ+nbty/BwcFUqVIlW+VFRESwefNmihQpQs+ePfOo1SIiIiIijwareWMB4ODgwOjRoxk9enSmeQMCAjKcYV+2bFnu3r2bi60TEREREXl0Wc0bCxERERERsVwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGw2+d0AESngAtxyfu4d4z9//qIs2Bpy2IbonLdBREREskSBhYiIiOQ/PYQQsXoaCiUiIiIiImbTGwvJPZbwtAn0xElEREQkH+iNhYiIiIiImE1vLERE5OHL6RtOvd0UEbFYCixERERExDLpIYRV0VAoERERERExmwILERERERExmwILERERERExmwILERERERExmwILERERERExm1aFEhERecRV+nh1js67fyc+5c81RqyjkK19jtsQmvNTRcRC6I2FiIiIiIiYTW8sCoicPm2C3HvipKdNlkdPIUVERORh0RsLERERERExmwILERERERExm4ZCiYiIiEgqljDEGjSc1trojYWIiIiIiJhNgYWIiIiIiJhNQ6FERB4hGt4gIiJ5RW8sRERERETEbAosRERERETEbAosRERERETEbAosRERERETEbAosRERERETEbAosRERERETEbFpuVkREHkmGUYacn3znnz86j3EG25wVYxxpzHkbREQsjFW9sYiPj2fkyJFUrVoVe3t7PDw86N+/P+fPn89ReadPn+a1116jUqVK2NvbU7JkSRo0aMDXX3+dyy0XERERESnYrCawiI+Pp0WLFowePZrY2Fg6deqEp6cn06ZNo06dOoSEhGSrvKVLl/LEE0/w66+/UqJECbp06ULt2rU5e/YsP//8cx5dhYiIiIhIwWQ1Q6HGjBlDUFAQ9evXZ8OGDTg7OwMwbtw4PvjgA/r378+2bduyVNbhw4d54YUXcHFxYePGjfj7+6ek3b9/n4MHD+bJNYiIiIjlsoThcaAhcmK9rOKNRWJiIhMmTABg0qRJKUEFwJAhQ/D19WX79u0cOHAgS+W988473Llzh+nTp6cKKgAKFSpE3bp1c6/xIiIiIiKPAKsILAIDA4mKisLb25vatWunSe/WrRsAK1euzLSsY8eOsWPHDqpWrUr79u1zva0iIiIiIo8iqxgKdfjwYQDq1KljMj35eHK+jPz+++8APPfcc8THxzN//nz279+PwWDA19eXHj164OrqmkstFxFLoOENIiIiec8qAotz584BUL58eZPpyceT82Xkzz//BMDBwYEnn3ySEydOpEofOnQoixcvpnHjxumWkZCQQEJCQsrfY2JiMq1XRERERKQgs4qhULGxsQA4OjqaTHdyckqVLyM3btwA4Pvvv+f69essWbKEqKgoTpw4Qe/evYmMjKRz585ERESkW8bYsWNxc3NL+Xh6emb3kkREREREChSrCCyMxqThAwaD6eEMyelZce/ePQDu3r3Lb7/9RpcuXXBzc6Nq1arMnj0bPz8/bty4waRJk9ItY+jQoURHR6d8wsPDs3E1IiIiIiIFj1UEFi4uLgDcunXLZHpcXBxAqtWiMiurXLlytGzZMk36K6+8AsDWrVvTLcPOzg5XV9dUHxERERGRR5lVBBYVKlQASHeH7eTjyfkyUqlSJQAqVqyYYfqVK1ey2UoRERERkUeXVQQWtWrVAkh347rk476+vpmWlbxc7fXr102mX7t2Dcja2w8REREREUliFYFFw4YNcXNzIyQkhODg4DTpixYtAsjSvhQtWrTAycmJkJAQk3MjkodApbe0rYiIiIiIpGUVgYWtrS2DBg0CYNCgQanmWowbN44jR47g7++Pn59fyvGJEydSvXp1hg4dmqosR0dH3nnnHRITE3nzzTdTlbVu3TpmzJiBwWDg9ddfz+OrEhERkeyKuHmfgxH3Un0OXbqXkn7o0r006Qcj7hFx834+tlrk0WAV+1gADB8+nE2bNhEUFISPjw+NGjUiLCyMPXv2UKJECaZNm5Yqf2RkJCdOnDC5bOzIkSPZsWMHq1evxsfHh2eeeYYrV66we/du7t+/zxdffMHTTz/9sC5NREi6WYiITb3C2+3Ef/5+6NI9HIqkXRmurLOBsi5W8YxERHLBzwfuMGrbnXTT/afFmTw+soktAU3t86pZIoIVBRb29vZs2bKFsWPHMmfOHJYtW0axYsXo27cvn332Wbb2krC3t2fz5s188803/Pbbb6xduxZ7e3uaNWvG+++/T7t27fLwSiSvWcIuy9phOft0syAiWTHwKVs6ViuS7fPKOpvxu0FEssRqAgtI2i179OjRjB49OtO8AQEBBAQEpJtua2vLsGHDGDZsWC62ULJCT6bFFN0siEhWlHUpRFmX/G6FiJhiVYGFFAx6Mi2m6GZB/k0PIUQkK/SzwnIosJCHTk+mRSQr9BBCRLJCPysshwILeej0ZFpEskIPIUQkK/SzwnIosBAREYukhxAikhX6WWE5NLBMRERERETMpsBCRERERETMpsBCRERERETMpsBCRERERETMpsBCRERERETMplWhRERERETSYRhlxrK0D2yv4TzGGWxzVoxxpDHzTBZAbyxERERERMRsCixERERERMRsCixERERERMRsCixERERERMRsCixERERERMRsCixERERERMRsWm5WREREMnU39jr3Yq+nOmZM/GctzTuXz2AoknYtzcLOxbFxLp7n7ROR/KfAQkRERDIVe2gt0Tvnppt+ec6HJo+7NexFUf8+edUsEbEgCixEREQkU85PtsGhyjPZPq+w3laIPDIUWIiIiEimbDSkSUQyocBC5BGncdMiIiKSGxRYPGJ0Eyn/pnHTIiIikhsUWDxidBMp/6Zx0yIiIpIbFFg8YnQTKf+mcdMiIpJTGgkhD1Jg8YjRTaSIiIjkFo2EkAcpsBARERGRHNFICHmQAgsREUlDwxtEJCs0EkIepMBCRETS0PAGERHJLgUWIiKShoY3iIhIdimwEBGRNDS8QUREsqtQfjdARERERESsnwILERERERExmwILERERERExmwILERERERExmwILERERERExmwILERERERExmwILERERERExmwILERERERExmwILERERERExmwILERERERExmwILERERERExmwILERERERExmwILERERERExmwILERERERExmwILERERERExm1UFFvHx8YwcOZKqVatib2+Ph4cH/fv35/z589kqp1KlShgMhnQ/x48fz6MrEBEREREpmGzyuwFZFR8fT4sWLQgKCqJs2bJ06tSJ0NBQpk2bxqpVq9i1axfe3t7ZKrNv374mj7u5ueVGk0VEREREHhlWE1iMGTOGoKAg6tevz4YNG3B2dgZg3LhxfPDBB/Tv359t27Zlq8zp06fnQUtFRERERB49VjEUKjExkQkTJgAwadKklKACYMiQIfj6+rJ9+3YOHDiQX00UEREREXmkWUVgERgYSFRUFN7e3tSuXTtNerdu3QBYuXLlw26aiIiIiIhgJUOhDh8+DECdOnVMpicfT86XVV9//TUhISHY2dnx2GOP0aVLF0qWLGleY0VEREREHkFWEVicO3cOgPLly5tMTz6enC+rPvzww1R/f//99xk/fjwDBgzI8LyEhAQSEhJS/h4TE5OtekVEREREChqrGAoVGxsLgKOjo8l0JyenVPky07FjR5YsWUJYWBhxcXEcPXqUIUOGkJCQwKuvvsqyZcsyPH/s2LG4ubmlfDw9PbN+MSIiIiIiBZBVBBZGoxEAg8GQYXpWjR8/ni5dulChQgUcHBx47LHH+Pbbb/nxxx8B+OijjzI8f+jQoURHR6d8wsPDs1W/iIiIiEhBYxWBhYuLCwC3bt0ymR4XFweQarWonHj11VcpVaoUJ0+e5OzZs+nms7Ozw9XVNdVHRERERORRZhWBRYUKFQDS3WE7+XhyvpwqVKhQyiZ7ERERZpUlIiIiIvIosYrAolatWgAcPHjQZHrycV9fX7PrunHjBmD+2w8RERERkUeJVQQWDRs2xM3NjZCQEIKDg9OkL1q0CID27dubVc+ff/7JiRMncHR0pHr16maVJSIiIiLyKLGKwMLW1pZBgwYBMGjQoFRzLcaNG8eRI0fw9/fHz88v5fjEiROpXr06Q4cOTVXW+vXrTe7QfeTIEbp3747RaOTVV1/F1tY2j65GRERERKTgsYp9LACGDx/Opk2bCAoKwsfHh0aNGhEWFsaePXsoUaIE06ZNS5U/MjKSEydOpJkrsWvXLkaNGkXFihXx9vamZMmSnD17loMHD3L37l2aNGnC2LFjH+aliYiIiIhYPasJLOzt7dmyZQtjx45lzpw5LFu2jGLFitG3b18+++yzLO8l0apVK8LDw9m3bx+HDx8mOjoaV1dX/P396dOnD6+88gqFCxfO46sRERERq3Xz78+D7j7w50uYvsNy+fsjUkBZTWAB4ODgwOjRoxk9enSmeQMCAggICEhzvH79+tSvXz8PWiciIiKPhP3AtgzSp6ZzvAnQLPebI2IprCqwEBEREcl3dYFqOThPbyukgFNgISIiIpIdGtIkYpICCxGRZBo3LSIikmMKLEREkmnctIiISI4psBARSaZx0yIiIjmmwEJEJJmGNIkpGiInIpIlCixEREQyoiFyIiJZosBCREQkIxoiJyKSJQosREREMqIhTSIiWVIovxsgIiIiIiLWT4GFiIiIiIiYTUOh5NGllV5EREREco0CC3l0aaUXERERkVyjwEIeXVrpRURERCTXKLCQR5eGNImIiIjkGk3eFhERERERsymwEBERERERsymwEBERERERsymwEBERERERsymwEBERERERsymwEBERERERsymwEBERERERsymwEBERERERsymwEBERERERsymwEBERERERs9nkdwNERERERKzezb8/D7r7wJ8vYfrO2+XvTwGgwEJERERExFz7gW0ZpE9N53gToFnuNyc/KLAQERERETFXXaBaDs4rIG8rQIGFiIiIiIj5CtCQppzS5G0RERERETFbtt5Y7Nu3j127dmFvb8/rr7+eaX6j0ciUKVO4ffs2jRo1onbt2jluqIiIiIiIWK4sv7G4e/cuvXv35v3338doNGbpHIPBAMDgwYN5+eWXs3yeiIiIiIhYlywHFmvWrCEkJARfX18GDhyY5Qpee+01ateuzV9//cW6dety1EgREREREbFsWQ4slixZgsFg4N133812Je+++y5Go5GFCxdm+1wREREREbF8WQ4s9u3bB0CbNm2yXUmrVq0A2Lt3b7bPFRERERERy5flwOLChQvY2dlRpkyZbFdSpkwZ7O3tOX/+fLbPFRERERERy5flwOL27ds4ODjkuCIHBwdu376d4/NFRERERMRyZTmwKFasGNHR0dy9ezfbldy9e5eoqCiKFSuW7XNFRERERMTyZTmwqFixIkajkd27d2e7kt27d2M0GqlYsWK2zxUREREREcuX5cCiWbNmGI1GJk+enO1KJk+ejMFgoGnTptk+V0RERERELF+WA4s+ffpgMBiYN28eS5YsyXIFS5YsYe7cuRgMBl588cUcNVJERERERCxblgOLJ554ghdeeIH79+/Tq1cvxowZk+Fk7Nu3b/PFF1/Qq1cvALp3784TTzxhfotFRERERMTi2GQn888//8zhw4f566+/GDFiBN988w3PPfcctWvXpnjx4hgMBq5du0ZwcDAbN24kOjoao9FIzZo1+eWXX/LqGkREREREJJ9lK7BwdnYmMDCQ3r17s27dOqKioli0aBGLFi1Kk9doNALQsmVL5syZg7Ozc+60WERERERELE6Wh0IlK1q0KGvWrGH16tW0bdsWJycnjEZjqo+TkxNt27Zl9erVrFu3juLFi+dF20VERERExEJk643Fg9q0aUObNm24d+8eYWFhXLt2DaPRiLu7OxUrVqRw4cK52U4REREREbFg2X5j8W+FCxfGy8sLPz8/nn76aby8vPIsqIiPj2fkyJFUrVoVe3t7PDw86N+/P+fPnzer3FOnTuHg4IDBYKB169a51FoRERERkUeH2YHFwxIfH0+LFi0YPXo0sbGxdOrUCU9PT6ZNm0adOnUICQnJcdkDBw4kISEhF1srIiIiIvJoyfJQqO3bt2e5UAcHB0qWLEmlSpVy0iaTxowZQ1BQEPXr12fDhg0pk8HHjRvHBx98QP/+/dm2bVu2y/3111/ZsmULr7/+Ov/73/9yrb0iIiIiIo+SLAcWTZs2xWAwZKvw4sWL0717d4YNG0b58uWz3bhkiYmJTJgwAYBJkyalWmFqyJAhzJgxg+3bt3PgwAGeeuqpLJd75coV/vOf//Dss8/Sq1cvBRYiIiIiIjmUraFQ/179KbPPtWvX+Pnnn6lTpw579+7NcSMDAwOJiorC29ub2rVrp0nv1q0bACtXrsxWue+++y63b9/mp59+ynHbREREREQkG28stmzZkuVC4+LiuHDhAoGBgSxatIjIyEi6du3KsWPHcHFxyXYjDx8+DECdOnVMpicfT86XFWvWrGH+/PmMHj2aKlWqmD0BXERERETkUZblwKJJkybZLvzVV19lxIgRNG/enPPnzzNlyhTef//9bJdz7tw5gHSHUyUfT86XmVu3bvHWW29RrVo1Pvroo2y3JyEhIdVk75iYmGyXISIiIiJSkOT5qlDe3t58++23GI1GVq1alaMyYmNjAXB0dDSZ7uTklCpfZoYPH05YWBg//fQTtra22W7P2LFjcXNzS/l4enpmuwwRERERkYLkoSw3265dOwoVKsSff/6Zo/ONRiNAupPHk9OzYv/+/UyYMIGXX36ZZs2a5ag9Q4cOJTo6OuUTHh6eo3JERERERAqKHO+8nR0ODg4ULVqUGzdu5Oj85HkZt27dMpkeFxcHkGq1KFPu3r3La6+9hpubG998802O2gJgZ2eHnZ1djs8XERERESloHkpgAUkb3Nnb2+fo3AoVKgCkO8E6+XhyvvScP3+eQ4cOUaZMGbp3754qLSoqCoC9e/fStGlTnJ2dczx0S0RERETkUfNQAotTp04RFxdHtWrVcnR+rVq1ADh48KDJ9OTjvr6+WSrv0qVLXLp0yWTajRs32LZtG25ubjloqYiIiIjIo+mhzLH4+uuvMRgMNGjQIEfnN2zYEDc3N0JCQggODk6TvmjRIgDat2+fYTmVKlVKd8+N5OV0W7VqhdFoTHmDISIiIiIimcvTwOLcuXO8+eabTJkyBUhafjYnbG1tGTRoEACDBg1KNddi3LhxHDlyBH9/f/z8/FKOT5w4kerVqzN06FAzrkBERERERLIiy0OhmjdvnuVCb9++zYULF7hw4ULKsQEDBlC/fv3ste4Bw4cPZ9OmTQQFBeHj40OjRo0ICwtjz549lChRgmnTpqXKHxkZyYkTJ4iIiMhxnSIiIiIikjVZDiy2bt2KwWDI1tKuADY2Nrz33nt8+eWX2W7cg+zt7dmyZQtjx45lzpw5LFu2jGLFitG3b18+++wz7SUhIiIiIpKPshxYNG7cON19JP7NwcEBd3d3nnrqKbp27ZprN/0ODg6MHj2a0aNHZ5o3ICCAgICALJfdtGnTbAdNIiIiIiKSJFtvLEREREREREx5KKtC3b9/n5UrV9K5c+eHUZ2IiIiIiDxkebqPxcmTJ5k6dSozZ87k8uXLeVmViIiIiIjko1wPLOLi4liwYAFTp05l586dAClzF2rUqJHb1YmIiIiIiAXItcBi9+7dTJ06lfnz5xMbGwskBRTVq1ene/fudO/enccffzy3qhMREREREQtiVmBx9epVZs2axa+//srx48eBf95OGAwG9u3bx1NPPWV+K0VERERExKJlO7AwGo2sXbuWX3/9lVWrVnH37l2MRiMODg507tyZvn370rp1a0BDn0REREREHhVZDixCQkKYOnUqM2bMICIiAqPRiMFgwN/fn5dffpkePXrg4uKSl20VERERERELleXAwsfHJ2XnbS8vL1566SVefvllKleunJftExERERERK5DtoVDvvvsuX331Fba2tnnRHhERERERsUJZ3iDP1tYWo9HIhAkT8PDw4O2332b37t152TYREREREbESWQ4sLl26xPjx4/H19eX69ev89NNPNGzYkGrVqjFmzBjOnTuXl+0UERERERELluXAomjRogwaNIjg4GAOHDjAm2++iZubG6dOnWLEiBF4eXnRvHlzpk2blpftFRERERERC5TlwOJBtWvXZtKkSURERDBr1iyaNGmC0Whk69atvPrqqyn5NmzYwN27d3OtsSIiIiIiYplyFFgks7Ozo0+fPmzevJnTp08zbNgwypUrByTtd/H8889TqlQpXnnlFdasWaMgQ0RERESkgDIrsHhQ5cqV+fzzzwkLC2PNmjV07doVGxsboqKimDlzJh06dKB06dK5VZ2IiIiIiFiQXAsskhkMBlq3bs2iRYu4cOEC33zzDTVr1sRoNBIVFZXb1YmIiIiIiAXI9cDiQe7u7gwZMoQ//viDoKAgBgwYkJfViYiIiIhIPsn2Bnk5Va9ePerVq/ewqhMRERERkYcoT99YiIiIiIjIo0GBhYiIiIiImE2BhYiIiIiImE2BhYiIiIiImE2BhYiIiIiImE2BhYiIiIiImE2BhYiIiIiImE2BhYiIiIiImE2BhYiIiIiImE2BhYiIiIiImE2BhYiIiIiImE2BhYiIiIiImE2BhYiIiIiImE2BhYiIiIiImE2BhYiIiIiImE2BhYiIiIiImE2BhYiIiIiImE2BhYiIiIiImE2BhYiIiIiImE2BhYiIiIiImE2BhYiIiIiImE2BhYiIiIiImE2BhYiIiIiImE2BhYiIiIiImE2BhYiIiIiImE2BhYiIiIiImM2qAov4+HhGjhxJ1apVsbe3x8PDg/79+3P+/Pksl3H37l0CAgJo164dXl5euLi4YG9vj4+PD2+//Tbnzp3LwysQERERESmYrCawiI+Pp0WLFowePZrY2Fg6deqEp6cn06ZNo06dOoSEhGS5nFGjRrF9+3bKli1L69atadWqFXfu3OHHH3/E19eXgwcP5vHViIiIiIgULFYTWIwZM4agoCDq16/PyZMnmT9/Pnv27OHbb7/l6tWr9O/fP0vl2NvbExgYyI0bN9i5cycLFy5k+fLlnDlzhqFDhxIdHc1bb72Vx1cjIiIiIlKwWEVgkZiYyIQJEwCYNGkSzs7OKWlDhgzB19eX7du3c+DAgUzLsrGxoWHDhtjY2KQ6XrhwYUaPHo29vT179uzh1q1buXsRIiIiIiIFmFUEFoGBgURFReHt7U3t2rXTpHfr1g2AlStXmlWPwWCgUKFCFCpUKE3gISIiIiIi6bOKwOLw4cMA1KlTx2R68vHkfDlhNBr58ssviYuLo3nz5tjZ2eW4LBERERGRR41VPJZPXqmpfPnyJtOTj2d3RaePPvqIy5cvExMTw5EjRwgJCaF69er873//y/C8hIQEEhISUv4eExOTrXpFRERERAoaqwgsYmNjAXB0dDSZ7uTklCpfVi1evDjValKPP/44s2fPpnLlyhmeN3bsWEaNGpWtukRERERECjKrGAplNBqBpDkQGaVn1+nTpzEajVy9epV169ZhZ2fHU089xYwZMzI8L3n1qORPeHh4juoXERERESkorCKwcHFxAUh3paa4uDiAVKtFZYe7uzutWrXi999/x8PDgzfffDPDYMHOzg5XV9dUHxERERGRR5lVBBYVKlQASHeH7eTjyflyys3Njfbt23P79m02btxoVlkiIiIiIo8SqwgsatWqBZDujtjJx319fc2uy93dHYCrV6+aXZaIiIiIyKPCKgKLhg0b4ubmRkhICMHBwWnSFy1aBED79u3Nrmvbtm0AeHt7m12WiIiIiMijwioCC1tbWwYNGgTAoEGDUs21GDduHEeOHMHf3x8/P7+U4xMnTqR69eoMHTo0VVkrVqxg7dq1aSZ8x8XF8cknn7Bt2zbKlClD69at8/CKREREREQKFqtYbhZg+PDhbNq0iaCgIHx8fGjUqBFhYWHs2bOHEiVKMG3atFT5IyMjOXHiBBEREamOHzx4kFGjRuHh4UHt2rVxc3Pj0qVLHDp0iOvXr+Pm5saCBQtyPBFcRERERORRZDWBhb29PVu2bGHs2LHMmTOHZcuWUaxYMfr27ctnn32Gp6dnlsrp2rUrN2/eZMeOHezbt4/r16/j4OBAlSpVGDhwIO+88w5ly5bN46sRERERESlYrCawAHBwcGD06NGMHj0607wBAQEEBASkOe7r68u3336bB60TEREREXl0WcUcCxERERERsWwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGwKLERERERExGxWFVjEx8czcuRIqlatir29PR4eHvTv35/z589nuYyoqCjmzJlD7969qVmzJk5OTri4uPDMM8/www8/kJiYmIdXICIiIiJSMFlNYBEfH0+LFi0YPXo0sbGxdOrUCU9PT6ZNm0adOnUICQnJUjnffPMNffr0Yf78+Tg6OtKhQweefvppDh8+zODBg2nevDlxcXF5fDUiIiIiIgWL1QQWY8aMISgoiPr163Py5Enmz5/Pnj17+Pbbb7l69Sr9+/fPUjnOzs4MGzaMc+fOsX//fubNm8fvv//OH3/8QYUKFQgMDOTzzz/P46sRERERESlYrCKwSExMZMKECQBMmjQJZ2fnlLQhQ4bg6+vL9u3bOXDgQKZlffzxx3zxxReUK1cu1XEfHx++/PJLAObOnZuLrRcRERERKfisIrAIDAwkKioK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mn/99Vdu3LjBxo0bqVOnDhUqVKBs2bLExcVx+vTplEnbv/76a5bL3L5pPds3rcemSBEqVPLC0cmZa1cvczniIvfv38fOzp7Pv/uR0mVNr6BlicqUcmfwq734ZvIs+g7+lBFf/0jJEsX46+RZ7t67y/jRH/Lm0Ix33s6JZ5o8g2tRVw7tPUSHpztQrkI5CtsUpn7T+vQb1C9V3pq1auJTw4dTx5KWvG3fo32ut0dERMSSKLAQi+bs5MiiX75mx56DzFi4ih17ggkNv8idxETcixelXQt/urZtTq9OrXH41wZng4YOolbdWsyfOp9jR45x+thp3Eu50/b5tvR7px9lypVJlb//e/2p5FOJAzsPEHEhgksXL1GseDHq1K9Dpxc60bJzyxztAp6t63V2Zt26dcybN4+ZM2dy4MABDh48iLu7O76+vjRt2pTnn38ee/usbeb2+Xc/snvHVgK3bOLY0cNcvXyJc2dDsHdwwKfGYzzTsAk9Xx5A+YqV8vS68sJXwwdTvmxpJs9axJlzF4i7Hc+zjZ7mk3cHULpkiTyp09nFmQlzJvDzNz/z58E/+ePAH9y/f5+y5cuazN++R3u+G/UdJUqVoH6z+nnSJhEREUthMJq77qMQExODm5sb0dHRuLq6Zpo/Pj6es2fPUrly5SzfIGbmyPmoXCnHHL6FzuZ3EwDYz738bgJ1PermdxMA9Ytk+dUnJoyZwMxJM3nxjRd5b8R7FtEvLKFPwCPQL+5C5IVI3tj5BmG3wtLNZhxpGb+CK328OvNMeSzUvnd+NwGDISa/mwBYRr+whD4B6hfJ8rNPZOc+V3MsRETywN3Eu6xZtAZI2jRPRESkoFNgISKSB+b9Oo/Iy5HUqV8Hr6pe+d0cERGRPKc5FiIiuSTySiSfvPUJ0TeiCTkeQqFChXjro7fyu1kiIiIPhQILEZFccifhDgd3HcSmiA1e1bwY+MFAavnVyu9miYiIPBQKLEREcomHpwf7LuzL72aIiIjkC82xEBERERERsymwEBERERERsymwEBERERERsymwEBERERERsymwEBERERERsymwEBERERERsymwEBERERERsymwEBERERERsymwEBERERERsymwEBERERERsymwEBERERERsymwEMmCgMEB+JXzY+X8lfndlIfqQvg5ankWo0193/xuSq66GH4Rv3J+dHymY343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",
      "text/plain": [
       "<Figure size 800x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "x = np.arange(5)  # 5 groups\n",
    "width = 0.25      # narrower width to accommodate 3 bars\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(8, 6))\n",
    "\n",
    "# Bars for A\n",
    "bars_A = ax.bar(x - width, np.average(AUC_scores, axis=1), width, \n",
    "                yerr=np.std(AUC_scores, axis=1), capsize=5, label='Cosine Similarity')\n",
    "\n",
    "# Bars for B\n",
    "bars_B = ax.bar(x, np.average(AUC_scores_cond, axis=1), width, \n",
    "                yerr=np.std(AUC_scores_cond, axis=1), capsize=5, label='Projected Cosine Similarity')\n",
    "\n",
    "# Bars for C (new green bars)\n",
    "bars_C = ax.bar(x + width, np.average(AUC_scores_dist, axis=1), width, \n",
    "                yerr=np.std(AUC_scores_dist, axis=1), capsize=5, color='green', label=r'Negative Similarity to $Z$')\n",
    "\n",
    "# Labels and title\n",
    "LLM_names = ['GPT-3.5', 'GPT-4', 'Phi', 'Mistral', 'Gemma']\n",
    "ax.set_xlabel('Cheater LLMs', fontsize=18)\n",
    "ax.set_ylabel('AUC', fontsize=18)\n",
    "ax.set_xticks(x)\n",
    "ax.set_xticklabels(LLM_names, fontsize=17)\n",
    "ax.legend(fontsize=16)\n",
    "ax.set_ylim(0, 0.8)\n",
    "ax.tick_params(axis='y', labelsize=15)\n",
    "\n",
    "plt.tight_layout()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
