{
 "cells": [
  {
   "metadata": {
    "collapsed": true,
    "ExecuteTime": {
     "end_time": "2025-02-08T20:35:41.626180Z",
     "start_time": "2025-02-08T20:35:41.620467Z"
    }
   },
   "cell_type": "code",
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "import pandas as pd\n",
    "from matplotlib.colors import LinearSegmentedColormap\n",
    "import os \n",
    "import glob\n",
    "\n",
    "\n",
    "# Create a custom color map from white to black\n",
    "white_black_cmap = LinearSegmentedColormap.from_list('white_black', ['white', 'black'], N=256)\n"
   ],
   "id": "initial_id",
   "outputs": [],
   "execution_count": 34
  },
  {
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2025-02-08T20:24:44.773123Z",
     "start_time": "2025-02-08T20:24:44.763196Z"
    }
   },
   "cell_type": "code",
   "outputs": [],
   "execution_count": 2,
   "source": [
    "def merge_seeds(file_name_pattern='CUB_results_s*_hessian_exact.csv', data_dir='./logs/ISR_Hessian_results_new'):\n",
    "    # Create the full pattern for glob\n",
    "    full_pattern = os.path.join(data_dir, file_name_pattern)\n",
    "\n",
    "    # Use glob to get all file paths matching the pattern\n",
    "    all_files = glob.glob(full_pattern)\n",
    "\n",
    "    # Initialize an empty list to hold the dataframes\n",
    "    df_list = []\n",
    "\n",
    "    # Loop through the files, read each into a dataframe, and append it to the list\n",
    "    for file_path in all_files:\n",
    "        df = pd.read_csv(file_path)\n",
    "        df['gradient_alpha'] = df['gradient_alpha'].astype(float).round(8)\n",
    "        df['hessian_beta'] = df['hessian_beta'].astype(float).round(8)\n",
    "        df_list.append(df)\n",
    "\n",
    "    # Concatenate all the dataframes in the list\n",
    "    merged_df = pd.concat(df_list, ignore_index=True)\n",
    "    merged_df.drop(0, inplace=True)\n",
    "    merged_df['gradient_alpha'] = pd.to_numeric(merged_df['gradient_alpha'], errors='coerce')\n",
    "    merged_df['hessian_beta'] = pd.to_numeric(merged_df['hessian_beta'], errors='coerce')\n",
    "    merged_df['penalty_anneal_iters'] = pd.to_numeric(merged_df['penalty_anneal_iters'], errors='coerce')\n",
    "    # Define columns for the groupby operation based on 'fishr' in filename\n",
    "\n",
    "    if 'fishr' in file_name_pattern:\n",
    "        group_columns = ['dataset', 'split', 'method', 'ISR_class', 'ISR_scale', 'num_iter', 'ema', 'lambda',\n",
    "                         'penalty_anneal_iters']\n",
    "    elif 'coral' in file_name_pattern:\n",
    "        group_columns = ['dataset', 'split', 'method', 'ISR_class', 'ISR_scale', 'num_iter', 'mmd_gamma']\n",
    "    else:\n",
    "        group_columns = ['dataset', 'split', 'method', 'ISR_class', 'ISR_scale', 'num_iter', 'gradient_alpha',\n",
    "                     'hessian_beta', 'penalty_anneal_iters']\n",
    "    # Add 'num_runs' before groupby\n",
    "    merged_df['num_runs'] = merged_df.groupby(group_columns).transform('size')\n",
    "    # merged_df['seed_runs'] = merged_df.groupby(group_columns)['seed'].transform(lambda x: list(x.unique()))\n",
    "    seed_runs = merged_df.groupby(group_columns)['seed'].agg(lambda x: list(set(x))).rename('seed_runs')\n",
    "\n",
    "    # Merge this aggregated data back to the original DataFrame if needed\n",
    "    merged_df = merged_df.merge(seed_runs, on=group_columns, how='left')\n",
    "\n",
    "    # Group and aggregate data\n",
    "\n",
    "    merged_df['num_iter'] = pd.to_numeric(merged_df['num_iter'], errors='coerce')\n",
    "\n",
    "\n",
    "    # base_columns = ['dataset', 'seed', 'split', 'method', 'ISR_class', 'ISR_scale', 'num_iter', 'acc-0', 'acc-1', 'acc-2', 'acc-3', 'worst_group', 'avg_acc', 'worst_acc','num_runs','seed_runs']\n",
    "    if 'fishr' in file_name_pattern:\n",
    "        merged_df = merged_df[['dataset','seed','split','method','ISR_class','ISR_scale','num_iter', 'ema','lambda','penalty_anneal_iters', 'acc-0', 'acc-1', 'acc-2', 'acc-3', 'worst_group', 'avg_acc', 'worst_acc','num_runs','seed_runs']]\n",
    "\n",
    "    elif 'coral' in file_name_pattern:\n",
    "        merged_df = merged_df[['dataset','seed','split','method','ISR_class','ISR_scale','num_iter', 'mmd_gamma', 'acc-0', 'acc-1', 'acc-2', 'acc-3', 'worst_group', 'avg_acc', 'worst_acc','num_runs','seed_runs']]\n",
    "    else:\n",
    "        merged_df = merged_df[['dataset','seed','split','method','ISR_class','ISR_scale','num_iter', 'gradient_alpha', 'hessian_beta','penalty_anneal_iters', 'acc-0', 'acc-1', 'acc-2', 'acc-3', 'worst_group', 'avg_acc', 'worst_acc','num_runs','seed_runs']]\n",
    "\n",
    "\n",
    "    if 'CUB' in file_name_pattern:\n",
    "        merged_df = merged_df[merged_df['num_iter']==300]\n",
    "    elif 'CelebA' in file_name_pattern:\n",
    "        merged_df = merged_df[merged_df['num_iter']==50]\n",
    "    elif 'MultiNLI' in file_name_pattern:\n",
    "        merged_df = merged_df[merged_df['num_iter']==3]\n",
    "    # if 'fishr' in file_name_pattern:\n",
    "    #     grouped = merged_df.groupby(['dataset', 'split', 'method', 'ISR_class', 'ISR_scale',\n",
    "    #                                  'num_iter','ema','lambda','penalty_anneal_iters']).agg({\n",
    "    #         'avg_acc': ['mean', 'sem'],\n",
    "    #         'worst_acc': ['mean', 'sem']\n",
    "    #     })\n",
    "    # else:\n",
    "    #     merged_df.fillna(0, inplace=True)\n",
    "    #     grouped = merged_df.groupby(['dataset', 'split', 'method', 'ISR_class', 'ISR_scale',\n",
    "    #                             'num_iter', 'gradient_alpha', 'hessian_beta','penalty_anneal_iters']).agg({\n",
    "    #         'avg_acc': ['mean', 'sem'],\n",
    "    #         'worst_acc': ['mean', 'sem']\n",
    "    #     })\n",
    "\n",
    "    merged_df['avg_acc'] = pd.to_numeric(merged_df['avg_acc'], errors='coerce')\n",
    "    merged_df['worst_acc'] = pd.to_numeric(merged_df['worst_acc'], errors='coerce')\n",
    "    grouped = merged_df.groupby(group_columns).agg({\n",
    "        'avg_acc': ['mean', 'sem'],\n",
    "        'worst_acc': ['mean', 'sem'],\n",
    "        'num_runs': 'first',\n",
    "        'seed_runs': 'first'\n",
    "    })\n",
    "\n",
    "    import numpy as np\n",
    "    # manually check for sem\n",
    "    grouped2 = merged_df.groupby(group_columns).agg({\n",
    "        'avg_acc': ['mean', lambda x: x.std(ddof=1) / np.sqrt(len(x))],\n",
    "        'worst_acc': ['mean', lambda x: x.std(ddof=1) / np.sqrt(len(x))],\n",
    "        'num_runs': 'first',\n",
    "        'seed_runs': 'first'\n",
    "    })\n",
    "\n",
    "\n",
    "    # Renaming the columns for clarity\n",
    "    grouped.columns = ['avg_acc_mean', 'avg_acc_sem', 'worst_acc_mean', 'worst_acc_sem', 'num_runs','seed_runs']\n",
    "    grouped2.columns = ['avg_acc_mean', 'avg_acc_sem', 'worst_acc_mean', 'worst_acc_sem', 'num_runs','seed_runs']\n",
    "    # Resetting the index if you want the grouped columns back as regular columns\n",
    "    grouped = grouped.reset_index()\n",
    "    grouped2 = grouped2.reset_index()\n",
    "\n",
    "    # cleaned_grouped = grouped.dropna(subset=['avg_acc_sem', 'worst_acc_sem'])\n",
    "    cleaned_grouped = grouped\n",
    "    # Display the cleaned DataFrame\n",
    "    # print(cleaned_grouped)\n",
    "    val = cleaned_grouped[cleaned_grouped['split'] == 'val']\n",
    "    test = cleaned_grouped[cleaned_grouped['split'] == 'test']\n",
    "    num_runs = len(all_files)\n",
    "    dataset = file_name_pattern.split('_')[0]\n",
    "    if 'fishr' in file_name_pattern:\n",
    "        val.to_csv(f'{data_dir}/{dataset}_{num_runs}runs_fishr_val.csv', index=False)\n",
    "        test.to_csv(f'{data_dir}/{dataset}_{num_runs}runs_fishr_test.csv', index=False)\n",
    "    elif 'coral' in file_name_pattern:\n",
    "        val.to_csv(f'{data_dir}/{dataset}_{num_runs}runs_coral_val.csv', index=False)\n",
    "        test.to_csv(f'{data_dir}/{dataset}_{num_runs}runs_coral_test.csv', index=False)\n",
    "    else:\n",
    "        val.to_csv(f'{data_dir}/{dataset}_{num_runs}runs_val.csv', index=False)\n",
    "        test.to_csv(f'{data_dir}/{dataset}_{num_runs}runs_test.csv', index=False)\n",
    "    # print(f\"Saved {dataset}_{num_runs}runs_val.csv and {dataset}_{num_runs}runs_test.csv in {data_dir}\")\n",
    "    return val, test"
   ],
   "id": "ea66df2ba2c115f2"
  },
  {
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2025-02-08T20:24:45.581722Z",
     "start_time": "2025-02-08T20:24:45.239225Z"
    }
   },
   "cell_type": "code",
   "outputs": [
    {
     "ename": "ValueError",
     "evalue": "No objects to concatenate",
     "output_type": "error",
     "traceback": [
      "\u001B[0;31m---------------------------------------------------------------------------\u001B[0m",
      "\u001B[0;31mValueError\u001B[0m                                Traceback (most recent call last)",
      "Cell \u001B[0;32mIn[3], line 3\u001B[0m\n\u001B[1;32m      1\u001B[0m data_dir \u001B[38;5;241m=\u001B[39m \u001B[38;5;124m'\u001B[39m\u001B[38;5;124m./logs/ISR_result_bias\u001B[39m\u001B[38;5;124m'\u001B[39m\n\u001B[0;32m----> 3\u001B[0m \u001B[43mmerge_seeds\u001B[49m\u001B[43m(\u001B[49m\u001B[43mfile_name_pattern\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[38;5;124;43m'\u001B[39;49m\u001B[38;5;124;43mCUB_results_s*_hessian_exact.csv\u001B[39;49m\u001B[38;5;124;43m'\u001B[39;49m\u001B[43m,\u001B[49m\u001B[43m \u001B[49m\u001B[43mdata_dir\u001B[49m\u001B[43m \u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43m \u001B[49m\u001B[43mdata_dir\u001B[49m\u001B[43m)\u001B[49m\n\u001B[1;32m      4\u001B[0m merge_seeds(file_name_pattern\u001B[38;5;241m=\u001B[39m\u001B[38;5;124m'\u001B[39m\u001B[38;5;124mCelebA_results_s*_hessian_exact.csv\u001B[39m\u001B[38;5;124m'\u001B[39m, data_dir \u001B[38;5;241m=\u001B[39m data_dir)\n\u001B[1;32m      5\u001B[0m merge_seeds(file_name_pattern\u001B[38;5;241m=\u001B[39m\u001B[38;5;124m'\u001B[39m\u001B[38;5;124mMultiNLI_results_s*_hessian_exact.csv\u001B[39m\u001B[38;5;124m'\u001B[39m, data_dir \u001B[38;5;241m=\u001B[39m data_dir)\n",
      "Cell \u001B[0;32mIn[2], line 19\u001B[0m, in \u001B[0;36mmerge_seeds\u001B[0;34m(file_name_pattern, data_dir)\u001B[0m\n\u001B[1;32m     16\u001B[0m     df_list\u001B[38;5;241m.\u001B[39mappend(df)\n\u001B[1;32m     18\u001B[0m \u001B[38;5;66;03m# Concatenate all the dataframes in the list\u001B[39;00m\n\u001B[0;32m---> 19\u001B[0m merged_df \u001B[38;5;241m=\u001B[39m \u001B[43mpd\u001B[49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43mconcat\u001B[49m\u001B[43m(\u001B[49m\u001B[43mdf_list\u001B[49m\u001B[43m,\u001B[49m\u001B[43m \u001B[49m\u001B[43mignore_index\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[38;5;28;43;01mTrue\u001B[39;49;00m\u001B[43m)\u001B[49m\n\u001B[1;32m     20\u001B[0m merged_df\u001B[38;5;241m.\u001B[39mdrop(\u001B[38;5;241m0\u001B[39m, inplace\u001B[38;5;241m=\u001B[39m\u001B[38;5;28;01mTrue\u001B[39;00m)\n\u001B[1;32m     21\u001B[0m merged_df[\u001B[38;5;124m'\u001B[39m\u001B[38;5;124mgradient_alpha\u001B[39m\u001B[38;5;124m'\u001B[39m] \u001B[38;5;241m=\u001B[39m pd\u001B[38;5;241m.\u001B[39mto_numeric(merged_df[\u001B[38;5;124m'\u001B[39m\u001B[38;5;124mgradient_alpha\u001B[39m\u001B[38;5;124m'\u001B[39m], errors\u001B[38;5;241m=\u001B[39m\u001B[38;5;124m'\u001B[39m\u001B[38;5;124mcoerce\u001B[39m\u001B[38;5;124m'\u001B[39m)\n",
      "File \u001B[0;32m~/anaconda3/envs/isr/lib/python3.9/site-packages/pandas/core/reshape/concat.py:372\u001B[0m, in \u001B[0;36mconcat\u001B[0;34m(objs, axis, join, ignore_index, keys, levels, names, verify_integrity, sort, copy)\u001B[0m\n\u001B[1;32m    369\u001B[0m \u001B[38;5;28;01melif\u001B[39;00m copy \u001B[38;5;129;01mand\u001B[39;00m using_copy_on_write():\n\u001B[1;32m    370\u001B[0m     copy \u001B[38;5;241m=\u001B[39m \u001B[38;5;28;01mFalse\u001B[39;00m\n\u001B[0;32m--> 372\u001B[0m op \u001B[38;5;241m=\u001B[39m \u001B[43m_Concatenator\u001B[49m\u001B[43m(\u001B[49m\n\u001B[1;32m    373\u001B[0m \u001B[43m    \u001B[49m\u001B[43mobjs\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    374\u001B[0m \u001B[43m    \u001B[49m\u001B[43maxis\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43maxis\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    375\u001B[0m \u001B[43m    \u001B[49m\u001B[43mignore_index\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43mignore_index\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    376\u001B[0m \u001B[43m    \u001B[49m\u001B[43mjoin\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43mjoin\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    377\u001B[0m \u001B[43m    \u001B[49m\u001B[43mkeys\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43mkeys\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    378\u001B[0m \u001B[43m    \u001B[49m\u001B[43mlevels\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43mlevels\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    379\u001B[0m \u001B[43m    \u001B[49m\u001B[43mnames\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43mnames\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    380\u001B[0m \u001B[43m    \u001B[49m\u001B[43mverify_integrity\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43mverify_integrity\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    381\u001B[0m \u001B[43m    \u001B[49m\u001B[43mcopy\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43mcopy\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    382\u001B[0m \u001B[43m    \u001B[49m\u001B[43msort\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43msort\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    383\u001B[0m \u001B[43m\u001B[49m\u001B[43m)\u001B[49m\n\u001B[1;32m    385\u001B[0m \u001B[38;5;28;01mreturn\u001B[39;00m op\u001B[38;5;241m.\u001B[39mget_result()\n",
      "File \u001B[0;32m~/anaconda3/envs/isr/lib/python3.9/site-packages/pandas/core/reshape/concat.py:429\u001B[0m, in \u001B[0;36m_Concatenator.__init__\u001B[0;34m(self, objs, axis, join, keys, levels, names, ignore_index, verify_integrity, copy, sort)\u001B[0m\n\u001B[1;32m    426\u001B[0m     objs \u001B[38;5;241m=\u001B[39m \u001B[38;5;28mlist\u001B[39m(objs)\n\u001B[1;32m    428\u001B[0m \u001B[38;5;28;01mif\u001B[39;00m \u001B[38;5;28mlen\u001B[39m(objs) \u001B[38;5;241m==\u001B[39m \u001B[38;5;241m0\u001B[39m:\n\u001B[0;32m--> 429\u001B[0m     \u001B[38;5;28;01mraise\u001B[39;00m \u001B[38;5;167;01mValueError\u001B[39;00m(\u001B[38;5;124m\"\u001B[39m\u001B[38;5;124mNo objects to concatenate\u001B[39m\u001B[38;5;124m\"\u001B[39m)\n\u001B[1;32m    431\u001B[0m \u001B[38;5;28;01mif\u001B[39;00m keys \u001B[38;5;129;01mis\u001B[39;00m \u001B[38;5;28;01mNone\u001B[39;00m:\n\u001B[1;32m    432\u001B[0m     objs \u001B[38;5;241m=\u001B[39m \u001B[38;5;28mlist\u001B[39m(com\u001B[38;5;241m.\u001B[39mnot_none(\u001B[38;5;241m*\u001B[39mobjs))\n",
      "\u001B[0;31mValueError\u001B[0m: No objects to concatenate"
     ]
    }
   ],
   "execution_count": 3,
   "source": [
    "data_dir = './logs/ISR_result_bias'\n",
    "\n",
    "merge_seeds(file_name_pattern='CUB_results_s*_hessian_exact.csv', data_dir = data_dir)\n",
    "merge_seeds(file_name_pattern='CelebA_results_s*_hessian_exact.csv', data_dir = data_dir)\n",
    "merge_seeds(file_name_pattern='MultiNLI_results_s*_hessian_exact.csv', data_dir = data_dir)\n",
    "\n"
   ],
   "id": "274b0a9983a2997a"
  },
  {
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2025-02-08T20:24:45.884631Z",
     "start_time": "2025-02-08T20:24:45.676755Z"
    }
   },
   "cell_type": "code",
   "outputs": [
    {
     "ename": "FileNotFoundError",
     "evalue": "[Errno 2] No such file or directory: './logs/ISR_result_bias/CelebA_5runs_val.csv'",
     "output_type": "error",
     "traceback": [
      "\u001B[0;31m---------------------------------------------------------------------------\u001B[0m",
      "\u001B[0;31mFileNotFoundError\u001B[0m                         Traceback (most recent call last)",
      "Cell \u001B[0;32mIn[4], line 16\u001B[0m\n\u001B[1;32m     12\u001B[0m multinli_file_coral \u001B[38;5;241m=\u001B[39m \u001B[38;5;124m'\u001B[39m\u001B[38;5;124mMultiNLI_5runs_coral_val.csv\u001B[39m\u001B[38;5;124m'\u001B[39m\n\u001B[1;32m     15\u001B[0m \u001B[38;5;66;03m# df = pd.read_csv(os.path.join('./logs/ISR_Hessian_results_new', cub_file))\u001B[39;00m\n\u001B[0;32m---> 16\u001B[0m df \u001B[38;5;241m=\u001B[39m \u001B[43mpd\u001B[49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43mread_csv\u001B[49m\u001B[43m(\u001B[49m\u001B[43mos\u001B[49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43mpath\u001B[49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43mjoin\u001B[49m\u001B[43m(\u001B[49m\u001B[43mdata_dir\u001B[49m\u001B[43m,\u001B[49m\u001B[43m \u001B[49m\u001B[43mceleba_file\u001B[49m\u001B[43m)\u001B[49m\u001B[43m)\u001B[49m\n\u001B[1;32m     17\u001B[0m \u001B[38;5;66;03m# df = pd.read_csv(os.path.join('./logs/ISR_Hessian_results_new', multinli_file))\u001B[39;00m\n\u001B[1;32m     21\u001B[0m \u001B[38;5;28;01mif\u001B[39;00m df[\u001B[38;5;124m'\u001B[39m\u001B[38;5;124mdataset\u001B[39m\u001B[38;5;124m'\u001B[39m]\u001B[38;5;241m.\u001B[39miloc[\u001B[38;5;241m0\u001B[39m] \u001B[38;5;241m==\u001B[39m \u001B[38;5;124m'\u001B[39m\u001B[38;5;124mCUB\u001B[39m\u001B[38;5;124m'\u001B[39m:\n",
      "File \u001B[0;32m~/anaconda3/envs/isr/lib/python3.9/site-packages/pandas/io/parsers/readers.py:912\u001B[0m, in \u001B[0;36mread_csv\u001B[0;34m(filepath_or_buffer, sep, delimiter, header, names, index_col, usecols, dtype, engine, converters, true_values, false_values, skipinitialspace, skiprows, skipfooter, nrows, na_values, keep_default_na, na_filter, verbose, skip_blank_lines, parse_dates, infer_datetime_format, keep_date_col, date_parser, date_format, dayfirst, cache_dates, iterator, chunksize, compression, thousands, decimal, lineterminator, quotechar, quoting, doublequote, escapechar, comment, encoding, encoding_errors, dialect, on_bad_lines, delim_whitespace, low_memory, memory_map, float_precision, storage_options, dtype_backend)\u001B[0m\n\u001B[1;32m    899\u001B[0m kwds_defaults \u001B[38;5;241m=\u001B[39m _refine_defaults_read(\n\u001B[1;32m    900\u001B[0m     dialect,\n\u001B[1;32m    901\u001B[0m     delimiter,\n\u001B[0;32m   (...)\u001B[0m\n\u001B[1;32m    908\u001B[0m     dtype_backend\u001B[38;5;241m=\u001B[39mdtype_backend,\n\u001B[1;32m    909\u001B[0m )\n\u001B[1;32m    910\u001B[0m kwds\u001B[38;5;241m.\u001B[39mupdate(kwds_defaults)\n\u001B[0;32m--> 912\u001B[0m \u001B[38;5;28;01mreturn\u001B[39;00m \u001B[43m_read\u001B[49m\u001B[43m(\u001B[49m\u001B[43mfilepath_or_buffer\u001B[49m\u001B[43m,\u001B[49m\u001B[43m \u001B[49m\u001B[43mkwds\u001B[49m\u001B[43m)\u001B[49m\n",
      "File \u001B[0;32m~/anaconda3/envs/isr/lib/python3.9/site-packages/pandas/io/parsers/readers.py:577\u001B[0m, in \u001B[0;36m_read\u001B[0;34m(filepath_or_buffer, kwds)\u001B[0m\n\u001B[1;32m    574\u001B[0m _validate_names(kwds\u001B[38;5;241m.\u001B[39mget(\u001B[38;5;124m\"\u001B[39m\u001B[38;5;124mnames\u001B[39m\u001B[38;5;124m\"\u001B[39m, \u001B[38;5;28;01mNone\u001B[39;00m))\n\u001B[1;32m    576\u001B[0m \u001B[38;5;66;03m# Create the parser.\u001B[39;00m\n\u001B[0;32m--> 577\u001B[0m parser \u001B[38;5;241m=\u001B[39m \u001B[43mTextFileReader\u001B[49m\u001B[43m(\u001B[49m\u001B[43mfilepath_or_buffer\u001B[49m\u001B[43m,\u001B[49m\u001B[43m \u001B[49m\u001B[38;5;241;43m*\u001B[39;49m\u001B[38;5;241;43m*\u001B[39;49m\u001B[43mkwds\u001B[49m\u001B[43m)\u001B[49m\n\u001B[1;32m    579\u001B[0m \u001B[38;5;28;01mif\u001B[39;00m chunksize \u001B[38;5;129;01mor\u001B[39;00m iterator:\n\u001B[1;32m    580\u001B[0m     \u001B[38;5;28;01mreturn\u001B[39;00m parser\n",
      "File \u001B[0;32m~/anaconda3/envs/isr/lib/python3.9/site-packages/pandas/io/parsers/readers.py:1407\u001B[0m, in \u001B[0;36mTextFileReader.__init__\u001B[0;34m(self, f, engine, **kwds)\u001B[0m\n\u001B[1;32m   1404\u001B[0m     \u001B[38;5;28mself\u001B[39m\u001B[38;5;241m.\u001B[39moptions[\u001B[38;5;124m\"\u001B[39m\u001B[38;5;124mhas_index_names\u001B[39m\u001B[38;5;124m\"\u001B[39m] \u001B[38;5;241m=\u001B[39m kwds[\u001B[38;5;124m\"\u001B[39m\u001B[38;5;124mhas_index_names\u001B[39m\u001B[38;5;124m\"\u001B[39m]\n\u001B[1;32m   1406\u001B[0m \u001B[38;5;28mself\u001B[39m\u001B[38;5;241m.\u001B[39mhandles: IOHandles \u001B[38;5;241m|\u001B[39m \u001B[38;5;28;01mNone\u001B[39;00m \u001B[38;5;241m=\u001B[39m \u001B[38;5;28;01mNone\u001B[39;00m\n\u001B[0;32m-> 1407\u001B[0m \u001B[38;5;28mself\u001B[39m\u001B[38;5;241m.\u001B[39m_engine \u001B[38;5;241m=\u001B[39m \u001B[38;5;28;43mself\u001B[39;49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43m_make_engine\u001B[49m\u001B[43m(\u001B[49m\u001B[43mf\u001B[49m\u001B[43m,\u001B[49m\u001B[43m \u001B[49m\u001B[38;5;28;43mself\u001B[39;49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43mengine\u001B[49m\u001B[43m)\u001B[49m\n",
      "File \u001B[0;32m~/anaconda3/envs/isr/lib/python3.9/site-packages/pandas/io/parsers/readers.py:1661\u001B[0m, in \u001B[0;36mTextFileReader._make_engine\u001B[0;34m(self, f, engine)\u001B[0m\n\u001B[1;32m   1659\u001B[0m     \u001B[38;5;28;01mif\u001B[39;00m \u001B[38;5;124m\"\u001B[39m\u001B[38;5;124mb\u001B[39m\u001B[38;5;124m\"\u001B[39m \u001B[38;5;129;01mnot\u001B[39;00m \u001B[38;5;129;01min\u001B[39;00m mode:\n\u001B[1;32m   1660\u001B[0m         mode \u001B[38;5;241m+\u001B[39m\u001B[38;5;241m=\u001B[39m \u001B[38;5;124m\"\u001B[39m\u001B[38;5;124mb\u001B[39m\u001B[38;5;124m\"\u001B[39m\n\u001B[0;32m-> 1661\u001B[0m \u001B[38;5;28mself\u001B[39m\u001B[38;5;241m.\u001B[39mhandles \u001B[38;5;241m=\u001B[39m \u001B[43mget_handle\u001B[49m\u001B[43m(\u001B[49m\n\u001B[1;32m   1662\u001B[0m \u001B[43m    \u001B[49m\u001B[43mf\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m   1663\u001B[0m \u001B[43m    \u001B[49m\u001B[43mmode\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m   1664\u001B[0m \u001B[43m    \u001B[49m\u001B[43mencoding\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[38;5;28;43mself\u001B[39;49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43moptions\u001B[49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43mget\u001B[49m\u001B[43m(\u001B[49m\u001B[38;5;124;43m\"\u001B[39;49m\u001B[38;5;124;43mencoding\u001B[39;49m\u001B[38;5;124;43m\"\u001B[39;49m\u001B[43m,\u001B[49m\u001B[43m \u001B[49m\u001B[38;5;28;43;01mNone\u001B[39;49;00m\u001B[43m)\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m   1665\u001B[0m \u001B[43m    \u001B[49m\u001B[43mcompression\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[38;5;28;43mself\u001B[39;49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43moptions\u001B[49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43mget\u001B[49m\u001B[43m(\u001B[49m\u001B[38;5;124;43m\"\u001B[39;49m\u001B[38;5;124;43mcompression\u001B[39;49m\u001B[38;5;124;43m\"\u001B[39;49m\u001B[43m,\u001B[49m\u001B[43m \u001B[49m\u001B[38;5;28;43;01mNone\u001B[39;49;00m\u001B[43m)\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m   1666\u001B[0m \u001B[43m    \u001B[49m\u001B[43mmemory_map\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[38;5;28;43mself\u001B[39;49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43moptions\u001B[49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43mget\u001B[49m\u001B[43m(\u001B[49m\u001B[38;5;124;43m\"\u001B[39;49m\u001B[38;5;124;43mmemory_map\u001B[39;49m\u001B[38;5;124;43m\"\u001B[39;49m\u001B[43m,\u001B[49m\u001B[43m \u001B[49m\u001B[38;5;28;43;01mFalse\u001B[39;49;00m\u001B[43m)\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m   1667\u001B[0m \u001B[43m    \u001B[49m\u001B[43mis_text\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43mis_text\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m   1668\u001B[0m \u001B[43m    \u001B[49m\u001B[43merrors\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[38;5;28;43mself\u001B[39;49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43moptions\u001B[49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43mget\u001B[49m\u001B[43m(\u001B[49m\u001B[38;5;124;43m\"\u001B[39;49m\u001B[38;5;124;43mencoding_errors\u001B[39;49m\u001B[38;5;124;43m\"\u001B[39;49m\u001B[43m,\u001B[49m\u001B[43m \u001B[49m\u001B[38;5;124;43m\"\u001B[39;49m\u001B[38;5;124;43mstrict\u001B[39;49m\u001B[38;5;124;43m\"\u001B[39;49m\u001B[43m)\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m   1669\u001B[0m \u001B[43m    \u001B[49m\u001B[43mstorage_options\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[38;5;28;43mself\u001B[39;49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43moptions\u001B[49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43mget\u001B[49m\u001B[43m(\u001B[49m\u001B[38;5;124;43m\"\u001B[39;49m\u001B[38;5;124;43mstorage_options\u001B[39;49m\u001B[38;5;124;43m\"\u001B[39;49m\u001B[43m,\u001B[49m\u001B[43m \u001B[49m\u001B[38;5;28;43;01mNone\u001B[39;49;00m\u001B[43m)\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m   1670\u001B[0m \u001B[43m\u001B[49m\u001B[43m)\u001B[49m\n\u001B[1;32m   1671\u001B[0m \u001B[38;5;28;01massert\u001B[39;00m \u001B[38;5;28mself\u001B[39m\u001B[38;5;241m.\u001B[39mhandles \u001B[38;5;129;01mis\u001B[39;00m \u001B[38;5;129;01mnot\u001B[39;00m \u001B[38;5;28;01mNone\u001B[39;00m\n\u001B[1;32m   1672\u001B[0m f \u001B[38;5;241m=\u001B[39m \u001B[38;5;28mself\u001B[39m\u001B[38;5;241m.\u001B[39mhandles\u001B[38;5;241m.\u001B[39mhandle\n",
      "File \u001B[0;32m~/anaconda3/envs/isr/lib/python3.9/site-packages/pandas/io/common.py:859\u001B[0m, in \u001B[0;36mget_handle\u001B[0;34m(path_or_buf, mode, encoding, compression, memory_map, is_text, errors, storage_options)\u001B[0m\n\u001B[1;32m    854\u001B[0m \u001B[38;5;28;01melif\u001B[39;00m \u001B[38;5;28misinstance\u001B[39m(handle, \u001B[38;5;28mstr\u001B[39m):\n\u001B[1;32m    855\u001B[0m     \u001B[38;5;66;03m# Check whether the filename is to be opened in binary mode.\u001B[39;00m\n\u001B[1;32m    856\u001B[0m     \u001B[38;5;66;03m# Binary mode does not support 'encoding' and 'newline'.\u001B[39;00m\n\u001B[1;32m    857\u001B[0m     \u001B[38;5;28;01mif\u001B[39;00m ioargs\u001B[38;5;241m.\u001B[39mencoding \u001B[38;5;129;01mand\u001B[39;00m \u001B[38;5;124m\"\u001B[39m\u001B[38;5;124mb\u001B[39m\u001B[38;5;124m\"\u001B[39m \u001B[38;5;129;01mnot\u001B[39;00m \u001B[38;5;129;01min\u001B[39;00m ioargs\u001B[38;5;241m.\u001B[39mmode:\n\u001B[1;32m    858\u001B[0m         \u001B[38;5;66;03m# Encoding\u001B[39;00m\n\u001B[0;32m--> 859\u001B[0m         handle \u001B[38;5;241m=\u001B[39m \u001B[38;5;28;43mopen\u001B[39;49m\u001B[43m(\u001B[49m\n\u001B[1;32m    860\u001B[0m \u001B[43m            \u001B[49m\u001B[43mhandle\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    861\u001B[0m \u001B[43m            \u001B[49m\u001B[43mioargs\u001B[49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43mmode\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    862\u001B[0m \u001B[43m            \u001B[49m\u001B[43mencoding\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43mioargs\u001B[49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43mencoding\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    863\u001B[0m \u001B[43m            \u001B[49m\u001B[43merrors\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43merrors\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    864\u001B[0m \u001B[43m            \u001B[49m\u001B[43mnewline\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[38;5;124;43m\"\u001B[39;49m\u001B[38;5;124;43m\"\u001B[39;49m\u001B[43m,\u001B[49m\n\u001B[1;32m    865\u001B[0m \u001B[43m        \u001B[49m\u001B[43m)\u001B[49m\n\u001B[1;32m    866\u001B[0m     \u001B[38;5;28;01melse\u001B[39;00m:\n\u001B[1;32m    867\u001B[0m         \u001B[38;5;66;03m# Binary mode\u001B[39;00m\n\u001B[1;32m    868\u001B[0m         handle \u001B[38;5;241m=\u001B[39m \u001B[38;5;28mopen\u001B[39m(handle, ioargs\u001B[38;5;241m.\u001B[39mmode)\n",
      "\u001B[0;31mFileNotFoundError\u001B[0m: [Errno 2] No such file or directory: './logs/ISR_result_bias/CelebA_5runs_val.csv'"
     ]
    }
   ],
   "execution_count": 4,
   "source": [
    "\n",
    "# Example DataFrame\n",
    "cub_file = 'CUB_5runs_val.csv'\n",
    "celeba_file = 'CelebA_5runs_val.csv'\n",
    "multinli_file = 'MultiNLI_5runs_val.csv'\n",
    "\n",
    "cub_file_fishr = 'CUB_5runs_fishr_val.csv'\n",
    "celeba_file_fishr = 'CelebA_5runs_fishr_val.csv'\n",
    "multinli_file_fishr = 'MultiNLI_5runs_fishr_val.csv'\n",
    "\n",
    "cub_file_coral = 'CUB_5runs_coral_val.csv'\n",
    "celeba_file_coral = 'CelebA_5runs_coral_val.csv'\n",
    "multinli_file_coral = 'MultiNLI_5runs_coral_val.csv'\n",
    "\n",
    "\n",
    "# df = pd.read_csv(os.path.join('./logs/ISR_Hessian_results_new', cub_file))\n",
    "df = pd.read_csv(os.path.join(data_dir, celeba_file))\n",
    "# df = pd.read_csv(os.path.join('./logs/ISR_Hessian_results_new', multinli_file))\n",
    "\n",
    "\n",
    "\n",
    "if df['dataset'].iloc[0] == 'CUB':\n",
    "    acc_min, acc_max = 0.8, 0.9\n",
    "elif df['dataset'].iloc[0] == 'CelebA':\n",
    "    acc_min, acc_max = 0.5, 0.70\n",
    "elif df['dataset'].iloc[0] == 'MultiNLI':\n",
    "    acc_min, acc_max = 0.5, 0.7\n",
    "# Creating a pivot table, averaging over 'penalty_anneal_iters'\n",
    "pivot_df = df.pivot_table(values='worst_acc_mean', index='gradient_alpha', columns='hessian_beta', aggfunc='mean')"
   ],
   "id": "598d3c7ae06bd836"
  },
  {
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2025-02-08T20:24:46.425860Z",
     "start_time": "2025-02-08T20:24:46.413630Z"
    }
   },
   "cell_type": "code",
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'pivot_df' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001B[0;31m---------------------------------------------------------------------------\u001B[0m",
      "\u001B[0;31mNameError\u001B[0m                                 Traceback (most recent call last)",
      "Cell \u001B[0;32mIn[5], line 1\u001B[0m\n\u001B[0;32m----> 1\u001B[0m sns\u001B[38;5;241m.\u001B[39mheatmap(\u001B[43mpivot_df\u001B[49m, annot\u001B[38;5;241m=\u001B[39m\u001B[38;5;28;01mTrue\u001B[39;00m, cmap\u001B[38;5;241m=\u001B[39mwhite_black_cmap, fmt\u001B[38;5;241m=\u001B[39m\u001B[38;5;124m\"\u001B[39m\u001B[38;5;124m.4f\u001B[39m\u001B[38;5;124m\"\u001B[39m, vmin\u001B[38;5;241m=\u001B[39macc_min, vmax\u001B[38;5;241m=\u001B[39macc_max)\n\u001B[1;32m      2\u001B[0m plt\u001B[38;5;241m.\u001B[39mtitle(\u001B[38;5;124m'\u001B[39m\u001B[38;5;124mHeatmap of Worst Accuracy Mean by Gradient Alpha and Hessian Beta\u001B[39m\u001B[38;5;124m'\u001B[39m)\n\u001B[1;32m      3\u001B[0m plt\u001B[38;5;241m.\u001B[39mxlabel(\u001B[38;5;124m'\u001B[39m\u001B[38;5;124mHessian Beta\u001B[39m\u001B[38;5;124m'\u001B[39m)\n",
      "\u001B[0;31mNameError\u001B[0m: name 'pivot_df' is not defined"
     ]
    }
   ],
   "execution_count": 5,
   "source": [
    "sns.heatmap(pivot_df, annot=True, cmap=white_black_cmap, fmt=\".4f\", vmin=acc_min, vmax=acc_max)\n",
    "plt.title('Heatmap of Worst Accuracy Mean by Gradient Alpha and Hessian Beta')\n",
    "plt.xlabel('Hessian Beta')\n",
    "plt.ylabel('Gradient Alpha')\n",
    "plt.show()"
   ],
   "id": "f38a3612d97896de"
  },
  {
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2025-02-08T20:24:47.526570Z",
     "start_time": "2025-02-08T20:24:47.509443Z"
    }
   },
   "cell_type": "code",
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'df' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001B[0;31m---------------------------------------------------------------------------\u001B[0m",
      "\u001B[0;31mNameError\u001B[0m                                 Traceback (most recent call last)",
      "Cell \u001B[0;32mIn[6], line 3\u001B[0m\n\u001B[1;32m      1\u001B[0m \u001B[38;5;66;03m# We can create multiple heatmaps for each unique pairs value of 'ISR_class'and 'penalty_anneal_iters'\u001B[39;00m\n\u001B[1;32m      2\u001B[0m \u001B[38;5;28;01mfrom\u001B[39;00m \u001B[38;5;21;01mitertools\u001B[39;00m \u001B[38;5;28;01mimport\u001B[39;00m product\n\u001B[0;32m----> 3\u001B[0m df \u001B[38;5;241m=\u001B[39m \u001B[43mdf\u001B[49m[df[\u001B[38;5;124m'\u001B[39m\u001B[38;5;124mhessian_beta\u001B[39m\u001B[38;5;124m'\u001B[39m] \u001B[38;5;241m<\u001B[39m\u001B[38;5;241m=\u001B[39m \u001B[38;5;241m10000\u001B[39m]\n\u001B[1;32m      4\u001B[0m unique_iters \u001B[38;5;241m=\u001B[39m product(df[\u001B[38;5;124m'\u001B[39m\u001B[38;5;124mpenalty_anneal_iters\u001B[39m\u001B[38;5;124m'\u001B[39m]\u001B[38;5;241m.\u001B[39munique(), df[\u001B[38;5;124m'\u001B[39m\u001B[38;5;124mISR_class\u001B[39m\u001B[38;5;124m'\u001B[39m]\u001B[38;5;241m.\u001B[39munique())\n\u001B[1;32m      5\u001B[0m \u001B[38;5;66;03m# unique_iters = df['penalty_anneal_iters'].unique()\u001B[39;00m\n\u001B[1;32m      6\u001B[0m \n\u001B[1;32m      7\u001B[0m \u001B[38;5;66;03m# for iters, isr_class in unique_iters:\u001B[39;00m\n",
      "\u001B[0;31mNameError\u001B[0m: name 'df' is not defined"
     ]
    }
   ],
   "execution_count": 6,
   "source": [
    "# We can create multiple heatmaps for each unique pairs value of 'ISR_class'and 'penalty_anneal_iters'\n",
    "from itertools import product\n",
    "df = df[df['hessian_beta'] <= 10000]\n",
    "unique_iters = product(df['penalty_anneal_iters'].unique(), df['ISR_class'].unique())\n",
    "# unique_iters = df['penalty_anneal_iters'].unique()\n",
    "\n",
    "# for iters, isr_class in unique_iters:\n",
    "for iters, isr_class in product(df['penalty_anneal_iters'].unique(), [1]):\n",
    "    sub_df = df[df['penalty_anneal_iters'] == iters]\n",
    "    sub_df = sub_df[sub_df['ISR_class'] == isr_class]\n",
    "    pivot_df = sub_df.pivot_table(values='worst_acc_mean', index='gradient_alpha', columns='hessian_beta', aggfunc='mean')\n",
    "    plt.figure(figsize=(6, 4))\n",
    "    sns.heatmap(pivot_df, annot=True, cmap=white_black_cmap, fmt=\".4f\", vmin=acc_min, vmax=acc_max)\n",
    "    plt.title(f'Heatmap of Worst Accuracy Mean (Penalty Anneal Iters: {iters}), (ISR Class: {isr_class})')\n",
    "    plt.xlabel('Hessian Beta')\n",
    "    plt.ylabel('Gradient Alpha')\n",
    "    plt.show()\n"
   ],
   "id": "340cdcd739a15013"
  },
  {
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2025-02-08T20:24:47.862368Z",
     "start_time": "2025-02-08T20:24:47.818656Z"
    }
   },
   "cell_type": "code",
   "outputs": [
    {
     "ename": "FileNotFoundError",
     "evalue": "[Errno 2] No such file or directory: './logs/ISR_Hessian_results_new/MultiNLI_5runs_fishr_val.csv'",
     "output_type": "error",
     "traceback": [
      "\u001B[0;31m---------------------------------------------------------------------------\u001B[0m",
      "\u001B[0;31mFileNotFoundError\u001B[0m                         Traceback (most recent call last)",
      "Cell \u001B[0;32mIn[7], line 1\u001B[0m\n\u001B[0;32m----> 1\u001B[0m df \u001B[38;5;241m=\u001B[39m \u001B[43mpd\u001B[49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43mread_csv\u001B[49m\u001B[43m(\u001B[49m\u001B[43mos\u001B[49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43mpath\u001B[49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43mjoin\u001B[49m\u001B[43m(\u001B[49m\u001B[38;5;124;43m'\u001B[39;49m\u001B[38;5;124;43m./logs/ISR_Hessian_results_new\u001B[39;49m\u001B[38;5;124;43m'\u001B[39;49m\u001B[43m,\u001B[49m\u001B[43m \u001B[49m\u001B[43mmultinli_file_fishr\u001B[49m\u001B[43m)\u001B[49m\u001B[43m)\u001B[49m\n\u001B[1;32m      2\u001B[0m df\n",
      "File \u001B[0;32m~/anaconda3/envs/isr/lib/python3.9/site-packages/pandas/io/parsers/readers.py:912\u001B[0m, in \u001B[0;36mread_csv\u001B[0;34m(filepath_or_buffer, sep, delimiter, header, names, index_col, usecols, dtype, engine, converters, true_values, false_values, skipinitialspace, skiprows, skipfooter, nrows, na_values, keep_default_na, na_filter, verbose, skip_blank_lines, parse_dates, infer_datetime_format, keep_date_col, date_parser, date_format, dayfirst, cache_dates, iterator, chunksize, compression, thousands, decimal, lineterminator, quotechar, quoting, doublequote, escapechar, comment, encoding, encoding_errors, dialect, on_bad_lines, delim_whitespace, low_memory, memory_map, float_precision, storage_options, dtype_backend)\u001B[0m\n\u001B[1;32m    899\u001B[0m kwds_defaults \u001B[38;5;241m=\u001B[39m _refine_defaults_read(\n\u001B[1;32m    900\u001B[0m     dialect,\n\u001B[1;32m    901\u001B[0m     delimiter,\n\u001B[0;32m   (...)\u001B[0m\n\u001B[1;32m    908\u001B[0m     dtype_backend\u001B[38;5;241m=\u001B[39mdtype_backend,\n\u001B[1;32m    909\u001B[0m )\n\u001B[1;32m    910\u001B[0m kwds\u001B[38;5;241m.\u001B[39mupdate(kwds_defaults)\n\u001B[0;32m--> 912\u001B[0m \u001B[38;5;28;01mreturn\u001B[39;00m \u001B[43m_read\u001B[49m\u001B[43m(\u001B[49m\u001B[43mfilepath_or_buffer\u001B[49m\u001B[43m,\u001B[49m\u001B[43m \u001B[49m\u001B[43mkwds\u001B[49m\u001B[43m)\u001B[49m\n",
      "File \u001B[0;32m~/anaconda3/envs/isr/lib/python3.9/site-packages/pandas/io/parsers/readers.py:577\u001B[0m, in \u001B[0;36m_read\u001B[0;34m(filepath_or_buffer, kwds)\u001B[0m\n\u001B[1;32m    574\u001B[0m _validate_names(kwds\u001B[38;5;241m.\u001B[39mget(\u001B[38;5;124m\"\u001B[39m\u001B[38;5;124mnames\u001B[39m\u001B[38;5;124m\"\u001B[39m, \u001B[38;5;28;01mNone\u001B[39;00m))\n\u001B[1;32m    576\u001B[0m \u001B[38;5;66;03m# Create the parser.\u001B[39;00m\n\u001B[0;32m--> 577\u001B[0m parser \u001B[38;5;241m=\u001B[39m \u001B[43mTextFileReader\u001B[49m\u001B[43m(\u001B[49m\u001B[43mfilepath_or_buffer\u001B[49m\u001B[43m,\u001B[49m\u001B[43m \u001B[49m\u001B[38;5;241;43m*\u001B[39;49m\u001B[38;5;241;43m*\u001B[39;49m\u001B[43mkwds\u001B[49m\u001B[43m)\u001B[49m\n\u001B[1;32m    579\u001B[0m \u001B[38;5;28;01mif\u001B[39;00m chunksize \u001B[38;5;129;01mor\u001B[39;00m iterator:\n\u001B[1;32m    580\u001B[0m     \u001B[38;5;28;01mreturn\u001B[39;00m parser\n",
      "File \u001B[0;32m~/anaconda3/envs/isr/lib/python3.9/site-packages/pandas/io/parsers/readers.py:1407\u001B[0m, in \u001B[0;36mTextFileReader.__init__\u001B[0;34m(self, f, engine, **kwds)\u001B[0m\n\u001B[1;32m   1404\u001B[0m     \u001B[38;5;28mself\u001B[39m\u001B[38;5;241m.\u001B[39moptions[\u001B[38;5;124m\"\u001B[39m\u001B[38;5;124mhas_index_names\u001B[39m\u001B[38;5;124m\"\u001B[39m] \u001B[38;5;241m=\u001B[39m kwds[\u001B[38;5;124m\"\u001B[39m\u001B[38;5;124mhas_index_names\u001B[39m\u001B[38;5;124m\"\u001B[39m]\n\u001B[1;32m   1406\u001B[0m \u001B[38;5;28mself\u001B[39m\u001B[38;5;241m.\u001B[39mhandles: IOHandles \u001B[38;5;241m|\u001B[39m \u001B[38;5;28;01mNone\u001B[39;00m \u001B[38;5;241m=\u001B[39m \u001B[38;5;28;01mNone\u001B[39;00m\n\u001B[0;32m-> 1407\u001B[0m \u001B[38;5;28mself\u001B[39m\u001B[38;5;241m.\u001B[39m_engine \u001B[38;5;241m=\u001B[39m \u001B[38;5;28;43mself\u001B[39;49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43m_make_engine\u001B[49m\u001B[43m(\u001B[49m\u001B[43mf\u001B[49m\u001B[43m,\u001B[49m\u001B[43m \u001B[49m\u001B[38;5;28;43mself\u001B[39;49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43mengine\u001B[49m\u001B[43m)\u001B[49m\n",
      "File \u001B[0;32m~/anaconda3/envs/isr/lib/python3.9/site-packages/pandas/io/parsers/readers.py:1661\u001B[0m, in \u001B[0;36mTextFileReader._make_engine\u001B[0;34m(self, f, engine)\u001B[0m\n\u001B[1;32m   1659\u001B[0m     \u001B[38;5;28;01mif\u001B[39;00m \u001B[38;5;124m\"\u001B[39m\u001B[38;5;124mb\u001B[39m\u001B[38;5;124m\"\u001B[39m \u001B[38;5;129;01mnot\u001B[39;00m \u001B[38;5;129;01min\u001B[39;00m mode:\n\u001B[1;32m   1660\u001B[0m         mode \u001B[38;5;241m+\u001B[39m\u001B[38;5;241m=\u001B[39m \u001B[38;5;124m\"\u001B[39m\u001B[38;5;124mb\u001B[39m\u001B[38;5;124m\"\u001B[39m\n\u001B[0;32m-> 1661\u001B[0m \u001B[38;5;28mself\u001B[39m\u001B[38;5;241m.\u001B[39mhandles \u001B[38;5;241m=\u001B[39m \u001B[43mget_handle\u001B[49m\u001B[43m(\u001B[49m\n\u001B[1;32m   1662\u001B[0m \u001B[43m    \u001B[49m\u001B[43mf\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m   1663\u001B[0m \u001B[43m    \u001B[49m\u001B[43mmode\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m   1664\u001B[0m \u001B[43m    \u001B[49m\u001B[43mencoding\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[38;5;28;43mself\u001B[39;49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43moptions\u001B[49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43mget\u001B[49m\u001B[43m(\u001B[49m\u001B[38;5;124;43m\"\u001B[39;49m\u001B[38;5;124;43mencoding\u001B[39;49m\u001B[38;5;124;43m\"\u001B[39;49m\u001B[43m,\u001B[49m\u001B[43m \u001B[49m\u001B[38;5;28;43;01mNone\u001B[39;49;00m\u001B[43m)\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m   1665\u001B[0m \u001B[43m    \u001B[49m\u001B[43mcompression\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[38;5;28;43mself\u001B[39;49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43moptions\u001B[49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43mget\u001B[49m\u001B[43m(\u001B[49m\u001B[38;5;124;43m\"\u001B[39;49m\u001B[38;5;124;43mcompression\u001B[39;49m\u001B[38;5;124;43m\"\u001B[39;49m\u001B[43m,\u001B[49m\u001B[43m \u001B[49m\u001B[38;5;28;43;01mNone\u001B[39;49;00m\u001B[43m)\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m   1666\u001B[0m \u001B[43m    \u001B[49m\u001B[43mmemory_map\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[38;5;28;43mself\u001B[39;49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43moptions\u001B[49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43mget\u001B[49m\u001B[43m(\u001B[49m\u001B[38;5;124;43m\"\u001B[39;49m\u001B[38;5;124;43mmemory_map\u001B[39;49m\u001B[38;5;124;43m\"\u001B[39;49m\u001B[43m,\u001B[49m\u001B[43m \u001B[49m\u001B[38;5;28;43;01mFalse\u001B[39;49;00m\u001B[43m)\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m   1667\u001B[0m \u001B[43m    \u001B[49m\u001B[43mis_text\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43mis_text\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m   1668\u001B[0m \u001B[43m    \u001B[49m\u001B[43merrors\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[38;5;28;43mself\u001B[39;49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43moptions\u001B[49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43mget\u001B[49m\u001B[43m(\u001B[49m\u001B[38;5;124;43m\"\u001B[39;49m\u001B[38;5;124;43mencoding_errors\u001B[39;49m\u001B[38;5;124;43m\"\u001B[39;49m\u001B[43m,\u001B[49m\u001B[43m \u001B[49m\u001B[38;5;124;43m\"\u001B[39;49m\u001B[38;5;124;43mstrict\u001B[39;49m\u001B[38;5;124;43m\"\u001B[39;49m\u001B[43m)\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m   1669\u001B[0m \u001B[43m    \u001B[49m\u001B[43mstorage_options\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[38;5;28;43mself\u001B[39;49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43moptions\u001B[49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43mget\u001B[49m\u001B[43m(\u001B[49m\u001B[38;5;124;43m\"\u001B[39;49m\u001B[38;5;124;43mstorage_options\u001B[39;49m\u001B[38;5;124;43m\"\u001B[39;49m\u001B[43m,\u001B[49m\u001B[43m \u001B[49m\u001B[38;5;28;43;01mNone\u001B[39;49;00m\u001B[43m)\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m   1670\u001B[0m \u001B[43m\u001B[49m\u001B[43m)\u001B[49m\n\u001B[1;32m   1671\u001B[0m \u001B[38;5;28;01massert\u001B[39;00m \u001B[38;5;28mself\u001B[39m\u001B[38;5;241m.\u001B[39mhandles \u001B[38;5;129;01mis\u001B[39;00m \u001B[38;5;129;01mnot\u001B[39;00m \u001B[38;5;28;01mNone\u001B[39;00m\n\u001B[1;32m   1672\u001B[0m f \u001B[38;5;241m=\u001B[39m \u001B[38;5;28mself\u001B[39m\u001B[38;5;241m.\u001B[39mhandles\u001B[38;5;241m.\u001B[39mhandle\n",
      "File \u001B[0;32m~/anaconda3/envs/isr/lib/python3.9/site-packages/pandas/io/common.py:859\u001B[0m, in \u001B[0;36mget_handle\u001B[0;34m(path_or_buf, mode, encoding, compression, memory_map, is_text, errors, storage_options)\u001B[0m\n\u001B[1;32m    854\u001B[0m \u001B[38;5;28;01melif\u001B[39;00m \u001B[38;5;28misinstance\u001B[39m(handle, \u001B[38;5;28mstr\u001B[39m):\n\u001B[1;32m    855\u001B[0m     \u001B[38;5;66;03m# Check whether the filename is to be opened in binary mode.\u001B[39;00m\n\u001B[1;32m    856\u001B[0m     \u001B[38;5;66;03m# Binary mode does not support 'encoding' and 'newline'.\u001B[39;00m\n\u001B[1;32m    857\u001B[0m     \u001B[38;5;28;01mif\u001B[39;00m ioargs\u001B[38;5;241m.\u001B[39mencoding \u001B[38;5;129;01mand\u001B[39;00m \u001B[38;5;124m\"\u001B[39m\u001B[38;5;124mb\u001B[39m\u001B[38;5;124m\"\u001B[39m \u001B[38;5;129;01mnot\u001B[39;00m \u001B[38;5;129;01min\u001B[39;00m ioargs\u001B[38;5;241m.\u001B[39mmode:\n\u001B[1;32m    858\u001B[0m         \u001B[38;5;66;03m# Encoding\u001B[39;00m\n\u001B[0;32m--> 859\u001B[0m         handle \u001B[38;5;241m=\u001B[39m \u001B[38;5;28;43mopen\u001B[39;49m\u001B[43m(\u001B[49m\n\u001B[1;32m    860\u001B[0m \u001B[43m            \u001B[49m\u001B[43mhandle\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    861\u001B[0m \u001B[43m            \u001B[49m\u001B[43mioargs\u001B[49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43mmode\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    862\u001B[0m \u001B[43m            \u001B[49m\u001B[43mencoding\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43mioargs\u001B[49m\u001B[38;5;241;43m.\u001B[39;49m\u001B[43mencoding\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    863\u001B[0m \u001B[43m            \u001B[49m\u001B[43merrors\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[43merrors\u001B[49m\u001B[43m,\u001B[49m\n\u001B[1;32m    864\u001B[0m \u001B[43m            \u001B[49m\u001B[43mnewline\u001B[49m\u001B[38;5;241;43m=\u001B[39;49m\u001B[38;5;124;43m\"\u001B[39;49m\u001B[38;5;124;43m\"\u001B[39;49m\u001B[43m,\u001B[49m\n\u001B[1;32m    865\u001B[0m \u001B[43m        \u001B[49m\u001B[43m)\u001B[49m\n\u001B[1;32m    866\u001B[0m     \u001B[38;5;28;01melse\u001B[39;00m:\n\u001B[1;32m    867\u001B[0m         \u001B[38;5;66;03m# Binary mode\u001B[39;00m\n\u001B[1;32m    868\u001B[0m         handle \u001B[38;5;241m=\u001B[39m \u001B[38;5;28mopen\u001B[39m(handle, ioargs\u001B[38;5;241m.\u001B[39mmode)\n",
      "\u001B[0;31mFileNotFoundError\u001B[0m: [Errno 2] No such file or directory: './logs/ISR_Hessian_results_new/MultiNLI_5runs_fishr_val.csv'"
     ]
    }
   ],
   "execution_count": 7,
   "source": [
    "df = pd.read_csv(os.path.join('./logs/ISR_Hessian_results_new', multinli_file_fishr))\n",
    "df"
   ],
   "id": "424b5499cd6088df"
  },
  {
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2025-02-08T20:24:48.361167Z",
     "start_time": "2025-02-08T20:24:48.348597Z"
    }
   },
   "cell_type": "code",
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'df' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001B[0;31m---------------------------------------------------------------------------\u001B[0m",
      "\u001B[0;31mNameError\u001B[0m                                 Traceback (most recent call last)",
      "Cell \u001B[0;32mIn[8], line 3\u001B[0m\n\u001B[1;32m      1\u001B[0m \u001B[38;5;66;03m# We can create multiple heatmaps for each unique pairs value of 'ISR_class'and 'penalty_anneal_iters'\u001B[39;00m\n\u001B[1;32m      2\u001B[0m \u001B[38;5;28;01mfrom\u001B[39;00m \u001B[38;5;21;01mitertools\u001B[39;00m \u001B[38;5;28;01mimport\u001B[39;00m product\n\u001B[0;32m----> 3\u001B[0m unique_iters \u001B[38;5;241m=\u001B[39m product(\u001B[43mdf\u001B[49m[\u001B[38;5;124m'\u001B[39m\u001B[38;5;124mpenalty_anneal_iters\u001B[39m\u001B[38;5;124m'\u001B[39m]\u001B[38;5;241m.\u001B[39munique(), df[\u001B[38;5;124m'\u001B[39m\u001B[38;5;124mlambda\u001B[39m\u001B[38;5;124m'\u001B[39m]\u001B[38;5;241m.\u001B[39munique())\n\u001B[1;32m      4\u001B[0m \u001B[38;5;66;03m# unique_iters = df['penalty_anneal_iters'].unique()\u001B[39;00m\n\u001B[1;32m      5\u001B[0m \n\u001B[1;32m      6\u001B[0m \u001B[38;5;66;03m# for iters, isr_class in unique_iters:\u001B[39;00m\n\u001B[1;32m      7\u001B[0m \u001B[38;5;28;01mfor\u001B[39;00m iters, isr_class \u001B[38;5;129;01min\u001B[39;00m product(df[\u001B[38;5;124m'\u001B[39m\u001B[38;5;124mpenalty_anneal_iters\u001B[39m\u001B[38;5;124m'\u001B[39m]\u001B[38;5;241m.\u001B[39munique(), [\u001B[38;5;241m2\u001B[39m]):\n",
      "\u001B[0;31mNameError\u001B[0m: name 'df' is not defined"
     ]
    }
   ],
   "execution_count": 8,
   "source": [
    "# We can create multiple heatmaps for each unique pairs value of 'ISR_class'and 'penalty_anneal_iters'\n",
    "from itertools import product\n",
    "unique_iters = product(df['penalty_anneal_iters'].unique(), df['lambda'].unique())\n",
    "# unique_iters = df['penalty_anneal_iters'].unique()\n",
    "\n",
    "# for iters, isr_class in unique_iters:\n",
    "for iters, isr_class in product(df['penalty_anneal_iters'].unique(), [2]):\n",
    "    sub_df = df[df['penalty_anneal_iters'] == iters]\n",
    "    sub_df = sub_df[sub_df['ISR_class'] == isr_class]\n",
    "    pivot_df = sub_df.pivot_table(values='worst_acc_mean', index='lambda', columns='ema', aggfunc='mean')\n",
    "    plt.figure(figsize=(6, 4))\n",
    "    sns.heatmap(pivot_df, annot=True, cmap=white_black_cmap, fmt=\".4f\", vmin=acc_min, vmax=acc_max)\n",
    "    plt.title(f'Heatmap of Worst Accuracy Mean (Penalty Anneal Iters: {iters}), (ISR Class: {isr_class})')\n",
    "    plt.xlabel('ema')\n",
    "    plt.ylabel('lambda')\n",
    "    plt.show()\n"
   ],
   "id": "ae01ecabce4f3ef8"
  },
  {
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2025-02-08T20:24:49.300738Z",
     "start_time": "2025-02-08T20:24:48.818771Z"
    }
   },
   "cell_type": "code",
   "outputs": [],
   "execution_count": 9,
   "source": [
    "# progress_dir = './logs/ISR_training_progress'\n",
    "progress_dir = './logs/ISR_Hessian_for_plotting'\n",
    "dataset = 'CelebA'\n",
    "# dataset = 'CUB'\n",
    "# steps_per_epoch = 10\n",
    "steps_per_epoch = 325\n",
    "seed_list = [0,1,2,3,4]\n",
    "ISR_class = 0\n",
    "grad_alpha = 5000\n",
    "# grad_alpha = 10\n",
    "hess_beta = 100\n",
    "# hess_beta = 1000\n",
    "penalty_anneal_iters = 4000\n",
    "# penalty_anneal_iters = 2100\n",
    "grad_alpha_formatted = \"{:.1e}\".format(grad_alpha).replace('.0e', 'e')\n",
    "hess_beta_formatted = \"{:.1e}\".format(hess_beta).replace('.0e', 'e')\n",
    "dfs = []\n",
    "dfs_val = []\n",
    "for seed in seed_list:\n",
    "    progress_file_dir = f\"ISRclass_{ISR_class}_grad_alpha_{grad_alpha_formatted}_hess_beta_{hess_beta_formatted}_anneal_{penalty_anneal_iters}.0\"\n",
    "    if not os.path.exists(os.path.join(progress_dir, dataset, f's{seed}', progress_file_dir)):\n",
    "        progress_file_dir = f\"ISRclass_{ISR_class}_grad_alpha_{grad_alpha_formatted}_hess_beta_{hess_beta_formatted}_anneal_{penalty_anneal_iters}\"\n",
    "    df_train = pd.read_csv(os.path.join(progress_dir, dataset, f's{seed}', progress_file_dir, 'train.csv'))\n",
    "    df_val = pd.read_csv(os.path.join(progress_dir, dataset, f's{seed}', progress_file_dir, 'train.csv'))\n",
    "    dfs.append(df_train)\n",
    "    dfs_val.append(df_val)\n",
    "    \n",
    "merged_df = pd.concat(dfs, ignore_index=True)\n",
    "merged_df_val = pd.concat(dfs_val, ignore_index=True)\n",
    "#compute the average and standard deviation of the accuracy, loss, and penalties across the runs\n",
    "merged_df['hessian_loss'] = merged_df['hessian_loss'] * hess_beta\n",
    "grouped = merged_df.groupby(['epoch']).agg({\n",
    "    'total_loss': ['mean', 'sem'],\n",
    "    'erm_loss': ['mean', 'sem'],\n",
    "    'grad_loss': ['mean', 'sem'],\n",
    "    'hessian_loss': ['mean', 'sem'],\n",
    "    'avg_acc': ['mean', 'sem'],\n",
    "    'worst_acc': ['mean', 'sem']\n",
    "})\n",
    "grouped_val = merged_df_val.groupby(['epoch']).agg({\n",
    "    'total_loss': ['mean', 'sem'],\n",
    "    'erm_loss': ['mean', 'sem'],\n",
    "    'grad_loss': ['mean', 'sem'],\n",
    "    'hessian_loss': ['mean', 'sem'],\n",
    "    'avg_acc': ['mean', 'sem'],\n",
    "    'worst_acc': ['mean', 'sem']\n",
    "})\n",
    "grouped.columns = ['total_loss_mean', 'total_loss_std', 'erm_loss_mean', 'erm_loss_std', 'grad_loss_mean', 'grad_loss_std', 'hessian_loss_mean', 'hessian_loss_std', 'avg_acc_mean', 'avg_acc_std', 'worst_acc_mean', 'worst_acc_std']\n",
    "\n",
    "grouped_val.columns = ['total_loss_mean', 'total_loss_std', 'erm_loss_mean', 'erm_loss_std', 'grad_loss_mean', 'grad_loss_std', 'hessian_loss_mean', 'hessian_loss_std', 'avg_acc_mean', 'avg_acc_std', 'worst_acc_mean', 'worst_acc_std']\n",
    "\n",
    "# steps_per_epoch = 325\n",
    "# steps_per_epoch = 10\n",
    "epoch_for_step = penalty_anneal_iters/ steps_per_epoch\n",
    "\n",
    "# progress_file_dir = f\"ISRclass_{ISR_class}_grad_alpha_{grad_alpha_formatted}_hess_beta_{hess_beta_formatted}_anneal_{penalty_anneal_iters}.0\"\n",
    "# df8000 = pd.read_csv(os.path.join(progress_dir, dataset, f's{seed}', progress_file_dir, 'train.csv'))"
   ],
   "id": "482a92cfb19865d"
  },
  {
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2025-02-09T19:51:14.260179Z",
     "start_time": "2025-02-09T19:51:13.984382Z"
    }
   },
   "cell_type": "code",
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "import scienceplots\n",
    "from mpl_sizes import get_format\n",
    "\n",
    "# formatter = get_format(\"NeurIPS\") # options: ICLR, ICML, NeurIPS, InfThesis\n",
    "\n",
    "# fig, ax = plt.subplots(figsize=formatter.text_width_plot())\n",
    "# Rescale the gradient loss by a factor of 100\n",
    "grouped['grad_loss_mean'] *= 100\n",
    "grouped['grad_loss_std'] *= 100\n",
    "\n",
    "# plt.style.use('science')\n",
    "\n",
    "# Constants\n",
    "# steps_per_epoch = 325\n",
    "# steps_per_epoch = 10  # Uncomment this line if using a different steps_per_epoch value\n",
    "epoch_for_step = penalty_anneal_iters / steps_per_epoch\n",
    "\n",
    "# Convert epoch to steps for plotting\n",
    "grouped['steps'] = grouped.index * steps_per_epoch\n",
    "# grouped_val['steps'] = grouped_val['epoch'] * steps_per_epoch  # Uncomment if using validation data\n",
    "\n",
    "sns.set_theme()\n",
    "# Create a figure and axis\n",
    "fig, ax1 = plt.subplots(figsize=formatter.text_width_plot())\n",
    "plt.rcParams.update({'grid.alpha': 0.5})\n",
    "\n",
    "# Plot Hessian Loss on the primary y-axis\n",
    "color = 'tab:blue'\n",
    "ax1.set_xlabel('Steps')\n",
    "# ax1.set_ylabel(r'$\\frac{\\beta}{K}\\sum_{i \\in [K]} \\|\\mathbf{H}_{\\mu_i}(\\theta) - \\overline{\\mathbf{H}(\\theta)}\\|^2_F$', color=color)\n",
    "ax1.set_ylabel('Hessian Penalty', color=color)\n",
    "sns.lineplot(data=grouped, x='steps', y='hessian_loss_mean', ax=ax1, label='Hessian Penalty', color=color)\n",
    "# sns.lineplot(data=grouped, x='steps', y='grad_loss_mean', ax=ax1, label='Gradient Penalty', color='tab:orange')\n",
    "plt.fill_between(grouped['steps'], grouped['hessian_loss_mean'] - grouped['hessian_loss_std'], grouped['hessian_loss_mean'] + grouped['hessian_loss_std'], alpha=0.3, color=color)\n",
    "# plt.fill_between(grouped['steps'], grouped['grad_loss_mean'] - grouped['grad_loss_std'], grouped['grad_loss_mean'] + grouped['grad_loss_std'], alpha=0.3, color='tab:orange')\n",
    "ax1.tick_params(axis='y', labelcolor=color)\n",
    "\n",
    "# Add a vertical line at penalty_anneal_iters\n",
    "ax1.axvline(x=penalty_anneal_iters, color='red', linestyle='--', label=f'Penalty Anneal. Iters. ({penalty_anneal_iters})')\n",
    "\n",
    "# Create a secondary y-axis to plot worst-group accuracy\n",
    "ax2 = ax1.twinx()  \n",
    "color = 'tab:green'\n",
    "ax2.set_ylabel('Worst-Group Acc.', color=color)\n",
    "sns.lineplot(data=grouped, x='steps', y='worst_acc_mean', ax=ax2, label='Worst-Group Accuracy', color=color, legend=False)\n",
    "plt.fill_between(grouped['steps'], grouped['worst_acc_mean'] - grouped['worst_acc_std'], grouped['worst_acc_mean'] + grouped['worst_acc_std'], alpha=0.3, color=color)\n",
    "ax2.tick_params(axis='y', labelcolor=color)\n",
    "\n",
    "\n",
    "# Add a title and show the plot\n",
    "plt.title(f'Hessian Penalty and Worst-Group Accuracy ({dataset})', fontsize=14, fontweight='bold')\n",
    "fig.tight_layout()  # Adjust layout to prevent clipping\n",
    "\n",
    "# Manually create legends\n",
    "lines, labels = ax1.get_legend_handles_labels()\n",
    "lines2, labels2 = ax2.get_legend_handles_labels()\n",
    "\n",
    "# Combine the legends and set them\n",
    "ax1.legend(lines + lines2, labels + labels2, loc='center right')\n",
    "# plt.savefig('./logs/ISR_Hessian_for_plotting/fig_hess'\n",
    "#             '_acc.svg',format = 'svg')\n",
    "plt.savefig('./logs/ISR_Hessian_for_plotting/fig_hess_acc_uai.pdf',format = 'pdf')\n",
    "plt.show()\n"
   ],
   "id": "99669c9a252ff192",
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Figure size 550.107x235.76 with 2 Axes>"
      ],
      "image/png": "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nI67ceN6trrOnj0t/G42mzl//pxwnbKyZ88ukpIS+fDD4cyd+7vw89tviwgNrcj69WswmUyUKVPubr1nhGMtFgvPPtuFLVs2UbZseS5cOOfk9tm5czs9e3bGYDAUWO6s/P33BpKTk5kxYw6DBr1KixatSE115IzJVFLKli3vJBPA0qWLePnl/wEgk8no2LELO3duuxtr0QWZTJbneUUeHzKpjNkdZlPWraywzWIresLBQisW6UYLHy07zm97rgCw5vgtmn63je5TdtN+wk4xQdZdYu7OCPFUeYo5LB4Fdjvy8+eQnz8HdjvlvbUA3E4u2TNDnkTq1avP1q2bATvVq9d02tewYSO2bNlEvXoNhJF4uXLlady4KT/++B179uzi2rWrzJ07i927d/LccwNyPY/R6AiS3LhxHbdv3+L48aMcPXqY8PAaAGg0jnt88eIFMjIycq1n5MgvkEqlvPzyANatW821a1e5fv0aa9euYtCg57h58zo1a9bK9fhnnulFeno6o0d/zqVLFzl79jSffz4cDw8P2rRxWBOqV6/JoUMH2L37H27evMHs2TNzdHHMmjWNvXt3ExV1hW+/HY1er6d792ezlVu/fjV+fv5069aD8uUrOP307/8/kpKS2LFjK6VLl6FFi1b89NM4Dh8+xLVrV/n++28wm83UrduAXr36kpyczA8/fEtU1BWOHz/K9OmTqV+/IWq1usByZ8XPLwCDQc+2bZuJjo7m4MH9fPGFIz7FbHYoX88/P5DTp08ya9Z0rl27yr59e5g/fy7NmrUU6unSpTtnzpzi0KGDdO6c/wqbIo+Wjn925HzCeeHv+gH10Soc79jJ2JO0XNqyyHUXelbIdxvOseFUNBEVHf7L8ZvOUTXQjbdbV+THv8/z3YZzTHqudpEFelq4rXfEWHirfPIpKfIwCPVxWCyiU43Y7fYSm/zoSaR27bqYTEYaNmyCQuGsJDdo0JglSxZly1/x1VffMnPmFMaN+5q0tFTKlQvl66/HO/nd76d7956kpqbw22+/cudODK6urrRs2YY33ngXcEwVbdy4KV98MYLXX38rVyXF29uHX39dwF9/LWPlyj+ZPPknTCYzQUFBNG7clF69+gmBmjlRqlQwkyfPZPr0yQwePAiFQkmDBo34/PMxuLq6AtC///+4desmY8Z8jkQioXXrdvTt+3y26aQ9evRm8uSfuHMnhmrVqjNlyi/4+Dj3CQkJ8ezfv5dXXhmczXUC0K5dR375ZRorV/5J+/ad+PTTL5g69We++GIERqORqlWrM2HCVDw9PZFKJUyYMIXp0yfz8ssDcHXV0aZNewYPfqtQcmelVas2nD8/kClTJpKenkZgYBBduz7D7t3/cObMaXr06E3FimF8++2P/PrrDBYtmo+Xlze9e/fjhRdeFuoJDg6hWrXq2Gy2PC1XIo+O9ZfXY7E7LBG30m6x9dpWzieez1buwO0DD2SxkNgLGQra6JutvNe2Is81KM3pW8l0nbybac/XoVP1QDacvM3Ilac48nm7IgtUHNjtduLi0vIvmAdSqQS1WoHBYMZms/Pizv5cT7/GyxVfY0DFlx6SpMXP/e0sNtLT8S0XCEDsldvEoaDTjP1IgI1vNMJLq8z7+Hx4kHaazSbi42/j7R2IQvFgcjxqpFJJ8d7Hx8Tjbuft27fo06c7kybNoE6devkf8JAoyffTbrfTv39PBgwYRLduPYpcT3G2Mb9328dH90CDGpvdxvTj01lxYQUpphRq+9Xms0afUdqtdI7lV11axWd7Psu2fV3PdTke8/2h71lwZgHgcC3m9fl/sdqLfFjvwyK1o9AWi8QME6G+jilH28/dQS6V0KySIwGUu1aBwWzN6/D/BHa7nRi9Y72EEHG59MeCt1aBq0pOqtHC8ZsptKooWopEREoCFouF3bt3cvjwv6Snp9O2bYf8D/qPMvP4TJaeX8qYpmPw1/rz0+GfeGPLG6x8ZiUKWXaX+oXEC9QPqM/45uOdtnuqcl7a4P067/O/Kv/Djp1Of3ZiQqsJVPFyTmoplUhxVbrioih4vpb7KbRiEeyp4Xx0Cg3KebHhVDS1S3uiUzmq2XE+lhBPbZGFeVpINCVisjmW8S6rE01+jwOJREIFHy1Hb6ZwJjpVVCxEREoIcrmciRN/AGDUqDFoNE/WzKjHhdlqZt6ZeQytO5TmwY6p29+3+J42S9uw5doWOpXrlO2Yi4kXCfMMw0dTsP5OIVMQpAsCYGOvjfhqfR9JDGChFYuBjcowZt1ZftsbxeW4dCb1d8RTDFlwmL/PRPNl92oPXcjHgVT6YD55iUSCROL4/47BkfpXp3DFTeX6wHWXJLK2M4dZc48PmRTu5jeQyqQglVAz2J0bKUaSDZaHej8L206pVIJcLkcqlZT4e1/s9/Ex8bjbWapUKfbuPZx/wYdMSb2fq1dvfGh1FWcbC/Ju37p1i4EDB+Zax9atW3Pcfi7hHOnmdBoENBC2uSndqOJdhcMxh3NULC4kXqBd2aKFHgTpglgduRoPlQfNg5tzLuEcw/8ZTnRGNO3LtOezRp+hlBXNlVtoxWJQ03J46VQcuBzPB+0q0bWGQ/uRyyR83aM6zzfM2RdU0lE/YLZGiUSCXC5FrZYQb3G4QTxUHri7uKJWPD2zQrK282Fmais0Mi22jx15E9SuWlAo6FIjCA9XNT4uyod6PwvbTqVSikTihVarRiot2VPq8vOzPi2I7Xx6KM42Psp3OybD8d0IcHFOCOer8eV2+u1s5RMMCcQb4jkcc5hFZxeRbEymuk91Pqj7AWXdy+Z7vnmn5/HT4Z94q9ZbNA9uztj9Y0k2JfNsxWdZdWkVnmpPPqj7QZHaUqS1QrrXDKJ7zSCnbVOeL1xmt0xsNjsTt15kyaFrJOvN1C/rxZhnwinrk79/Z9Wxm7y3+Bi7Pm5FiNeDuWAMBvMDHf//9u48PKrqbuD4986efWFLwlYMEpaETYEAgUBU3BAXVERcirzIK6igVnDp02pp0VrFhYqAUl5bxSpgUdvC+6JUBEUMERBZBETWkH0zyexz3j8mmSQkkG1IMuH3eZ55ZnLvnTvnN3eZX84951xN07BYDNhsLk4UnwIgwhABTj02d/PW3ZZUj7O1T2C2eyoGTXIDbielZXbe3XGCIIOO/h2D6dmMfaI5cTqdDgoLC/B49JhMbXtwtIvhhwgkzvakNWN0OOwUFRWglKHOxpvBwSbi4uLOWStxPpU3ADu7lsCsN1PsKK61/JFCbzdhvabnDyl/oNxZzvLvlnPvxntZN2ldvZdH1h1ex/QB07l/4P2cKT3Dntw9PD3iaab0nUKviF68+d2bLZtYrMs4RXSIifF9O7Mvs5h5f9/NmWIb1yXFsPCmRMyGhmdyr20+zOodx/nTrYPoEm7huQ0H+OWqb/i/R1IxGc5d33WqsJxfr//+nPMbq7mtjHU674h9SinOlHm7mkaZo9Ghb7OttJuiepxtLa6EzqEEG3QcL7Ryz9++ZfmUQfTpXPsOlw3RnDg1TYfL5cJms2EwtPVeIc3f9wOBxNl+tGaMNpsNl8uFpvn/vG4xeAdSdLgdvtcAdre9zhF7h8cOZ9sd24gwV90yon+H/kxYN4GPjnzEjKQZ5/280z+fJqVrCgBbT29F0zRSu3vv49MrvBcFtoImx9LoxOKtrUdZ9O8DPHpVH8b37cxvPtpHkdXJlGHdWZtxiugQM09cW3tkubo4XB7e2voTT1zbl/F9OwPemo8Riz5l476sWrUilTwexSPv7yapawRf/Zjf2BAuuDMV9wmJljEsWpRRr+PNOwYx473dnCyyMfP9PSy9dSADYsNatBw6nZ6goFBKSwsBMJnMbXZcDU2rHMK6fZM424/WiFEphcNhp7S0kKCg0DqHZW+umGDvJZDc8ly6h1fdqyXXmkufqD51vqd6UgEQbAymW2g332WV84myRJFv8/5+fn7yc3qF9/JdhjlUeKjBDULr0ujE4r1vTjArNZ4H0y7ldJGVb08U8rsbE7k7uSfxnUJ5/T9HGpxY7D9TQqndxaj4Dr5pEUFGEuMi+Oan/HMmFq//5wgOt2LuFb3bZmJRMThWF0vdN08SfmC1Enmj966RRR9thIqW5lHBJv5n2hBmvLeHYwXlPLBmD0smJzGoa8veCC483Hu/ksrkoq26GKrOQeJsT1ozxqCgUN+x7W8J0QmEGkNJz073JRYljhIO5B9gat+ptZZ//+D7/Hn3n9l06yZfDUepo5TjJce55dLao7uebVz3cbyS8Qpfn/mabae38fBQ70B0b+97m+V7lnNj7xubHEujE4uThVbGVYxb8Z+DOWjAlf28tQ3xnULIK7U3eF1Zxd5rSnGRNat5uoRbyCyqe2jm3SeLWLH1KB8/mEJWA4dvvuKKK84573//93/R6/V+60WgUORUjGHRM/wXbb5XQGO1mV4hKIy7dwGgQ0G17zky2MTbdw3hv97bzeHcMuas3curkxMZ1qPuvt11aX6cGlFRHYmIiMbtbv32KHXRNA2z2YDd3jbL5y8SZ/vRWjFqmoZeb7ggNRWVTHoTU/tO5eWMl4kyRxEXGsfijMXEhMRwZY8rcXvcFNoLCTWGYjFYSO2eymu7XuOpbU8xe9Bs7G47r3z7ClGWKCbFT6r38+YPm89z6jkysjO4PeF27h1wLwBrD60lpVsKDw15qMmxNDqx6BBiIq/UOz78Zweyie8USmyENzE4mPUzncIa3ljNWjGYlklfc2OZDTqKrI5ay5c7XMz7+y6euLYvvTqGNDixaAh/9SIoowSXcqGhcWl0fLPX29a0mV4h7qrv1WIxwlnfs8Vi5N37hjH9rxnsO/MzD6/dy5Ipg0iJb1j1nn/jbJsNOCtjNJs97faHCCTO9qS9xzhn8BxcysUz25/B5rJxWZfLWHbVMox6I6dLT3PNumtYOHohN/W+iZiQGFZevZKXM17mng33oFCMjBvJX67+S402Guey8dhGZg2cVasXytpJa5t9R+5GJxZX9uvCHzceZNuRPD4/lMuvJiQA3rYXr352mNsu617PGqpYKhp5OtweLNW67thdHoKMtYv2zMf76NUxhGkjejaqzPW10FVK+a1XyLHC4wCEGcMxeMzNXm9b02Z6hdicVPYbstmcoK/9PeuBFVMG8cAH3/FdZglz/r6HF27sT2rv+pOLNhPnBXQxxAgSZ3vS1mMMbuatBPQ6PY9e9iiPXvZorXldQ7uy9969Nab1je7L8quWN+mz/pT+J54Z9UytxKK5SQU0IbH49cR+uD5WfPNTPtNG9OD+sZcAsHrHCcYndOZXV9fdyKQusRWXQLJLbPTsUNW9NLvERr/Y8FrLf7DzFCaDjv6/8Q62Unmb9gkvf8HNQ7uy6Oakxobj469eIZX9jcON4Zg0c7trod1meoVU+2yPR9X4uzqTXscbtw3k4XV7yThVzOPr9zH1sm5MH9Gd8PPUJrWZOC+giyFGkDjbk4shxpYSbYnmZ8fPF2TdjU4szAY9z91S+wf833PHYDE2bsCQfrFhhJkNfH0035dYFFudfJ9ZzD2jflFr+c9/Na7G37tPFjHv/d2smj6M3k3sVuhvlQ03o8xRfsn8RPOZDDr+fGsSj63fx1fHCnln5ynW7cnk7su7cefl3QgxNanXtRBCBKzJl05m0Y5FpGel0zuyNx2COtRapiFtNerS5DPqf37IYdvhPLJLbCy4pi/7MotJ7BpBt0bcK8Rs0HPPqJ48v+Eg0SFmukUFsejfB4iLCOKaATG4PYr8MjvhFiMWo77WoFlnKtpYdI0MomNo2/gRzyr31lhEmqIx6OQHq60w6HW8cksin3yfzZvbj5P1s50V20/w3reZTE/uwe2D4zCfZ9wUIYRoT17c6b1/yyc/flLnfE3TWi6xsDrc3P+3nWw7kkeo2UCZ3cV/p8bzztcn2JdZzPuzRtKnS8PHDXj0qgRcHsUT677D5nQzvFc0b983HJNBx8mCcsa88B/+dOtAbru84W03WtOZ8tMAdLDIGBYXmqdD7Qz7fDRNY1JSDNcP6MwHuzJ5+5uT5Jc7eW3LUd5JP8nMkT25KSkGg14SDCFE+7Zxsv/u33I2TTWyBcyzn+zjH7tOs3TaUIb/IppLf72BTx5MoXO4mXtWfkPPDsEsv/vyC1XeC0IpRV5eabPWodNpWCxGbvrXDWRZz/DffR/k9kvu9FMJ247KOG02Z8Bf43S43Pxt5yneyzhNsc0FQJjZwLhLOzChb2dS+nTC43QHfJzn0p625flInO1HW4+xY8fQNjsY3vlYXVbKnGVEmCP8crfTRtdY/PO7M8y/ui+j4jv6Gk8CdA6z8FDapfzmI/8Nsx1o3MpNri0HgJ5yu/Q2z2TQMyO5J3de1o2VX59g3Z5Mfra7+OT7bD75PpsQk54x8R24sk9HRvSManQbIiGEaMsysjNYnLGYfXn7UHh/zxM7JjJ3yFyGxw6v593n1ujEosTqpFtU7XHLwTtqZpnD1eTCBLpcay5u5Uan6ega0rW1iyMaKMio58Exvfiv5B5s+iGXTT/ksjezhFKHm40Hcth4IAeLQceoXtGkXBJN8i+i6NRG2vQIIURT7M7Zzcz/m0m3sG7MGjiLDkEdyLXmsvGnjcz6dBarrl7F4M6Dm7TuRicWCTFhrN99mrEVo29W9+mBbBIa0b6ivcks87avCDeGE2yo/+6sohmsViKmTgag+L11viG9m8Ni1HNDYgw3JMbgcHvYfqKIj/Zksud0CSU2F5sP57H5cB4AvaKDGdUripG9ohncNUIafgohAsqSXUsY2mUoy69cjr7aOFIPDHqAWZtmsXT3UlZMWNGkdTc6sXhwfG9mvZNBUbmTK/p1RgO+PprPmp0neXfHCV6bOqRJBWkPqsawiMCsq3/kM9EMHg+mr7b5Xvubxajn2gExjI/vgN3pZvtPBWw4kMOB7FJOF9v4qaCcnwrKeTfjNCa9jiHdwhnWI4p+XULp2yX0vGNkCCFEa9ubt5cXxr5QI6kA0Gk67ux7J09ve7rJ6250YjFhQAyvTBnMHzcc5D8/eNsT/OHfB+gQYuYPNydyXVJskwsT6CrvahppkjEs2hOjXsfY3h0Z27sjSilOFlrZdCiPnScK+SGnlJ/tbnYcL2LH8SLfe+IiLAyICaN/TBj9uoSS0DmUULN0PxZCtA0hxhBcnrqbLjg9Tl+bi6Zo0pnuxsFduXFwV37MLaWo3EG4xUh8p9B2d8OtxsosqxwcS8awaK80TaNHdDAzknswI7kHTpebjFPFfHYojx/zyjhVZKPQ6iSz2EZmsY1NP+T63hsVZKRrpIXukUF0jwqiW6SFbhFBdI8MIiLIEJCtyYUQgWlI5yG8ufdNRsWNIthYNf5UmbOMt/a+xdAuQ5u87mb9+sV3ahujXbYVlW0sOphlDIuLhdGgJ/kX0ST/wnsrZZfbw+liK+knitmbWcLxQiuniqwU21wUWp0UWp18f6b2MLpBRh2x4RbiIix0jfA+V/4dG24mzCyJhxDCf+YNnceUf07h2g+vZWy3sXQM6kieNY8vTn2B3W1n4eiFTV53gxKLqSu+bvAKNQ1Wz0xucoECWWViERcsPUIuVga9jp7RIfSMDuHWwXEAON0ezpTY+CGnlKN55WQW28gptZNX5qCg3EmJzYXV6eFofjlH88vrXK/FoKNTqJkuYSa6hFvoEmqiS5iZzmFmooJNRFgMRAYZCTHpJQERQtSrR3gP3rnuHd7Y8wZbT22l2FFMhCmCYTHDeGDQA8RHxjd53Q1KLDxKUf1cpRR8c6yAxLgIQsw1G360wRvOtQiXx0We1dtjoEdY4+6+Kto3o15Hj6hgekQFQ0LVdKUUdpeHEquLHwvKOJZfzolCK3llDvIrko4iq5Myhxuby8PJIisni6xA8Tk/S6dBuMVAuMXoTTaCjUQFGYms4xEdYiImSsNwsR60Qlxk1hxaw6i4UXQN9f7zGx8Zz4upL/r9cxqUWLw/a2SNv11uD5f+egPP3ZJEYtcIvxcqEOVYs/HgQa8ZiAuSGouWoIIbfl+atkjTNCxGPRajns7hZkZWXE6p5KlIPIrKHRwvtHGqqJzTxTYKypy+pKPY5qTc4abc6cbpVngUFFldFFkbPp6MXqcRYTEQEeRNQqKCvYlHhMVAkFFPsElPkLHiYdITbNQTZNQRajb4HoaLvH2VEIFg4faFaJpG97DujIwdyeiuoxkeM7xGGwt/aFIbC6lqrS3LWnW7dIuh+WMqiHqEhJB3LKu1S3FB6TTN+2MeEURsRBAQVWsZt0fhcHtwuRWldhc5pXbyy5zkl9nJL3dSbHVS5nBRYnNT5nBRavcmIeUOF2UObzLi9igKyr3Jyk9NLGv1RCO84tmblOiqkpKKxCTI4J1mqUhQKudZznqtk/OMEH714aQP2Zm9k2+zv2Xzyc28/8P7GHQGkjomMSpuFKPiRpHYMbHZv/HSdcFPKruaRpgiMOukq6loGXqdRpBOD0YIsxiIjah//BSXR+Fye3ArcKA4kVdOdomtos2Hg2Kri5/tLsrsbhxuD3aXG4db4XB5cLgrHi4PdpcHh9t7GcXq9GB1OsgtdfgtNrNB50s8LBUJR3BF0mE26DDpdZgMOizVXpv0Oox6zfdsrJgeEmQEtweTXlcjoal8bTHo0Uuti2jnekf1pndUb+7oewcAJ0tOsjN7Jzuzd7L+yHpe3/064eZwRsSMYHTX0dxy6S1N+hxJLPykssYi0hSFRcawEG2YQadh0Ol9N3TqYDHi8YTX+z6P8tZuuD3eSy5uj8Lq9PZ2KSjz9ngptjp9iYnD7cHmdGOvSELs7opkxOXB6fbWtDjd3uTEWZGwON1V7T0q39eYyzrNUZmQmA1ViYvZqMOs12E26DHqNfQ6DYPO+6zXKp4rphmrJTXVExujXodJXzXfoNdh1HmXM+i97zXodRg0Db1e8z7rNAx672dUX49Rr0lNjvCb7uHd6R7enZsvvRmAb858wweHPmDzic18euJTSSxam17zfpVxIV3RyxgWF57NRvh9dwFQ8pd3wCIjnV5oOk1Dp9eofi+2MIuBzmGN/+6VUrgrkpPqCYvL46HM7uZnh4tSm9tbc1Jx2abM4b2E43ApnB5vEuKsSE5cbuVNUDweXJ7q66tKhCqXrZ7UON1VwwB51+f9nLbMcFYio9M09Drv9jHodWh4G/F6Ex5dxbJVtTgGnc6XJNX3OZXrqJ5Qneu5eqJVOf1cy+q0yge+Z03zrkPTvHcx1VdM1+u80/SahtGgI9itcDtd6Ki5TtF4WWVZfHn6S74+8zXpWekU2gsJN4WT1iON0XGjm7xe+QX0k2m978FkNBJjimvtolwc3G7Mn/6f77UILJqmYdCos9FnBz/fZkfTwGQ2Um514HYr3Er5EhqX20O508PPdieldrf3ko7Dhc3lwerwYHO5sbm8tS5Ot0Kpqpob7zO4lfd1ZYLj8lQ9nG6PN8nxJU9Ue6188yrX5al47al47Z1XM57Kddtc/h/KPlBpUCO5UHiTV6jZU9Gb1FCRjFUlZWaDjjkpvbi2f5eWLXgLc7qdpGen8+XpL/kq8yuOFh9Fp+kY2HEgU/tObdk2Fil/3Exdn/Nfb+/EaKg5Q0Pji/njm1WoQGTUGekd3huXS37khGhLtIofEaNeh16r3bXW2xenZRpcq4pEwfeMN4FQChQVzxXJiwJQ4PRUtWmxVl5acnuwO93Y3R5cHm/NjwI0nYbN4fa2oamoAXK4qpIcV40k5/zdjL1JD3g8nqoEyqNw1UqCqhIgT+V7qiVI7hrL1R1v5WtPjddnP1f7Xs7+XvEmXPWpWqb2sl/8mN/uE4vRfx+N3W2nW2g3RsaN5MEhD5Icm0yI0b/ZfIMSixG9OtRKLEb08ms52oUhnYbidMh/EUKIunmr+8H7P7Z/VbaZsdmceBrwI3uhqYokQKmarz3VqhB8P/MVCUXl6+rTVEUChgJNBwaTgdIyOzaXt4bI7vL4ekcpVfXNarrK195aCqWqaotcFUmX26Nwub1vGnIRDJ1gc9mINEcyInYEw2OGMyxmmN+TCmhgYvHS7YP8/sHtUZgpDJunbRzUQgjRmjRNoyqH8k8iVZk8hRl0cp5tgjU3rGHb6W18lfkVHx35CI/yMKDjAEbHjWZU11EM7DjQL8NJSBsLIYQQ4iKQEJ1AQnQCM5JmUO4sZ8eZHXyZ+SWfHP2EN/a8QZgpjOTYZEZ3Hc2ouFHEhMQ06XMksRBCCCEuMsHGYMb3GM/4Ht42kSdKTrA9czs7snawaMciXB4Xu+/Z3aR1a0qpi74+Sb6CwKS5vOMbKIPkx0KItiHQRqbOt+azO3c3u3N2813udxwoOIDL42Jgp4H8zzX/06R1SmIhhBBCXCSOFh1lV84uduXsYnfubk7+fBKASyMvJTk2mRGxI7g85nKCmnFrCkkshBBCiIvA6PdGU+osRSlFXGgcybHJJMcmMzx2ONGW6PpX0EBShyyEEEJcBEbEjmBk3EiSY5PpHtb9gn2O1FgIIYQQwm90rV0AIYQQQrQfklgIIYQQwm8ksRBCCCGE30hiIYQQQgi/kcRCCCGEEH4jiYUQQggh/EYSCyGEEEL4jSQWQgghhPAbSSyEEEII4TeSWAghhBDCbySx8AOPx8Nrr73GmDFjGDRoEPfddx/Hjx9v7WKdV1FREb/5zW8YO3YsQ4cOZerUqezcudM3/8knnyQhIaHGY+zYsb75DYn5wIED3HXXXQwePJhx48axcuXKFosP4PTp07ViSEhIYM2aNQ0qXyDEuGPHjjpjTEhI4IorrgACf1suXbqUu+++u1Hl8UdMLX1c1xXn5s2bmTx5MkOGDCEtLY0//vGP2Gw23/z69vFAibMl9tFAPE8HLCWabcmSJWrkyJHq888/VwcOHFD33Xefuuqqq5Tdbm/top3T9OnT1aRJk1R6err68ccf1cKFC9XAgQPVkSNHlFJK3XzzzWrx4sUqJyfH98jPz/e9v76YCwoK1IgRI9TTTz+tjhw5otauXauSkpLU2rVrWyzGzz77TCUlJans7OwacVit1gaVLxBitNvtNWLLyclR27ZtU/3791cffPCBUiqwt+WqVatUQkKCuuuuu3zTWmrbteRxXVec6enpql+/fmr58uXq2LFjasuWLSo1NVU98cQTvmXOt48HSpxKtcw+Gojn6UAliUUz2e12NWTIELV69WrftOLiYjVw4ED1z3/+sxVLdm7Hjh1Tffr0URkZGb5pHo9HXXXVVeqVV15RLpdLJSUlqU2bNtX5/obEvGzZMjVmzBjldDp9y7z00kvq6quvvkBR1fbGG2+oSZMm1TmvvvIFSoxnczgc6vrrr1fz5s1TSqmA3ZZZWVlqxowZavDgweqaa66p8UPUEtuupY7r88X52GOPqenTp9dYfv369ap///6+H8Pz7eNKBUacLbGPBuJ5OpDJpZBmOnjwIGVlZSQnJ/umhYeH079/f9LT01uxZOcWFRXFihUrSExM9E3TNA2lFMXFxRw7dgy73U58fHyd729IzDt37mTYsGEYDAbfMsnJyfz000/k5+dfoMhq+uGHH+jdu3ed8+orX6DEeLZ3332XM2fO8OSTTwIE7Lbct28fERERfPzxxwwaNKjGvJbYdi11XJ8vzvvuu4/58+fXeo/L5aK0tBQ4/z4OgRFnS+yjgXieDmSG+hcR55OVlQVAbGxsjemdO3fmzJkzrVGkeoWHh5Oamlpj2oYNGzhx4gQpKSkcOnQITdN4++23+eKLL9DpdKSmpjJv3jzCwsIaFHNWVhZ9+vSpNR8gMzOTDh06XKjwfA4dOkSnTp248847OXbsGD179mT27NmMGTOm3vIFSozV2e12li1bxr333usrR6Buy7S0NNLS0uqc1xLbrqWO6/PF2b9//xp/OxwOVq1axYABA4iOjgbOv49DYMTZEvtoIJ6nA5nUWDST1WoFwGQy1ZhuNpux2+2tUaRGy8jI4KmnnuKKK64gLS2Nw4cPo9Pp6Nq1K8uWLWPBggVs2bKF2bNn4/F4GhSzzWarcz7QIt+Lw+Hg2LFjlJaWMm/ePFasWEFSUhIzZ85k+/bt9ZYvEGI820cffYTdbq/RMK49bMuztcS2a2vHtcvlYv78+Rw5coTf/va3QP37OARGnC2xj7aFOC8mUmPRTBaLBfAe5JWvwbszBwUFtVaxGuzTTz/lV7/6FYMGDWLx4sUAPPTQQ/zyl78kPDwcgD59+tCpUyemTJnC3r17GxSzxWLB4XDU+KzKAzg4OPiCx2UymUhPT8dgMPhOJomJifz444+sXLmy3vIFQoxnW79+PRMmTCAqKso3rT1sy7O1xLZrS8d1ZeKwY8cOXnvtNd+lhPr28ZEjRwZEnC2xj7aFOC8mUmPRTJVVazk5OTWm5+TkEBMT0xpFarB33nmHhx56iLFjx/Lmm2/6DjhN03wHeaXKasasrKwGxRwTE1PnfIAuXbr4P5g6BAcH1/oPpU+fPmRnZ9dbvkCJsVJBQQG7du3iuuuuqzG9vWzL6lpi27WV4zonJ4dp06axa9cu3nzzzVqXE863j0NgxNkS+2hbiPNiIolFM/Xt25fQ0FB27Njhm1ZSUsL+/fu5/PLLW7Fk57d69WoWLlzItGnTeOWVV2qcnB577DFmzJhRY/m9e/cC0Lt37wbFPGzYMDIyMnC73b5ltm/fTq9evVqk7cHBgwcZMmRIjbE5AL7//nt69+5db/kCIcbqvv32WzRNY/jw4TWmt4dtebaW2HZt4bguLi7m3nvvpaCggNWrV9doeAj17+MQGHG2xD7aFuK8qLR2t5T2YPHixWr48OHq008/9fWPnjBhQpvtH3306FE1YMAANWfOnFpjIJSUlKjNmzerhIQEtXTpUnX8+HH1+eefq7S0NPXoo4/61lFfzHl5eWrYsGFqwYIF6vDhw2rdunUqKSlJffjhhy0So9vtVrfddpuaOHGiSk9PV0eOHFGLFi1SiYmJ6uDBgw0qX1uPsbolS5aoCRMm1JreHrblggULanRPbKlt19LH9dlxLliwQA0YMEBt37691nHqcrnq3ccDJc6W2kcD7TwdyCSx8AOXy6VeeOEFlZycrAYPHqxmzpypTp482drFOqc33nhD9enTp87HggULlFJKbdy4Ud10001q4MCBavTo0er5559XNpvNt46GxLxnzx51++23q8TERDV+/Hj1t7/9rUXjzM/PV08++aQaPXq0SkpKUlOmTFHp6ekNLl8gxFjpt7/9rbr99tvrnBfo2/LsH6KGlMcfMbX0cV09TrfbrZKSks55nFaWo759vK3HWakl9tFAO08HMk0ppVq71kQIIYQQ7YO0sRBCCCGE30hiIYQQQgi/kcRCCCGEEH4jiYUQQggh/EYSCyGEEEL4jSQWQgghhPAbSSyEEEII4TeSWAghAJAhbYQQ/iCJhRDt3KFDh3jkkUcYPXo0iYmJpKSkMG/ePPbv3+9bJiMjg1mzZrViKYUQ7YUkFkK0Y4cPH2bKlCkUFBTw9NNP85e//IX58+eTmZnJlClT2L17NwBr1qzhyJEjrVtYIUS7YGjtAgghLpxVq1YRGRnJW2+9hdFo9E2/8sorufbaa1m6dCkrVqxoxRIKIdobSSyEaMfy8vKA2u0ngoODefLJJ7FarTzxxBP84x//ACAhIYHnnnuOW265Bbvdzquvvsq//vUv8vPz6dWrFw888ADXXXedbz1paWnccMMN2Gw23zpSU1N56qmniIqKAqCgoIBFixaxfft2SkpKuOSSS5g+fTo33XRTC3wDQoiWJomFEO3YuHHj2LJlC3fccQeTJ08mOTmZSy65BE3TuOaaawC47LLLKCgoYP/+/fz5z3+mR48eKKWYM2cO3377LQ8//DDx8fFs2rSJRx55BIfDUSMpWL16NT179mTRokUUFBTw0ksvcfToUdasWYNOp+Pxxx8nPz+fZ599lpCQED7++GMWLFhAbGwsI0aMaKVvRghxoUhiIUQ7duedd5Kbm8vKlSv53e9+B0BUVBQpKSncfffdDBo0iB49ehAdHY3JZGLw4MEAfPnll2zdupWXX37ZV0MxZswYrFYrL774IhMnTsRg8J4+NE1j1apVhIWFARAdHc2cOXP44osvGDduHN988w2zZ8/myiuvBGDEiBFERkai1+tb+NsQQrQEabwpRDs3d+5ctm7dyksvvcStt95KaGgon3zyCVOmTOHtt9+u8z3bt29H0zRSU1NxuVy+R1paGrm5uRw+fNi37Pjx431JBXgvjxiNRnbu3Al4E4klS5Ywd+5cPvzwQwoKCliwYAGXX375hQ1cCNEqpMZCiItAREQEEydOZOLEiQDs37+f+fPn8+KLLzJp0qRayxcVFaGUYujQoXWuLycnh379+gHQuXPnGvN0Oh2RkZGUlJQA8PLLL7Ns2TI2bNjAxo0b0el0jBo1imeeeYbu3bv7M0whRBsgiYUQ7VR2djaTJ09m7ty53HbbbTXm9e/fn3nz5jFnzhxOnjxZ671hYWEEBwfz17/+tc519+zZ0/e6qKioxjy3201hYSHR0dG+dT3++OM8/vjjHD16lM8++4ylS5fy7LPP8tZbbzUzSiFEWyOXQoRopzp27IjBYGD16tXY7fZa848ePYrZbKZnz57odDVPBcOHD6e8vBylFElJSb7H4cOHef3113G5XL5lt27disPh8P392Wef4XK5GDlyJKdPnyY1NZWNGzcCcMkllzBz5kxGjRpFVlbWBYpcCNGapMZCiHZKr9fzzDPPMGfOHCZPnsy0adOIj4/HarXy5Zdf8u677zJ37lwiIiIIDw8nLy+PLVu20K9fP1JTUxk2bBizZ89m9uzZxMfH891337FkyRJSUlJ8tREAWVlZPPDAA9xzzz2cOXOGxYsXk5KS4uvxERMTw+9//3tKS0vp0aMH33//PVu2bJGRPoVopzQlNwgQol3bt28fK1euJCMjg4KCAkwmE/379+fuu+9mwoQJgHfY77lz53Ly5Ekefvhh7r//fsrLy3n11VfZuHEj+fn5dOnSheuvv545c+ZgNpsBb0PNIUOGEB4ezvr16wkODmbixIk88sgjWCwWAHJzc1m8eDHbtm2jsLCQ2NhYJk+ezP3331+rpkQIEfgksRBCNFlaWhrDhw/n+eefb+2iCCHaCPl3QQghhBB+I4mFEEIIIfxGLoUIIYQQwm+kxkIIIYQQfiOJhRBCCCH8RhILIYQQQviNJBZCCCGE8BtJLIQQQgjhN5JYCCGEEMJvJLEQQgghhN9IYiGEEEIIv/l/3ia9Or5qooUAAAAASUVORK5CYII="
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "execution_count": 47
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-02-08T20:26:14.724295Z",
     "start_time": "2025-02-08T20:26:11.884433Z"
    }
   },
   "cell_type": "code",
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "import scienceplots\n",
    "from mpl_sizes import get_format\n",
    "\n",
    "formatter = get_format(\"NeurIPS\") # options: ICLR, ICML, NeurIPS, InfThesis\n",
    "\n",
    "# fig, ax = plt.subplots(figsize=formatter.text_width_plot())\n",
    "# Rescale the gradient loss by a factor of 100\n",
    "\n",
    "# plt.style.use('science')\n",
    "\n",
    "# Constants\n",
    "# steps_per_epoch = 325\n",
    "# steps_per_epoch = 10  # Uncomment this line if using a different steps_per_epoch value\n",
    "epoch_for_step = penalty_anneal_iters / steps_per_epoch\n",
    "\n",
    "# Convert epoch to steps for plotting\n",
    "grouped['steps'] = grouped.index * steps_per_epoch\n",
    "# grouped_val['steps'] = grouped_val['epoch'] * steps_per_epoch  # Uncomment if using validation data\n",
    "\n",
    "# Create a figure and axis\n",
    "fig, ax1 = plt.subplots(figsize=formatter.text_width_plot())\n",
    "plt.rcParams.update({'grid.alpha': 0.5})\n",
    "\n",
    "# Plot Hessian Loss on the primary y-axis\n",
    "color = 'tab:blue'\n",
    "ax1.set_xlabel('Steps')\n",
    "# ax1.set_ylabel(r'$\\frac{\\beta}{K}\\sum_{i \\in [K]} \\|\\mathbf{H}_{\\mu_i}(\\theta) - \\overline{\\mathbf{H}(\\theta)}\\|^2_F$', color=color)\n",
    "ax1.set_ylabel('Hessian Penalty', color=color)\n",
    "sns.lineplot(data=grouped, x='steps', y='grad_loss_mean', ax=ax1, label='Gradient Penalty', color='tab:orange')\n",
    "plt.fill_between(grouped['steps'], grouped['grad_loss_mean'] - grouped['grad_loss_std'], grouped['grad_loss_mean'] + grouped['grad_loss_std'], alpha=0.3, color='tab:orange')\n",
    "ax1.tick_params(axis='y', labelcolor=color)\n",
    "\n",
    "# Add a vertical line at penalty_anneal_iters\n",
    "ax1.axvline(x=penalty_anneal_iters, color='red', linestyle='--', label=f'Penalty Anneal. Iters. ({penalty_anneal_iters})')\n",
    "\n",
    "# Create a secondary y-axis to plot worst-group accuracy\n",
    "ax2 = ax1.twinx()  \n",
    "color = 'tab:green'\n",
    "ax2.set_ylabel('Worst-Group Accuracy', color=color)\n",
    "sns.lineplot(data=grouped, x='steps', y='worst_acc_mean', ax=ax2, label='Worst-Group Accuracy', color=color, legend=False)\n",
    "plt.fill_between(grouped['steps'], grouped['worst_acc_mean'] - grouped['worst_acc_std'], grouped['worst_acc_mean'] + grouped['worst_acc_std'], alpha=0.3, color=color)\n",
    "ax2.tick_params(axis='y', labelcolor=color)\n",
    "\n",
    "\n",
    "# Add a title and show the plot\n",
    "plt.title(f'Gradient Penalty and Worst-Group Accuracy for {dataset}')\n",
    "fig.tight_layout()  # Adjust layout to prevent clipping\n",
    "\n",
    "# Manually create legends\n",
    "lines, labels = ax1.get_legend_handles_labels()\n",
    "lines2, labels2 = ax2.get_legend_handles_labels()\n",
    "\n",
    "# Combine the legends and set them\n",
    "ax1.legend(lines + lines2, labels + labels2, loc='center right')\n",
    "plt.savefig('./logs/ISR_Hessian_for_plotting/fig_grad'\n",
    "            '_acc.svg',format = 'svg')\n",
    "plt.savefig('./logs/ISR_Hessian_for_plotting/fig_grad'\n",
    "            '_acc.pdf',format = 'pdf')\n",
    "plt.show()\n"
   ],
   "id": "faacf904673fc409",
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Figure size 550.107x235.76 with 2 Axes>"
      ],
      "image/png": "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"
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "execution_count": 19
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-02-09T03:19:14.454120Z",
     "start_time": "2025-02-09T03:19:13.930035Z"
    }
   },
   "cell_type": "code",
   "source": [
    "# import matplotlib.pyplot as plt\n",
    "# import seaborn as sns\n",
    "# plt.rcParams['text.usetex'] = False\n",
    "# import scienceplots\n",
    "# from mpl_sizes import get_format\n",
    "\n",
    "# formatter = get_format(\"NeurIPS\") # options: ICLR, ICML, NeurIPS, InfThesis\n",
    "sns.set_theme()\n",
    "fig, ax = plt.subplots(figsize=(5.50107, 2.3576014285714284))\n",
    "# fig, ax = plt.subplots(figsize=(7, 3))\n",
    "# print(formatter.text_width_plot())\n",
    "# Rescale the gradient loss by a factor of 100\n",
    "grouped['grad_loss_mean'] *= 100\n",
    "grouped['grad_loss_std'] *= 100\n",
    "\n",
    "# plt.style.use('science')\n",
    "\n",
    "# Constants\n",
    "# steps_per_epoch = 325\n",
    "# steps_per_epoch = 10  # Uncomment this line if using a different steps_per_epoch value\n",
    "epoch_for_step = penalty_anneal_iters / steps_per_epoch\n",
    "\n",
    "# Convert epoch to steps for plotting\n",
    "grouped['steps'] = grouped.index * steps_per_epoch\n",
    "# grouped_val['steps'] = grouped_val['epoch'] * steps_per_epoch  # Uncomment if using validation data\n",
    "\n",
    "# Create a figure and axis\n",
    "fig, ax1 = plt.subplots(figsize=(5.50107, 2.3576014285714284))\n",
    "# fig, ax1 = plt.subplots(figsize=(7, 3))\n",
    "plt.rcParams.update({'grid.alpha': 0.5})\n",
    "\n",
    "\n",
    "# Plot Hessian Loss on the primary y-axis\n",
    "color = 'tab:blue'\n",
    "ax1.set_xlabel('Steps', fontsize=12, fontweight='bold')\n",
    "# ax1.set_ylabel(r'$\\frac{\\beta}{K}\\sum_{i \\in [K]} \\|\\mathbf{H}_{\\mu_i}(\\theta) - \\overline{\\mathbf{H}(\\theta)}\\|^2_F$', color=color)\n",
    "ax1.set_ylabel('Hessian Penalty', color=color, fontsize=12, fontweight='bold')\n",
    "sns.lineplot(data=grouped, x='steps', y='hessian_loss_mean', ax=ax1, label='Hessian Penalty', color=color)\n",
    "plt.fill_between(grouped['steps'], grouped['hessian_loss_mean'] - grouped['hessian_loss_std'], grouped['hessian_loss_mean'] + grouped['hessian_loss_std'], alpha=0.3, color=color)\n",
    "\n",
    "ax1.tick_params(axis='y', labelcolor=color)\n",
    "\n",
    "# Add a vertical line at penalty_anneal_iters\n",
    "ax1.axvline(x=penalty_anneal_iters, color='red', linestyle='--', label=f'Penalty Anneal. Iters. ({penalty_anneal_iters})')\n",
    "\n",
    "# Create a secondary y-axis to plot worst-group accuracy\n",
    "ax2 = ax1.twinx()  \n",
    "color = 'tab:green'\n",
    "ax2.set_ylabel('Worst-Group Accuracy', color=color, fontsize=12, fontweight='bold')\n",
    "sns.lineplot(data=grouped, x='steps', y='worst_acc_mean', ax=ax2, label='Worst-Group Accuracy', color=color, legend=False)\n",
    "plt.fill_between(grouped['steps'], grouped['worst_acc_mean'] - grouped['worst_acc_std'], grouped['worst_acc_mean'] + grouped['worst_acc_std'], alpha=0.3, color=color)\n",
    "ax2.tick_params(axis='y', labelcolor=color)\n",
    "\n",
    "\n",
    "# Add a title and show the plot\n",
    "plt.title(f'Hessian Penalty and Worst-Group Accuracy for {dataset}', fontsize=14, fontweight='bold')\n",
    "fig.tight_layout()  # Adjust layout to prevent clipping\n",
    "\n",
    "# Manually create legends\n",
    "lines, labels = ax1.get_legend_handles_labels()\n",
    "lines2, labels2 = ax2.get_legend_handles_labels()\n",
    "\n",
    "# Combine the legends and set them\n",
    "ax1.legend(lines + lines2, labels + labels2, loc='center right')\n",
    "# plt.savefig('./logs/ISR_Hessian_for_plotting/fig_hess'\n",
    "#             '_acc.svg',format = 'svg')\n",
    "plt.savefig('./logs/ISR_Hessian_for_plotting/fig_hess'\n",
    "            '_acc_uai.pdf',format = 'pdf')\n",
    "plt.show()\n"
   ],
   "id": "4dfc56bce7ef08b7",
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Figure size 550.107x235.76 with 1 Axes>"
      ],
      "image/png": "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"
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "text/plain": [
       "<Figure size 550.107x235.76 with 2 Axes>"
      ],
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAhYAAADbCAYAAAAxrtiQAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8pXeV/AAAACXBIWXMAAA9hAAAPYQGoP6dpAACvT0lEQVR4nOydZXgUVxeA31nfjbuQ4BAkOAQLpbhTKFCoUKEC9ZYalJaPlkILFSoUKQWKu7tDcYfgEjQQd1nf/X5sMmSJkIRAgO7Lsw+bmTt3zp3ZmXvuOeeeK1itVisOHDhw4MCBAwelgKSsBXDgwIEDBw4cPDk4FAsHDhw4cODAQanhUCwcOHDgwIEDB6WGQ7Fw4MCBAwcOHJQaDsXCgQMHDhw4cFBqOBQLBw4cOHDgwEGp4VAsHDhw4MCBg/8Y4w+P50LShQdSt+DIY+HAgQMHDhz8t6g7qy6CIFDNvRrPVH2GrpW64qX2KpW6HYqFAwcOHDhw8B/jxXUvcjrxNFarFUEQkAgSwgPD6VGlB22C2yCXyktcd4lcIcOGDSMkJISQkBBiYmLy7D948KC4f9KkSSUW7kGQI9err75aZjIsX75clCPnU6NGDUJDQ2nevDmDBg3i8OHDZSZfYbRt25aQkBA6dOiQZ19mZiZRUVFlIFXpsmrVKvG+LF++vMByPXr0ICQkhJo1a5KRkWG3b/z48WIdtWrVIj093W7/iBEjxP2nTp16IO0oDgaDgatXrxb7uBs3bvDDDz/QrVs3GjduTGhoKOHh4QwZMoQtW7Y8AEkfLfbs2SPex9q1axMbG1vWIj2RGAwGxo4dS3h4OKGhoTz99NOsWbPmocqg1WqZPn06/fv3p0mTJoSGhtKmTRs+/fTT+36GC3uvFoV79cn5Ma/bPDb12cTQRkORzpWS9V0Wm9/ZzEfDP6LNkjZ8d+A7TsafLJE8jhiLRwSr1YrRaCQpKYm9e/fy2muv8e+//5a1WEXCZDKxYMECOnbsyKFDh8panIdG48aNAbBYLERERNjt279/v/jdbDZz5MgRu/0nT9oeWI1GQ61atR6wpIWzfv16unbtytq1a4t13JIlS3jmmWeYOXMmly9fJj09HaPRSHx8PDt27OC9995j6NChWCyWByR52bN06VLxu8lkYtmyZWUozZPL9OnTmTVrFvHx8RiNRqKjo5HLSz6iLi6RkZH06NGD8ePHc+LECdLS0jAajdy+fZs1a9bw3HPPMWfOnIcmT2nh7+RPK3UrMq9nitvMZ8ykZaSx5OISXt7wMq9tfI0kXVKx6v3PKRa7du1i165d/PLLL2UtCgBfffUVu3btYseOHaxatYr+/fsDYDQaGTt27GPxUl6/fj2jRo0iISGhrEV5qOQoFgAnTpwQvycnJ3Pu3Dm7srkVroyMDCIjIwFo2LAhUqn0wQpaCEePHuXjjz/m5s2bxTpu69atfP3112RlZeHh4cGXX37JmjVrWLt2LSNGjMDFxQWAdevWMX369AchepmTnJzMtm3b7LYtXbr0sXhmHzdyP19//fUXa9euJTw8/KGcOzU1lTfffJObN28ilUoZPHgwq1atYs2aNXz88cfI5XIsFgtjx47l+PHjD0Wm0mTGvBn2G/RgPmvGSeaE1WrlWNwxxhwYU6w6ZaUo32OBv79/WYtgh6urqyhTYGAg3377LcePH+fixYtcvXqV6OhoypUrV8ZSFs5/NUwnt2KRY4EAm7Ui55o4OzuTkZHBwYMHxf2nTp0SO5/cdZQFJbl3er2eESNGYLVacXZ2ZuHChVSsWFHcX61aNapVqya6G2fNmsUbb7yBIAilJPWjwerVqzEYDABUrFiRa9eucevWLfbs2cNTTz1VxtI9WWRlZQEgkUho3br1Qz339OnTuXXrFmBzObz88svivurVq+Pq6so333yDxWJhxYoVNGjQ4KHKV1Jmnp7J+svriViZbW11B1IBK1S8WpG1P69lxeUVjNo3ikMxxbNEP3SLRWRkJB999BFNmzalTp06dOnShcmTJ4sPaA6pqal8//33dOjQgTp16hAaGkq7du0YPXo0qampdmVjYmIYMWIEbdq0ITQ0lLp169KlSxcmTJiQp96CYiyOHj3KkCFDaNWqFaGhoYSFhfH888+zcuVKu3I5vqymTZuSnp7O6NGjCQ8Pp27dujz33HPs2bPnvq9R1apVxe/x8fHi99jYWEaMGCH6Gdu3b8+4cePy+O9LIuPKlSsZMGAATZs2JTQ0lBYtWjBkyBC7kUJ+/PHHH3z++efi38OHDyckJIR9+/YRHh5OSEgIbdq0ydOBvfvuu4SEhBAaGkpSUuFmtp07d/LKK6/QokULQkNDadq0Ka+99hq7du2yKzdw4EBCQkJ49tlniY2N5bPPPqNp06bUq1ePV155JV8/6Jo1a+jVqxd16tTh6aef5s8//yzyiNPPz4+goCAgr2IBNqWxb9++AJw/f168T7mvaW7FwmAwMH36dHr37k2DBg1o0KAB/fv3Z+nSpXmuX45P9oMPPuCvv/4iLCyM+vXr8+effwJw/PhxhgwZQvPmzalVqxYNGzakX79+dqb65cuX8+KLL4p/T5w48Z5xJQCbN28mJSUFgJdeeslOqcihefPmDBs2jD/++IPFixeLSkXu+KJt27YxYMAA0WeeU2dxrkPOPb/bnVRQnFfu38jVq1d5++23adiwIU2aNGHo0KHcvn270LbnJscN4uzszLfffituX7x4cYHHrFu3jhdeeIGGDRvSoEEDunfvzl9//YVer7crp9frmTx5Mj169KBu3bo0bdqUAQMGsH79ertyBfnWo6KixO0jRozIt/0rVqwQ3wtfffWVeN6JEyfSrVs3GjZsSN26dWnbti1fffVVvvEj92rP3LlzRTmWLFlid+z58+fFfWPHjs33euXcxxyLn8ViISQkhLZt24plSvO5yY+cPsDNzY3nn38+z/4+ffrwww8/sHXrVrvfAdjeC2+99RaNGzembt269OrVi3nz5hX5HZOWlsb3338v9m1PPfUUI0eOJC4ursBjkpKSGDZsGE2aNKFBgwa8/vrrnD59Ok+5CUcncPbgWcj2gnTs2ZHmLZoDcPnsZS5cuMCz1Z7FR+OD0WIskrw53LfFInfHl0NBHUVERASvvvoqmZl3/DlXrlzh119/Zf/+/cyYMQOZTIbFYuG1117jzJkzdsdHRUUxd+5cjh8/zuLFi5HJZGRkZPD888/neSFcuXKFKVOmcPHiRSZPnlxoGyIiInjttdfsHu7U1FSOHTvGsWPHAOjVq5fdMUajkYEDB9qZvE+ePMngwYPZsGED5cuXL/ScBWGxWLhw4c7cYi8v2/Sfmzdv8vzzz9td75s3bzJjxgx2797NwoULcXZ2LpGMs2fPZswYe1NXYmIiO3bsYN++faxevTrfzqMwpFIpPXv2ZPr06dy+fZvjx4/TsGFDwBbkmaPcPPXUU3h6ehZYz9atW3n//fftHsSUlBT27dvH/v37mTNnDk2aNLE7JiUlhf79+xMdHS1uO3DgAIMGDWL79u2imX769OmMHz9eLBMdHc3vv/+Or69vkdvZuHFjoqKiSE5O5vr161SoUIF9+/YB0LRpU8LDw/nnn38wm80cPnyYtm3bikqIQqGgXr16gG1ENnDgwDwvgBMnTnDixAn+/fdfJkyYkMdtsn//fjZt2iT+XbduXSIiIhg4cCBG452XQWZmJhEREURERJCWlsZrr71W5DbezdGjR8XvLVu2LLDcvc4xbNgw0tLSAJuS5u7uXuLrUFwSExMZMGCAqMyArZM8dOgQy5Ytw8/Pr9DjIyIiuHjxIgAdOnSgadOmVKhQgevXr7Njxw7i4+Px8fGxO2bcuHHMmGFvdr506RI///wzhw4dYurUqUilUgwGA6+++qr47gFbh3/8+HGOHz/O9evXefvtt++r/devX+fLL78Un6vQ0FAAPvnkkzxBt7du3WLJkiUcPnyY9evXi9e+KO3p0aMH48aNw2AwsGHDBvr16yeW3bhxo/i9d+/eJWpHaT43+REdHS0qVKGhofnGdSiVynzl37ZtGx9++KHdc3ju3Dm+/fZbTp48affuyY/U1FQGDBjAlStXxG2xsbEsWrSInTt3smjRIgICAvIcN3jwYDvFY8+ePRw+fJhZs2bZWVPcle7II+VEYQu4//zlzzl27Bj799oGRosXL2bkyJE8V/05Apzznqcw7tti0bdvX1q3bm33+eijj/KUs1qtjBgxgszMTLy8vPjzzz/ZuHEjX3/9NRKJhIMHD7JgwQIAzp49KyoVr732Ghs2bGD9+vW89NJLgO3i5viy9u7dKyoVn3/+OZs3b2b16tV07txZrOvGjRuFtmHRokXo9Xo8PDyYMWMGW7duZcKECUgktsuzffv2PMdkZmaSlpbG33//zcqVK2ne3KbpmUwmVq9eXeTrl5aWRkxMDLdu3SIiIoJhw4aJ/vdq1aoRHBwMwOjRo4mPj0elUjFu3Dg2bdrETz/9hEaj4dKlS0ycOLFEMlosFubNmwdA/fr1WbFiBZs2beLNN98EbC+0vXv3Fij/a6+9Jo52wGax2LVrFw0aNKBPnz7i9twjrZ07d6LT6YB7v1Dmzp2LxWKhQoUKLFy4kC1btogjMKvVmu+9uXXrFu7u7sybN48lS5YQEhIiXuutW7cCNuX3119/BWwBlGPGjGH9+vV88cUXJCYmFipTbho1aiR+P378OFFRUeLMmObNm9O4cWPxZZQz6soJ9Kxbty4KhQKwzSLJeTl2796d5cuXs3DhQrHj3rRpU76xCmlpaXTu3JkNGzYwYcIEWrRowapVqzAajWg0Gv766y+2bt3K/PnzqVatGjKZjI0bN2KxWOjSpYvd7+bVV19l165ddOnSpdA25x4Z362EJSQkEBMTk+dzt+UQbIrv1KlTWblypWj1Kul1KC4xMTG4u7szffp0Vq1aRffu3QHbQOnnn3++5/G5gzZzju3RoweQfxDn8ePHxU44JCSEOXPmsH79evHY3bt3ix3dzJkzRaWiS5curFq1ikWLFlGzZk0A/vzzzyJH/hdERkYGjRs3Zu3atUyaNIkuXbpw7do1MWD8ueeeY+PGjaxatUqMZbh27ZrYyRW1PW5ubrRv3x6wKfe5n62c9ubMrMqPBg0asGvXLurXrw/YBiy7du1i0aJFQOk+N/mReyDn4eFR6DXNjVar5auvvsJoNFKxYkVmzJjBhg0beOeddwDbzLP83l25+fXXX7ly5QoSiYThw4ezceNGJk+ejI+PD7GxsQVaeaxWKxMnTmTdunUMGjQIsL3H7x48zm89n+jTtsFXgwYNCA4O5um2T6NWqwGbq0+r1TK43mB6VulZ5LbDQ4yxuHDhgqjh9+7dW9SQ27dvz+bNmzl48CArVqxg4MCBuLm5icedO3eO8+fPExYWxpdffskHH3xgt9/d3V38fvLkSSpVqkSjRo348ccfGTNmTJ5RfH6MGTOGL774gtTUVIKDgzEajSQkJODs7ExaWloe10sOX3zxBa1atQLg448/Fk3g+VlxCuK7777ju+++y7NdrVbzzTffALaHYPfu3YDtejVr1gyAJk2a0KFDB1atWsXKlSsZNmxYsWWUSCRs2rSJmJgYFAoFnp6eZGRkULlyZbGO3KO6u3F2dsbV1VX8O3fMSJUqVWjQoAHHjx9n48aNfPnll+L5wHbv7uUv/eeff0hMTMRkMuHn54der6dKlSri/oLuzXfffSf+xoYMGcLHH39s1+59+/aJnd3rr78uuiyqVKnCmTNnijxDIrdicfLkSbsOtHnz5qjVaho0aMChQ4c4dOgQN2/eFF+uOW6QzMxMVqxYAdhesj/++KOo1E6cOJGOHTsSHx/PnDlzeOutt/LIMHz4cPz9/cV7lvNM6PV6Dh06hJOTE3Xq1GHBggUolUpRmVGr1XYvS2dnZ7sYpPw6L09PT7tYCbPZbLf/1Vdf5dKlS3mOmz17Nk2bNrXb1q1bN55++mnx7/u9DsVl7Nix4v37/vvvOXLkCDExMWzfvl2c258fWq2WdevWATaLYo7C3rNnT1FRW7JkCYMHDxbryCkPtkFCjqVq1KhRVK5cmZCQEHHUnFPWzc2NH374AZVKBdjeU4cOHSIkJKRI77V78eGHH4rxMDnny7GIlCtXDqVSSVxcHBUqVBAtjDnPW3Ha06dPH9avX4/ZbGbTpk288MILXLx4UVRSChtcKBQK/P39xd8s3ImTK+3nJj9yW0qLE4+0d+9e0XL/0ksvie+s/v37s27dOq5fv87KlSvtXDq5sVqt4mCsYcOG4kC5Vq1a9OnThylTprBt2zbS0tLs3r8An376qTht9YsvvuDo0aOcPHmSU6dOkZiYKFrBV69YLT6/OQrhFe0VTFVMcBrS09PZsGEDzz77bJHbncN9Kxa7du3KExB58OBBuwAXwG6O/N9//83ff/+dp66LFy9iMpkIDg7mnXfeYfLkyRw4cIADBw4AUL58ecLDw+nfvz81atQAICwsjGeffZbly5ezadMmNm3ahCAIVK1alVatWvHCCy+Io/7CuHLlCuvWrePYsWNcunTJzi1SkD+sevXq4vfcL2iTyXTP892NRCJBqVTi6elJ3bp1eeedd8T6r127Jsqwdu3afDu95ORkbt26lSfQsygyWiwWTp48yY4dOzhx4gTXr1+3a/P9RLn36dOH48ePEx8fz6FDh6hXr544KurevbvdC6Mgzp07x+bNmzl+/DhXr161My2W9N7kdp3dbQatX79+kRWLKlWq4OnpSVJSEidPniQ5ORnA7oXVvHlzDh06xLlz5+ziW3IUi6tXr4oWnObNm4svR7BZU+rXr8+WLVuIi4sjKSnJznXk4uKS5/kbOHAg27dv5+zZs+KzJpfLqVOnDh06dOC5554rUseUn9I3e/ZsO/NrVFSUnaJXHHI6tBzu5zrczb06AalUKnaGYOvAQkNDiYmJIT09nZSUlAJHqBs3bhTzloSEhNhZ9AIDA7l9+zZRUVHs3btXHO1fv35dLJPz7gLb/Xv33Xft6s8pW6lSJVGpAKhduza1a9cutF05FKUTzP2M5KDVatm/fz/79u3j1KlTeeIqcjqi4rSnRYsW4nVZv349L7zwgugGkclkoqWnuJT2c5MfuY8pzJJ5tyJ67do18XtBg8f84h5ySE5OFgd0R44cyfdZNJvN4qA7N3e/z+rWrSu6X2/fvo2XlxdWq5XZC2ffqUtm5t9//2X3rd1YXO+8UxcvXlw2ikWRTyS796mMRiNpaWl4enry4Ycf0r17d9avX8++ffs4c+YMN27cYP78+SxcuJBJkybRpk0bBEHg+++/F3+sBw4c4Pz581y6dIlLly4xf/585s2bJ45e82PKlClMmDABsPnF33nnHerVq8cXX3xRaMKbHJMRYPejLg7jx4/nmWeeKbRMUa4d2Mz7dysW95LRarXy1ltvsXv3buRyOe3bt+ell17Cz8+P9957r0jnLYwuXbowduxYsrKyWL9+PcnJyWi1WqBoftWRI0eyaNEiMRq8d+/e1K1b1y7o8G6kUqmdwnKve3P3S7i497JRo0Zs2bKFCxcuiNHjOaPYnO+//fYbFouFmTNnijLm+Dtz39/8Rsm55bt7f068SG7c3d1ZunSpOI350KFDXLt2TYwZWrRoEUuXLs332KLQokUL0X3277//2r30citkw4YNE0eU+XH3+e/nOtytYN4dDHk3ZrMZs9lsd87C6s9NbjfIvn37xJiau1m8eLGoWOSu22QyoVQqC6w/p2xuBboo5LYe5ed6upu7lcv4+Hiee+45bt++jaenJx07dqRBgwZERUXxxx9/5Csj3Ls9EomEXr16MWnSJI4ePUpsbKxotWzVqhXe3t5Fat/dlPZzkx/BwcF4eHiQnJzMmTNnMBgMeQZDiYmJdO/enRYtWtCtWzfatm1bpHd2ziAkP4oaQ5RfPOPdA9vcsuTUe+DAAZJj75x/7P/yd6vkzFDMTwktjIc2KyR3MOMnn3zChQsXxM/y5cvZu3cvFy5cwNPTk7S0NI4cOcLRo0d58cUXWbBgAUePHmXWrFkoFAosFouYjCQxMZEDBw5w6tQpPvzwQ5YtW8bRo0dFRUGn04n+uPzQ6XRiRHDr1q2ZPXs2Q4YMoUmTJnZBpmVJ7ms3YMAAu2u3Zs0adu3axYULF6hTp06x6z548KDoZvnoo4/49ddfRcWiqOR+aO/upJ2dnenUqRNgm02QY0KtVq1aocoe2IJTc+7dgAEDmDJlCoMGDSrUdFlUcl/Tu5Nb5Q6aKwo5lgeTySSOMnIrFnXr1hVf4jkjvZo1a4rbgoKCxJfV/v377TrJrKwscbTh7++fZxSd3wvs5s2b7N69G61Wy+jRo9m0aRP79+8X/a3Xrl1j586dQOH3LvfvLOfTtGlTnnrqKTEwccmSJZw9ezbf63L3bKW7uVv2klyHnPJWq9Uu+2nuwN2CyJ3d1mQyiUHO7u7udu7W3Fy7di1PsrOC2L59u5jbJXfwc+6Rql6vp1+/fnz00UeiUlahQgXxXLnbdOLECfr378/w4cPF32zuTi532XvNbpFKpXkU6AULFojHTZ06lW+++YZevXrZWU1yKE57AJ599lkEQcBisfDnn39y+fJlIG9QfHEo7ecmPwRBoGdPW3xBenq6GAeYmxkzZpCUlMTatWvFd2nu98uECRPsnqHFixdz8ODBQnNeuLm5iS7NVq1a2R2/ceNGtm7dyrlz50QXSW7uztqcMxtOEARxFltu5fheFDbLqSAemmJRvXp10WQ2ffp01q9fz5UrV1i8eDH9+vWjZcuWfPDBB4AtuO/FF1/k66+/Zvjw4Zw6dYro6Giio6PFH0/OD2Px4sW88sorfPPNN/zvf//jwoULYtkcCvsRGY1GUbs/e/Yshw8f5vz583zxxRfig1oS10Zp4uzsTJs2bQDbdL1FixZx9epVNmzYQP/+/WndujV9+vQpUU6C3MrTzp07uXjxIgcOHGDUqFHi9nu1P/do5ezZs1y8eNFOk84xpSUnJ4sR50V5oeSW7dChQ5w6dYqTJ0/y6aefFlm2gggPD8fJyQmwueaWLFlCZGQk06ZNyzOl717kjrPIIbdiIZVK85grc08zdXZ2Fl8QOb+9s2fPcuLECd5//30xLiQnePlejBw5ksGDB/Ppp5/yzz//cO3aNeLi4uxif3Keidz37uLFi0RGRt6zU1YoFGIgmF6v5+WXX2bGjBlcunSJa9eusX79evr16ycGyhaVklyH3MGj//zzDxaLhXPnzvHXX3/d83wjR44Uf/MjR44UO9X27dsXaLHI/UIeMWJEvspXTtCy0WgUp+7mDoj95ptv2L9/P5GRkYwaNYqIiAg2bNgg/pa7du0K2H7/n3/+OWfPniUiIoLvvvuOEydOsHLlStFEn7v9s2fPxmg0cuPGDXFgVRxyP2+rV6/m2rVrrFu3zs5tnWMVKU57wDbyz5m9lTNYcHNzKzDGoCiU9nNTEEOGDBEHWuPGjWPChAlcvHiRc+fOMX78eDE4VKPR8MYbbwA2q16O8v3TTz+xc+dOIiMjmTx5Ms899xxNmzZl3LhxhZ43x0W0Z88epkyZQmRkJLt27eLll1+mffv2tGnTRnQF5eann35i+fLlXL58md9++01UhMPCwnB1dSUtLe3OzB8n2HRgk73icmgjincVkP0IrFq1Kt/zFMZDc4UIgsCIESN44403SElJEYPpcnB3d+f9998HbA/WunXr2Llzp/jJjUKhEINxBg4cyLZt2zh16hTLly/PMwff1dU1T7xHblxcXGjRogX79u0jPj4+3x/ho5BR8rPPPuP48eOkpKQwcuRIu30qlYrPPvusRAmIGjVqhJeXF4mJiRw+fDhff+e92p87onvu3LnMnTuXX3/9VXz5hIWFiVPx4M5U1HtRtWpVqlSpQmRkJJcvXxYDLIsjW0E4OzszYsQIRowYgU6ns5vZUrt27TxTnQujVq1aaDQaMYlP1apV88yWaN68uV0U+N1TZL/66ivOnz/PxYsXWb16dZ6ZRZ06dRItDvdi2LBhvPLKKyQnJ/P999/z/fff55G3Xbt2gG3kqVar0Wq1bNmyhS1btvDZZ5+JL8iCaN26Nb/88gtfffUV6enpjBs3Lt8XpVQqpW/fvve0TuVQ3OuQMxMAbDlVJk6ciNVqpX79+qJbKj8EQcBkMjF48GC77f7+/nneTTmYTCYxp4FcLi8wNuD5558XZ4UsWbKEN998k0aNGvHyyy8ze/ZsIiMj8+TRCQ8Pp1u3bgAMGjSInTt3cuLECbZt25Ynu+e7774rjjw7d+7MlClTMBqNLF26lGXLlmG1WqlWrZrdb7IodOjQgdmzZ4sW4fxSVOd01sVpTw59+vSxy0DbtWvXIsVYFUZpPjcF4enpybRp0xg8eDDR0dFMmTKFKVOm2JVRqVT88ssvoitapVIxfPhwPv30U27dupXndxYUFHTP6dhDhgxh+/bt3Lp1iwkTJtgpixKJhE8++SSPNcnJyYmAgACGDx9ut12j0fDll18Cttw9Oa5CaW0pr215jc4VO+OudCcuK47N1zcjcZfgF+pH7KlY0tLS2LhxY7GsSw81QVZYWBiLFy+mS5cueHt7I5fLCQgI4Nlnn2Xx4sViMJdMJuOPP/5g5MiR1K1bF3d3d2QyGT4+PnTq1ImFCxeKIz5nZ2f++ecfPvnkE2rWrImrqytyuZzAwEB69+7N0qVLqVSpUqFy/fzzz/Tt2xcfHx/UajWVK1fmnXfeEWMMbty4IZruyooqVaqwdOlSnn32Wfz9/ZHL5eL1mD9/vjhTpLi4u7szY8YMwsPDcXV1xcXFhTp16jB+/HhxytauXbvyRP/npnz58nz22WdUqFABuVwuRpTnJnc8RYsWLYqUK0ImkzFt2jQ6d+6Mp6cnGo2GkJAQhg8fLioZR48eLXBmyL3o06cPf/75J6GhoSgUCgIDA3n//fcLnMZVELnjJcDeWpFD7ulsgiDksXK4ubmxbNkyPv/8c2rXro1Go0GtVlOvXj2+++47fvvttyL7XUNCQli6dKmYvEqtVqNUKqlatSpDhgxhzpw54gvd2dmZUaNGUbVqVRQKBb6+vnmizAuiW7dubNiwgQ8++IDQ0FA8PT3F32Xz5s35+OOP2b59O99++61oHboXxb0OLVu25Mcff6R69eriPXz33XfvmbtGIpGwaNEiOnTogEajwdXVle7du7No0aICff67du0SO9a2bdsWGNxZp04dMcjyxo0b4kysESNGMG7cOBo0aIBGo8HJyYmQkBA+/fRTJk6cKE5LViqVzJo1i/fff58qVaqgUCjw8PCgUaNGTJgwwS72qWrVqkyePJk6deqgVCrx9vZm4MCBzJ8/v9idduPGjfn999+pXbs2arUab29vwsPDmTt3rnj/civHRW1PDp07d7aL6yhp7orclOZzUxghISGsXbuWDz/8UBxIyOVygoOD6d+/P2vWrBGtyjl069aNWbNm8fTTT+Pu7o5cLicoKIiBAweycOHCe74Dvb29WbJkCS+//DLBwcHI5XI8PT0JDw9n5syZ+Q7O5HI5c+bM4dlnn8Xd3R2NRkPr1q1ZuHCh6DHIbXXzaeZDojaR+efnM+nkJJZeWkqqPhUftQ8fv35HwS4snCA/HMumO3goTJ06VVyf5aeffipxJLgDB/fDwIEDOXToEFKptMDYEAcPBq1Wy1NPPUVaWhoVK1a0S1DloGxI0aUw++xsDsYcJFWfipvCjaYBTRlYayAeqqLn7bib/9xaIQ4eHikpKRiNRs6dO8e0adMA7BLmOHDg4MknKioKQRD49ddfxUyruZPnOSg73FXufNDwg1Kv16FYOHhgbNmyxS52AeCdd96xmwLrwIGDJ5sXXnjBbtp+QEAAL7zwQhlK5CAHo9nIldQrZBozsVhtEyOsWEnTp7E/ej9fNfvqHjXkj0OxcPDAqFSpEu7u7mi1WoKCghgwYEChgbQOHDh48ggNDSUlJQWNRkPjxo357LPPSiVzqIP741T8Kd7e9jbphoKnhZdUsXDEWDhw4MCBAwf/Md7c/CYHow8WuL9NcBt+a/tbiep+6MumO3DgwIEDBw7KlrOJZ5FKpKx4ZgU9q/SkZbmWHH3pKEMbDQWginvJUvWDQ7Fw4MCBAwcO/nPoTDrcFG5Uca9CI79GnIw/iVwq59XQV3GWO7PpWsln7ThiLBw4cODAgYP/GN5qb+Ky4jiTeIZ6PvXIMGSw59Ye/DR+aE1aTNqSZ5x2KBYUbzlcB48OQnbKYGsR8/47cODAwYOmJBmQy4K25dsy79w8vtz9Jat6rcLPyY93t91ZmTbIJajEdTveyNkkJGTcu1AhSCQCKpUcnc6IxfLkKiqPTDszM/GpZFu+O+FqNBQxs2NReWTa+QD5L7QRHO18knjU2+jt/fjMdvmw4Yck6ZKwYhX//mrPV1isFuQSOR80KHl+i2IrFqPXnqVvoyBqBhQt7a8DBw4cOHDg4NFCIkgY99Q4TBab5bd75e7U8qrF5eTL1PauTTnnciWuu9iKxYy9V5m59yoh/q70bRTEM/UD8XZW3vtABw4cOHDgwMEjQd81fQlyDmJM+BgxfXdlt8pUdqt833UXW7GoF+RORFQK52PSGLPuLD9sOEfr6j482zCI9jX9UMgcE03uB6vVis5kIVNvItNgJstoJstgRqOQEuyuxlnp8F45cODAgYP7I0GbQKI28b7WBCmIYvdSK99tye0ULWsjbrMuIpqIW6lsOx/H9vNxuKrldK8bwLMNg2hYvvSFfRK5kpjJ0hPR/BuZSLrOhM5kpjDXobtaRpC7mgoeaip5aajgoaGCp4ZgDzUyyeMRNPRfwGwxkWHK4Hr6Na5mRJKgSyRQE0g11+p4qrzRyDQoJcp7BnpZrVZMVhNSQYpEcCjtDhw4KB26VurK0otLWX9lPV0qdSnVoNP7zrwZlZzFz5svsvLELXKL1aSiJ5NebIjXY+AmsVqtDzV402S2sCsykcXHb3MsquAlvxVSAYVUglwqQW+ykGUseOlyuVSgspeGGn4u1PJ3IcTXmareTihL2YL0yARP5QrejC/D4E2TxUSqIZXI9ItcSYvkesY1ojJvEquLIVmfhNma9565yF3xVfkSoAmkonNlqrlWRy1Tk2JIJdWQQrI+kRSj7XuGMR2jxYin0pNymmAquVSmgnMl3JXuqKUaNDINMknJrFglvZcWqwUrVgSEx0LZeWR+sw+Y/0I7H/U2ens7PzazQj7e8TH/Rv2LyWpCKVXiofRAKVMiZPfkAgIre60sUd0ltqtfS8hkzcnbrI2I5lKcLde4FXBWysjQmzh8LYmRq87w54sNS3qKJ474DD0rI2JYHhFNQqYBAAGo6uNEi0qe1PZ3xkUpx0khRaOQIpMKSAXBZokQBBIz9VxLzOJSfBY3U7KISzeQkGkgMcuA0WzlQlwmF+IyWXUqBgCJAOU91IT4OlMnwJVa/i5U83FCJZeW4VUoJeRyst75QPxeUkwWE7ezoriUdolr6VcwWUy4KlxxV3rg4+SFk+CCq9wdlVSFVJASr4vnUtoFLqdd5Gr6FW5n3SJRnyAu4HM3MkGGp9IbtUxFkj6JdGOa+IlMv8ye2H9LJLezzAUvlRfeSm88ld64KdxxV7rjpfDGXemOu8ITJ7kTMkGGFSt6s550YzqZpnTSjemkG9LINGdgEowYTSYsFguW7DGGxWrGihWL1YrJasRkMWf/b/tutpowWy24yl2p7FKVmh618FJ64yR3Qi3VoJKqHpuXqwMH/1W23dgmfteZdESbou32388zXGyLxdRdkayJuM3Z27blb62AWi6la50A+jcJpnEFDxYfucmw5adwV8s5PrJjiYV7WDxoi4XVauWn7ZEsi4jGnL1PI5fSMNiNDiHehJX3wNNJgaSYN9JssaI1mskymLickMXp6DQuxGUQlaIjOk2H1pi3s5MIUMFTQ00/Z0IDXKjl70p1Hyfk0qKNPB/1EUNhGMwG9sXt5kLKeW5mXudm5k3itDHoLfp7HmtzW0jQmbX57ldJVXgrffBQeuKmcMdF7oyHwgs3hTtKqRKFVIHZaiZVn0qsLoYkXQIphhSS9Ikk6OOxWq04yZzQyJxQS9WoZGrUUjVKqQoBSDWmkqJPJsmQSJYpq0jtlQlyFBI5BosRk9VYnEtVbNwVHviq/AjUBBLsXIGabrXwUnmjkqpRSVUopSpUUhUKqeKBypEf9/ObtVgtxGvjOBR/ECeZhhoetfBV+ZXYSvQgeZyfzaLyqLfxcbJYTDoxSbROFMTb9d8uUd3FViwqDV8nfq8X5E7/JsH0qBeYJ6iw2dhtZOhNnP6mU4kEe5g8aMVi79UkPlp+GoBybipaVPKgey0/KnhpcFKU/gvKaLaQrjNyPVnH6eg0TkenczNZy61UXb7uFJlEoIq3hrqBrtQLdKN2gAvl3PIfdT7qD3ZB3Mi4zldHPycq82aefQIC7goPPJSeCAjozDp0Zi06s5YsU5Y4zzunrKfSC2+VD55KT9zkHnipvHCVu6GSqlDJVLjK3XBTuKGRaVBLNahlGtRSFSarmUxTBpnGTDKMGSQbEkkzpJJl0mKyGrPjKKTIBBkSiQSZIEMukaOQKDFY9GhNWgwWPWmGNFIMKaQakkkzpqE1a9GZtGSZs8gyZZFlyszXBQM2C8qdzl6JXCq3jQ4QbP8EEJAgYBuxSASpGN+RI59EkCAgkGJIJlYbQ7oxLd9zaaQaXBVu4rX1Vnnjp/In2Lk8XkpvpIIUQZAgFSRIBAkSQYqAgFSQZltMLHf+t1qxYsFsMWOymtCbddnXw4DerEdn1qK3GLBYLbjIXfBQeuCu8BDbqFGpMBtBRnb7ZTYLVH5YrVZSDSkcTzzCpqiNnEo+gdasRUCgims1nvJ/mua+4QRoAtDICnfBGcwG0o1pmKwmvJTepa6QmK1msR2P67NZHB71Nj5OisWDpNiKRaPRW+jdoBzPNQmmup9LgeX+2HaJQHc1fRqVPHvXw+JBKxbvLIng8I0Umlf04Iv2VfFzUT30QEuT2UK6zsT15CxO3rZXNnSmvJYNV5Us26rhSnVfZ6p5O1HOXYVMKnk0HmyLBUmUTUmwBAWDpGCLy9Zbm/j51Dj0Fh0qqYogp/K4y91xV3rgofDAS+mDRq5BKVWikqrRm3W2Eb7USpZeS6YxgyyTFrPVhJvCFtugkqlwljnjqfTCReGKRuaEs8wJpVRVrLgDo8VIlikTnVmHTJAhk8iQCXLkEhkyiVysy2q1YrAY0Jqy0Jq1aE1aMk0ZpBpSyTRlYLKYMFmNmC1mjBYjBosBnVmH0WIUlROFVGHXmUolEhRyOSaTGasFbO/DO/7VnPejTdEQEARB/F+CgAUrOpOWVGMqibpEkg1JJOriidHGkGYsOHYIQIIkW2mRIJVIkQoypNlKjICABQtmi83lYraaMVvNWLL/z63o3QulRIlapkYtU6OUqHCRu+Kt9MFX7UuwUwWCnIJxlrugktksKjczbrD51noOJxwiQRcv1qOSqtCZdeLf/uoAwnya0yagHUFOwXgqvQDQmrNIM6YRlxXD8cRjnE89y+2sW7grPAjzaU5j7yb4qv1wV3iUqAMyWUykGdNI1CVwIvEYsdoYanmEUsmlEt5qH3xdvNDrTYU+m2armXRDGhmmDNv1zO4C7K+rFblEgafS857K08PEoViUHkdijtyzTGP/xiWqu9iKxYJDN3BXy+lSJ8Buu9liZc7+a2gUMp5rElwiYcqKB6lYXIjL4KU5xxAE+KZzCF1q+d2vuKVGjmXjYnwWx6NSOBebwfWkLGLS9fnOTFHJJFT01FAzwIWqXhqq+jhR2csJd3XJYxxKTBGCN40WI7+d/on1UWsAW2fQLagnlV2r4JptUcgZvef8n/NSMGNCIreSnpWJ3mTAYLF95BK5qEQopI9GYLLZalMmjBaDTakw22TN+S4IIJPc6bilggypRIpcIkOjVmHQm8gJEbG1/45yIREEBCTZbjoBqSCB7KBNi9VMhimDdGM6qfpkEvQJZBoz0Zq16M06MowZZGTHdKQZUkk2JJGkTyTTlFlqbZcLcmQSOXKJTRkDgSxTFlpzUd1FMlt8isIDs9XEjYzrWLBdDKkgpYZbLaq7heCl9CFJn8iZlFNcSr0glnGVu1HfqyGNvZtwM+MGl9IuEZV5nQR9Qr7n81X5UsezHi18W1HFtSo+Kj/UMnW+ZW3KogmdSUuKIYVzKWc4lniEyLRL3MqKwmixubckgpQgTRAh7jVo6t+UCpoqeChsLjmpIMVoMZJuTCNFb6vjZNJxrqZfIcWQbG8VwipahqyAn8qPUI+6NPVtQbBTebxVPgXK+rDI7z1rtppJNaSSpEvAYDHgInfFRe6Cs9ylUAuRxWohM/v3m2ZIRSNzorxzhfuS73FSLOrOqluorAICJ14+UaK6S+QKCXRTs3dYW7vtVquVut9sRimTcOSrDiUSpqx4kIrFyPXn2XAujlB/Fyb2q/NAXB+lic5oJinLQMTtdI5GpXAjScvtVB0JmQZMBYwQPNRyKnraFI1qPk5U8XaispfmwebcuIdiEZMVzVdHv+BK+mUA6nk2oHNQN+p5NsBfE5Cnurt51EdGpUFpt9FitZBlyiLDmJ4doJpOqiEVrTkLg9mA0WLAihWj2YgZMxarBbPVIloiLNnfrVhtLhckSCQSpNjcLzlWDolEQIIk25VyRxGy+XQEwIrZYsFg0WfHl+gxYSLTkEmaIS3bspJIkj5RVBByE6QJprZHHco5BaOUKHBTulPeqQIqqZrrGVe5knaFMymnOJtyusCYGwAvpRflnSvio/LjWsYVLqdeFM8nl8ip4lKNRt6NaeQVhkqmIsuYRZIhkTRjarYlKpMMQzo3Mq9zI/M6WXcpZLZ4HBWJ+kRxm4BAoKYcVV2qU8+rPlYrnE6J4Fr6VW5nRRUpnuhuFBIFlV2qUsejLo28wwh0KoeX0htBEDCYDegtegxmvc0tZdKRqE/AZDXjLHNGIVUgl8jtFNoc15pEsN3bOy43iehyk0tsx91Nzm82PSuLRG0iV9KusDt2B2eSTxGVeRONTIOf2p9ATTkquFQixLUmvmpfXOSuOMmd0Jn1pBlSuJh6gTPJp7iWcZXorFukGFLoGtSDT+oOK/b1yc3jplgURI4F798BJQsuv6diYbVaeWn6QW4k2UYAUclaZBIBfzeVXTmtwUJiph5npYxTox79uIrcPCjFIjZdzzN/H8JssfLhU5V46TGz5MCdhF1pWiOXEzI5G5vBlaQsbiRlEZOmJ01X8Ap4Hmo5/q5KAlxVBLmrKOemIsBNRYCr7XNfU2ELUSz2xvzL9xGjyTJlopQoeTqgHa38W1PHsx4u8qKloncoFqWHwWywxYFku3C0piwyTBnZsRMWm4KBBSsWLBYrFsxIkCKVSGz/CxIkEilSbP/bXEZymxtF7KTudFhmiznbYmOLv9BasjALBjL1WvQm23aTxYQZsy3exZROmjENq9VKBaeKqOVq1FJbBxXkFIyPylcMOjVbTMRoY7iecZUbGdc5n3qW00mnSDYk4af2p7xzRQI15fBWeiMVZEgEAZVUjUQiIV4bS2TaZc6lniUplzKglqoxWU2iBaIgZIKMCs6VqORSGX91IM4yZyyYSTGkEJV5gyvpl4nRxhRah0KioLxzRco7VcAzO6aIbKsUWMX4GZPFyNWMq1xMPW/n1nKSOVPVtSqVnKuQacok1ZhCmiGVdGM6GaYMMo0ZmKx33gk2S5Ii2x1n+z/HyiSTyJALMuRSBXIh2+okVeAkdcZN4YaH0gNvpS8uChc0Mg1yiQKFVM4N3VV23tzJ2eTTRGtvF9peqSDFW+WDvzoAtVTN7axbxGhjMOSjYPWu0Jf3aw8ttL578TgpFglae6ua2WImw5jByssrWR25mpmdZ5Y4C2eRLBabz8QweO5R2wHZ2wo6qGe9QH4b0KBEwpQVD0qx+OPfK8w+HEUFDzV/DaiHp+bhR8SXNjntzMgykK41kpBp4FJ8Jmdj0rmRnEV0mp64DD0Z+oJzbuTg7aQg2MOW7Kuip4byHmqCPdSUc1Pde5ZKPoqF0WJkyrk/WHF9KQA+Kl86letGE58wQtxqFmtGgkOxeHLIaWemVofOqBNjVLTmLDKMGaToU8gyZ2K0GHCSOVPeqSJ+Gn/cFG4F1mmxWojXxXEt/Sq3MqNsMTISGQICKqkKN4Ubvmo/3BTuuMrdkAgSYrUx3Mi4Trw2lptZN4hMu8yF1HN2HTGASmqbEaSR2QJ//dUBBGmC8VB6YMGKXJDhLHfBT+2Ph9KDDGMGt7JukW5MJdWUzPW060SmRXIr6yZKiYoKzhUp71wBP7U/LnJXrFYLcokCjVxjCxQWbAqcICBaiqSChExTJkn6JG5lRXEt/QoX087bxZk8LGzXwgknmRNacxbxuWJfAMppgqnhXotymnKkG9NJ0MURq40hKvMmWQW4xOSCnHJOwQQ7lcdP7YdaqqGWRyhNfZvfl6yPk2JRGF2Xd6WCawUmt59couOL7AqZc+A6GToT4zedx0Up4+2nq96pRLDNLAj21PB0iA9K2eOVJ+FBKBaZBhPdpx4kw2Dm1bAg3m11//nXHwXu1RkZzRYyDWZi03VcT9JyIymLqGxXSlKWkRSt7WM0F/yzkwjQMcSH0d1qFizIXYrFSd0Fxp/6nuisWwDUdq9D+8BO1PduSHmnCsV+2P8Lne5/oY1QtHYazLZg1+ImHLNarSTpE7mdGYVcqsBd4YGrwhW1VJPvb85itZCYXT4q8yaJukSyzJk4yZzE0X1OzEP2GbKVFTWeKk/81QG4KzxwU7jbyWmymEgxJpNmSeJq8jVS9CloTVqUUhUWLMgFGRq5E15Kb7xV3tlTol3zdTfkYLaYSNQnEpN1m6isKFJ1KURpb4rxGTmzn1zkrjjLnXGSOYtTpG0BtyZbnEh2YLHRYsJoNWIyGzFZTXc+5pz9tqDjDKPNgpRuTMt3dpOAQMVsN0eQU3lkEpty5KZwx0mmIcWQgi57xlCGKYMkXRLxulhMVhMB6kB81L44yZwh2+WmlqpxVbiJCtj98CQoFhmGDDot64TJYuLgiwdLVEeRn6CBzWwXXGc046KS8cYT0lE+KFadiiHDYMbLSU6PUP+yFuehIZdKcFdLcFfLCfG1nzVkNFvQGS3ojCbiMw1cSczicnwmt1J1xKXrReXDZLGy6Xw8H7SujM89MrdmKAXGnf+RzbFbsGJFLVXT0q8VLfxaUdezvhit78BBYSikihLl2BAEAS+VN14q7yKVlwgSfFQ++Kh8qOZWXbRimK1m5BIFSqkSpUSJUqrMDriVoZQqcVe4Fzo7QyaR4av2pbyqHBXVVUnUJhKviyfLlJGdQM0NV4VboYrE3UglMnzVfviq/ajuXpM4bSy3s25R3a0GOpNW7EClglQMoFVIFDjLXFBIFTb3jtmmMJisxlxxNNkfzFisVps7DCuWu5UIK7bgVbM+ezZUFnKpnAqu5TGazAhIcFO4UU4ThI/KFw+lJzKJDEN2Mrh0YzophmQSdPFkmjLQm/XIJXLUMg1eSm88lV64yl1xUbiikqryuQJPNm9vtc9RkRP/dDnlMhnGDHw1viWuu0iKRULGHX/UwOYV8my7m//6aqcmi5UFx2wj51aVvQhyL9tI6kcFeXZ6cheVDB8XFbX878Q75CT70hpMvDj3OMlZRg5eT6Z77YKVsi2NXBk7MICE2M0AhLjVpLlPOLU9Q6nlHlrmEewOHBSGRuZEJZcqVHKpUqr1yiQyfNS++KhL3jHcjUqqorxzBYKdyovTXQVByJ6irUKRrQwVprjkKBQ51ow73y1204lNFhMGix6dSUeGKYMsUxYGsw6jxYQFM+4qV3zlAXgpffBUeuWxMCmkSrykymxlrxIWq4UMYwaZpgxUUtuU40cxwdnDZu+tvQiCQEFOi4E1B5a47iJd3bAxW4tcoSAIRI7tWmKBngR2XEogJk2PRiGlVx3/YmfU/C8ilQg4K2U4K2XUDXBlV2QiJ6JS81Us4rXx/HpmHPvfLw+Ai8yFcL+nCPWsRy2PUIKdyj8Wa1g4cPC4IQgCbgq3QuNPCiJnJogMGVC8wWeOsmHChLezByaDtcjuO4kgwVXhiquiaIHb/xV6VOmRJ/NmzrVqFtiM8HLhJa67SIpFsbyv97em2WOP1Wpl7mFb4qaw8u6E+DqXsUSPH7X8XdgVmcj1ZPupfFmmLFZeW8rCK3PJMNliYup5NqSRV2OqulWnlnuo4+XhwMETiExiSx4nkQjIJDJMPNgU9f8FxoSPeWB1F0mxWPBmswcmwJPGiVupnI3NQCYR6F7bD1kR1+BwcIda/jZl7GaKzjbd1axjy60NLLgyl9js6XReSm/C/Z6iims1arrXpqJzRaQO86YDBw4cFJkEbQJbr29lQI0BANzKuMWSC0t4oeYLDz7GolllRwBcUZlzOAqAuoGuhFXwKGNp7o3VaguaEoQ7aZvLmhrZqeITszJYdnkd66MXci3jCmBL0dzEpxkhrjWoiCe15DXwcKkCj4DcDhw4cPC4cDX1KoM2DSJVn0qf6n2QS+ScTzrPjNMzWB25mhmdZlDRrWKJ6i7REC8mVUdEVAqZBhOW7FlRFquVVK2RfZGJzHi1SYmEedy5lpjJv5dtiW/ah3ijfsSWJ7dareLc/TRDGlfSL3MlPRILFqRIs6O7ZeL/ckGBi8IVP7UfTtnrYGjkGtwkzmCWIhdKlpdDa9KSYcrAZDGK6xPkXq/AarXi5XOJLM1mJl2yuZWkgpRGXk2o4V4bL6UXVRXBNG/YFrnZWmBKbwcOHDhwkD+/H/udRG0i5ZzLkapPxVvtjbvSnQquFbiedp2JJybyU+ufSlR3sRWLHefjGDz3KCZz3lS4JcFisfLrtkssOnyDVK2RJhU9Gf1MKBW98+8o4tJ1jF57jj2XbElSWlTx5qvuNQlwK/sZALMP3sAKVPN2okNI6UVklxSr1UqaMZWYrBgupp7nQto5ojJuEquLIVGXWOSltG0Jf9xxz15Twc/JD0+FbaVKD6UnLjIXVLKcNTds624opUokggS9WU9Gdla+VH0Kl9MucSX9MnG6WEwWky3botV+JUuDxYDBKxKZYFM26njUo75XQ1zkrlRwqkBVt+p4mJTIC8mF4cCBAwcOCuZY3DEUUgULui3AXeUOQCO/RsztOpe2i9tyLPZYiesutmLxx/ZLGM0W1HIpZosVuVSCRiElPkOPALzQtHyx6vt9+yXmH7zOj33r4eeq4vsN53h15iE2f9waRT4pn9+bfxyLxcqc15sC8PWq07w1+yhr3i95BGtpkJxlZOXJaADaVvcqm4W5sE3pSjWkcCb5FDujt3E6OYJ4XXy+K0LKBBneKh/bapJWC2ar/WqSZqs5e/lwHTptjBjfQK7Edy5yl+xEOe64KdzxVHjho/bBR+WLxWLhSsZlojJvEqONJk4bh95SxMx9Aph1/nhY69O8RmX8VAFUdwshQBNom/FRigtZOXDgwMF/jUxjJnKJXFQqcnBV2KbjphnSSlx3sRWLS7EZyKUSdn/ehglbLxIZl8mCt5qxLiKa9xYUT8MxmCz8vfsqw7rUoE0N2wh/4gsNaTp2KxvPxNCzXqBd+VStkUNXk/j75caElrNNd3rn6aq8OfsIyZkGPJzKLmX2hnOx6E0WAlyVdHvIK5harBaS9UmcSjrJzujtnE6JsFuLAGxz5gPUgfip/fFWeuOu9MRJ5oRVXIQpv2TtAiaLiSxTJhnGdFKNqaQYkkkyJBKvjUNn1omJaG5lRdmdT0AoUJkJ0ATirw5AIVHYUggLkuyluCVirIfF4Mb6M2mkS5xp4NmESi6VSpTAyIEDBw4c5KWSWyUuJl9kwtEJvF7ndVwVriRoE/gr4i+0Ji3VPaqXuO5iKxYGswVXlRwvZyVNKnqy4tgtLBYr3eoG8OUKOTvOx9+7kmzORqeRoTfRosqd4FA3tZzQQDcOXU3Mo1goZTbryLJjUTSt7IkgCKw4HkVlbyfcyshCkENFTw1eTgq61/bDz/XhZXG7mHqeBZFzOZl0nBRDsrhdgoTKrlWp5lodP1UASqkSQRCQZWfyU8vUYvphqSADrLYseFiyl062uSWMFiOphlQyTOnozTqMFgNSmQSj0YzJYs5edjjNtmyxPpFEfQKJ+gSMFiMCAt4qH4KcgimnCcJX7YerzA2D1YDZas6eQ22vfEiyl+W2WCSs1bqSpg9EaQ52KBUOHDhwUIoMrDWQr/Z8xT9n/uGfM/8gQSKuvisIAi/VeqnEdRdbsQh0V3M9MZNNZ2JoWN6DLKOZRUdu4ueqJF1nxFiM2IuYVK1YZ278XFXcTslrMlfJpYzvW5eRq85Q95vNCICvi4pFg5shkRQ8K6Bdu3YF7tu0aRNSqbTQ44tCy8perBrSDL3e9FCmmKYZ0ph+YSrrb64RV0WUClKquVanqls1/NQByCVynOXOeKtsGeo0UtuiRk5yJ5QSZbFmgJgspuy0ulrMUj1JmWkk65PIMKajNxswWPTZKXkFpIIUk8WISqbCim0dBrDFaqhlGsqryuOu8LApOwjZVoo7SoWAbVXEBcqLRGl1HLqRTGWfu2Juct0viUSw+7s0EAQBQbD9L3lCZwz/F9oIjnY+SfwX2viw6FmlJwnaBKacnILOpMOMLaW6Sqbirbpv0atqrxLXXWzFome9QH7ffokJWy6y8aOnqOztxIgVp8T91f1cCjnaHq3R1hDFXR2xUiYhRWvIU95qtXI+Op2G5T0Y0royJouVnzZdYPCcoyx9uwXOypLnMVCp7s/iIQgCzjIJJpOlwBSppYHJYmLD9fVMPTOZhOxV/oKdy9PIpzEBmgBkEjnOcif8NP4EOgXipfLGSV4aMybkOKO2WT1kEkxutnaaLCZ0Zh1Zpiyb4mHSkmpIJVWfisFiwE3hho/aBxe5Cy4K22JFRc2KWT8ojqiUGM7GZea9P+Y7f6tUcrjP+3c3Oe1UqQpOefu4819oIzja+STxX2jjw2RQ6CD6Ve9HRHwEKfoU3JRu1POph4ui6P14fhS7J/6wXTVMFgsZOttSv6N61uat2UfRmcy4q+V83b1WketSZa+CajBbUEnuTM3Umyyo5XlFW33yNrP3X2Pf8HaiEjH9lSa0HLedxYdvMii8Ur7n2bZtW6FyWK1WdLr7y+QmCAIqlQydzvTAfvAXUy7wx5kJnEo+CdjiJloHtKG8pjwuSjf8Vf74afzxUnmjkWlsB5lBZy69LHX5tVOGEldBiavcA+SA2nZNzVazfU5+Cxj0ZptQRSDE14m1wJX4jLz3x2RFOuAFAHQmK9zn/bub0rqfFosFs/nB/SbuB0EQUCpl6PWPpnylhaOdTw5l1UZBEJBKZUjuYSbRaB4/l63BbKBluZYAZBmziM2KffiKhUQi8FmnGuLfrar5cODLdlxPzKSqrzMaRdGrDMh2gcSm6ajgdWdUHZumo2ZA3tTMR64lU9nH2c4y4aaRU9nHiasJ9zdL4H6XjZZIbNnMrdai57AvKpnGTKZdmMSGqLVi7EIj7yaEutfFQ+lJVbfqVHSuiDpHmeD+21MQxWmnBOl9yVEzOx16VIoOg8mCLLe7Q64g/fcpd/4u5fbe7/20Wq2kpSWh1WaUqlylTWGLED1JONr55FCWbVSrnXF19XwkEgneL0aLkVH7RvFv1L/sHrAbgDOJZ3hj8xt0rdSVb1t8i1xaMktwqeRAdlPLqRvkXuzjaga44KKUceBKoqhYpGqNnL6dysstKuYpH+CuYk3EbXRGM6rs5FNag5kbSVk8U7/c/TThkeVGxnWGHR5KjNY2lTXYqTwtfZ/CU+VFBacKVHMLwV356Gf4LAkhvs4IAqTrTUQmZD5W667kKBXOzh4oFMWLZ3mYCMJ/Y3kfRzufHMqijVarFYNBT0aGLUDeze3xz0Y9LWIaayLXIAgCtzNuE+gcSFR6FFarlfVX11PRtSKD6w0uUd3FViwSM/R8u/YsO87HkWkw59Eci7O6qVIm5eUWFfhhw3k8nZQEeagZu/4cgW5qOtf2x2yxkpipx1UlRyWX0rdhENP+vcJ784/zScfqWK3wy5YLKGUS+jYKKm5THnkupJzli8OfkGZMRSNz4il/m9vDV+NPiFuNOzkdnlBUcimVPDVcSczi4PVke8XCaoWsLNt3jeaRSultsZhFpcLZ+dFeFE0iER6YdetRwtHOJ4eyaqNCYVuRNSMjGRcXj3u6RR511l5ZiyAI/Nz6ZwKdbTMwe1frjafKk/e3v8/aK2sfnmLx1crTbDoTU/CKp8VUJYd2CMFksTJsWQQ6o5mwSp7MGhSGQibhZlIWrcbv4Me+denXOBhfVxVLhjTnhw3neWHaASSCQJOKniwd0qLMp5uWNkcSDvG/o8PRmrV4Kb3pEtQNP3UAVV2rZ+d0KN6yw48rtf1duJKYxbmYdPsdWVn4VAoAeORSepvN2UHJiv/GPXLg4L9CzjNtNpuQSB6/eIrcxGXF4apwpX2F9nbbWwe3xlXpSkxmTInrLrZiseuibSZC+5p+dKjph0oh5X7GilKJwPAuNRnepWaefcGeGq790M1uW1VfF/5+5clei2Tn7W18HzEao8VAoKYc7QM7UcO9FjXda+OmcCtr8R4qtfxdWHMmlht3LaH+OPCouj8cOHBQMp6kZ9pd6U68Np6ziWep5XVn0sWJuBOk6dPwUfuUuO5iKxYahRSJIDDlpUZISzl3gANYc30lv539CYvVQkXnyrQLbE9N91BCPer+J5NE1fS3RSfbAjjNKGSP1sJuDhw4cPA40rZ8WxaeX8grG16heWBzPFQexGbFcij6EIIg0KZ8mxLXXWwnUd9GwehNZm6nPH4jyEedOZdnMuHMeCxWCyFuNekY2Jm6ng2o51n/P6lUgG1BN5lEIMto5kKcY32Qh817773FmDGj8t03Zswo3nvvrYcmS3h4Y9avX/PA6j927Ajh4Y3tPq1bN+XZZ7sxbtx3pKen37uSUuTuax8RcYKTJ088VBkcPLm83+B9anjWQG/Ws/PmTlZeXsm+W/swWUxU96jOhw0/LHHdxbZY1A92J8BNTZ/J++haJwAfF2Uey8WQ1lVKLNB/EavVyqRzv7Ps2iIA6nk2oIVvOHU961PNLeSJDtC8FwqZhCreGi7EZXLoRjJ1Ah/tYEgHD45Vqzbi7PzgZwZNmzYLX1/bej9ms5nIyMuMGTOKpKRExo2b8MDPXxDvvPMGX375P+rVq19mMjh4cnBRuDCv6zxWR67mYPRBMUFW04Cm9KzS874Gs8VWLN6ed1Rc4WH2/mv5lnEoFsVj1fXlolLR1KcFYd7NqOfVgEoulZ8on15JqeXvwoW4TM7HPto5IRw8WLy8vB/KedzdPezO5evrx3PPPc+0aZPJyMh4KMqNAwcPA7lUTp/qfehTvU+efQejD9I0oGmJ6i3+WiFu6kdpZt8TweobKwBo6NWYFr7hNPBuRJBTcBlL9ehQ29+FFRExj2UAZ26sVis6U9HX0ilNVDLJA1dSMzIy+PPP39i9ewdGo5GQkJq8884H1KhhCwzT6XT8+uuP7Nu3h4yMdCpUqMirr75B69ZtAbh58wYTJvzImTMRWCxW6tSpy7vvfkSVKlUBmyvkyy//R9euPTAYDMyY8Rfbt28hLi4WjcaJJk2aMnTo57i5uRMdfZt+/Xry7bc/sGDBHCIjL+Hl5cMrrwyie/dnit02qVSanU7a9sq8du0qEydO4OTJ42g0Gho2bMJ7730kKiTvvfcWNWrUIj09jV27tmOxWHnqqacZOvQLNBpbIrs9e/5l3rx/uHz5EmazmSpVqvLWW+/SpEnel3l4eGMAxo79huPHj5KRkU5mZia/50oSd+PGNV54oS8zZ86nWrWSr0zp4L9Lki6JlZdXsvzScqLSozjx8okS1VNsxWLvsLYlOpGD/LmVGcW1jCsICLT0bUWYbzP81P5lLdYjRc3s9WduperQGs2o5VKQStH36GUrIH30AzqtVitvLDxJxO20Mjl/vUBXpg2o98CUC6vVymeffYBMJmfcuF9xdnZm48Z1vP3260ydOpPq1WswbdpkIiMv8eOPv+Hi4sKaNSsZOXI4CxeuICAgkP/970uqVq3G33/PwWQy8eefv/Lll5+yaNHKPOebNOl3du/eyYgRowgMLMeVK5GMGfM/Zs2azgcffCKWmzhxAkOHfk758hVYsGAu48ePoWHDxgQGFi2hnslk4syZ0yxZspDmzVuiUqlISIjn3XffoF27jrz33sfodDpmzJjKkCGvM3v2QtRqW0bhZcsWMWDAS/z11ywuXbrAmDGjCAoK5tVX3+D8+XN8+eWnvP32B3z99WgyMzOZNm0S3377NcuXr0Mut58+v2rVRp55pjMffPAJXbv24MSJowwf/ikxMTH4+9veFxs2rCMkpIZDqXBQbPbf3s/Si0vZeXMnJqstXfr9vCtKnHnTYLJw6lYK0ak6utcNJENvuq9FwP6r/BuzE4BATTka+YQ5lIp8qOylQSEV0JssnI1Oo1F5D1CpSJs+u6xFKxaPq6Fv8+YN7NyZd70dg8FAnTr1ADh69DCnTkWwZs0WPDxsmWAHD36XU6dOsmTJQkaMGMXt21FoNM6UKxeEs7Mzb7wxhHr1GuDiYoubuX07irCwZgQEBCKTyRg+fCTXr1/DYrHkSUZUs2YtWrduQ4MGjQDw9w8gLKw5kZGX7coNGPAi4eGtkUgE3n33I9asWcmZM6cKVSwGDnxOfKnq9XokEgnNm4fz+edfArBixVK8vLwZOvQL8Zhvv/2Bbt3asWPHVrp27QFAhQqVGDz4XQDKl6/A1q2biYg4AYBUKuHDDz+lT5/nxDr69RvAxx+/R1JSIn5+9u+BHEuIs7Mzzs7ONGvWEk9PT7Zs2cDAga9hsVjYtGk9L730SoHtcvDoY7FamHxyMssvLifNkEYD3wZ81ewryruWz7e80WLkz+N/siZyDenGdGp51WJY2DBqeNbIt3xuErWJrLi8guWXlnMr4xZgGyAopApalWtFl0pdStyOEmkCc/Zf4+ctF0nTGhEEge51A+n9517a1vTNNx+Fg4LZGW17Ydd0r42PquTzhp9kZFIJ1XycOROTzuGbKTbF4jFDEASmDaj3WLpCwsOf4u23P8izffLk30lNTQXg4sXzADz3XE+7MgaDAb1eD8CLL77CF198TI8eHahduw5hYc1o166jGLPw5pvv8PvvP7Ny5VIaNmxC06bNadu2Q74ZDjt16sqRI4eYOvVPbt68wbVrV7lx4xp169a3K1ehwp2FCXPOYzKZCm3vjz/+ho+PLwByuRxPTy87C8LFi+e5fv0aHTq0ytPWa9eu5jp3Rbv9zs7OZGTYZpZUqxaCi4sb8+bN4saN69y8eYNLly4AtoXr7oVMJqNTp65s2rSegQNf4+jRwyQnJ9GxY+d7Huvg0WXqyaksvrCY0S1H46fx45ejv/D21rdZ+czKfNft+O7Ad+y8uZPRLUcT5BLE78d+5+2tb7O61+oCFxLbd2sfSy/ZrBNmq332bEEQ2NRnE17q+0tZXmzFYuXxW4xcfebOBqsVvclMZHwGkfEZ+DgreaNV5fsS6r9CnDaWS2m2l0kzn+Z2i4g5sKe2vwtnYtK5+BhPORUEwebGeczQaJwICsob86PROImKhcViwcnJienT5+Ypl9Mph4bWZfnydRw+fJAjRw6xdu0qpk+fys8//0HjxmH06fMcbdu2Z//+vRw9alMaZsyYysyZ8/H0tH/R/fTTD2zbtpkuXbrRokU4r7wyiAUL5hIXF5vvuXNzrwWs/P0DCAgILHC/xWKlYcPGfPLJsDz7nJ3vvMwVirxR9TnnPnHiGEOHvkezZi2pV68+7dt3RKfTMXz4p4XKlptu3Z5h/vw5nD9/js2bNxAe3hpXV7cnPqX3k4rRbGTW2VkMbTSUp4KeAuDH1j/SbnE7tt7YmseCEJUexfJLy/mz3Z9i+W9bfstza57jbOLZfAMvOy/rTHSmbd0pq9WKl9qLHpV70KtaL3qt7AWARn7//VCx5zH+9e8VBGDu603xd1UBoJBKGNWzNlZgwaEb9y3Uf4U9sbsA8FcHUNXN4RctjFrZibLEAM7MTHx8XfHxdYXMx1fZeFKoXLkqmZmZGAwGgoKCxc+8ebPYs8f2O58+fSoREScID2/NRx99xoIFyylXLoidO7eTlJTIL7+Mw2g00rVrD77+ejSzZi0gMTGR48eP2Z0rNTWFlSuX8umnw8SYg2rVQuysBQ+2rVW4fv0avr5+YjtdXV35/fefuXLl8r0rABYsmEODBo0ZO/ZH+vd/kSZNmhEba0uhXNSVOytUqEhoaF22b9/M3r27RReMg8eT80nnyTRmEuYfJm5zVbhS06smR2OP5im/7/Y+XBQuhJcLtyu/sc/GAmdz3M64DYBSquTr5l+zte9WhjYeSmW30jUGFNtiERmfgYdGQcuqd6ZjCYLAy80r8suWi0Q9ppH7kvvMIioIAoJg+7+oa9PkuEFquNfEW+1z3zI8DErSztKgXjk3fFyUGK1WtEYzTlIJZAetSaQSKOVrdz/tlEhsswckEuGRv6f3ap+7uzuuri75tsPV1QWt1h2JRKB58xaEhTXl11/H89Zb7+Dt7cumTes5dGg/Xbt2RyIRSEtLZfr0qajVavz9Azh//hwmk4mwsDDc3d05f/4sU6ZM5OWXX0Ot1rBt2yYCAgIIDa2DRCLg4+ODWq3CxcWFihUrcvLkcWrXroPBoGft2tUkJyfi4+Odff2l+Pj4oFAokEgEsZ05deTXHoVCgY+PDzKZtND71q9ff/bu/ZcJE8bRv/+LCILAP//8TWxsDFWrVkMiEfK9brmvV5UqVTl4cD/nzp3B29ubU6dOsnLlUnx8fABrvnUEB5cnISGejIw0XF1tqf379u3PtGmTCAgIoFmz5g/9uSwLyrKNRXm2b9++zcCBAwusY9u2vPFKALFZNmubv5N9fI2P2ke0MuTmWto1gpyD2Hp9K3+f+pu4rDhqetXks8afUdk9f0VBJpFhspjQm/WMPTiWnTd38kyVZ2gTXPIsm/mep7gHuKhkpGlNJGca7LZHRKWQqjXi6/J4LrykUt3fIma2qWgSVCqhSCOORF0iZ5JPA9AisCXeLo9H3EBx21laVAuQ80rzCpgsVrIs4OWigcG2lfdULhrIx+R9P9xPOxUKCYLgiUajQiJ5tF0fglB4+9q3b4eLi0u+z0eLFs1JT0/P3ifn11//4PDhg1y+fI7z508RGOjH1KnTKF++IgCff/45hw4d5MqVC5w7F4GzszPjx/9IrVqhAEycOJnDhw9w/PghTCYT/v6+TJs2Qwy07N+/P9WrV8PZWc3EiZM4dOgAu3dvQ6lU0qRJIzp2bM/Jk8eRyQS8vNzp378/wcGBqFRysZ05deTXnuDgQPr374+Xl3uh74OKFcszffpMjhw5xNGj+xEEgXbt2jJs2HA8PDwLvG65r9fbb79N3bqhnDt3ErDlzpgw4Td27doBmFCp5HnqGDXqG06dOklExFHat+8EQJcunUlJiadWrVCcnFT3vJ9PAmXZxgf5bGtNtkH53YmplFIlqYbUPOUzjZlEpUcxNWIqnzT6BBeFC3+d+otXNr7CymdW5hsnsb3fdlZHrmZl5EouJ19md9Ru9tzaYxePIZRCmLlgLeYdGrHiFPMP3aCKjzO3U7TojGa61Algx/k4dEYzA8LKM7Z3nfsW7GFitVpJSro/c7ogCKhUMnQ6U5F+9Kuvr+CXU+PxUfkwvumvVHJ5POJSitvO0uTTlac5HZNBv/oBvF7XB68w24yExEMnbUunlyL3006j0UBychweHr7I5Y92Kvb/QkcET247Y2NjGDJkEBMnTqNcuXJPbDtzU5ZtvNez7enpVOIg6S3XtzB051AOv3gYlUwlbv9k5ycYLAb+aPuHXfnvDnzHoguLWPXMKtFCoTPp6LC0A4NCB/Fa6GuFnu9U/CmWXVrG5mubyTDakg8KgoCfxo8OFTrQsWJH6vnUK1Fbim2x+KJLDSKiUjl9+44Gtf6UzUxTzdeZTzuGlEiQsuZ+A54kEtuK8VartUh17bi9FYDqrjXwkHs9NgFXxW1naRLoqmbHpURO3EzFUtsLYmw+aYvZAqUsy/2002KxYjKZsFge/jUqLhLJ/f/2HweetHbGxsZw7twZVqxYSuXKVQkICMRisT5x7cyPsmzjg3y2/TU2F0h8VjzBrneCpeO18VT3yBuD56fxQybI7NweKpmKIOcgcfpoYdTxqUMdnzoMCxvGxmsbWXFpBcfjjhOTGcPcc3OZd27ew0uQ5aqSs/ydFiw/FsW+yESSMg34uqhoWtmT3g3KIZc+4Q6+UiDNkEZEks0E2tCrCS7y/KcFObCnlr9tuuD1ZO0TPypz4KAwUlNTGDPmG4KDgxk79qeyFsdBKRDiGYKz3JnDsYdFxSLNkMa5xHM8X+P5POUb+TXCZDVxJuEMtb1rAzaLxc2Mm3SuVPRpxyqZil5Ve9Grai+up11n2aVlrIlcQ5IuqcRtKVEeC7lUQv8m5enfJP+kHQ4KZ3/cHsxWMx4KT+p5NXCsB1JEcmaGxKbrSdUZ8S1jeRw4KCuqV6/Bli3/lrUYDkoRhVTB8zWeZ8LRCXgoPQh0DuSXo7/g7+RP+/LtMVvMJOuTcZY7o5KpaOjXkGYBzfhyz5eMbD4Sd6U7f574E6kgpWeVnvc+YT5UcK3A0EZD+bDBh/wbVfLfV5EVi7kHrjNj71Vup2gp76nhnaer0qtB0dLiOrBnR/ZskOpuIXgqPctYmseHcm4qnBRSMg1mImKzKN++o23HY5DS24EDBw7uxbv138VkNTFq/yh0Jh2N/BoxpcMU5FI5tzJu0XlZZ0a3HE2vqr0A+LXNr0w4OoGPd3yMzqyjvk99ZnSagYfq/iYDSCVS2pQv+UyRIgVvLjh0gy9XnBJXNQVbeuJpLzemXU2/Ep/8UcFqtZKQcH8rZ0okAiqVHJ3OWKjvLcuUSe8tXTFajQwOeZd+lZ9/rJZFL2o7HxRvLz7JkZupPN+wHEPbPLhVdO+nnUajgcTEaLy8Ah754E2JRHjiffLgaOeTRFm28V7Ptre3s8MCTRETZM3ca0s8U9Hbibeeqkx5Tw1W4O/dDychzZPEgbh9GK1GXOVuNPRu/FgpFY8CNfzuSpTlwIEDBw4eKYrkCrmVrEUA5r3RlAA3Nf0bB9Pul12cjymblRofZ3ZGbwegmmt1vBxrgxSbyl62aaXRaboylsSBAwcOHORHkRQLncmCu0ZBgJttOeDKPs64q+Vk6s0PVLgnDb1Zz+H4AwDU9ayPu8K9bAV6DKni7QRAWmIqXhX8EQRIOBMJTk5lLJkDBw4cPF4k6ZKYe3Yux+KOkW5Ix13pThP/Jjxf43nclG4lrrdIioXFakUpszfZq+RSUrXGEp/4v8jh+APoLXqcZM408W7qcIOUgEpeGgQg02BGos0qa3EcOHDg4LHkaupVBm0aRJIuyW76/pHYIyy9uJSZnWcS7JJ38cGiUORZIUazlZM3U8TgTaPZtrRv7m051A92L5EwTzo5bpCqrtXwVjvcICVBLZfi76okJcHhCnHgwIGDkvLDoR9I1CaikqloX749fk5+xGXFsfX6VuKy4vj+4PdMaj+pRHUXeciclKmn96S9PJv9ScpeKyT3tmcn7aXP5H0lEuRJx2gxciBuLwChHnXxUDwea4M8ilT1drg9HhZ9+/YgPLyx+HnqqTA6d36a998fzMmTxx+qLOvXryE8vLH4d2pqCmvXrrzvet9+exDh4Y25dOnCfdf1oJg+fSp9+xZ99dLo6NuEhzfm2LEj4ra9e3dz9eqVByFesblw4TxvvvkyFoslz75Zs6bb3eccli1bTL9+z/D00y0YPPg1zp8/a7c/Ovo2n3/+ER07tqZHj45MmvQ7ZrM53zratm2Zp47z58/y5psvYzKZSqmVjzbHYo8hCAIzO89kbKuxfNjwQ8aEj2FO1zkIgsCR2CP3rqQAiqxYWIv4sTgyIubL8cSjZJmzUEvVNPVpjlRSotxkDrgTZ+Hg4TBgwEusWrWRVas2snz5eiZN+huNRsMnn7xPXFxsmcn155+/sXHj+vuq48aN65w6FUH58hVYuXJZKUn26BETE80XX3xMcnLJsymWFiaTibFjRzF48HtI7lqm9Ny5M8yY8VeeYzZsWMvkyb/z5ptvM3PmXIKCghk69H1SUlLEOocOfQ9BEJgyZTqfffYla9eu4p9//s63junT5+Spo0aNWpQvX5F582Y9sLY/SnioPHCSOVHbq7bd9uoe1dHINHiqSp5jqUi92+7PS3dJ1dxYLFZ+3XaJRYdvkKo10qSiJ6OfCaViAZ2H0Wzhly0XWX4sijStiTpBbvyvRy1qB5Y80ORhsPO2LSlWZZeq+Kof/9wfZYlDsXi4qNVqvLy8xb+9vb357LMv6dWrC7t27aBfvwFlIldppHVft2415ctXoHv3XsycOY133/0QjebJ+309SinwN21aj0QioXHjMLvtWq2Wb775mvr1G3L06GG7fbNnz6BPn/507NgZiURg+PCRPPfcM6xZs5KBA19lx46txMbG8Ndfs3BxcaFy5aokJycxadJvDBz4GgqFwq4OIE8dAM8/P5B33nmD3r374erq+lCuR1kxsNZAfjryE6sjV9tl6px/bj5Zpiw+b/J5iesukmIR5FG6K0fm5vftl5h/8Do/9q2Hn6uK7zec49WZh9j8cWsUsrwGla9WnGbruVh+7FeX8p5O/LjpPK/OPMy2T1rjep9Lnz8ozFYz++J2AzY3iKcy73K2DopOzpTTx5LMQlbRlUpBpSpaWYkE1OqSlS0FpNnZTuXZy9UbjUamTZvM5s0byMzMoFKlKrzxxhDCwpoBNjfGjBl/8frrg/nnn7+Ji4ulSpVqfPTRp4SG1gUgLi6WKVMmcvjwQdLSUvHy8qZTp668+ebbeUa2Y8aMYsOGtQCEhzdm7NifGDHiM5YsWY2/f4BY7q23XqVOnbp8+OEnedpgNpvZtGk9rVu3oU2bdkya9BubNm2gd+++Ypnp06dy/PhRmjdvydKli0hNTSE0tC6ffjpMXA4+PLwxn38+gu3btxARcRJXV1f69HmOgQPvrC65d+9upk+fyrVrV/Hx8aF9+0688srrKBS2JEtXrkQybdokTp48QVZWJn5+/vTp05/nnsu7RkRxiY6+Tb9+to7jgw+G8Nprb/L664O5du0qEydO4OTJ42g0Gho2bMJ7730kKpHvvfcW5coFceVKJDdvXuejjz6jadPm/PzzOI4fP4JWqyMkJIS33nqXBg0aFVmeBQvm0qVLtzzbf/vtJ6pUqULLlk/ZKRbJyUncvHmDRo2aiNtkMhn16zfk5MljDBz4KidPnqB69Rq4uNxZd6lRoyZkZmZy+fJFAgIC71kHQNWq1fDx8WHVquXitieV2xm38VR58vXer5l+ajo+ah+iMqKIzoxGI9Ow+fpmNl/fDNiWUi9OvEWZTkswmCz8vfsqH7WvTpsavtQKdGXiCw2JSdOx8UxMnvI3k7JYdOQmP/arS9saflT1dWZ833ooZRJOR+Vdr/5RIVYbQ5oxDakgpalPc2QON8h9UcFTAxKBA8GhpDRubus4HxN8KgUU+HEd9JJdWe/aVQos6/Z8H7uyXo1DCyzr/kzRFyQqCvHxcfzyy3jUag3NmrUEbB39wYP7GTlyNDNmzKNt2/Z8/vlH7Nu3RzwuISGelSuX8fXXo5kyZSaCIPDdd/8TR9Off24z1f/yyx/Mn7+MF14YyJw5M9m7N++aBR9++Clt23YgNLQuq1ZtpEWLcDw8PNm4cZ1Y5saN65w9e5ouXfKPTTh4cD8JCfE8/XQ7AgICqV27Tr7ukDNnTnHixDHGj/+VX3+dRExMND//PM6uzKRJv9GlS3f++Wc+3br1ZOrUP8UYlAMH9vH118Po2bMXc+Ys4pNPhrF9+xZGjx4JgE6n4+OP30Gt1jBp0t/MnbuEtm078PvvP5dK3Ievrx/TptnM+2PGjOf55weSkBDPu+++QWBgOaZNm824cb+SmZnBkCGvo9XeST63fv0a+vV7nkmTptO8eUt++ul79Hodf/zxF7NnLyQ4uALDh39id0xh3Lx5g2vXrtCy5VN223ft2sH+/Xv5/PMReY6Ji4sT25Ebb29vYmNt/UR8fGw++20B8rGxMUWqI4cWLVrl+5t70ph3bp44I+Rq6lUOxRzidsZtrFYrmcZM9t7ae+dze2+x6i7THu5sdBoZehMtqtwZwbup5YQGunHoaiI96wXald91MR5XlYynq/vald/zRdtCz9OuXbsC923atAmpVIpEcn9pWAVBQBBs/9/dz8XqbMvKuyncCHAOvO9zlSWFtfNhoVZI8fFxZ8ALP/B5u6r0dyp9C8b9tPNJy+g7Z85MFi6cC9hG+QaDgYoVK/Htt9/j7+9PVNRNtm7dxN9/z6ZGjVqALS7j8uVLzJ8/mxYtwgGbH/zTT4dRrVoIAC+//BrDh39KYmIiLi7OdOrUlTZt2okWh759BzB37iwiIy/TqtXTdjI5OzujVCqRyWTiCLtjxy5s2rSeV199A7D51ENCalK1arV827V+/Wq8vX2oV68BAO3bd+K3337i9OkI0YqSI/fXX3+Lq6ubKNfkyb/b1dWlSw86deoKwJtvvs3y5UuIiDhBvXoNmD17Bt2796RXL5slpFy5ID777Es++GAI0dG3UanU9Ov3PL1798XJybaC76BBbzFnzkwiIy+L16ukSKVS3N1tweIuLq5oNBrmzZuFl5c3Q4d+IZb79tsf6NatHTt2bKVrV5syVq1addF1AHDr1i2qVKlCuXJBKJVKPvzwEzp06JzHolQQZ86cQi6XExx8ZwHLhIR4fvxxDF999S1ubu55jtHpbDPAcqxjOSgUSgwGQ3YZPc7OLnftt1mDDAZDkerIoUqVqixePB+LxVJguwSBx/o9DtCjSg8EHkwbylSxiEm1abmB7vZmWj9XFbdT8k4nvJqQSXkvDRvPxDBp52ViUvWElnPlq241qep7f0uPq+7TjSIIAjKZBJVKyOPPTDTatGUPpScBrr6oZI+my6YoFNbOh0mInzM3krVcTsy673uXH/fTTkGwiIrJ3S+fxOt5LXEidym4SecKieCXSOzKJh87U+Sy9rLe+wXZq1cf0SQvkUhwdXW1e4lfvmwbVb///mC740wmE87OLkgkgqhsVapUWTxfjtnabDahVqvp168/O3ZsZcmSBdy8eYPLly+RkBCf/YK/U0fO8XcUP9vfPXo8w8KFczl37jS1aoWyefMGXnrpFfHY3O1MSUlm797d9O7dF5nM5tZp374Df/zxCytXLqNu3XrZ5xDw9PTE3d1dPNbFxRmj0WhXX6VKlez+dnJywmQyIZEIXLx4nnPnzoiuG7gT83DjxjWaN29Jnz7PsXXrJi5fvsTNmze4dOlidrmctgt2bS+InHbmlMv5fvffFy+e5/r1a3To0MrueIPBwPXr18RzBgeXtzvn66+/yTfffM2uXTuoX78hTZs2p127DqjVKopCcnISrq6uyOUy8TqMGTOKtm070KJFS7ENuduaU7fZbLK7l0ajAbVanb2ujxKTyf6e5CgMGo06Tx055K4jB09PT8xmM+npaXh42M/ey/nNKZVylMrH9z0OMCZ8zAOru0wVC63RNhVIIbXXCpUyCSlaQ57yGToT1xOz+H3bJb7sWhNXtZyJ2y/Tb8p+tgxtjbezMt/zbNu2rVA5rFYrOt39JfsSBAGVSoZOZ8rTEd1IjQLATeGO1ShBZ3p8E4sV1s6HSSVPm5XiZlLWfd+7/LifdhoMRqxWK1YreRdLUt/DupK7/IMqm4uiLOjk4uJKYGCQfXW5jjFn57T5889peQIfJRIJFovtWgDIZHLx2Dv/W8jK0vLuu2+i02lp27YDnTp14+OPa/Puu29itVrt6sg5zmpF3AdQoUIlatUKZePG9Wi1OpKTk2jXriMWizVPOzdu3IDRaGTp0kUsW7Y4V7ssbN++lQ8+GIqrqxtWqxW5XGF37N1y3N2u3HVZLDb5XnjhZbp06Z7n2np5eZOQkMDgwa/h5uZOePhTNGzYhJo1a/Hss93E31DOb/Be9yqnnbmvcUF/N2zYmE8+GZanDmdnF/GcCoXS7pytWrVh5cqNHDy4jyNHDjF37iz++msyU6fOpHLley8KmNOenDpjYqI5fPggEREnRMUrZ4pou3bhDBz4Gj169AZsLpHy5SuKbYyPj8fHxxeLxYqPjx9Xrly2kzUuLh4Ab29ffHz87OrIIXcdOZhMtvMLQt5nI+c3p9cbsVrzWjM0mkd70cHcRGdE37NMgHPAPcvkR5kqFqrskYLBbEElubP0td5kQS3PK5pcJpCuMzHxhQaihWLiCw1o/v02lh2NYnDrkq92eb+r5UkkeV90OcRk3QbAQ+EplnlcKaydD5Oqajj6+wtIJQLGrudLPaX3/bTzMb69JaJSJdtzl5CQQIsWNcTtU6f+iUQi4c03375nHQcP7uPChXOsXr0JT0+bazQtLZWkpMQCj8lvFclu3Xoyc+Y0AMLDW4vui7tZv34NlStXYdQo+1FbRMRJfvrpe9avX8OAAS/le2xxqVy5CtevXyMo6E4Ww+PHj7J48QI+/XQYW7ZsJDU1lQULliOT2d57kZGXgdJ7V9x9rSpXrsK2bZvx9fUTXQZpaal8993/GDDgJRo2zJtHwmAwMHXqRDp16kq7dh1p164jOp2OZ57pxP79e4qkWPj4+JCWliq6Gby9fVi4cIVdmV27tjN58h/MnDkfV1dXXF3dKF++AsePHxVnkphMJk6cOEbv3v0AqF+/ARs3riUzM0N0Jx05cgiNxomqVasjl8vvWUcOKSnJKBSKAn87QP6DhseMzssLj70SEDjx8okS1V1sL7nOaObHTefp+ttuWv+4g1bjt9t9nhq/o8h1BWS7QGLvWlAqNk1HgFte01qAmxqZRLBze6jkUsp7ariZ/Oimd76drVh4Kx3ZNkuLyl4avLRpuGemojM51qwpSypXrkKLFq346afv2bNnF7duRTF//hzmzv2HwMByRarDx8cWN7Vp0wZiYqI5efIEw4Z9gslkyuMDz0GtVpOQkMDt27fEbe3bdyQjI521a1eJcQJ3c+HCeS5fvkifPv2pXLmq3adnz94EBQWzcuXyUuvUX3zxZXbt2s706VO5ceM6R48eZuzYb0lPT8PLyxtfX390Oi3bt28hJiaGQ4cO8L//fQnYTPX5kZGRQXJycpFlUGfPCrpy5TIZGRn07t2XjIwMRo0awaVLF7h8+RKjRo3g7NkzVKpUOd86FAoFZ8+eZvz4sZw+fYro6NusW7earKwsMSYlKyuLxMSEAuWoVSsUs9nM5cs2V49MJiMoKNju4+Fhy58QFBQsdu4DBrzEwoVz2bBhLVevXuH777/FYNDTo0cvAFq1ehovL29GjvySy5cvsXv3Tv76axIDBrwoxlXcq44cLl48T61aoUW+to8rNqtqwR+LNW/ysqJSbIvFyFWnWXo0Kk8a7xyKEwpSM8AFF6WMA1cSqeBlG3Gmao2cvp3Kyy0q5ikfVskTk8VKRFQKdYPcAZuicz0pix53BXo+SsRobSanQM2jK+PjRpD7HcXzUnwmddye7Dnnjzrffvs9f/31Jz/++D3p6WkEBpbj889H0K1bz3sfjK3Def/9j1m0aD7Tpk3Gx8eHdu064uvrx9mzp/M9pkuX7vz7704GDnyORYtW4e3tjZOTM0891Ybjx4/SpEnTfI9bv341zs4uYrBlbiQSCc899wK//DIuTy6FktKmTXu++QbmzJnB3Ln/4OLiSsuWrXj77Q+y97fjwoWBTJxom5kREBBI9+7PsGfPv5w9e0YM+szNb7/9xPHjR1m6dE2RZHBzc6dbt55MmvQ7UVE3+eijz5g4cSpTpkzknXfeQCqVUrt2XX7/fbLYsefH6NHj+P33Xxg2bCiZmRmUL1+R//3vOzEAdsGCOcycOY09e/LP2liuXBBVqlTl6NEjVK9eI98y+dGzZ28yMjKYNm0yqakp1KhRiwkT/hRjX5RKJT///Ac///wDb731Kq6urjz7bD8xkLcodeRw9OjhIv9uH2fmdp1r97fZaibdkM7qyNWcij/F1A5TS1y3YC2mWl5n1CYy9SZCy7nxdHUfVAppnsjSt58uukvix03nmX/wBuP71iPIQ83Y9ee4laxl40dPIZUIJGbqcVXJUcltrpKX/j5ITJqOsb3r4KGRM2HrRQ5dTWLzx63xdCqZf8tqtZKQkFGiY3OwBRDJ0emMdiYyg1lP5022BGMTmk6inlf9+zpPWVNQOx86mZn4VLL5/yYuP0z/8PuLnL+b+2mn0WggMTEaL68A5PJH2+dalBiLx40PPhhCaGhd3nrrHXHbk9jO/Hgc2rl27UoWLZrPnDmL7104Hx5kG8+ePc3HH7/LkiVr8k2Qda9n29vbOV8X3eOExWqh07JONPBpwPjW40tUR7EtFhJBQCWXsnhwc7Gzvx+GdgjBZLEybFkEOqOZsEqezBoUhkIm4WZSFq3G7+DHvnXp19jmn5wysBE/bDjHkLlH0RrMNK7owYI3m5VYqXjQxGptKY/lEgUB6pIFwjgonMiER9cN5uDhsXv3Ti5evMDp0xGMGDGqjKVxUBCdO3dn/vw5HD58gCZNmpW1OHYsWjSf558f+MRn3SwMq9WK0Wxk963dJa6j2IpF1zr+LDt2C63BXCqKhVQiMLxLTYZ3qZlnX7Cnhms/2Gdoc1bK+K5XHb7rVee+z/0wiNHa4ivc5G6oZKWb/dCBjZg0fVmL4OARYO7cWdy8eYPPPvsSPz//shbHQQHIZDK++uobfv55HI0ahRU5B8aD5ty5M9y8eYOvv/62rEV5KHx34Du7v61WKwaLgVPxp0jSJT34tUJy07dRMHsvJzLgrwP0axyEj4sS6V1zq7vXdcQS5BCjteUtcFO4oZTmPx3Wwf0Rm+5YQt0BTJ06s6xFcFBEatUKZfr0OWUthh01a9Zmxoy59y74hLD4wuJ83TY50RG9q/Uucd3FViz6TbmzLPrY9efy7BcEwaFY5CImyxa46a7wQCF5NN01jyUSCZmh9bmckElspolMvQknpSNVugMHDhwUhUZ+jfIoFhIkuCpdaRbQjL7V8wYNF5Viv4nvFTLzOOdoeBDkuEK8lN6PfVDPI4VaTfrWXfT7fS8Gs4VzsRk0Lu9e1lI5cODAwWPBzM4PzsJXbMXi6vd5V6VzUDDR2RYLT5VjRdPSRioRqOip5mJ8Jqei0xyKhQMHDhwUkwRtArujdpOoS8RH7UOroFb3FV8BDyDzZly6Dl+XouWN/y8QnW2xCHIKukdJByWhmo8TF+MzuZLomBniwIEDB8Vh/rn5TDg6AYPlTiI2pVTJsLBhPFvt2RLXW2zFwmS2MH3PVY5eTybTYMKSnZzLYrWSqjUSGZ/BpTF5E8/8F9GZdaQaUgCo4FypbIV50sjKwrNVGGP1Jra99DvRqY4ATgcOHDgoKrtu7uKHQz8AoJAq8FJ5kahLRGfS8e3+b/HT+NGyXMsS1V1sxWLC1otM3hkJ2MdbCNl/O6II7pATuKmUKPFV+ZWxNE8YVivSmzdwAwQrxKTrsVqtjjgWBw4cOCgC009PRxAE+lXvx6eNP0UlU6Ez6Rh/eDxLLy7lr4i/SqxYFHsC8doIW2fZtU4AlbycCPFz4e3WVajo7YQAjOtTt0SCPInkpPJ2VbihlDrcQw+ShAw9GXpTWYvhwIEDB48F55POo5QqGR42HJXM1j+pZCq+bPolKpmKc0l5Z30WlWIrFjGpOpyUMv54vgG9GpTDYrXyeecazHujKRJBYMXxW/eu5D9CjsXCTeGOypHD4oGhlkswW+F0dHpZi/JEMXz4p7z11qt5tr/99uuEhzfm+PGjdtt37NhKeHhj4uJiH4g8VquVDRvWkpycdM+yWVmZ/PPP37z66gt07Niatm1b8uqrLzBnzswCFzV7VDh8+ADh4Y0ZPvzTshbFwROMXCLHbDFjtBjtthvMBkwWEwppydMjFFuxyMm2KQgC9YPdiYzPJCXLgL+rCo1CytnotBIL86SRY7HwUHggd+SweGBU9NQAcMrx2ytVGjcO4+LF8+j1d+JXMjIyOHv2NL6+fhw4sM+u/MmTx6lQoSK+vg/G7XfixDHGjBmFTld4PE1CQjyDBg1k69ZNvPDCy8ycOY/ZsxfSt29/li1bzOeff/RIT4tft24N5ctXYN++3cTHx5W1OA6eUOr41MFkNfHFv19wK8NmELiVcYvhu4djtpqp611y70OxFYvqfs5k6k0MXXSChhU8EIAPF57gvQXHSdebkDh83CLR2culeyq9HL7/B0iV7JVxryVpy1iSJ4smTcIwmUycO3dW3HbkyEFcXFzp2bM3Bw/utyt/4sTxB7r2Q1GVgXHjvsNsNjF16kw6duxMuXJBBAUF0737M/z88x8cPXqYAwf2PjA574f09HT+/XcnL788CLVaw+rVK8paJAdPKG/WeRMJEnZG7aTr8q7Un12frsu7sjNqJwICg0IHlbjuYisWH7SrhkwqISpFi7NSRodafvx7KZ4Np2yj87Y1fEsszJNG7uRYDh4cFb1ta7BEpz3aM0OsVitak7ZMPiUZoZcvb7M+nDp1Utx28OB+mjRpSlhYMy5fvkhCQgJg6xCvXLlMWJhNsdDrdUybNpl+/Z6hbdsWvPbaC/z7706xnvXr19C3bw9+++1nOnd+ms8//xiA+fPn8Nxzz9CmTXP69evJP//8jdVq5dixI3zwwRAA+vXryfr1+S8XHhV1k/379zJo0Fs4OTnn2V+lSlXmz19Gs2YtC5Xj2rWrfPHFx3Tt2o5OnVrz1VdfEBMTI9bz3ntvMWbMKLu6x4wZxXvvvQVAdPRtwsMbs3nzRl555Xnatm3JW2+9anct82Pr1k2YTEaaNm3OU089zZo1KzGZ7GOHtFotv/76E88805kOHVrx7rtv2i0tf/78OT766B06dGhFjx4dGT9+DFqttlhy//PP3/Ts2Ym+fXtk39tIhg//hK5d2/H0083o378XixcvsKvn8OEDDBkyiHbtWtK7d1emTJmI2Wxm8eL5dOjwlJ2lyWKx0Lt3V5YsWVjo9XDw4Gjk14gfW/+Iu9Idq9WKxWrBarXionBhTPgYGvs3LnHdxZ4V0qqaD2vfD+dqQiYAY3vXQSaVcCEmjUYVPPmya40SC/OkkbNOSLBz+TKW5AlEEDCF2H5rlbxtHUhM2qM7M8RqtfLBgSGcST5VJucP9ajLb80mF/vaNGrUhFOnIsS/Dx7cz5tvvk2NGrVwdXXj4MF9dOvWk4iIE0ilUho0aATAqFEjuHDhPEOHfkH58hXYtm0zI0Z8xvff/0R4eGsAYmKiiY+PY/r0uej1evbs+ZfZs2cwevT3BAdX5MyZCL777n8EBATStm0HxowZz4gRnzNt2iwqV66Sr7wnThwDoEmTpgW2KTjY/nm8W46YmGiGDHmNxo2b8vvvUzAY9Pz552+8//5bzJq1AI3GqcjX7/fff+LDDz+lWrUQ5s2bxUcfvcOcOYsJDCyXb/l161ZTr14DPDw8adeuI+vXr2Hv3t20bt1GLPO//w3n6tWrDB8+kqCgYObNm8XQoe+zcOEK9Hot77//FuHhrZk6dSaZmZmMGfMNP/44lpEjRxdZ7s2bN/Dbb5PR63XI5XI+/vgdGjUKY9Kkv5HJZKxbt5rff/+ZBg0aUq1aCGfOnOaTTz6gX7/nGT58JLGxMXz77VdIJBKee+4FJk/+g127ttOpky0VwZEjh0hJSaZDh85FlslB6WIwG2hfoT2tg1tzIu4ECdoEvNXe1Pepj1wqv6+6S5Qgq7qfC9X9XADwcFLwx/MN7kuIJ5EsUybpRpvPv6Ijh0Xpo9GQvPsQAJUy9MBlEjMNJGuNeGoezXgW4TGcjN24cRi//fYzVquVa9euEh8fR1hYMyQSCY0bh3Hw4H66devJyZPHCA2ti1qt5tq1q+zevYtx4ybQsmUrAF577U0uX77IrFkzRMUC4NVX36BcOVvyuCNHDqJUKggIKIe/vz/+/v54e/vi5+ePXC7HxcW2lLW7uwdKZf6zrHICO93dPey2d+zYGrPZnOvvLnz22Zf5yjFp0u+o1RpGjhyNQmH7LX333Tj69u3Bpk0b6N276GsovPTSq2Ln+cUXX3H06GFWr17BkCHv5Sl75cplzp8/y6efDgdsSp27uwerVi0TFYsbN66zb98efv75D5o2bQ7Axx9/jkajIS0thY0b1+Hi4sqIEaOQyWyv92HDvhIVrqLSu3c/KlWqDEBycjL9+j1P7959RSvQoEFvMWfOTCIjL1OtWghLliygZs3avP++zeJToUJFPvtsBAkJ8bi7u9OyZSs2bVovKhYbNqylZctWuLu7F0suB6VH3zV9CXIOYkz4GJr4NynVuoukWKyNuI1aLqVdTT/WRty+Z3nHImQQk2WzVqikajxVDlfIg8TLSYGLUka63sTJW2m0qfboXW9BEPit2WR05rJx16ikqhJZcho1CiMtLZXr169x6NB+qlathpeX7fqGhTVj6tQ/AVt8RXj4UwBERl4GoG7d+nZ11avXkClTJtptCw4OFr937NiVdetWM2BAb6pUqUaTJk1p3boN/v75L4H+0kvPERsbLf7900+/4+bmDkBqaoooJ8CMGXOxWGzuoG+++SrPzJDccly5cpkaNWqKSgWAh4cn5ctXIDLyUgFXKn8aNLhjTpbJZISE1OTKlcv5ll23bjVSqZSnn24nln/66XasWrWMW7eiKFcuSDx/7dp1xOMUCgXvvz8UgMuXLxESUlNUKgDq129I/foNiyV3UNCd6+Hh4cGzz/Zj69bNXL58kaiom1y6dBGwuTQAIiMv5bES5baydOvWky++GEpCQjwajYZ//93B6NHjiiWTg9IlQZtAojYRD5XHvQsXkyIpFu8vOE6gm5p2Nf14f8HxQsddjtVNbeSk8naTu6GUOKaaPkgEQaCKt4YTt9I4F5P+SCoWYJNTLVOXtRjFwtvbm4oVK3P6dASHDh0kLKy5uC8srBk//DCa8+fPcfHieYYO/Tx7T/7xHBaL2a7DA+wsD+7u7sycOZ/TpyM4fPggBw/uZ+HCubz++mBee+3NPPX99NNvdvEHPj4+omJx4sQx2rXrKO4LCgoWFQulMu/zmFsOWzhK3recxWKxk//uuJW7YyGAPO21Wi1IJHlD20wmE5s2bcBsNvPMM53szmG1Wlm1ahnvvPOhWF9BOqJtf+EKZFHkzn2NkpISGTz4Ndzc3AkPf4pGjcKoWbMWzz57Z90omUxWqOIaFtYcLy9vtmzZhJubG87OzqLFxUHZ0LVSV5ZeXMr6K+vpUqlLqbqQixy8mfvHaC3kY3mEp3E9TGK1OTks3Bw5LB4EWVl4tArDo1UYZGVRxdvm976e7JgZUto0bhzG6dMRREScsOsMfH39qFixMqtWLcPJyYnq1W0xL5UrVwUgIuKEXT0nT56gYsWC3YKbNq1nxYql1K1bn9dfH8xff/1Djx692LZtM0CeF5+/fwBBQcHiR6lUUbFiJcLCmjNjxl9kZWXmOYderyclJaXQ9lapUoVz587YWTWSkhK5efOmKL9cLiczM8PuuKiom3nqOnfujPjdaDRy4cJ58TrlZu/e3aSkJPPJJ8OYOXOe+Pnnn/lUqVKN9evXYDAYqFChUna9d2bqmEwmnn22G1u3bqJixcpcvHjezu2za9cOevfuik6nK7Lcudm8eQOpqalMmTKDV199g9at25CebssZk9MvVKxY2U4mgMWL5zNo0IsASKVSOnfuxq5d27NjLbohlUoLPa+DB0uiNhGpIGX4nuE0nd+UTks70XNlT55Z+QzPrHyGXit7lbjuIlkscq9o6ljdtGjkrGrqofB05LB4EFityC6cF79Xzp5y+qjPDHkcady4Cd988zVgpU6denb7mjZtxurVK2jRIlwciVeqVJnmzVvy88+2dQiCg8uzbdtm9uzZxbfffl/gefR6W5Ckk5MT9eo1IC4uluPHj4pmfLXalq/k0qWLuLm5o9Fo8q1nxIj/8dFH7zBo0EsMHPgaderUQyqVcPz4MebNm0VMTDQDBrxQoBzPPNOHFSuW8e23X/Pqq29gNBqYOPFX3N3dadfOZk2oU6ce8+fPZs+ef6lUqTIbN67jypXL1KxZ266uadMm4enpRWBgOWbPnoFWq6Vnz7yLO61fvxpfXz969OiVx8oxYMCLjBkzip07t9GxYxdat27DL7+M45NPhuHj48u8ebMwGo00ahRGgwaNWLJkIT/99D39+79IamoKkyf/QZMmTVGpVEWWOze+vv7odFq2b99C3boNuHHjGr///gsARqNN+XrhhYG88cbLTJs2mU6dunLrVhSzZ8+kT5/nxHq6devJvHmzkMnkvP32BwWez8HDYduNbeJ3nUlHtCnabv/9WDBKfXVTBzZykmN5qhw5LB4GVbxtnUysY82QUqdBg0YYDHqaNm2BXG4fLR4W1pxFi+bnyV/xzTffM3XqRMaN+46MjHQqVarCd9+Nt/O7303Pnr1JT0/jn3/+Ji4uFhcXF55+up3YCVWpUpXmzVvyv/8N56233uX551/Ktx4vL2/+/nsOK1YsYeXKZfzxxy8YDEYCAwNp3rwlffr0FwM186NcuSD++GMqkyf/weDBryKXKwgLa8bXX4/GxcUWtD5gwIvcvn2L0aO/RhAE2rbtwHPPvZBnOmmvXn35449fiIuLpXbtOkyc+Bfe3vauuqSkRA4c2Mfrrw/Oo1QAdOjQmb/+msTKlcvo2LELX375P/788zf+97/h6PV6atWqw4QJf+Lh4YFEIjBhwkQmT/6DQYNewsXFmXbtOjJ48LvFkjs3bdq048KFgUyc+CuZmRkEBATSvfsz7NnzL2fPnqFXr75UqxbC99//zN9/T2H+/Nl4enrRt29/Xn75Ti6EoKBgateug8ViKdRy5eDh8Ha9tx9Y3YK1BBPc90cmkqo10jnUn5M3U/hs6UkSMwz0bxLMZ51CHruXutVqJSEh494FC0EiEVCp5Oh0RiwWK2/sHsiV9EgGVnmV10LeKiVJy56721lmZGbiUykAgPir0aQICjpMtiVsWvdmU3xd78/9dD/tNBoNJCZG4+UVgFz+aFurJBKhbO/jQ+JhtzM6+jb9+vXk99+n0LBhyfMBFJdH+X5arVYGDOjNSy+9So8evUpcT1m28V7Ptre38331fxarhcknJ7P84nLSDGk08G3AV82+orxr/ikLVl1exVd7v8qzfV3vdQUe8zAotsVi05kY3p13jI61/egc6s/QxSe4kp3TYsquSPzdVLzcvGJpy/nYcSeHRcWyFeQ/grtGjodaTrLWyInoVDq6OhK1OXDwKGAymdizZxdHjx4hMzOT9u073fug/yhTT05l8YXFjG45Gj+NH78c/YW3t77NymdW5ptb4mLyRZr4N2H8U+PttnsoC5/pYbKYsFqtyKVytlzfgtZkH5tWx7sOldxKblUqtmIxZVckFqsVH2clZ26nciUhk9BAN7rWCWD8pvMsPHTzP69YpBvTyDLZlK0KDsXioVHVx4nDN1I4G5NOxxCHYuHAwaOATCbj119/AmDkyNGo1Y/XzKiHhdFsZNbZWQxtNJSngmxTt39s/SPtFrdj642tdKnUJc8xl5IvEeIRgre66DPhdtzYwegDoxkTPobmgc0Zd2gc8dp4uzLlXcqz8pmVSCUlC7AttmIRGZeBRiFjZI/a/LPvGgDPNizHay0rMWVXJDeTskokSFkjkdyf+0YQBATB9n+czmat0Mg0eKo87rvuR4nc7cxn1tzDQyqB7PwGEqkEJAL1yrlyLVlLut5cqvezuO2USARkMhkSifDI3/syv48PiYfdznLlyrFv39F7FyxlHtX7uXr1xlKrqyzbWJRn+/bt2wwcOLDAOrZt25bv9vNJ58k0ZhLmHyZuc1W4UtOrJkdjj+arWFxMvkiHih2KLP/5pPN8susTzFYzl1Mu0zzQNsvr7oiIG+k32HRtE10rdy1y3bkptmJhsYJCJkEqEThwJREBaFzBE7PFiun/7d13eFRl2vjx75k+6QkJhCQILEhogVBC7whYERsuKriiuPtieRV9UXR39VrUVXcXO6L+WEVWFFAXdC2LoCyyUiLNSBWQFkhCep3+/P6YZMiQCCmTfn+uK1cm55x5znPPOTNz55ynuD0YDc3wrK4Bi6V+Q5hqmobBoMNi0ch2eWckjDBFEB4cisVUv7Kbk8pxNukMkfogPPO94yZYQoPAaOSKpDhCgs20CzIF9HjWNk6TSYemRREUZEFXx4y/sWhaEx/HRiJxth5NGWNDvrczSzMBiA32HxAuxhrDmZIzVbbPteWSY8thR+YOVuxfQYG9gKToJB4c9CBdwrtUu4/l+5bj8rjo3a434zuda0itaRp7Zu3B7XEz84uZ7M3Zy/oT6xsvsUiItHIos4hnvzjAtz+dJSrYRI/YEJ78ZC+lTjeD48JqVZ7Ho3hxw0+sTD1BQZmTlC5RLLy2L12iLz4e/9rd6fzvB7v5dv54OkVV3/Wspmw258U3ugBN07BYDNhsLk4WnAIgzBgOTj02T/3Kbk4qx9nUH2C2WeWDJrkBt5PSMgfvbTuBWa/j0igrl8bUfE6H89UnTqfTQV5eLh6PHpOpeY9h0ha+iEDibE2aMkaHw05+fi5KGaptvBkUZCIuLu4Xr0pcSEU7B5Pev1yz3kyBo6DK9ofzvCO46jU9T496mlJnKW/88Aa3f3k7H039qNrbIz+c/QFN03h29LMkhFbtGaXX6fn9sN/z63/9mrTsus9rVOvE4pahl/DEJ3t5c9MRFDB7ZCd0msb720+gAXeOql2Dj5e//okV247zlxv70yHMwp+/2M9v3t7OugfHYrrA1Y9TeaX8fs2Pv7i+turbylin847Yp5TiTIl31M1IUxQGzdhsW2nXReU4m1tc3aODCTfrOZxdyuz3drH4pn706Rhap7LqE6em6XC5XNhsNgyG5t4rpP7nfksgcbYeTRmjzWbD5XKhafqA18Fi8I7+6nA7fI8B7G57tSP2Duk4hM2/3ky4Ody3rHe73kz+aDJrD6/lzqQ7qzwnszSTMFOY3xWNvtF9ybPl+ZURZg7zW1ZbtU4sZg3vggZsPHiWPnFhvmnUkxLCuXFQApf37VjjshwuD//v25959IqejC+fbv3VWwYy9Jn1fLk3g6n9qx8a3ONRPLhyN0nx4Xx3JKe2ITS4M6XexCLK3K6Ja9K2GHQab9zcn7ve38PPuaX8btUeXr0hif4J4Rd/cgDpdHqs1hCKi71vTJPJ3Gy7YGtaxRDWrZvE2Xo0RYxKKRwOO8XFeVitIdUOy15fsUHeWyBnS8/SKezcXC1ny87SI7JHtc+pnFQABBmDSAhJ8N1WOZ9BZ6DYWYzT48So894ufnH8i37beJQHh9tBsLHuV3zrNEDWzOFdmHlez49/zh1Z63L2nSmk2O5iRLdzX8DhViN948LZ/nPOLyYWr31zGIdb8b8TuzfPxKJ8cKxoq/RMaDBlZURc6501Mn/tl1De0jzMYuTvtyRz98o9/HS2hLkfpvHS9X0YfEngJ9q5kLCwKABfctFctYVL5yBxtiZNGaPVGuJ7bwdaYlQiIcYQUjNTfYlFoaOQ/Tn7mdFzRpXtVx5Yyau7X+WrG7/yXeEodhRzvPA4119adXRXgE6hnTiQe4ANJzZweZfqp6zfcGIDNpeNXlG96hxLnRKLglInZwrL6BkbRn6pg0VfHSKn2MFNgxMYV4tufhkF3ntKcRH+l3k6hFk4nV/90My7T+bz5rdH+eTeUWQU1Gz45okTJ/7iun//+9/o9fqA9SKAc/OEdA7t3Ox7BdRWs+kVgsK4excAOhRUep3DrEbevmUAd6/cw76MIu7/+EcWXdeHEV1rfgWp/nFqREZGEx4ehdvd9O1RqqNpGmazAbu9edYvUCTO1qOpYtQ0Db3e0CBXKiqY9CZm9JzBCzteINIcSVxIHIt2LCI2OJbLLrkMt8dNnj2PEGMIFoOFsZ3G8vKul3ls82PM7T8Xu9vOiztfJNISydRuU6vdx+TOk9mfs59ntj6DDh2Tu0z2W7/u2Dqe3PIkmqZV2wulpmqdWBzIKOTWt7YxLrE9f5ven/ve38V/D2ejgC/3ZvDOHSmMvjSmRmWVOb0T5Zj0/gfLbNCRX+aosn2pw8UDH+zi0St60jU6uMaJRU0EqheBXZfvmxo7sV2Pepfb3DSbXiHuc6+rxWKE815ni8XI8t8M5s5/7GT3qQIe/HgvL9zYjwmJNTs3Axtn82zAWRGj2exptV9EIHG2Jq09xnuS78GlXDy55UlsLhuDOgxiyaQlGPVG0ovTufyjy1k4ciHTuk8jNjiWpVOW8sKOF5j1xSwUiuFxw/n7lL/7tdGobFbvWXz282cczjvM/236P/609U90CumETqfjeOFxihxFKKXoGdWTGy69oc5x1Dqx+Ou/D5Jb6iCv1EF6fhmbD2cTE2KmX0I4Gw5ksfibIzVOLCwGb3cdh9uDpVLXHbvLg9VYtWpPfrKXrtHB3Dq0c63qfLEWukqpgPUK+TnvBADBhhDMylrvcpubZtMrxOak4g6gzeYEffWv8+s39eO+D9P4/mQ+D6zew9PX9GZSDZKLZhNnA2oLMYLE2Zo09xiDgurXWFuv0zNv0DzmDZpXZV18SDxpt/v31OgZ1ZM3Jr1R4/KNeiNvTnqThzY+xK6sXRTaC9lr3+u3zeDYwfx51J+rHemzpmqdWOw+WYBRr2PR9P6s2+dtIHLr0M7cM74bSU+u46esohqX1bH8FkhmoY3O7c41FMkstNGrY9Vuq6u+P4XJoKP3H72DrbjLW+VOfmET1w2M55nrkmobjk+geoVklPcICTOGY9RMra6FdrPpFVJp3x6P8vu7MoNO45Ub+jJvzV62HMvjsU/3sfNEHHcNv4TIC3wINJs4G1BbiBEkztakLcTY0KKt0Sy7Yhnbzmzjm5PfkF6cDkBCSALjO41nSMchFynh4mqdWBTbnYRZjEQEmdj+cy4akNIlEoNeh9moo8zhrnFZvTqGEmo2sPVoji+xKChz8uPpAmaN6FJl+40Pj/P7e/fJfB5YuZu370ihe/uQ2obSICqmS48wR2DWVX85SjQug17Houv6suDTfWw8nMOq3adZ+2MGvx4Yz+0pnQi1yCS/Qoi2ZWjHoQztONT397pj68gozQhI2bX+RO0QZiE9r4yNB7PYeDALs0HPwM6RrN2dTkGZkx7taz5ugNmgZ9aIzjz7xQGigs0kRFp55vP9xIVbubxPLG6PIqfETpjFiMWorzJo1pnyNhbxEVaiQ5rHfeyK6dIjTVFVBjoRTceg03h+am/WHTzL65uPkV5gY9n2k3y4+zQzBydwy+AErMbmPUqmEEI0lOdTnye7LPsXG37WRq2buE7q1QG3Usx+J5XcEgeTenfA7VE8sHI3Gt55Q2pj3qREpqd04tGPfuDG17/DoNNYNnsIJoOO0/llDHl6A5/uOV3bajaZ06Xey0rtZAyLBudp1w5Pu9r19JjSsz0fzx7MY5d1p0OomRKHmyXfHeeaN7exYscp7C5PA9ZYCCGaL0Vgbi9pqpYtYIrtLh758Ac2HsyiT1w4r946gPahFoY8vZ5hv2rHCzcno29hXSyVUmRnF9erDJ1Ow2IxctMX13Oy5ASze9zNbd1/E5gKNiMVcdpszhZ/j9Pl9rBy12neTT1Jbqm38WeQSc+YX0UxqWd7xvVsD25Pi4/zl7SmY3khEmfr0dxjjI4OabaD4V3MZasv42zZWfbM2lPvsmp9KyTEbOC1WwdWWb7mnpFVxqNoa5RSZJZ571F1Dqn7XPaicRj0Om4dnMBNyR1Ztv0UK3elU2Bz8eWBs3x54CwW435Gdo3ish4xjOgaRZBJbpUIIVqnQF2tgDoOkAWw52Q+mw9nk1FgY+G0vpzOL6NjuKXFZmuBkGvPweFxoKFxSXDtusSKpmMy6JkzojO3D+nExsPZfLk/ix9OF1Jgc7HhUDYbDmVj1GsM7RzJ6G7tGNY5krhwaZgrhGg9Vly5AreqeeeLC6l1YuF0e3jgg9188eO5aVwXTuvLPSt2Eh9h5Z3ZQwhrZYNC1VTF1LYhxtB6jbMuaqCsjPAZ3gFcCt7/yDekd32YDDom92zP5J7tcStF6qlCPt51ij3pheSWOtl8NJfNR3MBiA+3MKJrFCO6RjIwIUKuZgghWpQ//PcPRJgjeGjwQwB0CO4AgNvjZv6m+YSZw3hi+BN1KrvWicUrG37i8x/PEBNipqDMidPtoczhJqfYwdkiO4vWHeLJqX3qVJmW7nSJt+FmmDEMi17+o21QHg+m7zb7HgeaUa9jQmIMIzpH4HC6+f5kPp/vy2JfRhEn8stIL7CxevdpVu8+jV6n0S8ulJROkfSKDaFXh1DaBUuPICFE86GUIqPkXHfStYfXEmON4dZet/oNNlbqKmVz+mY0TWu8xOKfu9Mx6DTW3juS6xd/R2ahDatJz9p7R3Ltq//l33sz2mxiUTGGRbgpArMkFq2GQa9jWJcohnWJ8rajKbKz/mA2W4/ncTCrmPwyJ7tOFbLrVKHvOdHBJnrHhtAnNoxesSH0bB9ChNXYpm8VCiGajqZp/OG/fyA1M9W3LNuWzZSPplS7fZSl7pOt1TqxyCzwjivRMdz/0nOfuHCCTHpyS6rO8dFWnC45N116xZS0onXRNI3YMAu3pSRwW0oCTreHvRlFrD94lkNZJZzKL+NsiYPsEgebjuSy6Uiu77khJj3xERY6RVhJiLDSKcJKfISFhAgrMSEmdJJ0CCEa0Pwh85n+6XQ8yuP7J6e6jqE6TcdtvW6r835qnVh0jLBwMreUH9ML/JYv33KMIruLrtFtt21Bxa0QGcOi7TDqdSTHh5McHw54h5nPKrLz/cl8dqcXcDy3jFP5ZeSUOil2uDmYVcLBrJJqytHoEGomLsxCfISFuDALceEWOoZZ6BhuISrIKImHEKJeekT2YPU1qyl1lTLz85lEWaJ4ecLLvvUaGnqdnrjgOCIsEXXeT60Ti1uGXMKzXx7g+te/82U6g59aT26JHQ24YWBCnSvT0lUkFh2ssU1cE9FU9DqNjuEWrgmP5Zq+3vPA5VFkF9s5dLaEo9klnMwvI6vYQXaxnZxSZ3lbJcWpfBun8m1womq5Bp1GdLCJ9qFmYkPNtC//6RBiIjLIRLjVQLjFSLjFgEHfpPPZCyGasUsjLwVg6ZSlmPQm+sX0C/g+ap1Y/HZsN84U2Hh3yzFfr9ecEjs6TWP64AR+N7ZbgKvYMniUh8xS76Rs0tVUVGbQeW+fxIZZGNPN/2qWw+Wh2O7ieF4pR3NKOZFXRlaRN+HILXGQX+ak0ObC5VFkFNnJKLLzw0X2F2TUE2YxEG41EGE1ERlkJMJqJMJqINLqfRxuNRIVbCI2MgizVocheIUQLVpKbAoF9gIO5R2iR2QPCuwFvLrrVXJtuVx36XWMih9V57LrNI7Fk1P7cMfILnx3JIfcEgftQ82kdImqMpdHW5Jty8alXOjQkRBySVNXp01QQUFNXYV6Mxl0RBlMRAWbGJAQ4bdOKYXDrSi2OTlZUMbJPBunC2xkFdvJLXWSX+b9KXW4KXO6sTk9KKDU6abU6SajyA5Uve1SnVCznnCLkYggI5FBRiKtRsIsRoKMeqwmPUFGHRaj3ve31agnxKwn1Gwg1GzAbNBJw1QhWpBDeYeYs24Oo+JH8fSop5m/aT5bz2xFKcWGExtYfNliRsSNqFPZdR4gq3O7YL+pztu6isnHQoyhBBvkdWlwwcFkHwvMTHzNlaZpmA0a5hAz7ULMJFczDY9HKZxuhdPtwe70kFNqJ7vYSXapg9wSB7mlTkrsLorKf4odbkodbkocrvKExNtVt8jupsju5lT5xH61ZdBphJj1hJgMhFoMhJgNWI16gkx6rEYdVqM3GQky6rEY/ZdZKj22VkpgjHpNkhUhGsgrO18hz5ZHvj2fM8Vn2HJ6C9HWaPq068N/Tv2HpWlLGzaxmPHm1hoXqGmwYs6wOlWmJcvwdTUNl66motHoKpIPg44QM7QLMdGj/YWfU5GMuJVC6XWk55SQUWgju9jbmyWvzEmxzZuEOFwe7C4PDve53063B7tLYXedu0ri8ijyy1zkl7mg4ML7r3lslCch5YmIwZuomI06zHodZoMOk6H8d/nfRr33sVGvlT/WMBn0BFmM4PFg1uuwlCcvvuTG4E1u5KqLaEvSstMw6ow8M+oZvj7xNQA3Jd7EnKQ5jHh/BIfzD9e57BolFlt/zqmyTINqRxZvq2/LjFJvV9MIUyRmffOYwl2I6lQkIxUTOoUadPSICbno85RSeJS354tHKVwe75WSQpuL3BIHeWUu8ssc5Je5KLK5sLnc2F0ebC43DpfC7vJgd3uTFYdblf/24HQrX8LicHkTHgCPgtLyKyyNQcN7a6oiGTHrNcwGPSaDDotBh0GvoddpGDTvb71Ow6DT0GkaBl8i45/UnFtWsVzDqPM+NpQvM+g0DDqdrzxDpbL1Ov+yKsqRHkKivkqcJYSaQgk3h7MjcweapjGw/UAMOgMmvQmbq25XL6GmVyyGXFIlYVix/QTBJgPXJsfVeeetiVHnHWkxPjhBxrBoDDYbYbO9/awL//4PsMhVooamaRp6jSqzF0cGmegcVfv2Lh6l8Hi8CYpHef92e7wJSJHdSZHNTZHdRYnDRYndTYnDTanTRZnTm4y4PN5kpOJWkMNdfiXG48FVXq67/MejKN+2YrtzSY2rfJZMBd7kxwXYGyeZqSu9TsOo8yY0Ok1DXynZ0TR8f1ckKka9rvz3ucfebX85QfGW4R0gzlCePJ2f9OjPS7IqL/Ntq/dPnPQ6DZ3mTXArflfUWau0TK9p6HSVH3vrH2R143a60cG5ZK+83ApKlf/jq/yn1tLrJCmrEBMUw5niM2xO38y36d9i1ptJbp/MZ0c/o9BeSLeIunfEqFFi8cx1SVWWrdh+gjCLgaerWdcWTe82A6NBT6Qxuqmr0ja43ZjXr/M9Fi2PTtPQ6TUM1Uyz0j40cFf9dDoNs9lAmc2Jy+XBXSmJcXu8V0uK7W6K7S7KHG7KXB7KyhMYm9ONzeXG5vLgLL+a4q6UCHk855a5PApXeaLirEhuyhMgt8d7pcddab9+fyuFx1NeplK4/R4r3OddHq54Pq6AvUxtSkVyU5GwWAw6/nfsr7iyd4emrlqjGd9pPMv3LeeeDfcAMKXLFNweNwu+XYCmaUztNrXOZde58abwp9f0XBLaGadTvuSEaG68/wl7bz9U96FXgztBAaPK/4v2qHO3lyqWqfKEBby/lfIucykPDpcHm9N7a8nmPNfuxXdVBkCvw2534XR78HgUTk95416XB4fH40t8XOW3sy6kImlyucsTnEpJTsXtMI8Hb1LkS7jOT4rOPa58G63iikLluH2vBf6vi3dZpWROeetWn0m+3R6FG3CWl1LqcJN6Ir9NJRZzk+eSUZLB5vTN9IzqyfyU+QQZg4i2RjM4djCzes+qc9mSWATQoPaDsdvlXwghxC/TNA0Nb+PUQLZKq2gzY7M58Xjq87UbWJUTKSonEpXW+7b1rfMmH+fK8C7TtHNXn+wuDy63x9dmx+Xx+J6jld9eAe8rXPHY7VE43eDynEu83B6FBvTpGNqQL0OzczT/KM+OebbKrfsVV60gNrh+gzxKYhFAwcZg9O7m9aYWQoimFMhEqiJ5sug0+Zytp/u/uR+Xx8Un0z4h0hLpW17fpAJqmFj8fk1atcsLba4q6zQ0Fk7rW++KCSGEEKJh6NDhUR6/pCJQapRYvLftRLV5ZonDxYpt5yY2UHjzUUkshBBCiOZrbvJcFm5dyJ+2/Imp3aYSExSDWW9Gq/Rt385atwk1NVXdnKnnufmNLdSmh84Hdw+vU2WaSg1eAtEMaS5vexZlkDt6QojmoaUMsjbmgzEUO4txq+o7HGho7J61u05l1+gTeeVvW1aiUFst5UQQ5zF6Gx3J0RNCiNrJt+dfeIN6fLDW6IqFEEIIIVqP1IzUi26TEptSp7IlsRBCCCFEwMjNaSGEEKINKnQU8vru19lwYgM5ZTnEBMUwqfMkftf/dwQb6z5Lt1yxEEIIIdqYAnsBM7+YyfHC434dGDRNo1tEN5ZdvoxQU90GDdMFqpJCCCGEaBle2/0axwqOEW4K57f9f8ufRv6Ju/vdTbgpnCP5R1i8e3Gdy5YrFkIIIUQbc9nqyzhbdpZVV68iMSrRt/xA7gGmfzqdDsEd+OrGr+pUtlyxEEIIIdqYPFsewcZgv6QCoGdUT0KMIeTZ8upctiQWQgghRBvTMaQjJc4Stp/Z7rd865mtFDuL6Rjcsc5lS68QIYQQoo2Z0mUKb/3wFnM3zGVKlykkhCZwqugU/z72bzRNY3KXyXUuW9pYCCGEEG2M3W1n9pezSctO8xt9WilFz6ievHvFu1gMljqVLYmFEEII0QY5PU5WHljJhhMbyC7LJtoazZiEMdzS6xbMenOdy5XEQgghhGgDntr6FIM6DGJQh0G0D2rfYPuRxEIIIYRoA/ot6+e77REfEu9LMgZ1GESn0E4B24/0CgkAj8fDyy+/zOjRo+nfvz+zZ8/m+PHjTV2tC8rPz+ePf/wjY8aMYeDAgcyYMYPvv//et37BggUkJib6/YwZM8a3viYx79+/n9tuu43k5GTGjRvH0qVLGy0+gPT09CoxJCYmsnr16hrVryXEuG3btmpjTExMZOLEiUDLP5aLFy9m5syZtapPIGJq7Pd1dXF+/fXX3HDDDQwYMIAJEybw3HPPYbPZfOsvdo63lDgb4xxtiZ/TgXZp5KXo0KGU4lTRKT458glPfPcEV//zaiaunsj8TfNZdXAVR/KP1G9HStTbK6+8ooYPH642btyo9u/fr2bPnq0mTZqk7HZ7U1ftF91xxx1q6tSpKjU1VR05ckQtXLhQ9evXTx0+fFgppdR1112nFi1apLKysnw/OTk5vudfLObc3Fw1dOhQ9fjjj6vDhw+rDz/8UCUlJakPP/yw0WLcsGGDSkpKUpmZmX5xlJWV1ah+LSFGu93uF1tWVpbavHmz6t27t1q1apVSqmUfy7ffflslJiaq2267zbessY5dY76vq4szNTVV9erVS73xxhvq2LFj6j//+Y8aO3asevTRR33bXOgcbylxKtU452hL/JxuCKXOUrX9zHb11g9vqXs33KvGfjBWJb2TpJLeSVL9lvXz/Yz5YEyd9yGJRT3Z7XY1YMAAtWLFCt+ygoIC1a9fP/Wvf/2rCWv2y44dO6Z69OihduzY4Vvm8XjUpEmT1IsvvqhcLpdKSkpSX331VbXPr0nMS5YsUaNHj1ZOp9O3zd/+9jc1ZcqUBoqqqtdff11NnTq12nUXq19LifF8DodDXXXVVeqBBx5QSqkWeywzMjLUnXfeqZKTk9Xll1/u90XUGMeusd7XF4rzoYceUnfccYff9mvWrFG9e/f2fRle6BxXqmXE2RjnaEv8nG5MR/KPqIVbFqrBywerfsv6+ZKMupJbIfV04MABSkpKGDZsmG9ZWFgYvXv3JjX14vPdN4XIyEjefPNN+vbt61umaRpKKQoKCjh27Bh2u51u3bpV+/yaxPz999+TkpKCwXBuqJRhw4bx888/k5OT00CR+Tt48CDdu3evdt3F6tdSYjzfe++9x5kzZ1iwYAFAiz2We/fuJTw8nE8++YT+/fv7rWuMY9dY7+sLxTl79mzmz59f5Tkul4vi4mLgwuc4tIw4G+McbYmf0w3J6XGyM3Mnb/7wJnPWzeHX//o1qw+txu62+yYkiw+Jr3P5MkBWPWVkZADQsaP/KGXt27fnzJkzTVGliwoLC2Ps2LF+y7744gtOnDjBqFGjOHToEJqmsWzZMjZt2oROp2Ps2LE88MADhIaG1ijmjIwMevToUWU9wOnTp2nXrl1Dhedz6NAhYmJiuOWWWzh27BidO3dm7ty5jB49+qL1aykxVma321myZAm33367rx4t9VhOmDCBCRMmVLuuMY5dY72vLxRn7969/f52OBy8/fbb9OnTh6ioKODC5zi0jDgb4xxtiZ/TDWHJniV8n/E9P2T/gN1tB/AlEpGWSFJiUxjWcRjDOg4jITShzvuRxKKeysrKADCZTH7LzWYzBQUFTVGlWtuxYwePPfYYEydOZMKECbz88svodDri4+NZsmQJx48f57nnnuPQoUMsW7asRjHbbLZq14P3C7ChORwOjh07htVqZf78+QQFBfHJJ58wZ84c3n777YvWryXEeL61a9dit9v9Gsb99NNPLf5Ynq8xjl1ze1+7XC7mz5/P4cOHee+994CLn+PDhw9vEXE2xjnaHOJsDhbvXuy7Om0xWBjYfqA3kYgbRs+ongHbjyQW9WSxeEcmczgcvsfgPZmtVmtTVavG1q9fz8MPP0z//v1ZtGgRAPfddx+/+c1vCAsLA6BHjx7ExMRw8803k5aWVqOYLRYLDofDb18VX0JBQUENHpfJZCI1NRWDweD7MOnbty9Hjhxh6dKlF61fS4jxfGvWrGHy5MlERkb6lrWGY3m+xjh2zel9XVxczAMPPMC2bdt4+eWXfbcSLnaODx8+vEXE2RjnaHOIsznRNI1LIy6lf/v+JLdP5tKISwNavrSxqKeKS2tZWVl+y7OysoiNjW2KKtXYP/7xD+677z7GjBnDW2+95XvDaZrme5NXqLjMmJGRUaOYY2Njq10P0KFDh8AHU42goKAq/6H06NGDzMzMi9avpcRYITc3l127dnHllVf6LW8tx7Kyxjh2zeV9nZWVxa233squXbt46623qtxOuNA5Di0jzsY4R5tDnM3B1b+6mhhrDEop0rLTWLJnCbd/eTujPhjFfRvu4x/7/sHhvMP13o8kFvXUs2dPQkJC2LZtm29ZYWEh+/btY/DgwU1YswtbsWIFCxcu5NZbb+XFF1/0+3B66KGHuPPOO/22T0tLA6B79+41ijklJYUdO3bgdrt922zZsoWuXbs2StuDAwcOMGDAAL+xOQB+/PFHunfvftH6tYQYK9u5cyeapjFkyBC/5a3hWJ6vMY5dc3hfFxQUcPvtt5Obm8uKFSv8Gh7Cxc9xaBlxNsY52hzibA6eGf0M629az5ppa1gwdAHjEsYRYgyhxFnCf079h798/xdu+PQGJqyawGPfPlb3HQWms0rbtmjRIjVkyBC1fv16X//oyZMnN9v+0UePHlV9+vRR99xzT5UxEAoLC9XXX3+tEhMT1eLFi9Xx48fVxo0b1YQJE9S8efN8ZVws5uzsbJWSkqIeeeQR9dNPP6mPPvpIJSUlqY8//rhRYnS73eqmm25SV199tUpNTVWHDx9WzzzzjOrbt686cOBAjerX3GOs7JVXXlGTJ0+usrw1HMtHHnnEr3tiYx27xn5fnx/nI488ovr06aO2bNlS5X3qcrkueo63lDgb6xxtaZ/TjcXtcas9WXvUo5seVcnLkv3GtKgrSSwCwOVyqeeff14NGzZMJScnqzlz5qiTJ082dbV+0euvv6569OhR7c8jjzyilFLqyy+/VNOmTVP9+vVTI0eOVM8++6yy2Wy+MmoS8549e9T06dNV37591fjx49Xy5csbNc6cnBy1YMECNXLkSJWUlKRuvvlmlZqaWuP6tYQYKzzxxBNq+vTp1a5r6cfy/C+imtQnEDE19vu6cpxut1slJSX94vu0oh4XO8ebe5wVGuMcbWmf0w0p35avNp3cpF7b9Zr67brfqhErRvgGxgpEYiFzhQghhBBtwOObH+eHsz9wouiEb1nlFCDSEklyTDIDOwxkUIdB9I3uW10xFyW9QoQQQog24NMjn/r9HRcSx8D2AxnYwfvzq/BfBWQ/klgIIYQQbUD3yO4Maj/Im0i0H0iH4Ibp1SW3QoQQQggRMNLdVAghhBABI4mFEEIIIQJGEgshhBBCBIwkFkIIIYQIGEkshBB4PJ6mroIQopWQxEKIVmrTpk3ceeedDB06lD59+jBy5Ejuv/9+9u7d69tGKcWHH37IQw891IQ1FUK0JtLdVIhW6NNPP+Xhhx8GwGg0EhISQn5+PkopTCYTy5cvJzk5meeff56lS5cyZMgQli9f3sS1FkK0BnLFQohW6JVXXgFg2rRppKamsnXrVjZs2EBCQgIOh4NXX30VgOLi4qasphCiFZIrFkK0Qv369cNutzNz5kwef/xxNE0D4JtvvuG7774jMjKSEydO8M9//tPvee+++y5Dhw4lIyODv/zlL2zatAmHw0GvXr2YO3cuY8aM8W2bmJgIwNKlS/noo4/YuHEjFouFadOmMW/ePIxGIwBZWVm89NJLfPfdd2RnZxMeHs7QoUOZN28e8fHxjfSKCCEaiyQWQrRCc+bMYdOmTQB06tSJcePGMWLECIYOHUpwcDAAf/7zn1m1ahWlpaUYjUaioqJ46aWX6Nq1K9dffz3p6ekYjUaCgoIoKChAp9Px6quvMnHiROBcYhEdHU1OTg5Wq5XS0lLAe6XkueeeA+DGG28kLS0Ng8FAWFgYBQUFuN1uOnfuzGeffeZLQIQQrYPcChGiFXryySfp0qULACdPnmT58uX8z//8DyNHjuSpp56ipKSEBQsWcM011wAwYMAANm3axIABA3jnnXdIT08nJSWFbdu2sX37dp566ik8Hg9//etfq+zLZDKxfv16du7cyV133QXAmjVrOHr0KLm5uaSlpQGwdu1atmzZwrp160hJSWHw4MFkZ2c3zgsihGg0MgmZEK1QfHw8n376KZ9//jlfffUV27dvp7CwkLKyMpYvX86pU6dYsmRJtc/dunUrAPv27eOKK64AznVHPXr0KBkZGcTGxvq2nzFjBgkJCQDcf//9vPPOO7hcLnbs2MH1119PfHw86enp3HXXXYwZM4aUlBRefPFFoqOjG/IlEEI0EbliIUQr5Ha7KSgoYNq0abz22mts27aN1atXM27cOMDb1iI9Pb3a5+bl5QFQUlJCZmYmmZmZnD171rc+IyPDb/uYmBjfY7PZTGRkJABFRUXo9Xreeustxo4dy9mzZ1m5ciUPP/wwo0eP5sEHH8RutwcybCFEMyCJhRCtzPbt2+nbty+jRo3iyJEjAOh0Ovr16+frggqQk5Pja9RZWUWiMHv2bA4ePMjBgwdJS0sjLS2NgwcPkpyc7Lf9yZMnfY8dDgf5+fkAREREANCtWzcWLVrE1q1bWbJkCXPmzMFqtfL555/z7rvvBjByIURzIImFEK1McnIyVqsV8La1yMzMBLxXIP7+978DYLFY6Nq1KwaDwbcOwOVykZKSAnjHwjh+/DgAL7zwAgMGDGDGjBm43W6//a1atYqff/4ZgCVLluB0OtE0jZSUFHbt2sWwYcNISUnhwIEDjB8/nnvuuYfOnTsDkJub25AvhRCiCUgbCyFaGZPJxMKFC5k3bx7bt29n7NixhIeHU1RU5EsK7r33XkJDQ+nUqRMAe/fuZdCgQTz33HPMmjWL1atXc/bsWaZMmUJoaCiFhYUAXHnllej1er/9lZSUcMUVVxAUFORLUG666SY6depEXFwcXbt2ZefOndx2221ERkZSUlKCw+HAbDb7Go8KIVoPuWIhRCt01VVX8eabbzJq1ChfUhEaGsqwYcN46aWXmDNnDgDXXnsto0ePxmq1YrVaMRgMREZG8v7773PllVcSHh6O3W4nMTGRZ599lpkzZ1bZ16OPPsq1116LUoqoqCjuvvtunnjiCQBfG4u7776bzp07U1paSnh4OGPGjOHdd9+ld+/ejfq6CCEanoxjIYSok4pxLBYtWsRVV13VxLURQjQXcsVCCCGEEAEjiYUQQgghAkZuhQghhBAiYOSKhRBCCCECRhILIYQQQgSMJBZCCCGECBhJLIQQQggRMJJYCCGEECJgJLEQQgghRMBIYiGEEEKIgJHEQgghhBAB8/8B+P+bo3PuZigAAAAASUVORK5CYII="
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "execution_count": 43
  },
  {
   "cell_type": "code",
   "source": [
    "new_dir = './logs/ISR_Hessian_results_new'\n",
    "\n",
    "file_patterns = ['CelebA_results_s*_hessian_exact.csv', 'CUB_results_s*_hessian_exact.csv', 'MultiNLI_results_s*_hessian_exact.csv']\n",
    "\n",
    "file_list = []\n",
    "for file_pattern in file_patterns:\n",
    "    file_list.extend(glob.glob(os.path.join(new_dir, file_pattern)))\n",
    "\n",
    "for file_pattern in file_list:\n",
    "    df_new = pd.read_csv(file_pattern)\n",
    "    # round gradient_alpha and hessian_beta to 8 decimal places\n",
    "    df_new['gradient_alpha'] = df_new['gradient_alpha'].round(8)\n",
    "    df_new['hessian_beta'] = df_new['hessian_beta'].round(8)"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2025-02-08T20:26:14.750500Z",
     "start_time": "2025-02-08T20:26:14.747409Z"
    }
   },
   "id": "ca2fe7c87d92043b",
   "outputs": [],
   "execution_count": 20
  },
  {
   "cell_type": "code",
   "outputs": [
    {
     "data": {
      "text/plain": "'./logs/ISR_Hessian_results_new/MultiNLI_results_s0_hessian_exact.csv'"
     },
     "execution_count": 256,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": "file_list[-1]",
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2024-05-08T00:08:59.720149Z",
     "start_time": "2024-05-08T00:08:59.670759Z"
    }
   },
   "id": "1e0a84233b852817",
   "execution_count": 256
  },
  {
   "cell_type": "code",
   "outputs": [],
   "source": [
    "df_new = pd.read_csv(file_list[-1])\n"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2024-05-08T00:10:07.161793Z",
     "start_time": "2024-05-08T00:10:07.146080Z"
    }
   },
   "id": "37933a0c667c4586",
   "execution_count": 260
  },
  {
   "cell_type": "code",
   "outputs": [],
   "source": [
    "df_new['hessian_beta'] = df_new['hessian_beta'].round(8)"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2024-05-08T00:10:56.807990Z",
     "start_time": "2024-05-08T00:10:56.801597Z"
    }
   },
   "id": "a8e17d4fb9afd396",
   "execution_count": 263
  },
  {
   "cell_type": "code",
   "outputs": [],
   "source": [
    "df_new.to_csv(file_list[-1], index=False)"
   ],
   "metadata": {
    "collapsed": false,
    "ExecuteTime": {
     "end_time": "2024-05-08T00:11:07.010892Z",
     "start_time": "2024-05-08T00:11:06.958793Z"
    }
   },
   "id": "f7e91027f88e3db2",
   "execution_count": 264
  },
  {
   "cell_type": "code",
   "outputs": [],
   "source": [],
   "metadata": {
    "collapsed": false
   },
   "id": "25a9da01618341a2",
   "execution_count": null
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 2
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython2",
   "version": "2.7.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
