{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Data Split Creation\n",
    "\n",
    "This notebook creates data splits used to evaluate gRNAde on a set of RNA structures of interest from the PDB identified by [Das et al. (2011)](https://www.nature.com/articles/nmeth.1433), which mainly includes riboswitches, aptamers, and ribozymes.\n",
    "When benchmarking gRNAde vs. Rosetta, the training and validation data for the gRNAde model explicitly excluded these RNAsas well as any structurally similar RNAs with TM-score threshold of 0.45 (we used US-align for clustering).\n",
    "Thus, we tried to ensure that gRNAde has not memorized the evaluation dataset for fair comparison.\n",
    "\n",
    "**Workflow:**\n",
    "1. Cluster RNA sample sequences into groups based on structural similarity -- qTMclust for efficiently applying US-align with similarity threshold 0.45.\n",
    "2. Order the clusters based on a metric (median intra-sequence RMSD among available structures within the cluster).\n",
    "3. Identify the clusters belonging to RNAs identified in the Das et al. (2011) paper.\n",
    "4. Add all the selected RNAs as well as all other RNAs in the corresponding clusters to the test set (~100 samples).\n",
    "5. Training and validation splits are semi-randomly split based on the remaining RNAs. Very large (> 1000 nts) RNAs are added to the training set. Validation set RNAs would only come from clusters with less than 5 unique sequences/samples.\n",
    "4. If any samples were not assigned clusters, append them to the training set.\n",
    "\n",
    "Note that we separate very large RNA samples (> 1000 nts) from clustering and directly add these to the training set, as it is unlikely that we want to redesign very large RNAs. We do not process very short RNA samples (< 10 nts)."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "True"
      ]
     },
     "execution_count": 1,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2\n",
    "\n",
    "import sys\n",
    "sys.path.append('../')\n",
    "\n",
    "import dotenv\n",
    "dotenv.load_dotenv(\"../.env\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import torch\n",
    "from tqdm import tqdm\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "\n",
    "import lovely_tensors as lt\n",
    "lt.monkey_patch()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "DATA_PATH = os.environ.get(\"DATA_PATH\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>id_list</th>\n",
       "      <th>rfam_list</th>\n",
       "      <th>eq_class_list</th>\n",
       "      <th>type_list</th>\n",
       "      <th>cluster_seqid0.8</th>\n",
       "      <th>cluster_structsim0.45</th>\n",
       "      <th>sequence</th>\n",
       "      <th>length</th>\n",
       "      <th>mean_rmsd</th>\n",
       "      <th>median_rmsd</th>\n",
       "      <th>num_structures</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>['6WD5_1_2', '6WD1_1_2', '6WD9_1_2', '6OGI_1_2...</td>\n",
       "      <td>['5S_rRNA', '5S_rRNA', '5S_rRNA', '5S_rRNA', '...</td>\n",
       "      <td>['10157', '10157', '10157', '10157', '10157', ...</td>\n",
       "      <td>['Protein-RNA Complex', 'Protein-RNA Complex',...</td>\n",
       "      <td>56</td>\n",
       "      <td>133</td>\n",
       "      <td>UGCCUGGCGGCCGUAGCGCGGUGGUCCCACCUGACCCCAUGCCGAA...</td>\n",
       "      <td>120</td>\n",
       "      <td>0.879151</td>\n",
       "      <td>0.778740</td>\n",
       "      <td>91</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>['3B58_1_B-C-A']</td>\n",
       "      <td>['unknown']</td>\n",
       "      <td>['02086']</td>\n",
       "      <td>['Solo RNA']</td>\n",
       "      <td>660</td>\n",
       "      <td>283</td>\n",
       "      <td>UCCCAGUCCACCGCGGUGAGAAGGGGGCAGAGAAACACACGAUCGU...</td>\n",
       "      <td>61</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>['7M57_1_n-Y', '7M57_1_qq-bb', '4OQ9_1_S-h', '...</td>\n",
       "      <td>['unknown', 'unknown', 'unknown', 'unknown', '...</td>\n",
       "      <td>['20373', '20373', '24132', '20373', '20373', ...</td>\n",
       "      <td>['Protein-RNA Complex', 'Protein-RNA Complex',...</td>\n",
       "      <td>39</td>\n",
       "      <td>764</td>\n",
       "      <td>AAAAAAAAAAUUUUUUUUUU</td>\n",
       "      <td>20</td>\n",
       "      <td>0.808048</td>\n",
       "      <td>0.749047</td>\n",
       "      <td>46</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>['6DTI_1_X-W']</td>\n",
       "      <td>['SSU_rRNA_bacteria']</td>\n",
       "      <td>['63494']</td>\n",
       "      <td>['Protein-RNA Complex']</td>\n",
       "      <td>11</td>\n",
       "      <td>929</td>\n",
       "      <td>GGCUACGAACCCGUA</td>\n",
       "      <td>15</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>['3KTW_1_C']</td>\n",
       "      <td>['unknown']</td>\n",
       "      <td>['32874']</td>\n",
       "      <td>['Protein-RNA Complex']</td>\n",
       "      <td>438</td>\n",
       "      <td>171</td>\n",
       "      <td>AGAUAGUCGUGGGUUCCCUUUCUGGAGGGAGAGGGAAUUCCACGUU...</td>\n",
       "      <td>96</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4218</th>\n",
       "      <td>['354D_1_A-B']</td>\n",
       "      <td>['unknown']</td>\n",
       "      <td>['63943']</td>\n",
       "      <td>['DNA-RNA Hybrid']</td>\n",
       "      <td>1002</td>\n",
       "      <td>656</td>\n",
       "      <td>CCGAUGGUAGUGGCGAGAGUA_C</td>\n",
       "      <td>23</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4219</th>\n",
       "      <td>['2DER_1_D']</td>\n",
       "      <td>['tRNA']</td>\n",
       "      <td>['79496']</td>\n",
       "      <td>['Protein-RNA Complex']</td>\n",
       "      <td>567</td>\n",
       "      <td>212</td>\n",
       "      <td>CCCCUUCGUCUAGAGGCCCAGGACACCGCCCUUUCACGGCGGUAAC...</td>\n",
       "      <td>71</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4220</th>\n",
       "      <td>['4ILL_1_C']</td>\n",
       "      <td>['unknown']</td>\n",
       "      <td>['31263']</td>\n",
       "      <td>['Protein-RNA Complex']</td>\n",
       "      <td>42</td>\n",
       "      <td>789</td>\n",
       "      <td>GCUAAUCUACUAUAGAA</td>\n",
       "      <td>17</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4221</th>\n",
       "      <td>['3T1Y_1_X-W']</td>\n",
       "      <td>['SSU_rRNA_bacteria']</td>\n",
       "      <td>['61644']</td>\n",
       "      <td>['Protein-RNA Complex']</td>\n",
       "      <td>4</td>\n",
       "      <td>1048</td>\n",
       "      <td>AAGGACUUUAC</td>\n",
       "      <td>11</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4222</th>\n",
       "      <td>['5T2A_1_D']</td>\n",
       "      <td>['5S_rRNA']</td>\n",
       "      <td>['69984']</td>\n",
       "      <td>['Protein-RNA Complex']</td>\n",
       "      <td>377</td>\n",
       "      <td>133</td>\n",
       "      <td>GAGUACGACCACACUUGAGUGAAAACACCAUAUCCCGUCCGAUUUG...</td>\n",
       "      <td>119</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>0.000000</td>\n",
       "      <td>1</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>4223 rows × 11 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "                                                id_list  \\\n",
       "0     ['6WD5_1_2', '6WD1_1_2', '6WD9_1_2', '6OGI_1_2...   \n",
       "1                                      ['3B58_1_B-C-A']   \n",
       "2     ['7M57_1_n-Y', '7M57_1_qq-bb', '4OQ9_1_S-h', '...   \n",
       "3                                        ['6DTI_1_X-W']   \n",
       "4                                          ['3KTW_1_C']   \n",
       "...                                                 ...   \n",
       "4218                                     ['354D_1_A-B']   \n",
       "4219                                       ['2DER_1_D']   \n",
       "4220                                       ['4ILL_1_C']   \n",
       "4221                                     ['3T1Y_1_X-W']   \n",
       "4222                                       ['5T2A_1_D']   \n",
       "\n",
       "                                              rfam_list  \\\n",
       "0     ['5S_rRNA', '5S_rRNA', '5S_rRNA', '5S_rRNA', '...   \n",
       "1                                           ['unknown']   \n",
       "2     ['unknown', 'unknown', 'unknown', 'unknown', '...   \n",
       "3                                 ['SSU_rRNA_bacteria']   \n",
       "4                                           ['unknown']   \n",
       "...                                                 ...   \n",
       "4218                                        ['unknown']   \n",
       "4219                                           ['tRNA']   \n",
       "4220                                        ['unknown']   \n",
       "4221                              ['SSU_rRNA_bacteria']   \n",
       "4222                                        ['5S_rRNA']   \n",
       "\n",
       "                                          eq_class_list  \\\n",
       "0     ['10157', '10157', '10157', '10157', '10157', ...   \n",
       "1                                             ['02086']   \n",
       "2     ['20373', '20373', '24132', '20373', '20373', ...   \n",
       "3                                             ['63494']   \n",
       "4                                             ['32874']   \n",
       "...                                                 ...   \n",
       "4218                                          ['63943']   \n",
       "4219                                          ['79496']   \n",
       "4220                                          ['31263']   \n",
       "4221                                          ['61644']   \n",
       "4222                                          ['69984']   \n",
       "\n",
       "                                              type_list  cluster_seqid0.8  \\\n",
       "0     ['Protein-RNA Complex', 'Protein-RNA Complex',...                56   \n",
       "1                                          ['Solo RNA']               660   \n",
       "2     ['Protein-RNA Complex', 'Protein-RNA Complex',...                39   \n",
       "3                               ['Protein-RNA Complex']                11   \n",
       "4                               ['Protein-RNA Complex']               438   \n",
       "...                                                 ...               ...   \n",
       "4218                                 ['DNA-RNA Hybrid']              1002   \n",
       "4219                            ['Protein-RNA Complex']               567   \n",
       "4220                            ['Protein-RNA Complex']                42   \n",
       "4221                            ['Protein-RNA Complex']                 4   \n",
       "4222                            ['Protein-RNA Complex']               377   \n",
       "\n",
       "      cluster_structsim0.45  \\\n",
       "0                       133   \n",
       "1                       283   \n",
       "2                       764   \n",
       "3                       929   \n",
       "4                       171   \n",
       "...                     ...   \n",
       "4218                    656   \n",
       "4219                    212   \n",
       "4220                    789   \n",
       "4221                   1048   \n",
       "4222                    133   \n",
       "\n",
       "                                               sequence  length  mean_rmsd  \\\n",
       "0     UGCCUGGCGGCCGUAGCGCGGUGGUCCCACCUGACCCCAUGCCGAA...     120   0.879151   \n",
       "1     UCCCAGUCCACCGCGGUGAGAAGGGGGCAGAGAAACACACGAUCGU...      61   0.000000   \n",
       "2                                  AAAAAAAAAAUUUUUUUUUU      20   0.808048   \n",
       "3                                       GGCUACGAACCCGUA      15   0.000000   \n",
       "4     AGAUAGUCGUGGGUUCCCUUUCUGGAGGGAGAGGGAAUUCCACGUU...      96   0.000000   \n",
       "...                                                 ...     ...        ...   \n",
       "4218                            CCGAUGGUAGUGGCGAGAGUA_C      23   0.000000   \n",
       "4219  CCCCUUCGUCUAGAGGCCCAGGACACCGCCCUUUCACGGCGGUAAC...      71   0.000000   \n",
       "4220                                  GCUAAUCUACUAUAGAA      17   0.000000   \n",
       "4221                                        AAGGACUUUAC      11   0.000000   \n",
       "4222  GAGUACGACCACACUUGAGUGAAAACACCAUAUCCCGUCCGAUUUG...     119   0.000000   \n",
       "\n",
       "      median_rmsd  num_structures  \n",
       "0        0.778740              91  \n",
       "1        0.000000               1  \n",
       "2        0.749047              46  \n",
       "3        0.000000               1  \n",
       "4        0.000000               1  \n",
       "...           ...             ...  \n",
       "4218     0.000000               1  \n",
       "4219     0.000000               1  \n",
       "4220     0.000000               1  \n",
       "4221     0.000000               1  \n",
       "4222     0.000000               1  \n",
       "\n",
       "[4223 rows x 11 columns]"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "seq_to_data = torch.load(os.path.join(DATA_PATH, \"processed.pt\"))\n",
    "df = pd.read_csv(os.path.join(DATA_PATH, \"processed_df.csv\"))\n",
    "# df[\"cluster_structsim0.45\"] = df[\"cluster_structsim0.45\"].fillna(-1)\n",
    "# df[\"cluster_seqid0.8\"] = df[\"cluster_seqid0.8\"].fillna(-1)\n",
    "df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "das_list = [\n",
    "    \"1CSL\", # RRE high affinity site\n",
    "    \"1ET4\", # Vitamin B12 binding RNA aptamer\n",
    "    \"1F27\", # Biotin-binding RNA pseudoknot\n",
    "    \"1L2X\", # Viral RNA pseudoknot\n",
    "    \"1LNT\", # RNA internal loop of SRP\n",
    "    \"1Q9A\", # Sarcin/ricin domain from E.coli 23S rRNA\n",
    "    \"4FE5\", # Guanine riboswitch aptamer (\"1U8D\" is now obsolete, replaced by 4FE5)\n",
    "    \"1X9C\", # All-RNA hairpin ribozyme\n",
    "    \"1XPE\", # HIV-1 B RNA dimerization initiation site\n",
    "    \"2GCS\", # Pre-cleavage state of glmS ribozyme\n",
    "    \"2GDI\", # Thiamine pyrophosphate-specific riboswitch\n",
    "    \"2OEU\", # Junctionless hairpin ribozyme\n",
    "    \"2R8S\", # Synthetic FAB bound to ribozyme domain\n",
    "    \"354D\", # Loop E from E. coli 5S rRNA\n",
    "]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1104"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Number of clusters\n",
    "len(df[\"cluster_structsim0.45\"].unique())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "metadata": {},
   "outputs": [],
   "source": [
    "das_list_to_test_idx = {}\n",
    "\n",
    "for test_idx, idx in enumerate(test_idx_list):\n",
    "    data = list(seq_to_data.values())[idx]\n",
    "    for id in data[\"id_list\"]:\n",
    "        if id.split(\"_\")[0] in das_list:\n",
    "            das_list_to_test_idx[id.split(\"_\")[0]] = test_idx"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'1X9C': 1,\n",
       " '4FE5': 19,\n",
       " '2GDI': 52,\n",
       " '1L2X': 62,\n",
       " '2GCS': 66,\n",
       " '1ET4': 75,\n",
       " '1Q9A': 76,\n",
       " '2R8S': 84,\n",
       " '1XPE': 91,\n",
       " '1CSL': 93,\n",
       " '1LNT': 94,\n",
       " '1F27': 95,\n",
       " '2OEU': 96,\n",
       " '354D': 97}"
      ]
     },
     "execution_count": 47,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "das_list_to_test_idx"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 4223/4223 [00:00<00:00, 196887.01it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Number of excluded sequences (> 1000 nts): 1146\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "cluster_to_seq_idx_list = {}     # cluster -> list of seq idx in seq_to_data dict\n",
    "excluded_idx = []                # indexes which will be excluded from val/test set\n",
    "\n",
    "das_list_to_cluster = {}      # ID is Das list -> cluster ID\n",
    "\n",
    "unclustered_id = int(df[\"cluster_structsim0.45\"].max()) + 1  # some clusters were not assigned\n",
    "\n",
    "for seq_idx, data in enumerate(tqdm(seq_to_data.values())):\n",
    "    # exclude very long sequences which are generally ribosomal RNAs\n",
    "    if len(data[\"sequence\"]) > 1000:\n",
    "        excluded_idx.append(seq_idx)\n",
    "    \n",
    "    else:\n",
    "        cluster = int(data[\"cluster_structsim0.45\"])\n",
    "        if cluster == -1:\n",
    "            # assign unclustered sequences to a new cluster\n",
    "            cluster = unclustered_id\n",
    "            unclustered_id += 1\n",
    "\n",
    "        if cluster not in cluster_to_seq_idx_list:\n",
    "            cluster_to_seq_idx_list[cluster] = []\n",
    "        cluster_to_seq_idx_list[cluster].append(seq_idx)\n",
    "\n",
    "        for id in data[\"id_list\"]:\n",
    "            if id.split(\"_\")[0] in das_list:\n",
    "                das_list_to_cluster[id.split(\"_\")[0]] = cluster\n",
    "\n",
    "print(f\"Number of excluded sequences (> 1000 nts): {len(excluded_idx)}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'1L2X': 606,\n",
       " '1X9C': 283,\n",
       " '2GCS': 123,\n",
       " '4FE5': 237,\n",
       " '2GDI': 199,\n",
       " '1ET4': 504,\n",
       " '1Q9A': 603,\n",
       " '1CSL': 589,\n",
       " '1LNT': 693,\n",
       " '2R8S': 106,\n",
       " '1XPE': 312,\n",
       " '1F27': 771,\n",
       " '2OEU': 425,\n",
       " '354D': 656}"
      ]
     },
     "execution_count": 38,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "das_list_to_cluster"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Cluster ID</th>\n",
       "      <th>Cluster size</th>\n",
       "      <th>Median intra-sequence RMSD</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>133</td>\n",
       "      <td>101</td>\n",
       "      <td>0.667112</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>283</td>\n",
       "      <td>17</td>\n",
       "      <td>0.365617</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>764</td>\n",
       "      <td>1</td>\n",
       "      <td>0.749047</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>929</td>\n",
       "      <td>1</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>171</td>\n",
       "      <td>4</td>\n",
       "      <td>1.192810</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1084</th>\n",
       "      <td>256</td>\n",
       "      <td>1</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1085</th>\n",
       "      <td>724</td>\n",
       "      <td>1</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1086</th>\n",
       "      <td>677</td>\n",
       "      <td>1</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1087</th>\n",
       "      <td>656</td>\n",
       "      <td>1</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1088</th>\n",
       "      <td>1048</td>\n",
       "      <td>1</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>1089 rows × 3 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "      Cluster ID  Cluster size  Median intra-sequence RMSD\n",
       "0            133           101                    0.667112\n",
       "1            283            17                    0.365617\n",
       "2            764             1                    0.749047\n",
       "3            929             1                    0.000000\n",
       "4            171             4                    1.192810\n",
       "...          ...           ...                         ...\n",
       "1084         256             1                    0.000000\n",
       "1085         724             1                    0.000000\n",
       "1086         677             1                    0.000000\n",
       "1087         656             1                    0.000000\n",
       "1088        1048             1                    0.000000\n",
       "\n",
       "[1089 rows x 3 columns]"
      ]
     },
     "execution_count": 31,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Cluster sizes: number of sequences in each cluster\n",
    "cluster_ids = list(cluster_to_seq_idx_list.keys())\n",
    "cluster_sizes = [len(list) for list in cluster_to_seq_idx_list.values()]\n",
    "\n",
    "# Median RMSD for each cluster (in same order as cluster_id list)\n",
    "cluster_median_rmsds = []\n",
    "for cluster, seq_idx_list in cluster_to_seq_idx_list.items():\n",
    "    rmsds = []\n",
    "    for seq_idx in seq_idx_list:\n",
    "        sequence = list(seq_to_data.keys())[seq_idx]  # ugh, how longwinded...\n",
    "        _rmsds = list(seq_to_data[sequence][\"rmsds_list\"].values())\n",
    "        if len(_rmsds) > 0:\n",
    "            rmsds += _rmsds\n",
    "    if len(rmsds) > 0:\n",
    "        cluster_median_rmsds.append(np.median(rmsds))\n",
    "    else:\n",
    "        cluster_median_rmsds.append(0.0)\n",
    "\n",
    "df_split = pd.DataFrame({\n",
    "    'Cluster ID': cluster_ids,\n",
    "    'Cluster size': cluster_sizes,\n",
    "    'Median intra-sequence RMSD': cluster_median_rmsds,\n",
    "})\n",
    "# Sort df_split by median intra-sequence RMSD\n",
    "# df_split = df_split.sort_values(by=\"Median intra-sequence RMSD\", ascending=False)\n",
    "df_split"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>Cluster ID</th>\n",
       "      <th>Cluster size</th>\n",
       "      <th>Median intra-sequence RMSD</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>283</td>\n",
       "      <td>17</td>\n",
       "      <td>0.365617</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>31</th>\n",
       "      <td>237</td>\n",
       "      <td>34</td>\n",
       "      <td>0.718709</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>43</th>\n",
       "      <td>199</td>\n",
       "      <td>11</td>\n",
       "      <td>1.132334</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>54</th>\n",
       "      <td>606</td>\n",
       "      <td>2</td>\n",
       "      <td>0.627168</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>73</th>\n",
       "      <td>123</td>\n",
       "      <td>11</td>\n",
       "      <td>1.473743</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>168</th>\n",
       "      <td>504</td>\n",
       "      <td>1</td>\n",
       "      <td>0.869921</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>204</th>\n",
       "      <td>603</td>\n",
       "      <td>2</td>\n",
       "      <td>0.376233</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>254</th>\n",
       "      <td>106</td>\n",
       "      <td>10</td>\n",
       "      <td>1.239022</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>256</th>\n",
       "      <td>312</td>\n",
       "      <td>5</td>\n",
       "      <td>0.275090</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>481</th>\n",
       "      <td>589</td>\n",
       "      <td>1</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>555</th>\n",
       "      <td>693</td>\n",
       "      <td>1</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>932</th>\n",
       "      <td>771</td>\n",
       "      <td>1</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>942</th>\n",
       "      <td>425</td>\n",
       "      <td>1</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1087</th>\n",
       "      <td>656</td>\n",
       "      <td>1</td>\n",
       "      <td>0.000000</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "      Cluster ID  Cluster size  Median intra-sequence RMSD\n",
       "1            283            17                    0.365617\n",
       "31           237            34                    0.718709\n",
       "43           199            11                    1.132334\n",
       "54           606             2                    0.627168\n",
       "73           123            11                    1.473743\n",
       "168          504             1                    0.869921\n",
       "204          603             2                    0.376233\n",
       "254          106            10                    1.239022\n",
       "256          312             5                    0.275090\n",
       "481          589             1                    0.000000\n",
       "555          693             1                    0.000000\n",
       "932          771             1                    0.000000\n",
       "942          425             1                    0.000000\n",
       "1087         656             1                    0.000000"
      ]
     },
     "execution_count": 32,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "df_split.loc[df_split[\"Cluster ID\"].isin(das_list_to_cluster.values())]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Das split preparation\n",
    "\n",
    "# Initialize lists for test, validation, and training set indexes\n",
    "test_idx_list = []\n",
    "val_idx_list = []\n",
    "train_idx_list = []\n",
    "\n",
    "# Training, validation, and test splits become progressively harder.\n",
    "#     - All sequences from Das list as well as those in the same cluster -- test set.\n",
    "#     - All remaining samples -- randomly added to training or validation set.\n",
    "#     - Very large (> 1000 nts) RNAs -- training set.\n",
    "\n",
    "for _, (cluster, cluster_size, median_rmsd) in df_split.iterrows():\n",
    "    seq_idx_list = cluster_to_seq_idx_list[cluster]\n",
    "    assert cluster_size == len(seq_idx_list)\n",
    "\n",
    "    # Test set\n",
    "    if cluster in das_list_to_cluster.values():\n",
    "        test_idx_list += seq_idx_list\n",
    "\n",
    "    # Validation set\n",
    "    elif len(val_idx_list) < 100 and cluster_size < 3:\n",
    "        val_idx_list += seq_idx_list\n",
    "    \n",
    "    # Training set\n",
    "    else:\n",
    "        train_idx_list += seq_idx_list\n",
    "\n",
    "# Add all the sequences that were not assigned any clusters into the training set\n",
    "try:\n",
    "    assert len(test_idx_list) + len(val_idx_list) + len(train_idx_list) == len(list(seq_to_data.keys()))\n",
    "except:\n",
    "    train_idx_list += excluded_idx\n",
    "    assert len(test_idx_list) + len(val_idx_list) + len(train_idx_list) == len(list(seq_to_data.keys()))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Save RMSD split\n",
    "torch.save(\n",
    "    (train_idx_list, val_idx_list, test_idx_list), \n",
    "    os.path.join(DATA_PATH, \"das_split.pt\")\n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Split: train\n",
      "Average median RMSD: 0.48 +- 1.32\n",
      "Median number of structures: 1.00\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA0gAAANCCAYAAABcfOy9AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy81sbWrAAAACXBIWXMAAA9hAAAPYQGoP6dpAACJyElEQVR4nOzdfXwU5b3///dCloVgWEgwdyUgVaBoADkgELQCAoH8jIFCxYqmYCni4c4coCpYNVgFjaeKJ1SqlgKCGL/nKAqVRpYqUBpuo6lAKdU2ULGEUAwJdy5LMr8/mIxZNoEsbJJN9vV8PPZhZvba2etzJTL7nrlm1mYYhiEAAAAAgJo1dAcAAAAAIFgQkAAAAADAREACAAAAABMBCQAAAABMBCQAAAAAMBGQAAAAAMBEQAIAAAAAEwEJAAAAAEwEJAAAAAAwEZCAGixfvlw2m00HDx5s6K4oLy9PmZmZOnHihM9z1113nVJTU+u/UwCAkHDmzBllZmZq06ZNDdqPBQsW6L333mvQPiA0EJCARiAvL0/z58+vNiABAFCXzpw5o/nz5xOQEDIISAAAAAiYM2fONHQX/HL27NmG7gKCDAEJ8MPGjRs1dOhQtWnTRuHh4br11lv1hz/8watNZmambDab9u3bp3vvvVdOp1MxMTH6yU9+otLSUq+2J06c0KRJkxQZGalrrrlGd955p/7xj3/IZrMpMzPT2t7PfvYzSVLnzp1ls9lks9l8juTl5ubqP/7jP9SqVSt973vf029/+9s6GwcAQPVqsw84ePCgbDabli9f7vP6qv/+V93eZ599prvvvltOp1ORkZGaNWuWzp8/rwMHDmjkyJGKiIjQddddp6ysLL/7/NFHH2nw4MGKiopSq1at1LFjR40dO1ZnzpzRwYMHde2110qS5s+fb+2DJk6c6NW/Tz75RD/84Q/Vrl07XX/99ZKkwYMHa/DgwT7vN3HiRF133XVe69xut55++ml1795dLVu2VFRUlIYMGaK8vDxrXE6fPq0VK1ZYfajcdmUfLlbdVPnKaenvvvuuevfurZYtW2r+/PmSpKKiIk2ZMkUdOnRQixYt1LlzZ82fP1/nz5/32u6SJUvUq1cvXXPNNYqIiND3vvc9zZs3z99hRxALa+gOAI3FqlWr9OMf/1ijRo3SihUrZLfb9eqrr2rEiBH68MMPNXToUK/2Y8eO1T333KNJkyZpz549mjt3riRZwaWiokJ33XWXdu/erczMTP3Hf/yHtm3bppEjR3pt56c//am+/vprZWdn691331VcXJwk6cYbb7Ta/PnPf9bs2bP12GOPKSYmRr/5zW80adIk3XDDDbr99tvrclgAANW43D7AX+PGjdP999+vKVOmyOVyKSsrSx6PRxs3btTUqVM1Z84crV69Wo8++qhuuOEGjRkzplbbPXjwoO688059//vf129/+1u1bdtWX331lXJzc3Xu3DnFxcUpNzdXI0eO1KRJk/TTn/5UkqzQVGnMmDH60Y9+pIceekinT5/2q7bz588rJSVFf/zjH5WRkaE77rhD58+f1/bt2/XPf/5TAwcO1LZt23THHXdoyJAheuKJJyRJbdq08et9Kn3yySfav3+/fv7zn6tz585q3bq1ioqK1K9fPzVr1kxPPvmkrr/+em3btk3PPPOMDh48qGXLlkmScnJyNHXqVM2YMUP//d//rWbNmumLL77QX/7ylyvqC4KUAaBay5YtMyQZhYWFxunTp43IyEjjrrvu8mpTXl5u9OrVy+jXr5+17qmnnjIkGVlZWV5tp06darRs2dKoqKgwDMMwPvjgA0OSsWTJEq92CxcuNCQZTz31lLXuhRdesPpysU6dOhktW7Y0Dh06ZK07e/asERkZaUyZMuVKywcAXIHa7AMKCwsNScayZct8Xn/xv/+V2/vlL3/p1e7mm282JBnvvvuutc7j8RjXXnutMWbMmFr39//+7/8MSUZBQUGNbY4dO+bTr4v79+STT/o8N2jQIGPQoEE+6ydMmGB06tTJWn7jjTcMScbrr79+yb62bt3amDBhQo19uFjV/XilTp06Gc2bNzcOHDjg1XbKlCnGNddc47UvNQzD+O///m9DkrFv3z7DMAxj+vTpRtu2bS/ZTzR+TLEDaiEvL09ff/21JkyYoPPnz1uPiooKjRw5Urt27fI5YpaWlua13LNnT33zzTcqLi6WJG3evFnShaOCVd17771+9+/mm29Wx44dreWWLVuqa9euOnTokN/bAgBcvcvtA/x18d1Ku3fvLpvNppSUFGtdWFiYbrjhBr/+7b/55pvVokULPfjgg1qxYoX+8Y9/XFH/xo4de0Wvk6Tf//73atmypX7yk59c8Tb80bNnT3Xt2tVr3e9+9zsNGTJE8fHxXvv5yvGt3Gf369dPJ06c0L333qv3339f//73v+ulz6hfBCSgFo4ePSpJ+uEPfyi73e71eP7552UYhr7++muv10RFRXktOxwOSd9eDHr8+HGFhYUpMjLSq11MTIzf/bv4vSrfjwtPAaBhXG4f4K+L9xUtWrRQeHi4WrZs6bP+m2++qfV2r7/+em3cuFHR0dGaNm2arr/+el1//fV6+eWX/epf5fTvK3Hs2DHFx8erWbP6+VhaXV+PHj2qdevW+ezjb7rpJkmyglB6erp++9vf6tChQxo7dqyio6PVv39/uVyueuk76gfXIAG10L59e0lSdna2BgwYUG0bf4NNVFSUzp8/r6+//tprx1dUVHTlHQUABL3KUON2u73WHz9+vCG6o+9///v6/ve/r/Lycu3evVvZ2dnKyMhQTEyMfvSjH9VqG9XdJKFly5Y+NyeS5HPW5dprr9XWrVtVUVFxRSGp6nhWBtHq3udSfW3fvr169uypZ599ttrXxMfHWz8/8MADeuCBB3T69Glt2bJFTz31lFJTU/W3v/1NnTp18rv/CD6cQQJq4dZbb1Xbtm31l7/8RX379q320aJFC7+2OWjQIEnS22+/7bU+JyfHp+3VHnkEAASPmJgYtWzZUp999pnX+vfff7+BenRB8+bN1b9/f/3qV7+SdOFmBtKV74Ouu+46/e1vf/MKgsePH7fuTFcpJSVF33zzTbV39auqppkRlXfEu3g8161bV+u+pqamau/evbr++uur3cdXDUiVWrdurZSUFD3++OM6d+6c9u3bV+v3Q3DjDBJQC9dcc42ys7M1YcIEff311/rhD3+o6OhoHTt2TH/+85917NgxLVmyxK9tjhw5Urfeeqtmz56tsrIy9enTR9u2bdMbb7whSV5H0Xr06CFJevnllzVhwgTZ7XZ169ZNERERgSsSAFAvbDab7r//fv32t7/V9ddfr169emnnzp1avXp1vffl17/+tT766CPdeeed6tixo7755hvrTnvDhg2TJEVERKhTp056//33NXToUEVGRqp9+/Y+t+q+WHp6ul599VXdf//9mjx5so4fP66srCyfu8/de++9WrZsmR566CEdOHBAQ4YMUUVFhXbs2KHu3btbZ7F69OihTZs2ad26dYqLi1NERIS6deum/+//+/8UGRmpSZMm6emnn1ZYWJiWL1+uL7/8stbj8PTTT8vlcmngwIGaOXOmunXrpm+++UYHDx7U+vXr9etf/1odOnTQ5MmT1apVK916662Ki4tTUVGRFi5cKKfTqVtuucWPkUcw4wwSUEv333+/Pv74Y506dUpTpkzRsGHD9PDDD+uTTz7xucV3bTRr1kzr1q3Tj370Iz333HMaNWqU/vjHP2rVqlWSpLZt21ptBw8erLlz52rdunW67bbbdMsttyg/Pz9QpQEA6tkvf/lL3X///crKytKoUaO0bds2/e53v6v3ftx88806f/68nnrqKaWkpCg9PV3Hjh3T2rVrlZycbLVbunSpwsPDlZaWpltuucXru5pqcuutt2rFihXat2+fRo0apWeeeUZz5871+W6ksLAwrV+/XnPnztWaNWs0atQo/fjHP9bWrVu9pqy9/PLL6tKli370ox/plltu0ZQpUyRduN13bm6uIiIidP/99+uhhx5SYmKiHn/88VqPQ1xcnHbv3q3k5GS98MILGjlypHW90c0336x27dpJujAdce/evXr44Yc1fPhw/dd//Ze6du2qP/7xjz63PkfjZTMMw2joTgD41urVq3XffffpT3/6kwYOHNjQ3QEAAAgpBCSgAb311lv66quv1KNHDzVr1kzbt2/XCy+8oN69e1u3FAUAAED94RokoAFFREQoJydHzzzzjE6fPq24uDhNnDhRzzzzTEN3DQDQyJWXl+tSx8FtNpuaN29ejz0CGgfOIAEAADRB11133SW/NHbQoEHatGlT/XUIaCQ4gwQAANAErVu3zue7lqriTqhA9TiDBAAAAAAmbvMNAAAAAKYmO8WuoqJC//rXvxQRESGbzdbQ3QGARsUwDJ08eVLx8fFeX1qMhsN+DQCunD/7tSYbkP71r38pISGhobsBAI3al19+qQ4dOjR0NyD2awAQCLXZrzXZgFR54eGXX36pNm3a+PVaj8ejDRs2KDk5WXa7vS661+gwJr4YE1+MibfGPB5lZWVKSEjgIu4gcqX7tcb8d+gP6mw6QqFGKTTqDKYa/dmvNdmAVDn9oE2bNlcUkMLDw9WmTZsG/2UGC8bEF2PiizHx1hTGg6lcweNK92tN4e+wNqiz6QiFGqXQqDMYa6zNfo2J5QAAAABgIiABAAAAgImABAAAAAAmAhIAAAAAmAhIAAAAAGAiIAEAAACAiYAEAAAAACYCEgAAAACYCEgAgJC1ZMkS9ezZ0/ry1aSkJP3+97+3np84caJsNpvXY8CAAV7bcLvdmjFjhtq3b6/WrVsrLS1Nhw8f9mpTUlKi9PR0OZ1OOZ1Opaen68SJE/VRIgDATwQkAEDI6tChg5577jnt3r1bu3fv1h133KFRo0Zp3759VpuRI0fqyJEj1mP9+vVe28jIyNCaNWuUk5OjrVu36tSpU0pNTVV5ebnVZvz48SooKFBubq5yc3NVUFCg9PT0eqsTAFB7YQ3dAQAAGspdd93ltfzss89qyZIl2r59u2666SZJksPhUGxsbLWvLy0t1dKlS7Vy5UoNGzZMkrRq1SolJCRo48aNGjFihPbv36/c3Fxt375d/fv3lyS9/vrrSkpK0oEDB9StW7c6rBAA4C/OIAEAIKm8vFw5OTk6ffq0kpKSrPWbNm1SdHS0unbtqsmTJ6u4uNh6Lj8/Xx6PR8nJyda6+Ph4JSYmKi8vT5K0bds2OZ1OKxxJ0oABA+R0Oq02AIDgwRkkAEBI27Nnj5KSkvTNN9/ommuu0Zo1a3TjjTdKklJSUnT33XerU6dOKiws1BNPPKE77rhD+fn5cjgcKioqUosWLdSuXTuvbcbExKioqEiSVFRUpOjoaJ/3jY6OttpUx+12y+12W8tlZWWSJI/HI4/HU+v6Ktv685rGiDqbjlCoUQqNOoOpRn/64HdA2rJli1544QXl5+fryJEjWrNmjUaPHl1t2ylTpui1117TSy+9pIyMDGu92+3WnDlz9NZbb+ns2bMaOnSoXnnlFXXo0MFqU1JSopkzZ2rt2rWSpLS0NGVnZ6tt27b+dvmKJWZ+KHe5TZJ08Lk76+19AQD1p1u3biooKNCJEyf0zjvvaMKECdq8ebNuvPFG3XPPPVa7xMRE9e3bV506ddIHH3ygMWPG1LhNwzBks9ms5ao/19TmYgsXLtT8+fN91m/YsEHh4eG1Lc/icrn8fk1jRJ1NRyjUKIVGncFQ45kzZ2rd1u+AdPr0afXq1UsPPPCAxo4dW2O79957Tzt27FB8fLzPcxkZGVq3bp1ycnIUFRWl2bNnKzU1Vfn5+WrevLmkCxe0Hj58WLm5uZKkBx98UOnp6Vq3bp2/XQYAoEYtWrTQDTfcIEnq27evdu3apZdfflmvvvqqT9u4uDh16tRJn3/+uSQpNjZW586dU0lJiddZpOLiYg0cONBqc/ToUZ9tHTt2TDExMTX2a+7cuZo1a5a1XFZWpoSEBCUnJ6tNmza1rs/j8cjlcmn48OHq/exH1vq9mSNqvY3GoGqddru9obtTZ0KhzlCoUQqNOoOpxsqz8LXhd0BKSUlRSkrKJdt89dVXmj59uj788EPdeaf3mRcuaAUABDPDMLymtlV1/Phxffnll4qLi5Mk9enTR3a7XS6XS+PGjZMkHTlyRHv37lVWVpYkKSkpSaWlpdq5c6f69esnSdqxY4dKS0utEFUdh8Mhh8Phs95ut1/RBw273W7NiqhcboqudHwam1CoMxRqlEKjzmCo0Z/3D/g1SBUVFUpPT9fPfvYz6w5AVV3ugtYRI0Zc9oLW6gJSoOZqV75GkhzNDJ91oSqY5pAGC8bEF2PirTGPR2Ps85WYN2+eUlJSlJCQoJMnTyonJ0ebNm1Sbm6uTp06pczMTI0dO1ZxcXE6ePCg5s2bp/bt2+sHP/iBJMnpdGrSpEmaPXu2oqKiFBkZqTlz5qhHjx7WQcDu3btr5MiRmjx5snVW6sEHH1RqaioH/AAgCAU8ID3//PMKCwvTzJkzq32+ri5oDfRcbUn6Rd8K6+eLv/ciVAXDHNJgw5j4Yky8Ncbx8GeudmN29OhRpaen68iRI3I6nerZs6dyc3M1fPhwnT17Vnv27NEbb7yhEydOKC4uTkOGDNHbb7+tiIgIaxsvvfSSwsLCNG7cOOu62uXLl1tTxiXpzTff1MyZM62Dg2lpaVq8eHG91wsAuLyABqT8/Hy9/PLL+uSTTy554Wl1rvaC1kDN1Za+nS/5xO5mcldceL+mNlfbX8E0hzRYMCa+GBNvjXk8/Jmr3ZgtXbq0xudatWqlDz/88LLbaNmypbKzs5WdnV1jm8jISK1ateqK+ggAqF8BDUh//OMfVVxcrI4dO1rrysvLNXv2bC1atEgHDx6sswtaAz1XW5LcFTZrvnZj+3BTV4JhDmmwYUx8MSbeGuN4NLb+AgAQKAH9otj09HR99tlnKigosB7x8fH62c9+Zh2Fq3pBa6XKC1orA1LVC1or1eaCVgAAAAC4Gn6fQTp16pS++OILa7mwsFAFBQWKjIxUx44dFRUV5dXebrcrNjbWuhCVC1oBAAAABCu/A9Lu3bs1ZMgQa7nyup8JEyZo+fLltdoGF7QCAAAACEZ+B6TBgwfLMIzLNzQdPHjQZx0XtAIAAAAIRgG9BgkAAAAAGjMCEgAAAACYCEgAAAAAYCIgAQAAAICJgAQAAAAAJgISAAAAAJgISAAAAABgIiABAAAAgImABAAAAAAmAhIAAAAAmAhIAAAAAGAiIAEAAACAiYAEAAAAACYCEgAAAACYCEgAAAAAYCIgAQAAAICJgAQAAAAAJgISAAAAAJgISAAAAABgIiABAAAAgImABAAAAAAmAhIAAAAAmAhIAAAAAGAiIAEAAACAiYAEAAAAACYCEgAAAACYCEgAAAAAYCIgAQAAAICJgAQAAAAAJgISAAAAAJgISACAkLVkyRL17NlTbdq0UZs2bZSUlKTf//731vOGYSgzM1Px8fFq1aqVBg8erH379nltw+12a8aMGWrfvr1at26ttLQ0HT582KtNSUmJ0tPT5XQ65XQ6lZ6erhMnTtRHiQAAPxGQAAAhq0OHDnruuee0e/du7d69W3fccYdGjRplhaCsrCy9+OKLWrx4sXbt2qXY2FgNHz5cJ0+etLaRkZGhNWvWKCcnR1u3btWpU6eUmpqq8vJyq8348eNVUFCg3Nxc5ebmqqCgQOnp6fVeLwDg8sIaugMAADSUu+66y2v52Wef1ZIlS7R9+3bdeOONWrRokR5//HGNGTNGkrRixQrFxMRo9erVmjJlikpLS7V06VKtXLlSw4YNkyStWrVKCQkJ2rhxo0aMGKH9+/crNzdX27dvV//+/SVJr7/+upKSknTgwAF169atfosGAFwSAQkAAEnl5eX63//9X50+fVpJSUkqLCxUUVGRkpOTrTYOh0ODBg1SXl6epkyZovz8fHk8Hq828fHxSkxMVF5enkaMGKFt27bJ6XRa4UiSBgwYIKfTqby8vBoDktvtltvttpbLysokSR6PRx6Pp9Z1Vbb1eDxyNDd81jcVVetsykKhzlCoUQqNOoOpRn/64HdA2rJli1544QXl5+fryJEjWrNmjUaPHm298c9//nOtX79e//jHP+R0OjVs2DA999xzio+Pt7bhdrs1Z84cvfXWWzp79qyGDh2qV155RR06dLDalJSUaObMmVq7dq0kKS0tTdnZ2Wrbtq2/XQYAoEZ79uxRUlKSvvnmG11zzTVas2aNbrzxRuXl5UmSYmJivNrHxMTo0KFDkqSioiK1aNFC7dq182lTVFRktYmOjvZ53+joaKtNdRYuXKj58+f7rN+wYYPCw8P9K1KSy+VSVr9vl9evX+/3NhoDl8vV0F2oF6FQZyjUKIVGncFQ45kzZ2rd1u+AdPr0afXq1UsPPPCAxo4d6/PGn3zyiZ544gn16tVLJSUlysjIUFpamnbv3m21y8jI0Lp165STk6OoqCjNnj1bqampys/PV/PmzSVdmK99+PBh5ebmSpIefPBBpaena926df52GQCAGnXr1k0FBQU6ceKE3nnnHU2YMEGbN2+2nrfZbF7tDcPwWXexi9tU1/5y25k7d65mzZplLZeVlSkhIUHJyclq06bNZeuq5PF45HK5NHz4cPV+9iNr/d7MEbXeRmNQtU673d7Q3akzoVBnKNQohUadwVRj5Vn42vA7IKWkpCglJaXa55xOp09CzM7OVr9+/fTPf/5THTt2ZL42ACCotGjRQjfccIMkqW/fvtq1a5defvllPfroo5IunAGKi4uz2hcXF1tnlWJjY3Xu3DmVlJR4nUUqLi7WwIEDrTZHjx71ed9jx475nJ2qyuFwyOFw+Ky32+1X9EHDbrfLXW7zWm6KrnR8GptQqDMUapRCo85gqNGf96/za5BKS0tls9msqXF1NV87UHO1K18jSY5mTXeutr+CaQ5psGBMfDEm3hrzeDTGPgeKYRhyu93q3LmzYmNj5XK51Lt3b0nSuXPntHnzZj3//POSpD59+shut8vlcmncuHGSpCNHjmjv3r3KysqSJCUlJam0tFQ7d+5Uv34X5rjt2LFDpaWlVogCAASPOg1I33zzjR577DGNHz/emg5QV/O1Az1XW5J+0bfC+rmpztX2VzDMIQ02jIkvxsRbYxwPf+ZqN2bz5s1TSkqKEhISdPLkSeXk5GjTpk3Kzc2VzWZTRkaGFixYoC5duqhLly5asGCBwsPDNX78eEkXZk5MmjRJs2fPVlRUlCIjIzVnzhz16NHDmiXRvXt3jRw5UpMnT9arr74q6cK08dTUVGZEAEAQqrOA5PF49KMf/UgVFRV65ZVXLtv+audrB2qudmXfXS6XntjdTO6KC+/X1OZq+yuY5pAGC8bEF2PirTGPhz9ztRuzo0ePKj09XUeOHJHT6VTPnj2Vm5ur4cOHS5IeeeQRnT17VlOnTlVJSYn69++vDRs2KCIiwtrGSy+9pLCwMI0bN8668dDy5cuta2ol6c0339TMmTOt2RNpaWlavHhx/RYLAKiVOglIHo9H48aNU2FhoT766COvgFJX87UDPVdbktwVNmu+dmP7cFNXgmEOabBhTHwxJt4a43g0tv5eqaVLl17yeZvNpszMTGVmZtbYpmXLlsrOzlZ2dnaNbSIjI7Vq1aor7SYAoB41C/QGK8PR559/ro0bNyoqKsrr+arztStVzteuDEhV52tXYr42AAAAgLrm9xmkU6dO6YsvvrCWCwsLVVBQoMjISMXHx+uHP/yhPvnkE/3ud79TeXm5dc1QZGSkWrRowXxtAAAAAEHL74C0e/duDRkyxFquvO5nwoQJyszMtL7Y9eabb/Z63ccff6zBgwdLYr42AAAAgODkd0AaPHiwDMOo8flLPVeJ+doAAAAAglHAr0ECAAAAgMaKgAQAAAAAJgISAAAAAJgISAAAAABgIiABAAAAgImABAAAAAAmAhIAAAAAmAhIAAAAAGAiIAEAAACAiYAEAAAAACYCEgAAAACYCEgAAAAAYCIgAQAAAICJgAQAAAAAJgISAAAAAJgISAAAAABgIiABAAAAgImABAAAAAAmAhIAAAAAmAhIAAAAAGAiIAEAAACAiYAEAAAAACYCEgAAAACYCEgAAAAAYCIgAQAAAICJgAQAAAAAJgISAAAAAJgISAAAAABgIiABAAAAgImABAAAAAAmAhIAIGQtXLhQt9xyiyIiIhQdHa3Ro0frwIEDXm0mTpwom83m9RgwYIBXG7fbrRkzZqh9+/Zq3bq10tLSdPjwYa82JSUlSk9Pl9PplNPpVHp6uk6cOFHXJQIA/ERAAgCErM2bN2vatGnavn27XC6Xzp8/r+TkZJ0+fdqr3ciRI3XkyBHrsX79eq/nMzIytGbNGuXk5Gjr1q06deqUUlNTVV5ebrUZP368CgoKlJubq9zcXBUUFCg9Pb1e6gQA1F5YQ3cAAICGkpub67W8bNkyRUdHKz8/X7fffru13uFwKDY2ttptlJaWaunSpVq5cqWGDRsmSVq1apUSEhK0ceNGjRgxQvv371dubq62b9+u/v37S5Jef/11JSUl6cCBA+rWrVsdVQgA8BdnkAAAMJWWlkqSIiMjvdZv2rRJ0dHR6tq1qyZPnqzi4mLrufz8fHk8HiUnJ1vr4uPjlZiYqLy8PEnStm3b5HQ6rXAkSQMGDJDT6bTaAACCg99nkLZs2aIXXnhB+fn5OnLkiNasWaPRo0dbzxuGofnz5+u1115TSUmJ+vfvr1/96le66aabrDZut1tz5szRW2+9pbNnz2ro0KF65ZVX1KFDB6tNSUmJZs6cqbVr10qS0tLSlJ2drbZt2155tQAA1MAwDM2aNUu33XabEhMTrfUpKSm6++671alTJxUWFuqJJ57QHXfcofz8fDkcDhUVFalFixZq166d1/ZiYmJUVFQkSSoqKlJ0dLTPe0ZHR1ttLuZ2u+V2u63lsrIySZLH45HH46l1XZVtPR6PHM0Nn/VNRdU6m7JQqDMUapRCo85gqtGfPvgdkE6fPq1evXrpgQce0NixY32ez8rK0osvvqjly5era9eueuaZZzR8+HAdOHBAERERki7M1V63bp1ycnIUFRWl2bNnKzU1Vfn5+WrevLmkC3O1Dx8+bE1/ePDBB5Wenq5169b522UAAC5r+vTp+uyzz7R161av9ffcc4/1c2Jiovr27atOnTrpgw8+0JgxY2rcnmEYstls1nLVn2tqU9XChQs1f/58n/UbNmxQeHj4Zeu5mMvlUla/b5cvvo6qqXC5XA3dhXoRCnWGQo1SaNQZDDWeOXOm1m39DkgpKSlKSUmp9jnDMLRo0SI9/vjj1k5jxYoViomJ0erVqzVlyhTmagMAgs6MGTO0du1abdmyxWs2Q3Xi4uLUqVMnff7555Kk2NhYnTt3TiUlJV5nkYqLizVw4ECrzdGjR322dezYMcXExFT7PnPnztWsWbOs5bKyMiUkJCg5OVlt2rSpdW0ej0cul0vDhw9X72c/stbvzRxR6200BlXrtNvtDd2dOhMKdYZCjVJo1BlMNVaeha+NgN6kobCwUEVFRV7zsB0OhwYNGqS8vDxNmTLlsnO1R4wYcdm52tUFpEBNRah8jSQ5mjXdqQj+CqZTpMGCMfHFmHhrzOPRGPt8JQzD0IwZM7RmzRpt2rRJnTt3vuxrjh8/ri+//FJxcXGSpD59+shut8vlcmncuHGSpCNHjmjv3r3KysqSJCUlJam0tFQ7d+5Uv34XTuPs2LFDpaWlVoi6mMPhkMPh8Flvt9uv6IOG3W6Xu9zmtdwUXen4NDahUGco1CiFRp3BUKM/7x/QgFQ5j/rio2ExMTE6dOiQ1aYu5moHeiqCJP2ib4X1c1OdiuCvYDhFGmwYE1+MibfGOB7+TEVozKZNm6bVq1fr/fffV0REhLWPcTqdatWqlU6dOqXMzEyNHTtWcXFxOnjwoObNm6f27dvrBz/4gdV20qRJmj17tqKiohQZGak5c+aoR48e1kyJ7t27a+TIkZo8ebJeffVVSRemjqempjIrAgCCTJ3c5vvi+dSXmmNdUxt/52oHaiqC9O3pwCd2N5O74sL7NbWpCP4KplOkwYIx8cWYeGvM4+HPVITGbMmSJZKkwYMHe61ftmyZJk6cqObNm2vPnj164403dOLECcXFxWnIkCF6++23retqJemll15SWFiYxo0bZ918aPny5dZ1tZL05ptvaubMmdYMirS0NC1evLjuiwQA+CWgAanyOyKKioqsqQfShXnYlWeV6mqudqCnIkiSu8JmTUdobB9u6kownCINNoyJL8bEW2Mcj8bW3ytlGMYln2/VqpU+/PDDy26nZcuWys7OVnZ2do1tIiMjtWrVKr/7CACoXwH9HqTOnTsrNjbWazrJuXPntHnzZiv8VJ2rXalyrnZlm6pztStdbq42AAAAAFwtv88gnTp1Sl988YW1XFhYqIKCAkVGRqpjx47KyMjQggUL1KVLF3Xp0kULFixQeHi4xo8fL4m52gAAAACCl98Baffu3RoyZIi1XHndz4QJE7R8+XI98sgjOnv2rKZOnWp9UeyGDRuYqw0AAAAg6PkdkAYPHnzJOds2m02ZmZnKzMyssQ1ztQEAAAAEo4BegwQAAAAAjRkBCQAAAABMBCQAAAAAMBGQAAAAAMBEQAIAAAAAEwEJAAAAAEwEJAAAAAAwEZAAAAAAwOT3F8WGquse+8D6+eBzdzZgTwAAAADUFc4gAQAAAICJgAQAAAAAJgISAAAAAJgISAAAAABgIiABAAAAgImABAAAAAAmAhIAAAAAmAhIAAAAAGAiIAEAAACAiYAEAAAAACYCEgAAAACYCEgAAAAAYCIgAQAAAICJgAQAAAAAJgISAAAAAJgISAAAAABgIiABAAAAgImABAAAAAAmAhIAAAAAmAhIAAAAAGAiIAEAAACAiYAEAAAAACYCEgAgZC1cuFC33HKLIiIiFB0drdGjR+vAgQNebQzDUGZmpuLj49WqVSsNHjxY+/bt82rjdrs1Y8YMtW/fXq1bt1ZaWpoOHz7s1aakpETp6elyOp1yOp1KT0/XiRMn6rpEAICfCEgAgJC1efNmTZs2Tdu3b5fL5dL58+eVnJys06dPW22ysrL04osvavHixdq1a5diY2M1fPhwnTx50mqTkZGhNWvWKCcnR1u3btWpU6eUmpqq8vJyq8348eNVUFCg3Nxc5ebmqqCgQOnp6fVaLwDg8sIaugMAADSU3Nxcr+Vly5YpOjpa+fn5uv3222UYhhYtWqTHH39cY8aMkSStWLFCMTExWr16taZMmaLS0lItXbpUK1eu1LBhwyRJq1atUkJCgjZu3KgRI0Zo//79ys3N1fbt29W/f39J0uuvv66kpCQdOHBA3bp1q9/CAQA1CvgZpPPnz+vnP/+5OnfurFatWum73/2unn76aVVUVFhtAjVdAQCAQCotLZUkRUZGSpIKCwtVVFSk5ORkq43D4dCgQYOUl5cnScrPz5fH4/FqEx8fr8TERKvNtm3b5HQ6rXAkSQMGDJDT6bTaAACCQ8DPID3//PP69a9/rRUrVuimm27S7t279cADD8jpdOrhhx+W9O10heXLl6tr16565plnNHz4cB04cEARERGSLkxXWLdunXJychQVFaXZs2crNTVV+fn5at68eaC7DQAIcYZhaNasWbrtttuUmJgoSSoqKpIkxcTEeLWNiYnRoUOHrDYtWrRQu3btfNpUvr6oqEjR0dE+7xkdHW21uZjb7Zbb7baWy8rKJEkej0cej6fWdVW29Xg8cjQ3fNY3FVXrbMpCoc5QqFEKjTqDqUZ/+hDwgLRt2zaNGjVKd955pyTpuuuu01tvvaXdu3dLUsCmKwAAEEjTp0/XZ599pq1bt/o8Z7PZvJYNw/BZd7GL21TX/lLbWbhwoebPn++zfsOGDQoPD7/ke1fH5XIpq9+3y+vXr/d7G42By+Vq6C7Ui1CoMxRqlEKjzmCo8cyZM7VuG/CAdNttt+nXv/61/va3v6lr167685//rK1bt2rRokWSLj9dYcqUKZedrlBdQArUkbbK10iSo5lxyedDSTAdAQgWjIkvxsRbYx6PxtjnqzFjxgytXbtWW7ZsUYcOHaz1sbGxki6cAYqLi7PWFxcXW2eVYmNjde7cOZWUlHidRSouLtbAgQOtNkePHvV532PHjvmcnao0d+5czZo1y1ouKytTQkKCkpOT1aZNm1rX5vF45HK5NHz4cPV+9iNr/d7MpnWwsWqddru9obtTZ0KhzlCoUQqNOoOpxspsUBsBD0iPPvqoSktL9b3vfU/NmzdXeXm5nn32Wd17772SAjdd4WKBPtImSb/oW1Ht+qZ61K02guEIQLBhTHwxJt4a43j4c6StMTMMQzNmzNCaNWu0adMmde7c2ev5zp07KzY2Vi6XS71795YknTt3Tps3b9bzzz8vSerTp4/sdrtcLpfGjRsnSTpy5Ij27t2rrKwsSVJSUpJKS0u1c+dO9et34TTOjh07VFpaaoWoizkcDjkcDp/1drv9ij5o2O12ucttXstN0ZWOT2MTCnWGQo1SaNQZDDX68/4BD0hvv/22Vq1apdWrV+umm25SQUGBMjIyFB8frwkTJljtAjFdoapAHWmTvk27T+xuJneF7/s1taNutRFMRwCCBWPiizHx1pjHw58jbY3ZtGnTtHr1ar3//vuKiIiwDsI5nU61atVKNptNGRkZWrBggbp06aIuXbpowYIFCg8P1/jx4622kyZN0uzZsxUVFaXIyEjNmTNHPXr0sKaJd+/eXSNHjtTkyZP16quvSpIefPBBpaamcgc7AAgyAQ9IP/vZz/TYY4/pRz/6kSSpR48eOnTokBYuXKgJEyYEbLrCxQJ9pE2S3BU2r6NtVbcZqoLhCECwYUx8MSbeGuN4NLb+XqklS5ZIkgYPHuy1ftmyZZo4caIk6ZFHHtHZs2c1depUlZSUqH///tqwYYN1UyFJeumllxQWFqZx48bp7NmzGjp0qJYvX+51U6E333xTM2fOtKaPp6WlafHixXVbIADAbwEPSGfOnFGzZt53D2/evLl1m+9ATVcAAOBqGUb115pWZbPZlJmZqczMzBrbtGzZUtnZ2crOzq6xTWRkpFatWnUl3QQA1KOAB6S77rpLzz77rDp27KibbrpJn376qV588UX95Cc/kaSATVcAAAAAgEALeEDKzs7WE088oalTp6q4uFjx8fGaMmWKnnzySatNoKYrAAAAAEAgBTwgRUREaNGiRdZtvasTqOkKAAAAABBIzS7fBAAAAABCAwEJAAAAAEwEJAAAAAAwEZAAAAAAwERAAgAAAAATAQkAAAAATAQkAAAAADARkAAAAADAREACAAAAABMBCQAAAABMBCQAAAAAMBGQAAAAAMBEQAIAAAAAEwEJAAAAAEwEJAAAAAAwEZAAAAAAwERAAgAAAAATAQkAAAAATAQkAAAAADARkAAAAADAREACAAAAABMBCQAAAABMBCQAAAAAMBGQAAAAAMBEQAIAAAAAEwEJAAAAAEwEJAAAAAAwEZAAAAAAwERAAgAAAAATAQkAAAAATAQkAAAAADARkAAAAADAREACAIS0LVu26K677lJ8fLxsNpvee+89r+cnTpwom83m9RgwYIBXG7fbrRkzZqh9+/Zq3bq10tLSdPjwYa82JSUlSk9Pl9PplNPpVHp6uk6cOFHH1QEA/EVAAgCEtNOnT6tXr15avHhxjW1GjhypI0eOWI/169d7PZ+RkaE1a9YoJydHW7du1alTp5Samqry8nKrzfjx41VQUKDc3Fzl5uaqoKBA6enpdVYXAODK1ElA+uqrr3T//fcrKipK4eHhuvnmm5Wfn289bxiGMjMzFR8fr1atWmnw4MHat2+f1zZqczQOAICrlZKSomeeeUZjxoypsY3D4VBsbKz1iIyMtJ4rLS3V0qVL9ctf/lLDhg1T7969tWrVKu3Zs0cbN26UJO3fv1+5ubn6zW9+o6SkJCUlJen111/X7373Ox04cKDOawQA1F5YoDdYUlKiW2+9VUOGDNHvf/97RUdH6+9//7vatm1rtcnKytKLL76o5cuXq2vXrnrmmWc0fPhwHThwQBEREZIuHI1bt26dcnJyFBUVpdmzZys1NVX5+flq3rx5oLsNAECNNm3apOjoaLVt21aDBg3Ss88+q+joaElSfn6+PB6PkpOTrfbx8fFKTExUXl6eRowYoW3btsnpdKp///5WmwEDBsjpdCovL0/dunXzeU+32y23220tl5WVSZI8Ho88Hk+t+17Z1uPxyNHc8FnfVFStsykLhTpDoUYpNOoMphr96UPAA9Lzzz+vhIQELVu2zFp33XXXWT8bhqFFixbp8ccft47WrVixQjExMVq9erWmTJliHY1buXKlhg0bJklatWqVEhIStHHjRo0YMSLQ3QYAoFopKSm6++671alTJxUWFuqJJ57QHXfcofz8fDkcDhUVFalFixZq166d1+tiYmJUVFQkSSoqKrICVVXR0dFWm4stXLhQ8+fP91m/YcMGhYeH+12Hy+VSVr9vly+eJthUuFyuhu5CvQiFOkOhRik06gyGGs+cOVPrtgEPSGvXrtWIESN09913a/PmzfrOd76jqVOnavLkyZKkwsJCFRUVeR1pczgcGjRokPLy8jRlypRaHY27WKCOtFW+RpIczYxLPh9KgukIQLBgTHwxJt4a83g0xj7XlXvuucf6OTExUX379lWnTp30wQcfXHJanmEYstls1nLV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f2xsrM6dO6eSkpJLtjl69KjP9o8dOxa04zhjxgytXbtWH3/8sTp06GCtD9UxadGihW644Qb17dtXCxcuVK9evfTyyy+H5Hjk5+eruLhYffr0UVhYmMLCwrR582b9z//8j8LCwqz+htKYoPEIhf1a69at1aNHD33++ee1+jeqMQrUv72NTVxcnDp16qTPP/9cUuOqsa4/VwSLmuqsTmP7fRKQTC1atFCfPn3kcrm81rtcLg0cOLCBelV/OnfurNjYWK/6z507p82bN1v19+nTR3a73avNkSNHtHfvXqtNUlKSSktLtXPnTqvNjh07VFpaGnTjaBiGpk+frnfffVcfffSROnfu7PV8KI5JdQzDkNvtDsnxGDp0qPbs2aOCggLr0bdvX913330qKCjQd7/73ZAbEzQeobBfc7vd2r9/v+Li4mr1b1RjFKh/exub48eP68svv1RcXJykxlFjfX2uaGiXq7M6je73WT/3gmgcKm+HunTpUuMvf/mLkZGRYbRu3do4ePBgQ3ctIE6ePGl8+umnxqeffmpIMl588UXj008/tW73+txzzxlOp9N49913jT179hj33ntvtbee7NChg7Fx40bjk08+Me64445qb1fcs2dPY9u2bca2bduMHj16BOXtiv/zP//TcDqdxqZNm7xuQ3nmzBmrTaiNydy5c40tW7YYhYWFxmeffWbMmzfPaNasmbFhwwbDMEJvPKpT9S52hsGYILg1tf3a7NmzjU2bNhn/+Mc/jO3btxupqalGRESEVU9t/n8MRvW1f25Il6rx5MmTxuzZs428vDyjsLDQ+Pjjj42kpCTjO9/5TqOqsT4/VzSky9XZFH6fBKSL/OpXvzI6depktGjRwviP//gPr1sWNnYff/yxIcnnMWHCBMMwLtx+8qmnnjJiY2MNh8Nh3H777caePXu8tnH27Flj+vTpRmRkpNGqVSsjNTXV+Oc//+nV5vjx48Z9991nREREGBEREcZ9991nlJSU1FOVtVfdWEgyli1bZrUJtTH5yU9+Yv39X3vttcbQoUOtcGQYoTce1bk4IDEmCHZNab9W+Z0xdrvdiI+PN8aMGWPs27fPer42/z8Go/raPzekS9V45swZIzk52bj22msNu91udOzY0ZgwYYJP/4O9xvr8XNGQLldnU/h92gzDMOr2HBUAAAAANA5cgwQAAAAAJgISAAAAAJgISAAAAABgIiABAAAAgImABAAAAAAmAhIAAAAAmAhIAAAAAGAiIAEAAACAiYAEAAAAACYCEgAAAACYCEgAAAAAYCIgAQAAAICJgAQAAAAAJgISAAAAAJgISAAAAABgIiABAAAAgImABAAAAAAmAhIAAAAAmAhIAAAAAGAiIAEAAACAiYAEAAAAACYCEgAAAACYCEgAAAAAYCIgAQAAAICJgAQAAAAAJgISAAAAAJgISAAAAABgIiABAAAAgImABAAAAAAmAhIAAAAAmAhIAAAAAGAiIAEAAACAiYAEAAAAACYCEgAAAACYCEgAAAAAYCIgAQAAAICJgAQAAAAAJgISAAAAAJgISAAAAABgIiABAAAAgImABAAAAAAmAhIAAAAAmAhIAAAAAGAiIAEAAACAiYAEAAAAACYCEgAAAACYCEgAAAAAYCIgAQAAAICJgAQAAAAAJgISAAAAAJgISAAAAABgIiABAAAAgImABAAAAAAmAhIAAAAAmAhIAAAAAGAiIAEAAACAiYAEAAAAACYCEgAAAACYCEgAam3Tpk2y2WzatGlTQ3cFAHCFbDabMjMzreXly5fLZrPp4MGDDdanYHbxeKHpIyABAACEsDvvvFPbtm1TXFxcQ3cFCAphDd0BALV39uxZtWrVqqG7AQBoQq699lpde+21Dd2Nap05c0bh4eEN3Q2EGM4goVHLzMyUzWbTZ599prvvvltOp1ORkZGaNWuWzp8/rwMHDmjkyJGKiIjQddddp6ysLK/Xl5WVac6cOercubNatGih73znO8rIyNDp06e92v3qV7/S7bffrujoaLVu3Vo9evRQVlaWPB6PV7vBgwcrMTFRu3bt0ve//32Fh4fru9/9rp577jlVVFT4Vdt1112n1NRUvfvuu+rdu7datmyp+fPnW9PcVq9erUcffVRxcXG65pprdNddd+no0aM6efKkHnzwQbVv317t27fXAw88oFOnTnlt+3//93/Vv39/OZ1Oq48/+clPvNr89a9/1ciRIxUeHq727dvroYce0smTJ/2qAQDgq772XWVlZZo8ebKioqJ0zTXXaOTIkfrb3/7m05/qpti5XC6NGjVKHTp0UMuWLXXDDTdoypQp+ve//11tLfv27dO9994rp9OpmJgY/eQnP1Fpaalf4zJx4kRdc8012rNnj5KTkxUREaGhQ4dKujDNbfr06Vq2bJm6deumVq1aqW/fvtq+fbsMw9ALL7ygzp0765prrtEdd9yhL774wmvbn376qVJTUxUdHS2Hw6H4+HjdeeedOnz4sN/jhaaPM0hoEsaNG6f7779fU6ZMkcvlssLLxo0bNXXqVM2ZM8cKFDfccIPGjBmjM2fOaNCgQTp8+LDmzZunnj17at++fXryySe1Z88ebdy4UTabTZL097//XePHj7d2Rn/+85/17LPP6q9//at++9vfevWlqKhI9913n2bPnq2nnnpKa9as0dy5cxUfH68f//jHftX1ySefaP/+/fr5z3+uzp07q3Xr1tYOcN68eRoyZIiWL1+ugwcPas6cObr33nsVFhamXr166a233tKnn36qefPmKSIiQv/zP/8jSdq2bZvuuece3XPPPcrMzFTLli116NAhffTRR9b7Hj16VIMGDZLdbtcrr7yimJgYvfnmm5o+ffrV/JoAAFXU5b7LMAyNHj1aeXl5evLJJ3XLLbfoT3/6k1JSUmrVt7///e9KSkrST3/6UzmdTh08eFAvvviibrvtNu3Zs0d2u92r/dixY3XPPfdo0qRJ2rNnj+bOnStJPvvIyzl37pzS0tI0ZcoUPfbYYzp//rz13O9+9zt9+umneu6552Sz2fToo4/qzjvv1IQJE/SPf/xDixcvVmlpqWbNmqWxY8eqoKBANptNp0+f1vDhw9W5c2f96le/UkxMjIqKivTxxx9bB/6udrzQxBhAI/bUU08Zkoxf/vKXXutvvvlmQ5Lx7rvvWus8Ho9x7bXXGmPGjDEMwzAWLlxoNGvWzNi1a5fXa//v//7PkGSsX7++2vcsLy83PB6P8cYbbxjNmzc3vv76a+u5QYMGGZKMHTt2eL3mxhtvNEaMGOFXbZ06dTKaN29uHDhwwGv9xx9/bEgy7rrrLq/1GRkZhiRj5syZXutHjx5tREZGWsv//d//bUgyTpw4UeN7P/roo4bNZjMKCgq81g8fPtyQZHz88cd+1QIA+FZ97Lt+//vfG5KMl19+2avds88+a0gynnrqKWvdsmXLDElGYWFhtf2tqKgwPB6PcejQIUOS8f777/vUkpWV5fWaqVOnGi1btjQqKipqNyiGYUyYMMGQZPz2t7/1eU6SERsba5w6dcpa99577xmSjJtvvtnrfRYtWmRIMj777DPDMAxj9+7dhiTjvffeq/G9/RkvNH1MsUOTkJqa6rXcvXt32Ww2ryM/YWFhuuGGG3To0CFJF45EJSYm6uabb9b58+etx4gRI3zu1Pbpp58qLS1NUVFRat68uex2u3784x+rvLzc5/R7bGys+vXr57WuZ8+e1vv6o2fPnuratWuta5YuXGx78fqvv/7ammZ3yy23SLpw5PL//b//p6+++spn2x9//LFuuukm9erVy2v9+PHj/a4BAFC9utx3ffzxx5Kk++67z+s9avvveHFxsR566CElJCQoLCxMdrtdnTp1kiTt37/fp31aWprXcs+ePfXNN9+ouLi4Vu9X1dixY6tdP2TIELVu3dpartzvpaSkWDM+qq6vHLMbbrhB7dq106OPPqpf//rX+stf/uKz7asdLzQtBCQ0CZGRkV7LLVq0UHh4uFq2bOmz/ptvvpF0YRrZZ599Jrvd7vWIiIiQYRjWPOt//vOf+v73v6+vvvpKL7/8sv74xz9q165d+tWvfiXpwo0TqoqKivLpn8Ph8GlXG5e6o1B1NV9qfWXdt99+u9577z2dP39eP/7xj9WhQwclJibqrbfesl5z/PhxxcbG+rxndesAAFemLvddx48fV1hYmM8+qTb/jldUVCg5OVnvvvuuHnnkEf3hD3/Qzp07tX37dkm++z3Jd9/ncDhqbHsp4eHhatOmTbXPXel+z+l0avPmzbr55ps1b9483XTTTYqPj9dTTz1lXUt8NeOFpodrkBCy2rdvr1atWtU4P7p9+/aSpPfee0+nT5/Wu+++ax09k6SCgoI672PVI2KBNGrUKI0aNUput1vbt2/XwoULNX78eF133XVKSkpSVFSUioqKfF5X3ToAQP2p7b4rKipK58+f1/Hjx70+9Nfm3/G9e/fqz3/+s5YvX64JEyZY6y++8UFdqKv9Xo8ePZSTkyPDMPTZZ59p+fLlevrpp9WqVSs99thjVzVeaHo4g4SQlZqaqr///e+KiopS3759fR7XXXedpG//sa48GiZduJjz9ddfb4huB5TD4dCgQYP0/PPPS7owlVC6MI1h3759+vOf/+zVfvXq1fXeRwDAt2q77xoyZIgk6c033/R6fW3+Ha9uvydJr776agAqaFg2m029evXSSy+9pLZt2+qTTz6RdHXjhaaHM0gIWRkZGXrnnXd0++2367/+67/Us2dPVVRU6J///Kc2bNig2bNnq3///ho+fLhatGihe++9V4888oi++eYbLVmyRCUlJQ1dwhV58skndfjwYQ0dOlQdOnTQiRMn9PLLL8tut2vQoEGSLozNb3/7W91555165plnrLvY/fWvf23g3gNAaKvtvis5OVm33367HnnkEZ0+fVp9+/bVn/70J61cufKy7/G9731P119/vR577DEZhqHIyEitW7dOLperHioMvN/97nd65ZVXNHr0aH33u9+VYRh69913deLECQ0fPlySrmq80PQQkBCyWrdurT/+8Y967rnn9Nprr6mwsFCtWrVSx44dNWzYMOso3Pe+9z298847+vnPf64xY8YoKipK48eP16xZsxrl7T/79++v3bt369FHH9WxY8fUtm1b9e3bVx999JFuuukmSRfmXG/evFkPP/yw/vM//1Ph4eH6wQ9+oMWLF2vUqFENXAEAhK7a7ruaNWumtWvXatasWcrKytK5c+d06623av369fre9753yfew2+1at26dHn74YU2ZMkVhYWEaNmyYNm7cqI4dO9ZDlYHVpUsXtW3bVllZWfrXv/6lFi1aqFu3bl5TCK9mvND02AzDMBq6EwAAAAAQDLgGCQAAAABMTLED6ll5ebkudeLWZrOpefPm9dgjAADqTkVFhSoqKi7ZJiyMj6QIHpxBAurZ9ddf7/P9FVUfQ4cObeguAgAQMD/5yU8uud+z2+0N3UXAC9cgAfVsz549crvdNT4fERGhbt261WOPAACoOwcPHrS+wLYmffv2rafeAJdHQAIAAAAAE1PsAAAAAMDUZK+Iq6io0L/+9S9FRERY3wgNAKgdwzB08uRJxcfHq1kzjqUFA/ZrAHDl/NmvNdmA9K9//UsJCQkN3Q0AaNS+/PJLdejQoaG7AbFfA4BAqM1+rckGpIiICEkXBqFNmzZ+v97j8WjDhg1KTk7m7ipXibEMHMYysBjPmpWVlSkhIcH6txQNj/3apVFf49WUa5OoL1j4s19rsgGpcvpBmzZtrnhHEh4erjZt2gT1L7sxYCwDh7EMLMbz8pjKFTzYr10a9TVeTbk2ifqCTW32a0wsBwAAAAATAQkAAAAATAQkAAAAADARkAAAAADAREACAAAAABMBCQAAAABMBCQAAAAAMBGQAAAAAMBEQAIAAAAAEwEJAAAAAEwEJAAAAAAwEZAAAAAAwERAAgAAAAATAekyEjM/1HWPfdDQ3QAAICDY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",
      "text/plain": [
       "<Figure size 1000x1000 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Split: val\n",
      "Average median RMSD: 1.02 +- 3.19\n",
      "Median number of structures: 2.00\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAzYAAANCCAYAAAC0/FmWAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy81sbWrAAAACXBIWXMAAA9hAAAPYQGoP6dpAAB9SElEQVR4nO3dfXzT5aH//3egIbTQotw17ShQsXhXUAaK4E2L2mqHqAfnFLyB6XbwgM6u83AjZyN4sMVu4+AZyo4eh/h1DH87gtPJsOEIRYfMgjCxOmSzIDpqJ4KtFEKg1+8PTkPTG2jalORKX8/HIw/JlSvJ+/pQ8+mbT/KJwxhjBAAAAAAW6xLpAAAAAADQXhQbAAAAANaj2AAAAACwHsUGAAAAgPUoNgAAAACsR7EBAAAAYD2KDQAAAADrUWwAAAAAWI9iAwAAAMB6FBvEnOeee04Oh0O7d++OdBRt2rRJHo9HBw8ebHLb4MGDdeONN575UACATqG2tlYej0cbNmyIaI7CwkK9/PLLEc2AzoFiA3SgTZs2af78+c0WGwAAOlJtba3mz59PsUGnQbEBAACAamtrIx0hJIcPH450BEQZig06hXXr1unaa69VUlKSEhISdMUVV+h///d/g+Z4PB45HA6Vl5dr0qRJ6tWrl5KTk3Xvvffqq6++Cpp78OBB3Xffferdu7d69uyp8ePH6+OPP5bD4ZDH4wk83r/+679KktLT0+VwOORwOJr8y9natWv1zW9+U/Hx8Tr//PP1q1/9qsO2AwCgea3ZB+zevVsOh0PPPfdck/s3fP1v+HjvvfeebrvtNvXq1Uu9e/dWQUGBjh07pp07d+qGG25QYmKiBg8erOLi4pAzv/HGG8rOzlafPn0UHx+vgQMH6tZbb1Vtba12796tfv36SZLmz58f2AdNnTo1KN+7776rb3/72zr77LM1ZMgQSVJ2drays7ObPN/UqVM1ePDgoDGfz6dHH31UF1xwgbp3764+ffpo3Lhx2rRpU2C7HDp0SMuXLw9kqH/s+gyNNfeW8vq3b69atUojRoxQ9+7dNX/+fElSZWWlpk2bpgEDBqhbt25KT0/X/PnzdezYsaDHXbp0qS6++GL17NlTiYmJOv/88/XII4+EutkRxeIiHQDoaC+88ILuuece3XzzzVq+fLmcTqf+67/+S9dff71ef/11XXvttUHzb731Vt1+++267777tGPHDs2ZM0eSAoWjrq5OEyZM0JYtW+TxePTNb35Tb7/9tm644Yagx/ne976nL7/8Ur/4xS+0atUqpaSkSJIuvPDCwJw///nP+tGPfqTZs2crOTlZ//3f/6377rtP5557rq6++uqO3CwAgGacbh8Qqu985zu66667NG3aNHm9XhUXF8vv92vdunWaPn26Hn74Ya1YsUKzZs3Sueeeq4kTJ7bqcXfv3q3x48frqquu0q9+9SudddZZ+uyzz7R27VodPXpUKSkpWrt2rW644Qbdd999+t73vidJgbJTb+LEibrjjjt0//3369ChQyGt7dixY8rLy9Obb76p/Px8XXPNNTp27Jg2b96sTz75RGPHjtXbb7+ta665RuPGjdOPf/xjSVJSUlJIz1Pv3Xff1Ycffqh/+7d/U3p6unr06KHKykpddtll6tKli37yk59oyJAhevvtt7VgwQLt3r1by5YtkyStXLlS06dP14MPPqif/exn6tKli/7617/qgw8+aFMWRCkDxJhly5YZSaaiosIcOnTI9O7d20yYMCFozvHjx83FF19sLrvsssDYvHnzjCRTXFwcNHf69Omme/fupq6uzhhjzGuvvWYkmaVLlwbNKyoqMpLMvHnzAmM//elPA1kaGzRokOnevbvZs2dPYOzw4cOmd+/eZtq0aW1dPgCgDVqzD6ioqDCSzLJly5rcv/Hrf/3j/fznPw+ad8kllxhJZtWqVYExv99v+vXrZyZOnNjqvP/zP/9jJJnt27e3OOcf//hHk1yN8/3kJz9pcltWVpbJyspqMj5lyhQzaNCgwPXnn3/eSDLPPPPMKbP26NHDTJkypcUMjTXcj9cbNGiQ6dq1q9m5c2fQ3GnTppmePXsG7UuNMeZnP/uZkWTKy8uNMcY88MAD5qyzzjplTtiPt6Ihpm3atElffvmlpkyZomPHjgUudXV1uuGGG1RWVtbkX6huuummoOvDhw/XkSNHVFVVJUkqLS2VdOJf4RqaNGlSyPkuueQSDRw4MHC9e/fuGjp0qPbs2RPyYwEA2u90+4BQNT775QUXXCCHw6G8vLzAWFxcnM4999yQXvsvueQSdevWTf/8z/+s5cuX6+OPP25TvltvvbVN95OkP/zhD+revbvuvffeNj9GKIYPH66hQ4cGjf3+97/XuHHjlJqaGrSfr9++9fvsyy67TAcPHtSkSZP0u9/9Tl988cUZyYwzi2KDmPb5559Lkr797W/L6XQGXR5//HEZY/Tll18G3adPnz5B110ul6STH1Lcv3+/4uLi1Lt376B5ycnJIedr/Fz1z8cHIgEgMk63DwhV431Ft27dlJCQoO7duzcZP3LkSKsfd8iQIVq3bp369++vGTNmaMiQIRoyZIieeOKJkPLVv026Lf7xj38oNTVVXbqcmV8nm8v6+eef69VXX22yj7/oooskKVBg7r77bv3qV7/Snj17dOutt6p///4aPXq0vF7vGcmOM4PP2CCm9e3bV5L0i1/8Qpdffnmzc0ItJH369NGxY8f05ZdfBu2wKisr2x4UABD16suIz+cLGt+/f38k4uiqq67SVVddpePHj2vLli36xS9+ofz8fCUnJ+uOO+5o1WM09+H97t27NzlpjqQmRzn69eunt956S3V1dW0qNw23Z32BbO55TpW1b9++Gj58uB577LFm75Oamhr483e/+11997vf1aFDh7Rx40bNmzdPN954oz766CMNGjQo5PyIPhyxQUy74oordNZZZ+mDDz7QqFGjmr1069YtpMfMysqSJL344otB4ytXrmwyt73/0gcAiB7Jycnq3r273nvvvaDx3/3udxFKdELXrl01evRoPfnkk5JOfMheavs+aPDgwfroo4+CCtz+/fsDZzqrl5eXpyNHjjR7lriGWnonQv0Z1hpvz1dffbXVWW+88Ua9//77GjJkSLP7+IbFpl6PHj2Ul5enuXPn6ujRoyovL2/18yG6ccQGMa1nz576xS9+oSlTpujLL7/Ut7/9bfXv31//+Mc/9Oc//1n/+Mc/tHTp0pAe84YbbtAVV1yhH/3oR6qurtbIkSP19ttv6/nnn5ekoH+1GjZsmCTpiSee0JQpU+R0OnXeeecpMTExfIsEAJwRDodDd911l371q19pyJAhuvjii/XOO+9oxYoVZzzLL3/5S73xxhsaP368Bg4cqCNHjgTO3HbddddJkhITEzVo0CD97ne/07XXXqvevXurb9++TU7Z3Njdd9+t//qv/9Jdd92l73//+9q/f7+Ki4ubnM1s0qRJWrZsme6//37t3LlT48aNU11dnf70pz/pggsuCBw1GjZsmDZs2KBXX31VKSkpSkxM1Hnnnadvfetb6t27t+677z49+uijiouL03PPPae9e/e2ejs8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FzmNGTNGf/jDH6IuZ0uKiorkcDiUn58flZk9Ho8cDkfQxe12R2VWSfrss8901113qU+fPkpISNAll1yirVu3RmXewYMHN9m2DodDM2bMiLqsiF7Rso8LRbj2MdGora/p0SQcr6PR4NixY/q3f/s3paenKz4+Xuecc44effRR1dXVBeZE81ps+r3xdE61Fr/fr1mzZmnYsGHq0aOHUlNTdc899+jvf/970GOEfS3GQitXrjROp9M888wz5oMPPjAPPfSQ6dGjh9mzZ88Zz7JmzRozd+5c89JLLxlJZvXq1UG3L1y40CQmJpqXXnrJ7Nixw9x+++0mJSXFVFdXB+bcf//95hvf+Ibxer3m3XffNePGjTMXX3yxOXbsWFizXn/99WbZsmXm/fffN9u3bzfjx483AwcONF9//XXU5X3llVfMa6+9Znbu3Gl27txpHnnkEeN0Os37778fVTmb884775jBgweb4cOHm4ceeigwHk2Z582bZy666CKzb9++wKWqqioqs3755Zdm0KBBZurUqeZPf/qTqaioMOvWrTN//etfozJvVVVV0Hb1er1Gklm/fn3UZUV0iqZ9XCjCtY+JNu15TY8W4XodjQYLFiwwffr0Mb///e9NRUWF+e1vf2t69uxpFi9eHJgTzWux6ffG9qzl4MGD5rrrrjMvvvii+ctf/mLefvttM3r0aDNy5Migxwj3WqwsNpdddpm5//77g8bOP/98M3v27AglOqHxX2pdXZ1xu91m4cKFgbEjR46YXr16mV/+8pfGmBN/8U6n06xcuTIw57PPPjNdunQxa9eu7dC8VVVVRpIpLS21Iu/ZZ59t/vu//zuqc9bU1JiMjAzj9XpNVlZWYCcYbZnnzZtnLr744mZvi7ass2bNMldeeWWLt0db3sYeeughM2TIEFNXVxf1WREdonUfF6q27GOiTXte06NJOF5Ho8X48ePNvffeGzQ2ceJEc9dddxlj7FqLbb83nkpzJa2xd955x0gK/CNNR6zFureiHT16VFu3blVubm7QeG5urjZt2hShVM2rqKhQZWVlUFaXy6WsrKxA1q1bt8rv9wfNSU1NVWZmZoev56uvvpIk9e7dO6rzHj9+XCtXrtShQ4c0ZsyYqM0pSTNmzND48eN13XXXBY1HY+Zdu3YpNTVV6enpuuOOO/Txxx9HZdZXXnlFo0aN0m233ab+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AAAAAKxHsQEAAABgPYoNAAAAAOtRbAAAAABYj2IDAAAAwHoUGwAAAADWo9gAAAAAsB7FBgAAAID1KDYAAAAArEexAQAAAGA9ig0AAAAA61FsAAAAAFiPYgMAAADAehQbAAAAANaj2AAAAACwHsUGAAAAgPUoNgAAAACsR7EBAAAAYD2KDQAAAADrUWwAAAAAWI9iAwAAAMB6FBsAAAAA1qPYAAAAALAexQYAAACA9Sg2AAAAAKxHsQEAAABgPYoNAAAAAOtRbAAAAABYj2IDAAAAwHoUGwAAAADWo9gAAAAAsB7FBgAAAID1KDYAAAAArEexAQAAAGA9ig0AAAAA61FsAAAAAFiPYgMAAADAehQbAAAAANaj2AAAAACwHsUGAAAAgPUoNgAAAACsR7EBOokNGzbI4XBow4YNkY4CAGgDh8Mhj8cTuP7cc8/J4XBo9+7dEcsUzRpvL8Q+ig0AAICFxo8fr7ffflspKSmRjgJEhbhIBwA6i8OHDys+Pj7SMQAAMaJfv37q169fpGM0q7a2VgkJCZGOgU6GIzaIGI/HI4fDoffee0+33XabevXqpd69e6ugoEDHjh3Tzp07dcMNNygxMVGDBw9WcXFx0P2rq6v18MMPKz09Xd26ddM3vvEN5efn69ChQ0HznnzySV199dXq37+/evTooWHDhqm4uFh+vz9oXnZ2tjIzM1VWVqarrrpKCQkJOuecc7Rw4ULV1dWFtLbBgwfrxhtv1KpVqzRixAh1795d8+fPD7wdbMWKFZo1a5ZSUlLUs2dPTZgwQZ9//rlqamr0z//8z+rbt6/69u2r7373u/r666+DHvu3v/2tRo8erV69egUy3nvvvUFz/vKXv+iGG25QQkKC+vbtq/vvv181NTUhrQEAEOxM7beqq6v1/e9/X3369FHPnj11ww036KOPPmqSp7m3onm9Xt18880aMGCAunfvrnPPPVfTpk3TF1980exaysvLNWnSJPXq1UvJycm699579dVXX4W0XaZOnaqePXtqx44dys3NVWJioq699lpJJ94O9sADD2jZsmU677zzFB8fr1GjRmnz5s0yxuinP/2p0tPT1bNnT11zzTX661//GvTY27Zt04033qj+/fvL5XIpNTVV48eP16effhry9kLs44gNIu473/mO7rrrLk2bNk1erzdQOtatW6fp06fr4YcfDhSBc889VxMnTlRtba2ysrL06aef6pFHHtHw4cNVXl6un/zkJ9qxY4fWrVsnh8MhSfrb3/6myZMnB3Ykf/7zn/XYY4/pL3/5i371q18FZamsrNSdd96pH/3oR5o3b55Wr16tOXPmKDU1Vffcc09I63r33Xf14Ycf6t/+7d+Unp6uHj16BHZejzzyiMaNG6fnnntOu3fv1sMPP6xJkyYpLi5OF198sX7zm99o27ZteuSRR5SYmKj//M//lCS9/fbbuv3223X77bfL4/Goe/fu2rNnj954443A837++efKysqS0+nUU089peTkZP3617/WAw880J6/JgDA/+nI/ZYxRrfccos2bdqkn/zkJ7r00kv1xz/+UXl5ea3K9re//U1jxozR9773PfXq1Uu7d+/WokWLdOWVV2rHjh1yOp1B82+99Vbdfvvtuu+++7Rjxw7NmTNHkprsH0/n6NGjuummmzRt2jTNnj1bx44dC9z2+9//Xtu2bdPChQvlcDg0a9YsjR8/XlOmTNHHH3+sJUuW6KuvvlJBQYFuvfVWbd++XQ6HQ4cOHVJOTo7S09P15JNPKjk5WZWVlVq/fn3gH+vau70QYwwQIfPmzTOSzM9//vOg8UsuucRIMqtWrQqM+f1+069fPzNx4kRjjDFFRUWmS5cupqysLOi+//M//2MkmTVr1jT7nMePHzd+v988//zzpmvXrubLL78M3JaVlWUkmT/96U9B97nwwgvN9ddfH9LaBg0aZLp27Wp27twZNL5+/XojyUyYMCFoPD8/30gyP/jBD4LGb7nlFtO7d+/A9Z/97GdGkjl48GCLzz1r1izjcDjM9u3bg8ZzcnKMJLN+/fqQ1gIAOOFM7Lf+8Ic/GEnmiSeeCJr32GOPGUlm3rx5gbFly5YZSaaioqLZvHV1dcbv95s9e/YYSeZ3v/tdk7UUFxcH3Wf69Omme/fupq6urnUbxRgzZcoUI8n86le/anKbJON2u83XX38dGHv55ZeNJHPJJZcEPc/ixYuNJPPee+8ZY4zZsmWLkWRefvnlFp87lO2F2Mdb0RBxN954Y9D1Cy64QA6HI+hfW+Li4nTuuedqz549kk78609mZqYuueQSHTt2LHC5/vrrm5z5a9u2bbrpppvUp08fde3aVU6nU/fcc4+OHz/e5FC12+3WZZddFjQ2fPjwwPOGYvjw4Ro6dGir1yyd+CBo4/Evv/wy8Ha0Sy+9VNKJfy38//6//0+fffZZk8dev369LrroIl188cVB45MnTw55DQCApjpyv7V+/XpJ0p133hn0HK19Da+qqtL999+vtLQ0xcXFyel0atCgQZKkDz/8sMn8m266Kej68OHDdeTIEVVVVbXq+Rq69dZbmx0fN26cevToEbhev8/Ly8sLvLui4Xj9Njv33HN19tlna9asWfrlL3+pDz74oMljt3d7IbZQbBBxvXv3DrrerVs3JSQkqHv37k3Gjxw5IunE263ee+89OZ3OoEtiYqKMMYH3En/yySe66qqr9Nlnn+mJJ57Qm2++qbKyMj355JOSTnygv6E+ffo0yedyuZrMa41TnaWmuTWfarx+3VdffbVefvllHTt2TPfcc48GDBigzMxM/eY3vwncZ//+/XK73U2es7kxAEDoOnK/tX//fsXFxTXZH7XmNbyurk65ublatWqVZs6cqf/93//VO++8o82bN0tqus+Tmu73XC5Xi3NPJSEhQUlJSc3e1tZ9Xq9evVRaWqpLLrlEjzzyiC666CKlpqZq3rx5gc/Jtmd7IfbwGRtYqW/fvoqPj2/xPcB9+/aVJL388ss6dOiQVq1aFfgXK0navn17h2ds+K9Q4XTzzTfr5ptvls/n0+bNm1VUVKTJkydr8ODBGjNmjPr06aPKysom92tuDABwZrR2v9WnTx8dO3ZM+/fvD/plvTWv4e+//77+/Oc/67nnntOUKVMC440/kN8ROmqfN2zYMK1cuVLGGL333nt67rnn9Oijjyo+Pl6zZ89u1/ZC7OGIDax044036m9/+5v69OmjUaNGNbkMHjxY0skX2vp/gZJOfNDwmWeeiUTssHK5XMrKytLjjz8u6cRb7qQTh/zLy8v15z//OWj+ihUrznhGAMAJrd1vjRs3TpL061//Ouj+rXkNb26fJ0n/9V//FYYVRJbD4dDFF1+s//iP/9BZZ52ld999V1L7thdiD0dsYKX8/Hy99NJLuvrqq/XDH/5Qw4cPV11dnT755BOVlJToRz/6kUaPHq2cnBx169ZNkyZN0syZM3XkyBEtXbpUBw4ciPQS2uQnP/mJPv30U1177bUaMGCADh48qCeeeEJOp1NZWVmSTmybX/3qVxo/frwWLFgQOCvaX/7ylwinB4DOq7X7rdzcXF199dWaOXOmDh06pFGjRumPf/yj/t//+3+nfY7zzz9fQ4YM0ezZs2WMUe/evfXqq6/K6/WegRWG3+9//3s99dRTuuWWW3TOOefIGKNVq1bp4MGDysnJkaR2bS/EHooNrNSjRw+9+eabWrhwoZ5++mlVVFQoPj5eAwcO1HXXXRf4l6/zzz9fL730kv7t3/5NEydOVJ8+fTR58mQVFBRYeSrI0aNHa8uWLZo1a5b+8Y9/6KyzztKoUaP0xhtv6KKLLpJ04n3FpaWleuihh/Qv//IvSkhI0D/90z9pyZIluvnmmyO8AgDonFq73+rSpYteeeUVFRQUqLi4WEePHtUVV1yhNWvW6Pzzzz/lczidTr366qt66KGHNG3aNMXFxem6667TunXrNHDgwDOwyvDKyMjQWWedpeLiYv39739Xt27ddN555wW91a492wuxx2GMMZEOAQAAAADtwWdsAAAAAFiPt6IBITh+/LhOdZDT4XCoa9euZzARAAAdo66uTnV1daecExfHr5KIHhyxAUIwZMiQJt9B0PBy7bXXRjoiAABhce+9955yn+d0OiMdEQjCZ2yAEOzYsUM+n6/F2xMTE3XeeeedwUQAAHSM3bt3B744tCWjRo06Q2mA06PYAAAAALAeb0UDAAAAYL2o+8RXXV2d/v73vysxMTHwDboAgNYxxqimpkapqanq0oV/u4oW7NsAoG1C2a9FXbH5+9//rrS0tEjHAACr7d27VwMGDIh0DPwf9m0A0D6t2a9FXbFJTEyUdCJ8UlJSyPf3+/0qKSlRbm6udWfrIHvk2Jyf7JETjfmrq6uVlpYWeC1FdGjPvi0af84ihW0RjO1xEtvipFjbFqHs16Ku2NQfok9KSmpzsUlISFBSUpJ1f5lkjxyb85M9cqI5P293ii7t2bdF88/Zmca2CMb2OIltcVKsbovW7Nd4AzYAAAAA61FsAAAAAFiPYgMAAADAehQbAAAAANaj2AAAAACwHsUGAAAAgPUoNgAAAACsR7EBAAAAYD2KDQAAAADrUWwAAAAAWI9iAwAAAMB6FBsAAAAA1qPYAAAAALBezBabTM/rGjz7tUjHAAAgLNivAcCpxWyxAQAAANB5hFRsPB6PHA5H0MXtdgduN8bI4/EoNTVV8fHxys7OVnl5edhDAwAAAEBDIR+xueiii7Rv377AZceOHYHbiouLtWjRIi1ZskRlZWVyu93KyclRTU1NWEMDAAAAQEMhF5u4uDi53e7ApV+/fpJOHK1ZvHix5s6dq4kTJyozM1PLly9XbW2tVqxYEfbgAAAAAFAv5GKza9cupaamKj09XXfccYc+/vhjSVJFRYUqKyuVm5sbmOtyuZSVlaVNmzaFLzEAAAAANBIXyuTRo0fr+eef19ChQ/X5559rwYIFGjt2rMrLy1VZWSlJSk5ODrpPcnKy9uzZ0+Jj+nw++Xy+wPXq6mpJkt/vl9/vDyVe4H6S5Opigq7boD6rTZnr2Zxdsjs/2SMnGvNHUxYAAM6kkIpNXl5e4M/Dhg3TmDFjNGTIEC1fvlyXX365JMnhcATdxxjTZKyhoqIizZ8/v8l4SUmJEhISQokX5N9H1UmS1qxZ0+bHiBSv1xvpCG1mc3bJ7vxkj5xoyl9bWxvpCAAARERIxaaxHj16aNiwYdq1a5duueUWSVJlZaVSUlICc6qqqpocxWlozpw5KigoCFyvrq5WWlqacnNzlZSUFHImv98vr9erH2/pIl+dQ+97rg/5MSKlPntOTo6cTmek44TE5uyS3fnJHjnRmL/+qDcAAJ1Nu4qNz+fThx9+qKuuukrp6elyu93yer0aMWKEJOno0aMqLS3V448/3uJjuFwuuVyuJuNOp7Ndvyj46hzyHXdEzS8boWjv2iPJ5uyS3fnJHjnRlD9acgAAcKaFVGwefvhhTZgwQQMHDlRVVZUWLFig6upqTZkyRQ6HQ/n5+SosLFRGRoYyMjJUWFiohIQETZ48uaPyAwAAAEBoxebTTz/VpEmT9MUXX6hfv366/PLLtXnzZg0aNEiSNHPmTB0+fFjTp0/XgQMHNHr0aJWUlCgxMbFDwgMAAACAFGKxWbly5Slvdzgc8ng88ng87ckEAAAAACEJ+XtsAAAAACDaUGwAAAAAWI9iAwAAAMB6FBsAAAAA1qPYAAAAALAexQYAAACA9Sg2AAAAAKxHsQEAdFoej0cOhyPo4na7A7cbY+TxeJSamqr4+HhlZ2ervLw8gokBAC2h2AAAOrWLLrpI+/btC1x27NgRuK24uFiLFi3SkiVLVFZWJrfbrZycHNXU1EQwMQCgORQbAECnFhcXJ7fbHbj069dP0omjNYsXL9bcuXM1ceJEZWZmavny5aqtrdWKFSsinBoA0FhcpAMAABBJu3btUmpqqlwul0aPHq3CwkKdc845qqioUGVlpXJzcwNzXS6XsrKytGnTJk2bNq3Fx/T5fPL5fIHr1dXVkiS/3y+/3x9Svvr5ri4m6HpnVL/2zrwNGmJ7nMS2OCnWtkUo66DYAAA6rdGjR+v555/X0KFD9fnnn2vBggUaO3asysvLVVlZKUlKTk4Ouk9ycrL27NlzysctKirS/Pnzm4yXlJQoISGhTVn/fVSdJGnNmjVtun8s8Xq9kY4QVdgeJ7EtToqVbVFbW9vquRQbAECnlZeXF/jzsGHDNGbMGA0ZMkTLly/X5ZdfLklyOBxB9zHGNBlrbM6cOSooKAhcr66uVlpamnJzc5WUlBRSRr/fL6/Xqx9v6SJfnUPve64P6f6xpH5b5OTkyOl0RjpOxLE9TmJbnBRr26L+iHdrUGwAAPg/PXr00LBhw7Rr1y7dcsstkqTKykqlpKQE5lRVVTU5itOYy+WSy+VqMu50Otv8i4avziHfcUdM/KLSXu3ZjrGI7XES2+KkWNkWoayBkwcAAPB/fD6fPvzwQ6WkpCg9PV1utzvo7RxHjx5VaWmpxo4dG8GUAIDmcMQGANBpPfzww5owYYIGDhyoqqoqLViwQNXV1ZoyZYocDofy8/NVWFiojIwMZWRkqLCwUAkJCZo8eXKkowMAGqHYAAA6rU8//VSTJk3SF198oX79+unyyy/X5s2bNWjQIEnSzJkzdfjwYU2fPl0HDhzQ6NGjVVJSosTExAgnBwA0RrEBAHRaK1euPOXtDodDHo9HHo/nzAQCALQZn7EBAAAAYD2KDQAAAADrUWwAAAAAWI9iAwAAAMB6FBsAAAAA1qPYAAAAALAexQYAAACA9Sg2AAAAAKxHsQEAAABgPYoNAAAAAOtRbAAAAABYj2IDAAAAwHoUGwAAAADWo9gAAAAAsB7FBgAAAID1KDYAAAAArEexAQAAAGA9ig0AAAAA61FsAAAAAFiPYgMAAADAehQbAAAAANaj2AAAAACwHsUGAAAAgPUoNgAAAACsR7EBAAAAYD2KDQAAAADrUWwAAAAAWI9iAwAAAMB6FBsAAAAA1qPYAAAAALAexQYAAACA9Sg2AAAAAKxHsQEAAABgPYoNAAAAAOu1q9gUFRXJ4XAoPz8/MGaMkcfjUWpqquLj45Wdna3y8vL25gQAAACAFrW52JSVlenpp5/W8OHDg8aLi4u1aNEiLVmyRGVlZXK73crJyVFNTU27wwIAAABAc9pUbL7++mvdeeedeuaZZ3T22WcHxo0xWrx4sebOnauJEycqMzNTy5cvV21trVasWBG20AAAAADQUFxb7jRjxgyNHz9e1113nRYsWBAYr6ioUGVlpXJzcwNjLpdLWVlZ2rRpk6ZNm9bksXw+n3w+X+B6dXW1JMnv98vv94ecrf4+ri4m6LoN6rPalLmezdklu/OTPXKiMX80ZQEA4EwKudisXLlS7777rsrKyprcVllZKUlKTk4OGk9OTtaePXuafbyioiLNnz+/yXhJSYkSEhJCjRfw76PqJElr1qxp82NEitfrjXSENrM5u2R3frJHTjTlr62tjXQEAAAiIqRis3fvXj300EMqKSlR9+7dW5zncDiCrhtjmozVmzNnjgoKCgLXq6urlZaWptzcXCUlJYUST9KJf630er368ZYu8tU59L7n+pAfI1Lqs+fk5MjpdEY6Tkhszi7ZnZ/skRON+euPegMA0NmEVGy2bt2qqqoqjRw5MjB2/Phxbdy4UUuWLNHOnTslnThyk5KSEphTVVXV5ChOPZfLJZfL1WTc6XS26xcFX51DvuOOqPllIxTtXXsk2Zxdsjs/2SMnmvJHSw4AAM60kE4ecO2112rHjh3avn174DJq1Cjdeeed2r59u8455xy53e6gt2UcPXpUpaWlGjt2bNjDAwAAAIAU4hGbxMREZWZmBo316NFDffr0CYzn5+ersLBQGRkZysjIUGFhoRISEjR58uTwpQYAAACABtp0VrRTmTlzpg4fPqzp06frwIEDGj16tEpKSpSYmBjupwIAAAAASWEoNhs2bAi67nA45PF45PF42vvQAAAAANAqbfqCTgAAAACIJhQbAAAAANaj2AAAAACwHsUGAID/U1RUJIfDofz8/MCYMUYej0epqamKj49Xdna2ysvLIxcSANAsig0AAJLKysr09NNPa/jw4UHjxcXFWrRokZYsWaKysjK53W7l5OSopqYmQkkBAM2h2AAAOr2vv/5ad955p5555hmdffbZgXFjjBYvXqy5c+dq4sSJyszM1PLly1VbW6sVK1ZEMDEAoLGwf48NAAC2mTFjhsaPH6/rrrtOCxYsCIxXVFSosrJSubm5gTGXy6WsrCxt2rRJ06ZNa/bxfD6ffD5f4Hp1dbUkye/3y+/3h5Stfr6riwm63hnVr70zb4OG2B4nsS1OirVtEco6KDYAgE5t5cqVevfdd1VWVtbktsrKSklScnJy0HhycrL27NnT4mMWFRVp/vz5TcZLSkqUkJDQppz/PqpOkrRmzZo23T+WeL3eSEeIKmyPk9gWJ8XKtqitrW31XIoNAKDT2rt3rx566CGVlJSoe/fuLc5zOBxB140xTcYamjNnjgoKCgLXq6urlZaWptzcXCUlJYWU0e/3y+v16sdbushX59D7nutDun8sqd8WOTk5cjqdkY4TcWyPk9gWJ8Xatqg/4t0aFBsAQKe1detWVVVVaeTIkYGx48ePa+PGjVqyZIl27twp6cSRm5SUlMCcqqqqJkdxGnK5XHK5XE3GnU5nm3/R8NU55DvuiIlfVNqrPdsxFrE9TmJbnBQr2yKUNXDyAABAp3Xttddqx44d2r59e+AyatQo3Xnnndq+fbvOOeccud3uoLd0HD16VKWlpRo7dmwEkwMAGuOIDQCg00pMTFRmZmbQWI8ePdSnT5/AeH5+vgoLC5WRkaGMjAwVFhYqISFBkydPjkRkAEALKDYAAJzCzJkzdfjwYU2fPl0HDhzQ6NGjVVJSosTExEhHAwA0QLEBAKCBDRs2BF13OBzyeDzyeDwRyQMAaB0+YwMAAADAehQbAAAAANaj2AAAAACwHsUGAAAAgPUoNgAAAACsR7EBAAAAYD2KDQAAAADrUWwAAAAAWI9iAwAAAMB6FBsAAAAA1qPYAAAAALAexQYAAACA9Sg2AAAAAKxHsQEAAABgPYoNAAAAAOtRbAAAAABYj2IDAAAAwHoUGwAAAADWo9gAAAAAsB7FBgAAAID1KDYAAAAArEexAQAAAGA9ig0AAAAA61FsAAAAAFiPYgMAAADAehQbAAAAANaj2AAAAACwHsUGAAAAgPUoNgAAAACsR7EBAAAAYD2KDQAAAADrUWwAAAAAWI9iAwAAAMB6FBsAAAAA1qPYAAAAALAexQYAAACA9Sg2AAAAAKwXUrFZunSphg8frqSkJCUlJWnMmDH6wx/+ELjdGCOPx6PU1FTFx8crOztb5eXlYQ8NAAAAAA2FVGwGDBighQsXasuWLdqyZYuuueYa3XzzzYHyUlxcrEWLFmnJkiUqKyuT2+1WTk6OampqOiQ8AAAAAEghFpsJEyboW9/6loYOHaqhQ4fqscceU8+ePbV582YZY7R48WLNnTtXEydOVGZmppYvX67a2lqtWLGio/IDAAAAQNs/Y3P8+HGtXLlShw4d0pgxY1RRUaHKykrl5uYG5rhcLmVlZWnTpk1hCQsAAAAAzYkL9Q47duzQmDFjdOTIEfXs2VOrV6/WhRdeGCgvycnJQfOTk5O1Z8+eFh/P5/PJ5/MFrldXV0uS/H6//H5/qPEC93F1MUHXbVCf1abM9WzOLtmdn+yRE435oykLAABnUsjF5rzzztP27dt18OBBvfTSS5oyZYpKS0sDtzscjqD5xpgmYw0VFRVp/vz5TcZLSkqUkJAQaryAfx9VJ0las2ZNmx8jUrxeb6QjtJnN2SW785M9cqIpf21tbaQjAAAQESEXm27duuncc8+VJI0aNUplZWV64oknNGvWLElSZWWlUlJSAvOrqqqaHMVpaM6cOSooKAhcr66uVlpamnJzc5WUlBRqPPn9fnm9Xv14Sxf56hx633N9yI8RKfXZc3Jy5HQ6Ix0nJDZnl+zOT/bIicb89Ue9AQDobEIuNo0ZY+Tz+ZSeni632y2v16sRI0ZIko4eParS0lI9/vjjLd7f5XLJ5XI1GXc6ne36RcFX55DvuCNqftkIRXvXHkk2Z5fszk/2yImm/NGSAwCAMy2kYvPII48oLy9PaWlpqqmp0cqVK7VhwwatXbtWDodD+fn5KiwsVEZGhjIyMlRYWKiEhARNnjy5o/IDAAAAQGjF5vPPP9fdd9+tffv2qVevXho+fLjWrl2rnJwcSdLMmTN1+PBhTZ8+XQcOHNDo0aNVUlKixMTEDgkPAAAAAFKIxebZZ5895e0Oh0Mej0cej6c9mQAAAAAgJG3+HhsAAGy3dOlSDR8+XElJSUpKStKYMWP0hz/8IXC7MUYej0epqamKj49Xdna2ysvLI5gYANASig0AoNMaMGCAFi5cqC1btmjLli265pprdPPNNwfKS3FxsRYtWqQlS5aorKxMbrdbOTk5qqmpiXByAEBjFBsAQKc1YcIEfetb39LQoUM1dOhQPfbYY+rZs6c2b94sY4wWL16suXPnauLEicrMzNTy5ctVW1urFStWRDo6AKCRdp/uGQCAWHD8+HH99re/1aFDhzRmzBhVVFSosrJSubm5gTkul0tZWVnatGmTpk2b1uJj+Xw++Xy+wPX67xfy+/3y+/0h5aqf7+pigq53RvVr78zboCG2x0lsi5NibVuEsg6KDQCgU9uxY4fGjBmjI0eOqGfPnlq9erUuvPBCbdq0SZKafMl0cnKy9uzZc8rHLCoq0vz585uMl5SUKCEhoU05/31UnSRpzZo1bbp/LPF6vZGOEFXYHiexLU6KlW1RW1vb6rkUGwBAp3beeedp+/btOnjwoF566SVNmTJFpaWlgdsdDkfQfGNMk7HG5syZo4KCgsD16upqpaWlKTc3V0lJSSHl8/v98nq9+vGWLvLVOfS+5/qQ7h9L6rdFTk4OX0YrtkdDbIuTYm1b1B/xbg2KDQCgU+vWrZvOPfdcSdKoUaNUVlamJ554QrNmzZIkVVZWKiUlJTC/qqqqyVGcxlwul1wuV5Nxp9PZ5l80fHUO+Y47YuIXlfZqz3aMRWyPk9gWJ8XKtghlDZw8AACABowx8vl8Sk9Pl9vtDno7x9GjR1VaWqqxY8dGMCEAoDkcsQEAdFqPPPKI8vLylJaWppqaGq1cuVIbNmzQ2rVr5XA4lJ+fr8LCQmVkZCgjI0OFhYVKSEjQ5MmTIx0dANAIxQYA0Gl9/vnnuvvuu7Vv3z716tVLw4cP19q1a5WTkyNJmjlzpg4fPqzp06frwIEDGj16tEpKSpSYmBjh5ACAxig2AIBO69lnnz3l7Q6HQx6PRx6P58wEAgC0GZ+xAQAAAGA9ig0AAAAA61FsAAAAAFiPYgMAAADAehQbAAAAANaj2AAAAACwHsUGAAAAgPUoNgAAAACsR7EBAAAAYD2KDQAAAADrUWwAAAAAWI9iAwAAAMB6FBsAAAAA1qPYAAAAALAexQYAAACA9Sg2AAAAAKxHsQEAAABgPYoNAAAAAOtRbAAAAABYj2IDAAAAwHoUGwAAAADWo9gAAAAAsB7FBgAAAID1KDYAAAAArEexAQAAAGA9ig0AAAAA61FsAAAAAFiPYgMAAADAehQbAAAAANaj2AAAAACwHsUGAAAAgPUoNgAAAACsR7EBAAAAYD2KDQAAAADrUWwAAAAAWI9iAwAAAMB6FBsAAAAA1qPYAAAAALAexQYAAACA9Sg2AAAAAKxHsQEAAABgvZCKTVFRkS699FIlJiaqf//+uuWWW7Rz586gOcYYeTwepaamKj4+XtnZ2SovLw9raAAAAABoKKRiU1paqhkzZmjz5s3yer06duyYcnNzdejQocCc4uJiLVq0SEuWLFFZWZncbrdycnJUU1MT9vAAAAAAIElxoUxeu3Zt0PVly5apf//+2rp1q66++moZY7R48WLNnTtXEydOlCQtX75cycnJWrFihaZNmxa+5AAAAADwf0IqNo199dVXkqTevXtLkioqKlRZWanc3NzAHJfLpaysLG3atKnZYuPz+eTz+QLXq6urJUl+v19+vz/kTPX3cXUxQddtUJ/Vpsz1bM4u2Z2f7JETjfmjKQsAAGdSm4uNMUYFBQW68sorlZmZKUmqrKyUJCUnJwfNTU5O1p49e5p9nKKiIs2fP7/JeElJiRISEtoaT/8+qk6StGbNmjY/RqR4vd5IR2gzm7NLducne+REU/7a2tpIRwAAICLaXGweeOABvffee3rrrbea3OZwOIKuG2OajNWbM2eOCgoKAterq6uVlpam3NxcJSUlhZzL7/fL6/Xqx1u6yFfn0Pue60N+jEipz56TkyOn0xnpOCGxObtkd36yR0405q8/6g0AQGfTpmLz4IMP6pVXXtHGjRs1YMCAwLjb7ZZ04shNSkpKYLyqqqrJUZx6LpdLLperybjT6WzXLwq+Ood8xx1R88tGKNq79kiyObtkd36yR0405Y+WHAAAnGkhnRXNGKMHHnhAq1at0htvvKH09PSg29PT0+V2u4PelnH06FGVlpZq7Nix4UkMAECY8DUGABA7Qio2M2bM0AsvvKAVK1YoMTFRlZWVqqys1OHDhyWdeAtafn6+CgsLtXr1ar3//vuaOnWqEhISNHny5A5ZAAAAbcXXGABA7AjprWhLly6VJGVnZweNL1u2TFOnTpUkzZw5U4cPH9b06dN14MABjR49WiUlJUpMTAxLYAAAwoWvMQCA2BFSsTHGnHaOw+GQx+ORx+NpayYAACIiHF9jIIX3qwxs/hqDcIvGU6xHEtvjJLbFSbG2LUJZR7u+xwYAgFgRrq8xkDrmqwxs/hqDcIumU6xHA7bHSWyLk2JlW4TyNQYUGwAAFL6vMZDC+1UGNn+NQbhF4ynWI4ntcRLb4qRY2xahfI0BxQYA0OmF82sMpI75KgObv8Yg3KLpFOvRgO1xEtvipFjZFqGsIaSzogEAEEv4GgMAiB0csQEAdFozZszQihUr9Lvf/S7wNQaS1KtXL8XHxwd9jUFGRoYyMjJUWFjI1xgAQBSi2AAAOi2+xgAAYgfFBgDQafE1BgAQO/iMDQAAAADrUWwAAAAAWI9iAwAAAMB6FBsAAAAA1qPYAAAAALAexQYAAACA9Sg2AAAAAKxHsQEAAABgPYoNAAAAAOtRbAAAAABYj2IDAAAAwHoUGwAAAADWo9gAAAAAsB7FBgAAAID1KDYAAAAArEexAQAAAGA9ig0AAAAA61FsAAAAAFiPYgMAAADAehQbAAAAANaj2AAAAACwHsUGAAAAgPUoNgAAAACsR7EBAAAAYD2KDQAAAADrUWwAAAAAWI9iAwAAAMB6FBsAAAAA1qPYAAAAALAexQYAAACA9Sg2AAAAAKxHsQEAAABgPYoNAAAAAOtRbAAAAABYj2IDAAAAwHoUGwAAAADWo9gAAAAAsB7FBgAAAID1KDYAAAAArEexAQAAAGA9ig0AAAAA61FsAAAAAFiPYgMAAADAehQbAAAAANYLudhs3LhREyZMUGpqqhwOh15++eWg240x8ng8Sk1NVXx8vLKzs1VeXh6uvAAAAADQRMjF5tChQ7r44ou1ZMmSZm8vLi7WokWLtGTJEpWVlcntdisnJ0c1NTXtDgsAAAAAzYkL9Q55eXnKy8tr9jZjjBYvXqy5c+dq4sSJkqTly5crOTlZK1as0LRp09qXFgAAAACaEdbP2FRUVKiyslK5ubmBMZfLpaysLG3atCmcTwUAAAAAASEfsTmVyspKSVJycnLQeHJysvbs2dPsfXw+n3w+X+B6dXW1JMnv98vv94ecof4+ri4m6LoN6rPalLmezdklu/OTPXKiMX80ZbHFxo0b9dOf/lRbt27Vvn37tHr1at1yyy2B240xmj9/vp5++mkdOHBAo0eP1pNPPqmLLroocqEBAE2EtdjUczgcQdeNMU3G6hUVFWn+/PlNxktKSpSQkNDmDP8+qk6StGbNmjY/RqR4vd5IR2gzm7NLducne+REU/7a2tpIR7BO/WdHv/vd7+rWW29tcnv9Z0efe+45DR06VAsWLFBOTo527typxMTECCQGADQnrMXG7XZLOnHkJiUlJTBeVVXV5ChOvTlz5qigoCBwvbq6WmlpacrNzVVSUlLIGfx+v7xer368pYt8dQ6977k+5MeIlPrsOTk5cjqdkY4TEpuzS3bnJ3vkRGP++qPeaD0+OwoAsSGsxSY9PV1ut1ter1cjRoyQJB09elSlpaV6/PHHm72Py+WSy+VqMu50Otv1i4KvziHfcUfU/LIRivauPZJszi7ZnZ/skRNN+aMlR6w43WdHWyo24Xybtc1vsQ63aHz7ZySxPU5iW5wUa9silHWEXGy+/vpr/fWvfw1cr6io0Pbt29W7d28NHDhQ+fn5KiwsVEZGhjIyMlRYWKiEhARNnjw51KcCACCi2vLZUalj3mZt81uswy2a3v4ZDdgeJ7EtToqVbRHKW6xDLjZbtmzRuHHjAtfr30Y2ZcoUPffcc5o5c6YOHz6s6dOnBz5kWVJSwvuQAQDWCuWzo1J432Zt81uswy0a3/4ZSWyPk9gWJ8XatgjlLdYhF5vs7GwZY1q83eFwyOPxyOPxhPrQAABElbZ8dlTqmLdZ2/wW63CLprd/RgO2x0lsi5NiZVuEsoawfo8NAACxpOFnR+vVf3Z07NixEUwGAGisQ073DACALfjsKADEBooNAKBT47OjABAbKDYAgE6Nz44CQGzgMzYAAAAArEexAQAAAGA9ig0AAAAA61FsAAAAAFiPYgMAAADAepwVDQCAGDN49muBP+9eOD6CSQDgzOGIDQAAAADrUWwAAAAAWI9iAwAAAMB6Mf8Zm9a8z5j3IgMAAAB244gNAAAAAOvF/BEbAAA6g4bvPgCAzogjNgAAAACsR7EBAAAAYD2KDQAAAADr8RmbU+BsaQAAAIAdOGIDAAAAwHocsQEAwCK8mwAAmscRGwAAAADWo9gAAAAAsB7FBgAAAID1KDYAAAAArEexAQAAAGA9zooGAIClGp4hDQA6O47YAAAAALAexQYAAACA9Sg2AAAAAKxHsQEAAABgPYoNAAAAAOtxVjQAADqJhmdR271wfASTAED4ccQGAAAAgPUoNgAAAACsR7EBAAAAYD2KDQAAAADrdaqTBzT80GRHPOapPojJBzYBAACAjtOpig0AAGiqpX98a/wPgvzDHIBoxlvRAAAAAFiPYgMAAADAehQbAAAAANaj2AAAAACwHicPaKSlM6d1xBnVAADoaOzXAHQWHLEBAAAAYD2KDQAAAADrUWwAAAAAWI9iAwAAAMB6FBsAAAAA1uOsaGHU8AwzuxeOb9W8hlxdjYovkzI9r2vnYzeG9LgtPeapciA0rf37jZRMz+vyHXdIis58HSHa/05CFWvrgZ1ae7a0UPdNDefwsw7Elmj5f50jNgAAAACs12HF5qmnnlJ6erq6d++ukSNH6s033+yopwIAoMOxXwOA6NYhxebFF19Ufn6+5s6dq23btumqq65SXl6ePvnkk454OgAAOhT7NQCIfh1SbBYtWqT77rtP3/ve93TBBRdo8eLFSktL09KlSzvi6QAA6FDs1wAg+oX95AFHjx7V1q1bNXv27KDx3Nxcbdq0qcl8n88nn88XuP7VV19Jkr788kv5/f6Qn9/v96u2tlZx/i46XucI+f7hsn///qDrcccOnfY+cXVGtbV1ivN3Cbp/w/s2ftzTPX5L88Otfrvv379fTqfzjDxnOLUmf2v+HiKhuZ/5aMp3Ku39uYn030m4f+7DsZ6amhpJkjGm3XlwQqj7NSm8+7Zo2a9Jate+KdT7Nsf2fU24sT1OYlucFIltEe7/1xsKab9mwuyzzz4zkswf//jHoPHHHnvMDB06tMn8efPmGUlcuHDhwiWMl71794b75b3TCnW/Zgz7Ni5cuHAJ96U1+7UOO92zwxH8r0rGmCZjkjRnzhwVFBQErtfV1enLL79Unz59mp1/OtXV1UpLS9PevXuVlJQUevAIInvk2Jyf7JETjfmNMaqpqVFqamqko8Sc1u7XpPDu26Lx5yxS2BbB2B4nsS1OirVtEcp+LezFpm/fvuratasqKyuDxquqqpScnNxkvsvlksvlCho766yz2p0jKSnJ2r9MskeOzfnJHjnRlr9Xr16RjhBTQt2vSR2zb4u2n7NIYlsEY3ucxLY4KZa2RWv3a2E/eUC3bt00cuRIeb3eoHGv16uxY8eG++kAAOhQ7NcAwA4d8la0goIC3X333Ro1apTGjBmjp59+Wp988onuv//+jng6AAA6FPs1AIh+HVJsbr/9du3fv1+PPvqo9u3bp8zMTK1Zs0aDBg3qiKcL4nK5NG/evCZvAbAB2SPH5vxkjxzb86P12K9FB7ZFMLbHSWyLkzrztnAYwzlBAQAAANitQ76gEwAAAADOJIoNAAAAAOtRbAAAAABYj2IDAAAAwHpWFpunnnpK6enp6t69u0aOHKk333zzlPNLS0s1cuRIde/eXeecc45++ctfnqGkJxUVFenSSy9VYmKi+vfvr1tuuUU7d+485X02bNggh8PR5PKXv/zlDKU+wePxNMngdrtPeZ9o2Ob1Bg8e3Ox2nDFjRrPzI7ndN27cqAkTJig1NVUOh0Mvv/xy0O3GGHk8HqWmpio+Pl7Z2dkqLy8/7eO+9NJLuvDCC+VyuXThhRdq9erVZzy/3+/XrFmzNGzYMPXo0UOpqam655579Pe///2Uj/ncc881+/dx5MiRM5ZdkqZOndokw+WXX37axz1T2x6xKdT9Xaxqy34oVnTUfsFWHfVabZvW/F7Z2X42JAuLzYsvvqj8/HzNnTtX27Zt01VXXaW8vDx98sknzc6vqKjQt771LV111VXatm2bHnnkEf3gBz/QSy+9dEZzl5aWasaMGdq8ebO8Xq+OHTum3NxcHTp06LT33blzp/bt2xe4ZGRknIHEwS666KKgDDt27GhxbrRs83plZWVB2eu/ZO+222475f0isd0PHTqkiy++WEuWLGn29uLiYi1atEhLlixRWVmZ3G63cnJyVFNT0+Jjvv3227r99tt19913689//rPuvvtufec739Gf/vSnM5q/trZW7777rn784x/r3Xff1apVq/TRRx/ppptuOu3jJiUlBf1d7Nu3T927dz9j2evdcMMNQRnWrFlzysc8k9sesSfU/V2sC2U/FEs6Yr9gs454rbZRa36v7Gw/G5IkY5nLLrvM3H///UFj559/vpk9e3az82fOnGnOP//8oLFp06aZyy+/vMMytkZVVZWRZEpLS1ucs379eiPJHDhw4MwFa8a8efPMxRdf3Or50brN6z300ENmyJAhpq6urtnbo2W7SzKrV68OXK+rqzNut9ssXLgwMHbkyBHTq1cv88tf/rLFx/nOd75jbrjhhqCx66+/3txxxx1hz9xQ4/zNeeedd4wks2fPnhbnLFu2zPTq1Su84U6juexTpkwxN998c0iPE6ltj9gQ6v4uloW6H4pV4dovxIpwvVbHgsa/V3bWnw2rjtgcPXpUW7duVW5ubtB4bm6uNm3a1Ox93n777Sbzr7/+em3ZskV+v7/Dsp7OV199JUnq3bv3aeeOGDFCKSkpuvbaa7V+/fqOjtasXbt2KTU1Venp6brjjjv08ccftzg3Wre5dOJn6IUXXtC9994rh8NxyrnRsN0bqqioUGVlZdC2dblcysrKavHnX2r57+NU9zlTvvrqKzkcDp111lmnnPf1119r0KBBGjBggG688UZt27btzARsZMOGDerfv7+GDh2q73//+6qqqjrl/Gje9ohubdnfxbpQ9kOdRVv3C7Eu1NfqWND498rO+rNhVbH54osvdPz4cSUnJweNJycnq7Kystn7VFZWNjv/2LFj+uKLLzos66kYY1RQUKArr7xSmZmZLc5LSUnR008/rZdeekmrVq3Seeedp2uvvVYbN248g2ml0aNH6/nnn9frr7+uZ555RpWVlRo7dqz279/f7Pxo3Ob1Xn75ZR08eFBTp05tcU60bPfG6n/GQ/n5r79fqPc5E44cOaLZs2dr8uTJSkpKanHe+eefr+eee06vvPKKfvOb36h79+664oortGvXrjOYVsrLy9Ovf/1rvfHGG/r5z3+usrIyXXPNNfL5fC3eJ1q3PaJfW/Z3sSzU/VBn0db9Qixry2u17Zr7vbKz/mzERTpAWzT+l3ZjzCn/9b25+c2NnykPPPCA3nvvPb311lunnHfeeefpvPPOC1wfM2aM9u7dq5/97Ge6+uqrOzpmQF5eXuDPw4YN05gxYzRkyBAtX75cBQUFzd4n2rZ5vWeffVZ5eXlKTU1tcU60bPeWhPrz39b7dCS/36877rhDdXV1euqpp0459/LLLw/64OcVV1yhb37zm/rFL36h//zP/+zoqAG333574M+ZmZkaNWqUBg0apNdee00TJ05s8X7Rtu1hF35+TmjLfqgz4efkpLa+VtvsVL9XdrafDauO2PTt21ddu3Zt0jSrqqqaNNJ6bre72flxcXHq06dPh2VtyYMPPqhXXnlF69ev14ABA0K+/+WXX37G/6W6sR49emjYsGEt5oi2bV5vz549Wrdunb73ve+FfN9o2O71ZwAK5ee//n6h3qcj+f1+fec731FFRYW8Xu8pj9Y0p0uXLrr00ksj/veRkpKiQYMGnTJHtG172KMt+7vO5HT7oc6irfuFzqQ1r9U2a+n3ys76s2FVsenWrZtGjhwZOKtVPa/Xq7FjxzZ7nzFjxjSZX1JSolGjRsnpdHZY1saMMXrggQe0atUqvfHGG0pPT2/T42zbtk0pKSlhThcan8+nDz/8sMUc0bLNG1u2bJn69++v8ePHh3zfaNju6enpcrvdQdv26NGjKi0tbfHnX2r57+NU9+ko9aVm165dWrduXZuKrjFG27dvj/jfx/79+7V3795T5oimbQ+7tGV/15mcbj/UWbR1v9CZtOa12kan+72y0/5sROKMBe2xcuVK43Q6zbPPPms++OADk5+fb3r06GF2795tjDFm9uzZ5u677w7M//jjj01CQoL54Q9/aD744APz7LPPGqfTaf7nf/7njOb+l3/5F9OrVy+zYcMGs2/fvsCltrY2MKdx9v/4j/8wq1evNh999JF5//33zezZs40k89JLL53R7D/60Y/Mhg0bzMcff2w2b95sbrzxRpOYmBj127yh48ePm4EDB5pZs2Y1uS2atntNTY3Ztm2b2bZtm5FkFi1aZLZt2xY4a9jChQtNr169zKpVq8yOHTvMpEmTTEpKiqmurg48xt133x101qQ//vGPpmvXrmbhwoXmww8/NAsXLjRxcXFm8+bNZzS/3+83N910kxkwYIDZvn170P8HPp+vxfwej8esXbvW/O1vfzPbtm0z3/3ud01cXJz505/+dMay19TUmB/96Edm06ZNpqKiwqxfv96MGTPGfOMb34iabY/Yc7r9XWdyuv1QLAvHfiGWhOO1Oha05vfKzvazYYwx1hUbY4x58sknzaBBg0y3bt3MN7/5zaBTJk+ZMsVkZWUFzd+wYYMZMWKE6datmxk8eLBZunTpGU584pSEzV2WLVsWmNM4++OPP26GDBliunfvbs4++2xz5ZVXmtdee+2MZ7/99ttNSkqKcTqdJjU11UycONGUl5e3mNuY6NjmDb3++utGktm5c2eT26Jpu9efarrxZcqUKcaYE6dvnDdvnnG73cblcpmrr77a7NixI+gxsrKyAvPr/fa3vzXnnXeecTqd5vzzz++wknaq/BUVFS3+f7B+/foW8+fn55uBAweabt26mX79+pnc3FyzadOmM5q9trbW5Obmmn79+hmn02kGDhxopkyZYj755JOgx4jktkdsOtX+rjM53X4oloVjvxBLwvFaHQta83tlZ/vZMMYYhzH/96luAAAAALCUVZ+xAQAAAIDmUGwAAAAAWI9iAwAAAMB6FBsAAAAA1qPYAAAAALAexQYAAACA9Sg2AAAAAKxHsQEAAABgPYoNAAAAAOtRbAAAAABYj2IDAAAAwHoUGwAAAADW+/8BBa3/RQnzfhwAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1000x1000 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Split: test\n",
      "Average median RMSD: 0.65 +- 2.35\n",
      "Median number of structures: 1.00\n"
     ]
    },
    {
     "data": {
      "image/png": "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777TlClT9Kc//Un/+te/2iUzwhMFCB3aN998I0n6yU9+IqvV6vFYsmSJDMPQt99+67FOz549PaZtNpuk7//Ycv/+/YqKilKPHj08louPj/c53+mv1fR6/GEnAITGDx0DfHX6saJLly6KiYlR165dveYfPXq01dvt37+/3njjDfXq1Utz5sxR//791b9/fz3++OM+5Wu6PNsf//znP5WUlKROndrn18nmsn7zzTd6+eWXvY7xgwYNkiR30Zk+fbqeffZZ7d27VzfccIN69eqlUaNGyeFwtEt2hBf+Bggd2rnnnitJeuKJJ3TppZc2u4yvxaVnz546fvy4vv32W48DW01Njf9BAQBhr6m0OJ1Oj/n79+8PRRxdfvnluvzyy3XixAlt2bJFTzzxhHJzcxUfH69bbrmlVdto7iYEXbt29br5jySvsybnnXee3nnnHTU2NvpVgk4dz6ai2dzrnCnrueeeqyFDhuiRRx5pdp2kpCT317fffrtuv/12HT58WJs2bdKiRYs0YcIEffzxx+rbt6/P+RG5OAOEDm3s2LE6++yz9eGHHyo9Pb3ZR5cuXXzaZkZGhiTphRde8Ji/Zs0ar2Xb+i+HAIDwER8fr65du+qDDz7wmP+nP/0pRIlO6ty5s0aNGqXf/va3kk7eLEDy/xjUr18/ffzxxx5Fb//+/e47uzXJycnR0aNHm70r3qlaurKh6Y5yp4/nyy+/3OqsEyZM0K5du9S/f/9mj/GnFqAm3bp1U05OjhYuXKhjx46pqqqq1a+HjoEzQOjQzjrrLD3xxBOaOXOmvv32W/3kJz9Rr1699M9//lPvv/++/vnPf2r58uU+bfPaa6/V2LFjdf/996uurk4jRozQu+++q+eee06SPP4VbPDgwZKkxx9/XDNnzpTVatWFF16o2NjYwO0kAKBdWCwW3XrrrXr22WfVv39/DR06VO+9955KS0vbPctTTz2lN998U+PHj1efPn109OhR953qrrnmGklSbGys+vbtqz/96U+6+uqr1aNHD5177rlet7I+3fTp0/W73/1Ot956q372s59p//79Ki4u9rp725QpU7Ry5Urddddd2r17t6688ko1Njbqb3/7my666CL3WajBgwdr48aNevnll5WYmKjY2FhdeOGF+vGPf6wePXrozjvv1MMPP6yoqCitWrVK+/bta/U4PPzww3I4HBoz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Pb5PJGncuHHasmWLXC5XsKOe0bFjx/T888/rjjvukMViOeOy4TL2p/L3uNrS/5Nw+Nl1+rGsJYcOHVLfvn3Vu3dvTZgwQdu3b2+fgM3YuHGjevXqpQEDBuhnP/uZamtrz7h8uI7/N998o1deeUV33nnnDy4biPHvMAXIMAzl5eXpsssuU1pamiSppqZGkhQfH++xbHx8vPu59rZmzRpt27ZNRUVFXs+FW97PPvtMy5cvV2pqql5//XXddddduvfee/Xcc8+FXd758+drypQpGjhwoKxWq4YPH67c3FxNmTIl7LKerjXZampq1KVLF51zzjktLhMqR48e1YIFCzR16lTFxcVJCr+8S5YsUVRUlO69995mnw+nvLW1tTp06JAeffRRXXvttSorK9N//ud/avLkySovLw+7vIhczR03m5OYmKgVK1boxRdf1Nq1a3XhhRfq6quv1qZNm9ox7UmjRo3Sc889p9dff11PP/20ampqNGbMGO3fv7/Z5Wtqapr92Xr8+HH961//ao/ILVq/fr2+++473XbbbS0uE05jfzp/j6st/T8J9c+u5o5lzRk4cKBWrVqll156SX/4wx/UtWtXjR07Vp988kk7pj0pJydHv//97/Xmm2/qN7/5jSorK3XVVVfJ6XS2uE64jv/q1asVGxuryZMnn3G5QI1/VFvChpO7775bH3zwgd555x2v507/lxXDMH7wX1uCYd++fZo7d67KysrOeK1iuORtbGxUenq6CgsLJZ38F6iqqiotX75cM2bMcC8XDnlfeOEFPf/88yotLdWgQYO0Y8cO5ebmKikpSTNnzgyrrC3xJ1uo87tcLt1yyy1qbGzUk08++YPLhyLv1q1b9fjjj2vbtm0+v3Yo8jbduGPSpEm67777JEnDhg1TRUWFnnrqKWVkZLS4bqjfD4gsZzpunurCCy/UhRde6J4ePXq09u3bp1//+te64oorgh3TQ05OjvvrwYMHa/To0erfv79Wr16tvLy8Ztdp7mdrc/Pb2zPPPKOcnJxm/yaxSTiNfUv8OXaF27HYl2PZpZde6nGjgbFjx+o//uM/9MQTT+h//ud/gh3Vw8033+z+Oi0tTenp6erbt69eeeWVMxaJcBt/SXr22Wc1bdq0H/xbnkCNf4c4A3TPPffopZde0ltvvaXevXu75zfdGeb0VltbW+vVftvD1q1bVVtbqxEjRigqKkpRUVEqLy/X//zP/ygqKsqdKVzyJiYm6uKLL/aYd9FFF7nvRBVO4/vzn/9cCxYs0C233KLBgwdr+vTpuu+++9xn2sIp6+laky0hIUHHjh3TgQMHWlymvblcLt10002qrq6Ww+Hw+BezcMr79ttvq7a2Vn369HF/3+3du1f333+/+vXrF3Z5zz33XEVFRf3g91645EVkaum42VqXXnppSP7F+3TdunXT4MGDW8ySkJDQ7M/WqKgo9ezZsz0iNmvv3r1644039NOf/tTndcNl7P09rrb0/yQcj2Wt0alTJ40cOTIs/p8kJiaqb9++Z8wSbuMvnTxO796926/vB3/HP6ILkGEYuvvuu7V27Vq9+eabSklJ8Xg+JSVFCQkJ7rusSCevuS0vL9eYMWPaO66uvvpq7dy5Uzt27HA/0tPTNW3aNO3YsUPnn39+WOUdO3as1+1RP/74Y/Xt21dSeI1vQ0ODOnXyfDt37tzZ/a/p4ZT1dK3JNmLECFmtVo9lvv76a+3atSsk+ZsOGJ988oneeOMNr18kwinv9OnT9cEHH3h83yUlJennP/+5Xn/99bDL26VLF40cOfKM33vhlBeR5YeOm621fft2JSYmBjid75xOpz766KMWs4wePdrj+0SSysrKlJ6eLqvV2h4Rm7Vy5Ur16tVL48eP93ndcBl7f4+rLf0/CcdjWWsYhqEdO3aExf+T/fv3a9++fWfMEk7j3+SZZ57RiBEjNHToUJ/X9Xv823wbhRD6P//n/xjdu3c3Nm7caHz99dfuR0NDg3uZRx991Ojevbuxdu1aY+fOncaUKVOMxMREo66uLoTJv3fqXeAMI7zyvvfee0ZUVJTxyCOPGJ988onx+9//3oiJiTGef/75sMs7c+ZM40c/+pHx5z//2aiurjbWrl1rnHvuuca8efPCImt9fb2xfft2Y/v27YYkY+nSpcb27dvdd5ppTba77rrL6N27t/HGG28Y27ZtM6666ipj6NChxvHjx9s1r8vlMq677jqjd+/exo4dOzy+95xOZ9jlbc7pd4ELt7xr1641rFarsWLFCuOTTz4xnnjiCaNz587G22+/HZK86Dhac9xcsGCBMX36dPf0f//3fxvr1q0zPv74Y2PXrl3GggULDEnGiy++2O7577//fmPjxo3GZ599ZmzevNmYMGGCERsba+zZs6fZ7J999pkRExNj3HfffcaHH35oPPPMM4bVajX+93//t92zNzlx4oTRp08fY/78+V7PhdvYB+LYNX36dGPBggXu6b/+9a9G586djUcffdT46KOPjEcffdSIiooyNm/e3K75W3ssOz2/3W43XnvtNeMf//iHsX37duP22283oqKijL/97W/tmr++vt64//77jYqKCqO6utp46623jNGjRxs/+tGPImL8mxw8eNCIiYkxli9f3uw2gjX+EV2AJDX7WLlypXuZxsZGY9GiRUZCQoJhs9mMK664wti5c2foQp/m9AIUbnlffvllIy0tzbDZbMbAgQONFStWeDwfLnnr6uqMuXPnGn369DG6du1qnH/++cbChQs9foiFMmvTrUxPf8ycObPV2Y4cOWLcfffdRo8ePYzo6GhjwoQJxueff97ueaurq1v83nvrrbfCLm9zmitA4Zb3mWeeMS644AKja9euxtChQ43169eHLC86jtYcN2fOnGlkZGS4p5csWWL079/f6Nq1q3HOOecYl112mfHKK6+0f3jj5C3iExMTDavVaiQlJRmTJ082qqqq3M+fnt0wDGPjxo3G8OHDjS5duhj9+vVr8Ret9vL6668bkozdu3d7PRduYx+IY1dGRobXz+I//vGPxoUXXmhYrVZj4MCBQSt0gTiWnZ4/NzfX6NOnj9GlSxfjvPPOM7Kzs42Kiop2z9/Q0GBkZ2cb5513nmG1Wo0+ffoYM2fO9DoOhOv4N/nd735nREdHG999912z2wjW+FsM499/DQgAAAAAHVxE/w0QAAAAAPiCAgQAAADANChAAAAAAEyDAgQAAADANChAAAAAAEyDAgQAAADANChAAAAAAEyDAgQAAADANChAAAAAAEyDAgQAAADANChAAAAAAEyDAgQAAADANChAAAAAAEyDAgQAAADANChAAAAAAEyDAgQAAADANChAAAAAAEyDAgQAAADANChAAAAAAEyDAgQAAADANChAAAAAAEyDAgQAAADANChAAAAAAEyDAgQAAADANChAAAAAAEyDAgQAAADANChAAAAAAEyDAgQAAADANChAAAAAAEyDAgQAAADANChAAAAAAEyDAgQAAADANChAAAAAAEyDAgQAAADANChAAAAAAEyDAgQAAADANChAAAAAAEyDAgQAAADANChAAAAAAEyDAgQAAADANChAAAAAAEyDAgQAAADANChAAAAAAEyDAgQAAADANChAAAAAAEyDAgQAAADANChAAAAAAEyDAgQAAADANChAAAAAAEyDAgQAAADANChAAAAAAEyDAgQAAADANChAAAAAAEyDAgQAAADANChAAAAAAEyDAgQAAADANChAAAAAAEyDAgQAAADANChAgEls3LhRFotFGzduDHUUAIAfLBaL7Ha7e3rVqlWyWCzas2dPyDKFs9PHC2hCAQIAAIhA48eP17vvvqvExMRQRwEiSlSoAwBmceTIEUVHR4c6BgCggzjvvPN03nnnhTpGsxoaGhQTExPqGECzOAOEkLHb7bJYLPrggw904403qnv37urRo4fy8vJ0/Phx7d69W9dee61iY2PVr18/FRcXe6xfV1enBx54QCkpKerSpYt+9KMfKTc3V4cPH/ZY7re//a2uuOIK9erVS926ddPgwYNVXFwsl8vlsVxmZqbS0tJUWVmpyy+/XDExMTr//PP16KOPqrGx0ad969evnyZMmKC1a9dq+PDh6tq1qwoKCtyXoZWWlmr+/PlKTEzUWWedpYkTJ+qbb75RfX29/uu//kvnnnuuzj33XN1+++06dOiQx7b/+Mc/atSoUerevbs74x133OGxzN///ndde+21iomJ0bnnnqu77rpL9fX1Pu0DAMBTex236urq9LOf/Uw9e/bUWWedpWuvvVYff/yxV57mLoFzOByaNGmSevfura5du+qCCy7QrFmz9K9//avZfamqqtKUKVPUvXt3xcfH64477tDBgwd9GpfbbrtNZ511lnbu3Kns7GzFxsbq6quvlnTyMrS7775bK1eu1IUXXqjo6Gilp6dr8+bNMgxDjz32mFJSUnTWWWfpqquu0qeffuqx7e3bt2vChAnq1auXbDabkpKSNH78eH3xxRc+jxfQhDNACLmbbrpJt956q2bNmiWHw+EuJ2+88YZmz56tBx54wF0YLrjgAk2ePFkNDQ3KyMjQF198oQcffFBDhgxRVVWVfvnLX2rnzp164403ZLFYJEn/+Mc/NHXqVPcB5/3339cjjzyiv//973r22Wc9stTU1GjatGm6//77tWjRIq1bt075+flKSkrSjBkzfNqvbdu26aOPPtIvfvELpaSkqFu3bu6D3IMPPqgrr7xSq1at0p49e/TAAw9oypQpioqK0tChQ/WHP/xB27dv14MPPqjY2Fj9z//8jyTp3Xff1c0336ybb75ZdrtdXbt21d69e/Xmm2+6X/ebb75RRkaGrFarnnzyScXHx+v3v/+97r777rb8bwIA/Fswj1uGYej6669XRUWFfvnLX2rkyJH661//qpycnFZl+8c//qHRo0frpz/9qbp37649e/Zo6dKluuyyy7Rz505ZrVaP5W+44QbdfPPNuvPOO7Vz507l5+dLktfx8YccO3ZM1113nWbNmqUFCxbo+PHj7uf+/Oc/a/v27Xr00UdlsVg0f/58jR8/XjNnztRnn32mkpISHTx4UHl5ebrhhhu0Y8cOWSwWHT58WFlZWUpJSdFvf/tbxcfHq6amRm+99Zb7H/XaOl4wKQMIkUWLFhmSjN/85jce84cNG2ZIMtauXeue53K5jPPOO8+YPHmyYRiGUVRUZHTq1MmorKz0WPd///d/DUnGhg0bmn3NEydOGC6Xy3juueeMzp07G99++637uYyMDEOS8be//c1jnYsvvtgYN26cT/vWt29fo3Pnzsbu3bs95r/11luGJGPixIke83Nzcw1Jxr333usx//rrrzd69Ojhnv71r39tSDK+++67Fl97/vz5hsViMXbs2OExPysry5BkvPXWWz7tCwDgpPY4br366quGJOPxxx/3WO6RRx4xJBmLFi1yz1u5cqUhyaiurm42b2Njo+FyuYy9e/cakow//elPXvtSXFzssc7s2bONrl27Go2Nja0bFMMwZs6caUgynn32Wa/nJBkJCQnGoUOH3PPWr19vSDKGDRvm8TrLli0zJBkffPCBYRiGsWXLFkOSsX79+hZf25fxAppwCRxCbsKECR7TF110kSwWi8e/3kRFRemCCy7Q3r17JZ3816S0tDQNGzZMx48fdz/GjRvndaez7du367rrrlPPnj3VuXNnWa1WzZgxQydOnPA6RZ6QkKBLLrnEY96QIUPcr+uLIUOGaMCAAa3eZ+nkH7SePv/bb791XwY3cuRISSf/9fH/+//+P3355Zde237rrbc0aNAgDR061GP+1KlTfd4HAIC3YB633nrrLUnStGnTPF6jtT/Da2trdddddyk5OVlRUVGyWq3q27evJOmjjz7yWv66667zmB4yZIiOHj2q2traVr3eqW644YZm51955ZXq1q2be7rpmJeTk+O+WuPU+U1jdsEFF+icc87R/Pnz9dRTT+nDDz/02nZb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",
      "text/plain": [
       "<Figure size 1000x1000 with 4 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "df[\"split\"] = \"train\"\n",
    "df.loc[val_idx_list, \"split\"] = \"val\"\n",
    "df.loc[test_idx_list, \"split\"] = \"test\"\n",
    "\n",
    "for split in [\"train\", \"val\", \"test\"]:\n",
    "    print(f\"Split: {split}\")\n",
    "    print(f\"Average median RMSD: {df.loc[df.split == split]['median_rmsd'].mean():.2f} +- {df.loc[df.split == split]['median_rmsd'].std():.2f}\")\n",
    "    print(f\"Median number of structures: {df.loc[df.split == split]['num_structures'].median():.2f}\")\n",
    "    df.loc[df.split == split].hist(column=[\"length\", \"num_structures\", \"mean_rmsd\", \"median_rmsd\"], figsize=(10, 10), bins=100)\n",
    "    plt.show()\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "rna",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.10.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
