{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f63f3080",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "from glob import glob\n",
    "import importlib\n",
    "import ridge_regression_task\n",
    "importlib.reload(ridge_regression_task)\n",
    "from ridge_regression_task import train_regression_model, train_classification_model\n",
    "import warnings\n",
    "from sklearn.preprocessing import StandardScaler\n",
    "import sys\n",
    "sys.path.append(\"igloo\")\n",
    "from FLab_process_sequences import get_loop_regions\n",
    "\n",
    "warnings.filterwarnings('ignore')\n",
    "\n",
    "DATA_DIR = \"benchmarking_data/AbiBench\""
   ]
  },
  {
   "cell_type": "markdown",
   "id": "7f2504d3",
   "metadata": {},
   "source": [
    "# Data processing, get light chain and filter out repeated values"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2e7813da",
   "metadata": {},
   "outputs": [],
   "source": [
    "# fetch light chains for better folding with Ibex\n",
    "sabdab_df = pd.read_parquet(\"preprocessed_data/sabdab_2025-05-06-paired.parquet\")\n",
    "\n",
    "aayl_df = pd.read_csv('benchmarking_data/AbiBench/raw/aayl49_51_MITLL_AAlphaBio_Ab_Binding_dataset.csv')\n",
    "aayl_df['seed'] = aayl_df['POI'].str.split('_').str[0]\n",
    "aayl_df = aayl_df[aayl_df['seed'].isin(['AAYL49', 'AAYL51'])]\n",
    "aayl_df = aayl_df[['seed', 'LC']].drop_duplicates()\n",
    "aayl_df\n",
    "\n",
    "light_chains_dict = {}\n",
    "for pdb_code in [\"1mlc\", \"4fqi\", \"3gbn\", \"2fjg\", \"1n8z\", \"1mhp\", \"4fqi\"]:\n",
    "    light_chains = sabdab_df[sabdab_df['pdb_code'] == pdb_code]['fv_light'].unique()\n",
    "    if len(light_chains) != 1:\n",
    "        print(f\"Skipping {pdb_code} because it has {len(light_chains)} light chains\")\n",
    "    light_chain = light_chains[0]\n",
    "    light_chains_dict[pdb_code] = light_chain\n",
    "\n",
    "for _, row in aayl_df.iterrows():\n",
    "    light_chains_dict[row['seed'].lower()] = row['LC']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "id": "5c6c60a6",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1mlc: DIELTQSPATLSVTPGDSVSLSCRASQSISNNLHWYQQKSHESPRLLIKYVSQSSSGIPSRFSGSGSGTDFTLSINSVETEDFGMYFCQQSNSWPRTFGGGTKLEIK\n",
      "4fqi: QSALTQPPAVSGTPGQRVTISCSGSDSNIGRRSVNWYQQFPGTAPKLLIYSNDQRPSVVPDRFSGSKSGTSASLAISGLQSEDEAEYYCAAWDDSLKGAVFGGGTQLTVLG\n",
      "3gbn: QSVLTQPPSVSAAPGQKVTISCSGSSSNIGNDYVSWYQQLPGTAPKLLIYDNNKRPSGIPDRFSGSKSGTSATLGITGLQTGDEANYYCATWDRRPTAYVVFGGGTKLTVLG\n",
      "2fjg: DIQMTQSPSSLSASVGDRVTITCRASQDVSTAVAWYQQKPGKAPKLLIYSASFLYSGVPSRFSGSGSGTDFTLTISSLQPEDFATYYCQQSYTTPPTFGQGTKVEIK\n",
      "1n8z: DIQMTQSPSSLSASVGDRVTITCRASQDVNTAVAWYQQKPGKAPKLLIYSASFLYSGVPSRFSGSRSGTDFTLTISSLQPEDFATYYCQQHYTTPPTFGQGTKVEIK\n",
      "1mhp: dIQLTQSPSSLSASVGDRVTITCSASSSVNHMFWYQQKPGKAPKPWIYLTSNLASGVPSRFSGSGSGTDYTLTISSLQPEDFATYYCQQWSGNPWTFGQGTKVEIK\n",
      "aayl49: DVVMTQSPESLAVSLGERATISCKSSQSVLYESRNKNSVAWYQQKAGQPPKLLIYWASTRESGVPDRFSGSGSGTDFTLTISSLQAEDAAVYYCQQYHRLPLSFGGGTKVEIK\n",
      "aayl51: QAVLTQPSSLSASPGASVSLTCTLRSGINVGTYRIYWYQQKPGSPPQYLLRYKSDSDKQQGSGVPSRFSGSKDASANAGILLISGLQSEDEADYYCMIWHSSAWVFGGGTKLTVL\n"
     ]
    }
   ],
   "source": [
    "for k, v in light_chains_dict.items():\n",
    "    print(f\"{k}: {v}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "71664ec0",
   "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>pdb_id</th>\n",
       "      <th>light_chain</th>\n",
       "      <th>aho_light</th>\n",
       "      <th>LFW1</th>\n",
       "      <th>L1</th>\n",
       "      <th>LFW2</th>\n",
       "      <th>L2</th>\n",
       "      <th>LFW3</th>\n",
       "      <th>L4</th>\n",
       "      <th>LFW4</th>\n",
       "      <th>L3</th>\n",
       "      <th>LFW5</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>1mlc</td>\n",
       "      <td>DIELTQSPATLSVTPGDSVSLSCRASQSISNNLHWYQQKSHESPRL...</td>\n",
       "      <td>DIELTQSPATLSVTPGDSVSLSCRAS--QSIS------NNLHWYQQ...</td>\n",
       "      <td>DIELTQSPATLSVTPGDSVSLSC</td>\n",
       "      <td>RASQSISNNLH</td>\n",
       "      <td>WYQQKSHESPRLLI</td>\n",
       "      <td>KYVSQSSS</td>\n",
       "      <td>GIPSRFSGS</td>\n",
       "      <td>GSGTDF</td>\n",
       "      <td>TLSINSVETEDFGMYFC</td>\n",
       "      <td>QQSNSWPRT</td>\n",
       "      <td>FGGGTKLEIK</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>4fqi</td>\n",
       "      <td>QSALTQPPAVSGTPGQRVTISCSGSDSNIGRRSVNWYQQFPGTAPK...</td>\n",
       "      <td>QSALTQP-PAVSGTPGQRVTISCSGSD-SNIGR-----RSVNWYQQ...</td>\n",
       "      <td>QSALTQPPAVSGTPGQRVTISC</td>\n",
       "      <td>SGSDSNIGRRSVN</td>\n",
       "      <td>WYQQFPGTAPKLLI</td>\n",
       "      <td>YSNDQRPS</td>\n",
       "      <td>VVPDRFSGS</td>\n",
       "      <td>KSGTSA</td>\n",
       "      <td>SLAISGLQSEDEAEYYC</td>\n",
       "      <td>AAWDDSLKGAV</td>\n",
       "      <td>FGGGTQLTVLG</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>3gbn</td>\n",
       "      <td>QSVLTQPPSVSAAPGQKVTISCSGSSSNIGNDYVSWYQQLPGTAPK...</td>\n",
       "      <td>QSVLTQP-PSVSAAPGQKVTISCSGSS-SNIGN-----DYVSWYQQ...</td>\n",
       "      <td>QSVLTQPPSVSAAPGQKVTISC</td>\n",
       "      <td>SGSSSNIGNDYVS</td>\n",
       "      <td>WYQQLPGTAPKLLI</td>\n",
       "      <td>YDNNKRPS</td>\n",
       "      <td>GIPDRFSGS</td>\n",
       "      <td>KSGTSA</td>\n",
       "      <td>TLGITGLQTGDEANYYC</td>\n",
       "      <td>ATWDRRPTAYVV</td>\n",
       "      <td>FGGGTKLTVLG</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>2fjg</td>\n",
       "      <td>DIQMTQSPSSLSASVGDRVTITCRASQDVSTAVAWYQQKPGKAPKL...</td>\n",
       "      <td>DIQMTQSPSSLSASVGDRVTITCRAS--QDVS------TAVAWYQQ...</td>\n",
       "      <td>DIQMTQSPSSLSASVGDRVTITC</td>\n",
       "      <td>RASQDVSTAVA</td>\n",
       "      <td>WYQQKPGKAPKLLI</td>\n",
       "      <td>YSASFLYS</td>\n",
       "      <td>GVPSRFSGS</td>\n",
       "      <td>GSGTDF</td>\n",
       "      <td>TLTISSLQPEDFATYYC</td>\n",
       "      <td>QQSYTTPPT</td>\n",
       "      <td>FGQGTKVEIK</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>1n8z</td>\n",
       "      <td>DIQMTQSPSSLSASVGDRVTITCRASQDVNTAVAWYQQKPGKAPKL...</td>\n",
       "      <td>DIQMTQSPSSLSASVGDRVTITCRAS--QDVN------TAVAWYQQ...</td>\n",
       "      <td>DIQMTQSPSSLSASVGDRVTITC</td>\n",
       "      <td>RASQDVNTAVA</td>\n",
       "      <td>WYQQKPGKAPKLLI</td>\n",
       "      <td>YSASFLYS</td>\n",
       "      <td>GVPSRFSGS</td>\n",
       "      <td>RSGTDF</td>\n",
       "      <td>TLTISSLQPEDFATYYC</td>\n",
       "      <td>QQHYTTPPT</td>\n",
       "      <td>FGQGTKVEIK</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>1mhp</td>\n",
       "      <td>dIQLTQSPSSLSASVGDRVTITCSASSSVNHMFWYQQKPGKAPKPW...</td>\n",
       "      <td>dIQLTQSPSSLSASVGDRVTITCSAS--SSVN-------HMFWYQQ...</td>\n",
       "      <td>dIQLTQSPSSLSASVGDRVTITC</td>\n",
       "      <td>SASSSVNHMF</td>\n",
       "      <td>WYQQKPGKAPKPWI</td>\n",
       "      <td>YLTSNLAS</td>\n",
       "      <td>GVPSRFSGS</td>\n",
       "      <td>GSGTDY</td>\n",
       "      <td>TLTISSLQPEDFATYYC</td>\n",
       "      <td>QQWSGNPWT</td>\n",
       "      <td>FGQGTKVEIK</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>aayl49</td>\n",
       "      <td>DVVMTQSPESLAVSLGERATISCKSSQSVLYESRNKNSVAWYQQKA...</td>\n",
       "      <td>DVVMTQSPESLAVSLGERATISCKSS--QSVLYESRNKNSVAWYQQ...</td>\n",
       "      <td>DVVMTQSPESLAVSLGERATISC</td>\n",
       "      <td>KSSQSVLYESRNKNSVA</td>\n",
       "      <td>WYQQKAGQPPKLLI</td>\n",
       "      <td>YWASTRES</td>\n",
       "      <td>GVPDRFSGS</td>\n",
       "      <td>GSGTDF</td>\n",
       "      <td>TLTISSLQAEDAAVYYC</td>\n",
       "      <td>QQYHRLPLS</td>\n",
       "      <td>FGGGTKVEIK</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>aayl51</td>\n",
       "      <td>QAVLTQPSSLSASPGASVSLTCTLRSGINVGTYRIYWYQQKPGSPP...</td>\n",
       "      <td>QAVLTQP-SSLSASPGASVSLTCTLRS-GINVG----TYRIYWYQQ...</td>\n",
       "      <td>QAVLTQPSSLSASPGASVSLTC</td>\n",
       "      <td>TLRSGINVGTYRIY</td>\n",
       "      <td>WYQQKPGSPPQYLL</td>\n",
       "      <td>RYKSDSDKQQGS</td>\n",
       "      <td>GVPSRFSGS</td>\n",
       "      <td>KDASANAG</td>\n",
       "      <td>ILLISGLQSEDEADYYC</td>\n",
       "      <td>MIWHSSAWV</td>\n",
       "      <td>FGGGTKLTVL</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "   pdb_id                                        light_chain  \\\n",
       "0    1mlc  DIELTQSPATLSVTPGDSVSLSCRASQSISNNLHWYQQKSHESPRL...   \n",
       "1    4fqi  QSALTQPPAVSGTPGQRVTISCSGSDSNIGRRSVNWYQQFPGTAPK...   \n",
       "2    3gbn  QSVLTQPPSVSAAPGQKVTISCSGSSSNIGNDYVSWYQQLPGTAPK...   \n",
       "3    2fjg  DIQMTQSPSSLSASVGDRVTITCRASQDVSTAVAWYQQKPGKAPKL...   \n",
       "4    1n8z  DIQMTQSPSSLSASVGDRVTITCRASQDVNTAVAWYQQKPGKAPKL...   \n",
       "5    1mhp  dIQLTQSPSSLSASVGDRVTITCSASSSVNHMFWYQQKPGKAPKPW...   \n",
       "6  aayl49  DVVMTQSPESLAVSLGERATISCKSSQSVLYESRNKNSVAWYQQKA...   \n",
       "7  aayl51  QAVLTQPSSLSASPGASVSLTCTLRSGINVGTYRIYWYQQKPGSPP...   \n",
       "\n",
       "                                           aho_light                     LFW1  \\\n",
       "0  DIELTQSPATLSVTPGDSVSLSCRAS--QSIS------NNLHWYQQ...  DIELTQSPATLSVTPGDSVSLSC   \n",
       "1  QSALTQP-PAVSGTPGQRVTISCSGSD-SNIGR-----RSVNWYQQ...   QSALTQPPAVSGTPGQRVTISC   \n",
       "2  QSVLTQP-PSVSAAPGQKVTISCSGSS-SNIGN-----DYVSWYQQ...   QSVLTQPPSVSAAPGQKVTISC   \n",
       "3  DIQMTQSPSSLSASVGDRVTITCRAS--QDVS------TAVAWYQQ...  DIQMTQSPSSLSASVGDRVTITC   \n",
       "4  DIQMTQSPSSLSASVGDRVTITCRAS--QDVN------TAVAWYQQ...  DIQMTQSPSSLSASVGDRVTITC   \n",
       "5  dIQLTQSPSSLSASVGDRVTITCSAS--SSVN-------HMFWYQQ...  dIQLTQSPSSLSASVGDRVTITC   \n",
       "6  DVVMTQSPESLAVSLGERATISCKSS--QSVLYESRNKNSVAWYQQ...  DVVMTQSPESLAVSLGERATISC   \n",
       "7  QAVLTQP-SSLSASPGASVSLTCTLRS-GINVG----TYRIYWYQQ...   QAVLTQPSSLSASPGASVSLTC   \n",
       "\n",
       "                  L1            LFW2            L2       LFW3        L4  \\\n",
       "0        RASQSISNNLH  WYQQKSHESPRLLI      KYVSQSSS  GIPSRFSGS    GSGTDF   \n",
       "1      SGSDSNIGRRSVN  WYQQFPGTAPKLLI      YSNDQRPS  VVPDRFSGS    KSGTSA   \n",
       "2      SGSSSNIGNDYVS  WYQQLPGTAPKLLI      YDNNKRPS  GIPDRFSGS    KSGTSA   \n",
       "3        RASQDVSTAVA  WYQQKPGKAPKLLI      YSASFLYS  GVPSRFSGS    GSGTDF   \n",
       "4        RASQDVNTAVA  WYQQKPGKAPKLLI      YSASFLYS  GVPSRFSGS    RSGTDF   \n",
       "5         SASSSVNHMF  WYQQKPGKAPKPWI      YLTSNLAS  GVPSRFSGS    GSGTDY   \n",
       "6  KSSQSVLYESRNKNSVA  WYQQKAGQPPKLLI      YWASTRES  GVPDRFSGS    GSGTDF   \n",
       "7     TLRSGINVGTYRIY  WYQQKPGSPPQYLL  RYKSDSDKQQGS  GVPSRFSGS  KDASANAG   \n",
       "\n",
       "                LFW4            L3         LFW5  \n",
       "0  TLSINSVETEDFGMYFC     QQSNSWPRT   FGGGTKLEIK  \n",
       "1  SLAISGLQSEDEAEYYC   AAWDDSLKGAV  FGGGTQLTVLG  \n",
       "2  TLGITGLQTGDEANYYC  ATWDRRPTAYVV  FGGGTKLTVLG  \n",
       "3  TLTISSLQPEDFATYYC     QQSYTTPPT   FGQGTKVEIK  \n",
       "4  TLTISSLQPEDFATYYC     QQHYTTPPT   FGQGTKVEIK  \n",
       "5  TLTISSLQPEDFATYYC     QQWSGNPWT   FGQGTKVEIK  \n",
       "6  TLTISSLQAEDAAVYYC     QQYHRLPLS   FGGGTKVEIK  \n",
       "7  ILLISGLQSEDEADYYC     MIWHSSAWV   FGGGTKLTVL  "
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "light_chain_df = pd.DataFrame.from_dict(light_chains_dict, orient='index', columns=['light_chain']).reset_index().rename(columns={'index': 'pdb_id'})\n",
    "aho_light_chains = get_loop_regions(light_chain_df, heavy_chain_key=None, light_chain_key='light_chain')\n",
    "aho_light_chains"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "93a73ba1",
   "metadata": {},
   "outputs": [],
   "source": [
    "# mask_out_values = {\n",
    "#     '3gbn_h1': 7.0,\n",
    "#     '3gbn_h9': 7.0,\n",
    "#     '4fqi_h3': 6.0,\n",
    "#     '4fqi_h1': 7.0,\n",
    "# } # these values are used to denote non binders? we discard them for regression tasks\n",
    "\n",
    "# for fname in os.listdir(DATA_DIR):\n",
    "#     if not fname.endswith(\"_benchmarking_data.csv\"):\n",
    "#         continue\n",
    "#     fname_path = os.path.join(DATA_DIR, fname)\n",
    "\n",
    "#     df = pd.read_csv(fname_path)\n",
    "#     seed = fname.replace(\"_benchmarking_data.csv\", \"\")\n",
    "#     if seed in mask_out_values:\n",
    "#         df = df[df['binding_score'] != mask_out_values[seed]]\n",
    "    \n",
    "#     df['fv_light'] = light_chains_dict[seed.split(\"_\")[0]]\n",
    "\n",
    "#     df_loops = pd.read_csv(fname_path.replace('.csv', '_loops.csv'))\n",
    "#     # df_loops = get_loop_regions(df, heavy_chain_key='mut_heavy_chain_seq', light_chain_key=None)\n",
    "#     df = df[['mut_heavy_chain_seq', 'fv_light']].merge(df_loops, on='mut_heavy_chain_seq', how='left')\n",
    "#     df.rename(columns={'mut_heavy_chain_seq': 'fv_heavy'}, inplace=True)\n",
    "\n",
    "#     df.to_csv(fname_path.replace('.csv', '_loops.csv'), index=False)\n",
    "#     print(f\"Processed {fname} (N={len(df)}) and saved loop regions to {fname_path.replace('.csv', '_loops.csv')}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bc962d86",
   "metadata": {},
   "outputs": [],
   "source": [
    "# for fname in os.listdir(DATA_DIR):\n",
    "#     if not fname.endswith(\"benchmarking_data_loops.csv\"):\n",
    "#         continue\n",
    "#     fname_path = os.path.join(DATA_DIR, fname)\n",
    "#     df = pd.read_csv(fname_path)\n",
    "#     df['ibex_file'] = [f\"output_{i}\" for i in range(len(df))]\n",
    "#     df = df.merge(aho_light_chains[['light_chain', 'aho_light']], left_on='fv_light', right_on='light_chain', how='left')\n",
    "#     df.drop(columns=['light_chain'], inplace=True)\n",
    "#     df.to_csv(fname_path, index=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c814e106",
   "metadata": {},
   "outputs": [],
   "source": [
    "for fname in os.listdir(DATA_DIR):\n",
    "    if not fname.endswith(\"benchmarking_data_loops.csv\"):\n",
    "        continue\n",
    "\n",
    "    seed = fname.replace(\"_benchmarking_data_loops.csv\", \"\")\n",
    "    parquet_path = f'benchmarking_data/AbiBench/ibex_structures/{seed}_loop_angles.parquet'\n",
    "    if not os.path.exists(parquet_path):\n",
    "        print(f\"Skipping {fname} because {parquet_path} does not exist\")\n",
    "        continue\n",
    "    df_loops = pd.read_parquet(parquet_path)\n",
    "    df_loops['chain'] = df_loops['loop_type'].str[0]\n",
    "    df_loops['phi'] = df_loops['phi'].apply(lambda x: np.concatenate([np.zeros(1), x, np.zeros(36 - len(x) - 1)]))\n",
    "    df_loops['psi'] = df_loops['psi'].apply(lambda x: np.concatenate([np.zeros(1), x, np.zeros(36 - len(x) - 1)]))\n",
    "    df_loops['omega'] = df_loops['omega'].apply(lambda x: np.concatenate([np.zeros(1), x, np.zeros(36 - len(x) - 1)])) # start is cls, end is eos, padding zeros\n",
    "    df_loops['angles'] = df_loops.apply(lambda row: np.stack([row['phi'], row['psi'], row['omega']], axis=1), axis=1) # shape (36, 3)\n",
    "    df_loops['angles'] = df_loops['angles'].apply(lambda x: x.tolist())\n",
    "    agg_loops = (\n",
    "        df_loops\n",
    "            .groupby([\"ibex_file\", \"chain\"], as_index=False)\n",
    "            .agg(angles=(\"angles\", lambda s: np.stack(s.to_numpy())))\n",
    "    )\n",
    "    agg_loops['angles'] = agg_loops['angles'].apply(lambda x: x.tolist())  # Convert numpy arrays to lists for parquet compatibility\n",
    "\n",
    "    df = pd.read_csv(os.path.join(DATA_DIR, fname))\n",
    "    df = df.merge(agg_loops[agg_loops['chain'] == 'H'][['ibex_file', 'angles']], left_on='ibex_file', right_on='ibex_file', how='inner')\n",
    "    df.to_parquet(os.path.join(DATA_DIR, fname.replace('.csv', '_and_angles.parquet')), index=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "df20fe28",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "4fqi_h1 (63419, 1024)\n"
     ]
    }
   ],
   "source": [
    "import h5py\n",
    "\n",
    "for seed in [\"1mlc\", \"aayl51\", \"4fqi_h3\", \"3gbn_h1\", \"2fjg\", \"1n8z\", \"aayl49\", \"aayl49_ML\", \"1mhp\", \"3gbn_h9\", \"4fqi_h1\"]:\n",
    "    loop_df = pd.read_csv(os.path.join(DATA_DIR, f\"{seed}_benchmarking_data_loops.csv\"))\n",
    "    embeddings = []\n",
    "    if not os.path.exists(os.path.join(DATA_DIR, f\"prostt5/{seed}_embeddings.h5\")):\n",
    "        print(f\"Skipping {seed} because {os.path.join(DATA_DIR, f'prostt5/{seed}_embeddings.h5')} does not exist\")\n",
    "        continue\n",
    "    with h5py.File(os.path.join(DATA_DIR, f\"prostt5/{seed}_embeddings.h5\"), \"r\") as f:\n",
    "        for ibex_file in loop_df['ibex_file'].values:\n",
    "            embeddings.append(f[f\"{ibex_file}_H\"][:])\n",
    "    embeddings = np.array(embeddings)\n",
    "    print(seed, embeddings.shape)\n",
    "    np.save(os.path.join(DATA_DIR, f\"prostt5/{seed}_embeddings.npy\"), embeddings)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 60,
   "id": "e5eda3e5",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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oEEDff/996YyBwcHxcbG6urVq6Yp1jKn9bD0jPFvv/1WHTt2lJubm6pXr65XX31VsbGxcnBw0OnTp3OM6YsvvtDFixcVGhpqcfmAAQNUp06dYruS3dnZWW3bts1S/uCDD0qS2X5p0KCBqlatalbPxcVFvXr10q+//mp2Z02HDh3MpjHOLPP29jb7zOzUqFFDknT58mWzch8fHzVu3Fiffvpprp8BlGW//PKLnnnmGd1zzz1yc3NTlSpV9PDDD2fJSZcuXdILL7ygRo0aqWLFivL09FTPnj31zTffmOqkpqbK3d1dzz33XJbt/Prrr3JycsrTtLNz5sxRRkaGXnjhBYvL//vf/+quu+5Sly5dTGWOjo565JFHlJiYqN27d+f4+adOndK3336bbT5t166dunTpojlz5ujatWu5xlsYubU1O5Zyn4eHh7y9vXNdt2rVqmrQoEGWckv5XCKfomyyxdxoGIZSUlJy7OcFBQUV+Jm7169f16ZNm7LNjTVq1NDgwYNL5K7x5cuX68iRI/l+Lpul3JjXfr0krVu3Tn369FFgYKCpLDQ0VHXq1NGaNWvM6pIbgaxcXFzk5+eXp7o1atRQnz59tGvXLrVs2VJubm5q1KiRaQrHjz/+WI0aNZKrq6tatGihr7/+Ok+fu2LFCt17772qUKGCKleurA4dOmjLli05rmPtY21J8vX1lZubW671iuNY+7///a+kv9p5uwEDBsgwDH344Ydm5S1atJC3tzf5Dygi1sidZ8+eVb9+/VSxYkXdddddeuGFF8weq5X5KIl58+bp9ddfV1BQkNzc3NSxY8csM+5YYkv9yttVqFBBd911l1lfkRwI2J6C5MUvvvhC9957r1xdXVWzZk29//77ZvVSUlIk/dXnul21atUkydQPy+5RZnl5VNknn3wiZ2dndejQweLyl156Senp6cV+1/jNmzf13HPP6bnnnlOtWrUs1snrOURyZOnHwDgKxTAMJSUlmR2ELl++XPfdd59cXFxM01pml/jOnj2rzp076+jRo5owYYJGjx6tlStX6o033sjT9vfu3SsHBwc1a9bM4nInJydNnDhR33zzjdavX5/jZ/3555+6ePFirq8//vgj17gyp2C78+A8u7oVKlRQhQoVcqyXmpqq1NRUi59pGIYuXryoxMRE/fe//9Wzzz4rJycnderUKUvdFi1aaO/evbnGBZRlBw8e1N69ezVgwAAtXLhQTz/9tLZv365OnTqZTSX+888/65NPPlGfPn00f/58vfjii/ruu+/UsWNH04FsxYoV9eCDD+rDDz/M8qzqDz74QIZhaODAgTnGk5CQoFmzZmn27NnZnhxMS0uzuCwzt8THx+e4jcy80Lx582zrvPLKK0pKStKiRYty/Ky0tLQ85VNLz57MS1sz3bhxQxcvXtSZM2e0fv16zZs3T0FBQbr77rtzXC8/csrn5FOUNbaWGyWpZs2a8vLykoeHhx5//HElJSUVaZvj4+N148aNHHPjyy+/rFu3buV6IH/z5s0858Y7p6y7cuWKxo0bp5deeinXkyG3bt3SxYsXde7cOW3ZskUTJ06Uh4eH7r333hzXs9SvP3v2rC5cuKCWLVtmqX/vvfdaPLFMbgQK5+TJk/r73/+uvn37Kjo6Wn/88Yf69u2rlStXavTo0aZpG3/66Sc98sgjuU5xOXXqVA0aNEjly5fXtGnTNHXqVAUEBGjHjh05rmerx9r5UZhj7bS0NEnK0h/NqW/dvHlzi8/pBVD8Cps709PTFRYWpipVqmjevHnq2LGjXnvtNb3zzjtZtvX+++9r4cKFioyM1IQJE3TkyBF16dIl136orfQrpb8Gwy5evKgffvhBL730ko4cOaKuXbualpMDgdLv5MmTeuihh9StWze99tprqly5soYMGaKjR4+a6mReMPjcc89p3759+vXXX/XZZ59pxowZ6tevn+rWrStJ6t+/v9kjzJYvX65Ro0ZJ+uvi6Jzs3btXDRs2VPny5S0uDw4OzvNFQcnJyXnKe6mpqVnWXbBggf744w9NnDgxx23kBTnSDljnRnXYi+XLlxuSskyXmN00REFBQWbTV44cOdJwcHAwvv76a1PZ77//bnh7exuSjFOnTuW4/ccff9yoUqVKlvLM6d3mzp1r3Lp1y6hdu7bRpEkT0zSalqZ3yyzL7RUUFJTrfgkNDTU8PT2NP/74I8d6J06cMFxdXY1Bgwbl+pnTp0/PdsqN8+fPm8VYvXp148MPP7T4OTNnzjQkGUlJSbluEyirMqdsvF1cXJwhyXj//fdNZdevX88yFeOpU6cMFxcXY9q0aaayzZs3G5KMzz//3Kxu48aNjY4dO5reZzeV+kMPPWS0bdvW9F4WphcfOXKk4ejoaJw+fdqsfMCAAYYkIyoqKsc2Z04jdOXKlSzLbt9e586dDT8/P9M+sjSVemZZXl53yktbM33wwQdmn9WyZUvj22+/zbaNOU2DZElaWppRv359Izg42Lh582aW5eRTlDW2lBsXLFhgREVFGStXrjQ++ugj47nnnjPKlStn1K5d20hOTs62DfmdSv29994zJBnfffddlmW3T2c+dOhQw9XV1Th37pxZzLdPeZlZlpfXnX3gF154wQgODjauX7+eZdt3yvydZL7uueeePOU9S/36zCn6bv/9ZnrxxRcNSaaYMpEbgezlNu1lUFCQIcnYu3evqSwzV975SIO3334728dMZDpx4oTh6OhoPPjgg1nycuaxcXZs7Vg7p6nULSnssfa6desMScby5cvN6i5evNiQZDRs2DDL5wwfPtxwc3PLc4wA8qa4c2dERIQhyayfahiG0axZM6NFixam95n5z83Nzfj1119N5fv37zckGaNHj86xHbbSrzQMwwgLCzMtd3Z2Np566inj2rVrpuXkQMC25TUv7tmzx1R24cIFw8XFxXj++efN6r733ntGpUqVzPJGRESExfNgmX777TcjMDDQaNSokZGamppjrNWrVzfCw8OzlN9+PvGnn34yypUrZzz77LOm5ZamUu/YsWOe8t6dx/znz583PDw8TI8Cy8tjIXM6h0iOLP0sP2UeyIMffvhBkZGRCgkJUURERIE+Y9OmTQoJCVHTpk1NZd7e3ho4cKDefPPNXNf//fffVbly5RzrZF7JHhERoU8++cQ0Le6dBg8erPbt2+e6zdzuYJw5c6a2bdumt956S5UqVcq23p9//qmHH35Ybm5uuV4JumfPHk2dOlWPPPKI2TTJmby9vbV161Zdv35dX3/9tT7++GOLV0ZJMu2vixcv5npFF1BW3f5/fvPmTaWkpOjuu+9WpUqV9NVXX2nQoEGS/prGKFN6erouX76sihUr6p577tFXX31lWhYaGip/f3+tXLlSPXr0kCQdOXJE3377rd59990cY9m5c6fWrVun/fv351jvH//4hxYvXqxHHnlEr7/+unx9fbVmzRrTHTy5TX/++++/q1y5cqpYsWKO9V555RV17NhRixcv1ujRoy3WCQsL09atW3P8HEvy2tZMnTt31tatW3X58mVt375d33zzja5evZrv7WYnKipKx44d08aNG1WuXNYuE/kUZY0t5cY7p2APDw/Xvffeq4EDB+qtt97S+PHjC91e6a/cKCnX/ubEiRO1fPlyzZo1K9uZj5o0aZLn3Hj7XeE//vij3njjDX3wwQdm+zY79evX19atW3X16lXt3btX27Zty7ZfmCm7fn3md4el7bq6uprq3L6c3AgUTv369RUSEmJ637p1a0lSly5dzB5pkFn+888/W5wpTPpr6sqMjAxNnjw5y/ThuT1iwhaPtfOqKI61e/XqpaCgIL3wwguqUKGCWrRoof379+vll19WuXLlLPatK1eurGvXrunPP//M9S51AEWrKHLn008/bfb+vvvu0/Lly7Nsq1+/fvrb3/5men/vvfeqdevW+uyzzzR//vxsY7SFfmWmWbNm6fnnn9eZM2e0bNky3bhxQ7du3TItJwcCpV/9+vV13333md7fdddduueee/Tzzz+b1fvb3/6me++91/R//9///lcLFy5U1apVNW/evCyfm56erscee0xXrlzRjh075O7unmMceelT1qxZU4MGDdI777yj8ePHm6Zyv9Nrr72WpxmG/P39zd6PGzdONWvW1D/+8Y9c180LcmTpx8A4CiQxMVG9e/eWl5eXPvroIzk5ORXoc3755Rezjmum/EyDa+TheWYDBw7U9OnTNW3aNPXr189inZo1a6pmzZp53q4lH374oSZOnKhhw4ZpxIgR2dZLT0/XgAEDdOzYMX3++edZkvXtfvjhBz344INq2LCh3nvvPYt1nJ2dTc8o6tOnj7p27ap27drJx8dHffr0Maubub8K+qxNoCy4du2aoqOjFRsbq7Nnz5rlmeTkZNPPGRkZeuONN/TWW2/p1KlTZtMBV6lSxfSzo6OjBg4cqEWLFpk6QCtXrpSrq6sefvjhbOO4deuWnn32WQ0aNEitWrXKMebGjRtr1apVevrpp9WuXTtJfx0AL1iwQCNGjMh1wDuvOnTooM6dO2vOnDlZThxkqlatWrad2Ozkp62ZfH19Tc9BeuihhzRz5kx169ZNJ06cyPNzl7Izd+5cvfvuu5o+fbp69eplsQ75FGWNreTG7Pz973/X888/r23bthXZwHim3Pqbdx7IW1K5cuVsnymZk+eee05t27ZVeHh4nup7enqatvPAAw9o1apVeuCBB/TVV1+pSZMmWern1K/PHKTKnCrudtevXzerk4ncCBTO7QM4kuTl5SVJCggIsFie08nBn376SY6Ojqpfv36BYrGlY+28KqpjbVdXV23cuFGPPPKIKf+6uLhozpw5mjFjhsW+NfkPsJ7C5k5XV1fdddddZmWVK1e2mGNr166dpaxOnTpas2ZNnmK1Zr8y0+03KD3++ONq3ry5hgwZoo8++kgSORCwB3fmRSlrXvvyyy/Vp08f7du3z/T4rH79+snT01NTp07VE088kaUfOXHiRO3YsUMbN27M9lndd8pLnzIvFwW1aNEiT9u73b59+7R8+XJt3749y4WiBUWOLP14xjjyLTk5WT179tTly5e1adOmHA80i1uVKlXydJVQ5pXshw8f1qeffmqxTmpqqhITE3N9/fbbbxbX37p1qwYPHqzevXtr8eLFOcbz5JNPasOGDVq6dKnFO8AznTlzRt27d5eXl5c+++wzeXh45NpWSWrbtq2qVaumlStXZlmWub/y8vxzoKwaOXKkZsyYoUceeURr1qzRli1btHXrVlWpUsXs+VwzZ87UmDFj1KFDB61YsUKbN2/W1q1b1aBBgyzP8Ro8eLBSU1P1ySefyDAMrVq1Sn369DEdmFvy/vvv6/jx43rqqad0+vRp00v663mzp0+fNnuu70MPPaRz587pwIEDiouL0y+//GI6CVmnTp0c21ylShXdunVLV65cyXX/TJkyRYmJiXr77bctLr927Vqe8mnm87sL0lZLHnroIaWmpmab5/Nq6dKlGjdunJ5++ukcnz1EPkVZYyu5MScBAQG6dOlSodp5u8yB/Lz0NzOfCTl79myLy2/cuJHn3Jh5McGOHTu0adMmPffcc2a58datW7p27ZpOnz6tlJSUHOPq37+/JGn16tVZluXWr8+8yOn8+fNZ1j1//ry8vb2z3E1ObgQKJ7uLzrMrz8uJxoKwpWPt/CjKY+0GDRroyJEjOnLkiP773//q3LlzevLJJ3Xx4kWLfes//vhDFSpUKLI73wHkXWFzZ0Fv+MkPa/crs+Ps7Kz7779fH3/8sdldjuRAoHTLS/57++235evraxoUz3T//ffLMAzt3bvXrPyTTz7R7NmzNW3aNNOsb7nJa5+yZs2aevzxx/XOO+9YPP6UpEuXLuUp791+4f7YsWN13333KTg42HQ8ffHiRUl/HdMmJCTkqR13IkeWbtwxjny5fv26+vbtqx9//FHbtm0r8JXnmYKCgnTy5Mks5ZbKLKlbt65Wrlyp5OTkXE+gPv7443r11Vc1depU3X///VmWz5s3T1OnTs1TzJmDNZn279+vBx98UC1bttSaNWssTrmb6cUXX1RsbKwWLFigxx57LNt6v//+u7p37660tDRt374933dfXr9+3exLINOpU6dUtWrVLFfCAvifjz76SBEREXrttddMZdevX9fly5ez1OvcubOWLFliVn758uUsAwINGzZUs2bNtHLlSlWvXl0JCQm5PjIiISFBN2/eNN0Bfrv3339f77//vtavX292d46zs7PZHdfbtm2TpFyvJq9bt66kv3JE48aNc6zbsWNHderUSbNnz9bkyZOzLP/www81dOjQHD8jU2aHvCBtvVPmQbyl3JdXn376qf7xj3+of//+iomJybEu+RRlja3kxuwYhqHTp0+rWbNmBVrfkttzY6NGjXKsW6tWLT3++ON6++23TdN03m7v3r3q3LlznrZ76tQp1ahRw3SQnjm4fbuzZ88qODhYr7/+ukaNGpXtZ6WlpSkjIyNLbsxLv/5vf/ub7rrrLh06dCjLsgMHDpjdbXR77ORGwDbUqlVLGRkZOnbsmMX/15zYyrF2fhTHsbaDg4MaNGhgev/ZZ58pIyPDYt/61KlTqlevXoHjB1A6nDhxIkvZjz/+qBo1auS4nrX7lTm5du2aDMPQlStXzAZtyIGAfUtKSrJ48czNmzclyewRCz/++KMiIiLUr18/vfTSS3neRt26dXXq1Kk81Z04caJWrFiR7UVB/fv31+7du3P9nIiICC1dulTSX+cbf/nlFwUHB2epd//998vLyyvLOY28IkeWXgyMI8/S09P16KOPKi4uTp9++qnFKdDzKywsTDExMTp8+LDpQP3SpUsW73S2JCQkRIZhKD4+PserwaX/Xck+ZMgQi8sL+tyz77//Xr1791aNGjW0YcOGHK/6mTt3rubNm6eXXnopy7Mxb3f16lX16tVLZ8+e1c6dOy1O05RZz8HBIctzKdatW6c//vgjy9VekhQfH18kvzvAnjk5OWW5gvzNN9/M0lm0VG/t2rU6e/asxUdCDBo0SGPHjpWLi4uqVKminj175hjHgAEDLJ7EfPDBB9WrVy89+eSTFg+SM504cUKLFy9Wnz59cr1jPDMvHDp0KNeBcemvZ4136tRJ77zzTpZlBXnGeH7aevHiRVWpUiXL9EOZU2Bayn15sWfPHg0YMEAdOnTQypUrc51iiXyKssZWcqMk/fbbb1kGXhctWqTffvstz1eu50WLFi3k7OysQ4cOWRzsuVPm9G9z5szJsqwgz4Ls0qWL1q9fn2X58OHDFRQUpJdfftl0YvXy5ctyd3dX+fLlzepayo356deHh4dr2bJlOnPmjGk60u3bt+vHH3/U6NGjs9QnNwK2o1+/fho3bpymTZumjz76yKxvYxhGjlM52sKxdn4U9bG2JdeuXdOkSZNUrVo1iwPvX331lQYOHFig+AGUHp988onOnj1res74gQMHtH///hwvVJSs36+UpAsXLsjHx8ds+eXLl7Vu3ToFBARkWXY7ciBgf+rUqaMtW7Zo165d6tSpk6n8gw8+kCTTReepqal68MEH9be//U3Lli3L13TgISEhmjVrltLS0rLMNnan2y8KCgoKynLzYUGeMf7OO+9kmYFyx44devPNNzVv3jzTRUuFRY4sXRgYR549//zz+ve//62+ffvq0qVLWrFihdnyxx9/PN+fOXbsWK1YsULdunXTyJEj5e7urvfee0+BgYG6dOlSrkm2ffv2qlKlirZt25brwbr0v+efHT58OMuygjz37MqVKwoLC9Mff/yhF198URs3bjRbXqtWLdOJwfXr12vs2LGqXbu26tWrl2X/devWzfSs3IEDB+rAgQN64okn9P333+v777831atYsaLpjskTJ04oNDRUjz76qOrWrStHR0cdOnRIK1asUI0aNbKcELhw4YK+/fZbRUZG5qudQFnTp08fLV++XF5eXqpfv77i4uK0bds2s2fjZtabNm2ahg4dqrZt2+q7777TypUrs80lf//73zV27FitX79eI0aMyDJ4cae6detm20ELDg7Ocvd0/fr19fDDDyswMFCnTp3SokWL5O3tnevjHaS/cmDDhg21bds2PfHEE7nW79ixozp27GjxSs2CPGM8P21dsWKFFi9erH79+qlmzZq6cuWKaarmvn37Zvk+ePXVVyVJR48elSQtX75cX3zxhSSZpkr/5ZdfdP/998vBwUEPPfSQ1q5da/YZjRs3NrtggHyKsshWcqP0112Fjz76qBo1aiRXV1d98cUXWr16tZo2baqnnnrKrO5//vMfffPNN5L+uvL922+/NeWF+++/P8eLgVxdXdW9e3dt27ZN06ZNyzWuzAP5ZcuWZVlWkGdBBgYGWnw23KhRo+Tr62uWG3ft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LVtq3759mjRpkhISEvTOO+9YjDe3v5mhQ4dq/PjxWrVqlZ544on87ArAqn755RdduXJFERER8vf3159//ql169bp/vvv19tvv63hw4dbO8Qid/HiRU2bNk2BgYFq0qRJge5MeuONNxQcHKzOnTtbXD5t2jT1798/37OH5NVnn32m9957T40bN1bNmjX1448/WqyXkZGhbt266dixY3rmmWdUp04dnTx5Um+99ZY2b96s77//Xh4eHpKkf//73+rXr59CQkJMJzLXrFmjwYMH6+LFi6aLxDp06GDxJOnrr7+ub775Rl27djWVNWvWTC1bttRrr72m999/vxj2BFB8ymJ+/Oqrr9S+fXsFBARoypQpysjI0FtvvaWOHTvqwIEDuueee3L9jLlz56pr165Zjk8zvfLKK8V6ccGqVav04Ycfqnnz5tkeT0t/XSQVEhKiq1ev6plnnlFAQIC++eYb/fOf/9TOnTsVHx9v8ZzDm2++afHCIkl67733tGTJEoWHh+uZZ55RcnKy3n77bbVp00abNm1SaGioqS75Ecifjz/+WHFxcRaXpaSkqH379kpKStJzzz0nPz8/rVmzRo888ohWrlypv//97/nenqurq1atWqXHH3/crPz06dPau3dvlsHdwvrXv/6lW7du6bHHHrO4fO7cuRoxYoQqVKhQpNvNlNd+YEH29aJFi8wufnJycjJbfu3aNR09elS9evVSjRo15OjoqL1792r06NHav3+/Vq1aZarr5+enBx54QPPmzdP9999fLPsCAGCnDJQJjz76qNGlSxejY8eORoMGDbIs79y5s8Xy4hQREWG4u7sXeP158+YZkoy4uLhc6z777LNGYGCgkZGRYVbesWNHIzAw0KhcubLRt29fs2WnTp0yJBlz584tcIyZkpOTDV9fX+PBBx800tPTc6yb3e/oTjt37jQkGWvXri1QTB999JEhyfjggw9MZfltc1RUlBEUFJRlvwKlSWnPjwkJCaa80qBBA6Njx4752pY95sf9+/dnie/atWtGrVq1jJCQEFPZgQMHDEnGpEmTzNZ//vnnDQcHB+Obb76x+Pm5/c0YhmH06dPHuO+++3KNFbB1t27dMpo0aWLcc889BVo/NjbWkGQcPHiwiCPLmSQjMjIy13rXr183zp8/bxiGYRw8eNCQZMTGxuZ5Ozdu3DCqVq1qTJw40aw8M082bdrUkGSsW7fObPmUKVMMScZvv/2W521l5//Yu/f4nuv//+P3HezgsM2mnWpYJczZaIYklsUUoSghifLZhH1KfD7OypDDOsgSobKoPlEhmsmhzGlSopQQxSZpG4sdX78//Pb6etvBNju7XS+X14X38/l4v17P52t7P/Z6v5/v5/OVkJBg/PPPP4ZhGEZoaKiR31u8b775xpBkvPHGGxbl77zzjiHJ+OSTT8yy+++/3/D29jYuX75slmVkZBh33HGH0bx58wLb888//xi1atUy7r///lx1c+fONWrUqGFcuHCh0P0DKqqqnh979Ohh1K5d2zh37pxZdvr0aaNmzZpGnz59rvv8xMREw9bW1liyZIlFec772Jz8GB8fb1F/o58TXO2PP/4w0tPTDcMwjJCQEKNevXp5xq1cudKQZKxbt86ifPLkyYYkY//+/bmek5iYaDg7OxvTp0/P87p43759uXLduXPnjFtuucXo0KFDrv2RH4H/k5Mnvvrqq1x1ly5dMurXr2++9q7NZ3PmzDEkGbGxsWZZVlaW0bZtW8PT09NIS0srcjv69Olj2Nra5rpue/nllw0PDw+jY8eOud4X1qtXzwgJCSn0sa7WvHlz44knnshVfnXunDdvnkVdSf5NKex1YFHO9Y1e+4aFhRmSzOv2HB9//LFhZWVl/Prrr8XaLwDg5sRS6jeB7du36+OPP1ZkZGSuupxlHr/66isdOnTIXMomZ7ZMUlKSnnzySTk7O8vFxUVDhgzRgQMHci0zWZx76Ob4448/1Lt3b9WsWVO33HKLnn/+eWVlZV33eTnLoCUlJV03du3aterSpUuebaxVq5bGjh2rzz//XPv37y9q8wslOjpaiYmJevnll2Vtba3U1NTr3icoMzOz0EvFX7hw4brL/l7reucvNTVV6enpBe7j/vvv12+//Vak5fSAiqQq5Mece58XV1XMjx9//LFsbGwsZm85ODho2LBhiouL06lTpyRJO3bskHTlvo5XGzBggAzD0OrVq3Ptu6Dfmavdf//9+vrrr3X+/PkC44CKzsbGRj4+PrmuF7KzszV16lR5e3urevXquu+++3T48GHVr19fTz75ZK79/PPPP3rmmWfk5uYmJycnDR48WH///bdFTM6Sk19//bXuvvtuOTg46Pbbb7+h2XNr165V06ZNZW9vryZNmmjjxo0W9fb29vL09Cz2/r/++mudO3fOYubf1QYMGKC77rpL06dPl2EYxT5OQTw8POTo6HjduJSUFDP+al5eXpJksY+UlBTVrl1b9vb2Zpmtra3q1Klz3WN9/vnnunDhggYOHJir7v7771dqamqet7YAKpuqnh937NihoKAgubm5mWVeXl669957tW7duuu+V12/fr0yMzPzzY+jRo1S7dq1NXXq1GL34Xq8vb1VrVq168YVJT/mGD9+vBo2bJhrBmkOf3//XEvCu7m56Z577tGPP/6YK578iIrot99+07/+9S81bNhQjo6OcnNz0yOPPKITJ05YxJ0/f17PP/+8mjVrppo1a8rJyUndu3e3uD3AxYsXVaNGDY0ePTrXcX7//XfZ2NjkWhksL3PmzFF2draef/75POt37NihW265RV26dDHLrK2t9eijjyohIUHbtm0rZO//T69evWRvb59rifDo6Gg9+uijuWY934jjx4/r+++/zzd3dujQQV26dNGcOXN06dKlEjvu1Qp7HVicc20YhlJSUop8XZzfZ5g55+nTTz8t0v4AADc3BsaruKysLI0aNUpPP/20mjVrlqv+lltu0XvvvadGjRrptttu03vvvaf33ntPjRs3lmEY6tWrl9577z098cQTeumll/T7779ryJAhJdq+4OBgubm5ae7cubr33ns1b968PJevzczM1Llz53T69Gl9+eWXmjhxomrVqqW77767wGP88ccfOnnypFq3bp1vzOjRowv1pjw7O1vnzp0r1Hb1vW82b94sJycn/fHHH2rYsKH5RmHkyJF53oP2559/Vo0aNVSrVi15enpq0qRJue6lk2Po0KFycnKSg4OD7rvvvnzvJ2QYhs6dO6eEhATt2LFDzz33nGxsbPK8H/G0adNUs2ZNOTg4qG3btvryyy/z3GfO0srffPNNgecNqIiqUn4srqqaH7/99lvdddddcnJysijP+XuR82WetLQ0Sbk/7MxZku7a+15e73fmav7+/jIMI98l6oGKLDU1VefOndOvv/6qBQsW6IsvvrBYEluSJkyYoGnTpqlNmzZ65ZVX1KBBAwUHBys1NTXPfYaFhenHH3/U1KlTNXjwYK1cuVK9e/fO9aHY0aNH1a9fP91///2aN2+eateurSeffFKHDh0qcj++/vpr/etf/9KAAQM0Z84cXb58WX379i3WbSfys3PnTllZ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3367br/99hJt29WOHTum++67T++++66Z83r16mXe9/iLL75Q9+7dJV1Z2nnXrl3av3+/rK2v3H3r0UcfVZMmTTR69Oh8P5ReuXKlXF1dzf3khWtHVGY3U3589tlnderUKb3yyitasWKFpCu3ZBg3blyu66T8FCY/jh49WgsWLNDUqVPz/QKmn5+f/Pz8rruv4vrmm2/Us2dP7dq1S23atJEk9e7dW05OTpo2bZqeeuop+fn5KSUlRRMmTNALL7wgHx+fQu8/NTVVPXv21IULF/T111/ne+7Ij6hoLl26pIiICC1btkx//PGHxWv66lsXZGdn69VXX9Wbb76p48ePWyyV7ubmZv7f2tpaAwcO1KJFi/TPP/+oevXqWrlypRwcHPTII4/k247MzEw999xzGjRokNq2bVtgm5s3b67o6Gg9++yz6tChg6QrX+KOjIzUyJEjC5W78lKtWjU98sgjio6O1t13361Tp06V+DLqRdGpUyfdd999mjNnTq4v1Ofw8vKSl5dXkfdd2OvAGz3Xjz/+uP79739r8+bNuQbGPTw85OHhIUnq16+fZs6cqfvvv1+//PKLPD09LWLJnQCAouIe41XUL7/8osWLF+u5557T6dOndeLECZ04cUKXL19WRkaGTpw4ofPnz5d3My0Gbosq576Fq1atKjAu5yK8MB8YjB49Wi4uLpo2bVqe9VlZWUpISCjUdvXMAW9vb0kyL+pyuLu7F6ptOW+6C/Mz8/HxUXp6er7fpMzRvn17eXl5aeXKlYXaZ37HT0pKyvMeaUBFdTPkx8KqqvnRy8vLnM10tZyynGNKUpMmTfTDDz/ohx9+0I4dO3T69GkNHz5c586d01133SWpeL8zOe0mP6Iq6Nevn/bu3auff/651I+VX+4rzOBKae4rP25uboXKoTmzxg8cOJDvwM/FixcLlUP//PPPYrV1+fLlunz5cq4vRObMSM25N2N6erqWLl2qkJAQ88NQ6coHwt27d9e+ffss8niOkydPaseOHXrkkUcsZr9e6++//yY3osqo6vnx5ZdfVmJionbs2KHvv/9ee/fuVXZ2tiSZ10n5KWx+zPkC5meffZbvjL/k5ORC5cfiXsO/9dZb8vDwMAfFczz00EMyDMO85+/cuXOVnp6u/v37m9eDv//+u6Qrue3EiRO58mN6err69Omj77//Xp9++qmaNm2abzvIj6hoRo0apZdfflmPPvqoPvzwQ3355ZeKiYmRm5ubmQskaebMmQoPD1enTp30/vvva9OmTYqJiVGTJk0s4qQrXyq6ePGi1q5dK8MwFB0drZ49e8rZ2Tnfdrz77rs6cuSInnnmGfO1l/PloQsXLujEiRMW9zzPWdljz549iouL02+//WZ++fB6uasgjz/+uA4cOKCpU6eqRYsWpfKFHTc3N2VmZurChQvXjZ0yZYoSEhL01ltv5Vl/6dKlQr9Hz1HU68AbPdc+Pj6Fyt39+vXTxYsX87yOJncCAIqKgfEq6o8//lB2draee+45+fr6mtvu3bv1888/y9fXV9OnTy9wH/Xq1dOZM2dyLbd95MiR0mx6oaWlpSk7O9viW6p5yflG//Hjx6+7z5w35Z9++mmeb8pPnTplfuPyelvOm2dJ8vf3l3Tl53K106dPS9J1l+XNWdKuMMv3Hjt2TA4ODoX6Fuzly5eve/4KOv4ff/yh9PR0NW7c+Lr7ACqKmyE/FlZVzY8tW7bUzz//rJSUFIvYnG+2t2zZ0qLcyspKTZo0UceOHeXq6qqvvvpK2dnZ5gz44vzO5JxT8iOqgpxlEHOuGerVqydJOnr0qEXcX3/9le8gyC+//GLx+OLFizpz5ozq169fwq0tW40aNdLff/9dqOupJ554QnfeeaemTZuW50DW3LlzC5VDrzdTKj+JiYkyDMNiFpd0ZWlU6cpsLOnKzzEzMzNXXE5sdnZ2nnUffPCBDMMocBn1zMxMnTp1ityIKuNmyI+1a9dWx44d1axZM0nS5s2bddttt5nXkflp1KhRoa4xpStL1Bf0BczRo0cXKj/mfHm+qBITE/PNedL/5ceTJ0/q77//VpMmTczrwZzl7WfOnClfX18dPnzYfH52drYGDx6s2NhYRUdH69577823DeRHVEQff/yxhgwZonnz5qlfv366//771bFjRyUlJeWKu++++7R06VINGDBA3bp1U1BQUK44SWratKlatWqllStXaseOHTp58qS5JHt+Tp48qYyMDHXo0MHi/Zh0ZdDc19dXX375pcVz7Ozs1LZtW7Vr1052dnbavHmzJBVrlbMcHTt2VN26dbV169ZSmy1elPfo9957rzp37qzZs2fnuUT86tWrC/0ePUdxrgOLe64Nw9CJEycK9VnntX9vr3b8+HFyJwCgSFhKvYpq2rSpeU+Xq02cOFEXLlzQq6++anFPsbz06NFDixcv1qJFi/TCCy9IujIj8PXXXy+VNucnKSlJNWrUyDXzZMmSJZKU61vd17r11lvl4+Ojffv2Fep4Y8aMUWRkZJ4DY8W9h+6jjz6qWbNmaenSperSpYtZvmTJEtna2qpz586SpJSUFNnb21vcn8kwDL300kuSrtwfKMeff/6Z6+Lxu+++02effabu3bub3+xMTU2VlZWVqlevbhH7v//9T3///bfF+ctrn3/88YfeeecdNW/ePNcSTPHx8ZJkca9zoKKrSvnxRlXV/NivXz/NnTtXixcv1vPPPy/pypepli1bpoCAgAKXvrx06ZImTZokLy8vc3n34vzOxMfHy8rKSoGBgYU6J0BFcPbsWXO1hhwZGRl699135ejoaM6K6dq1q2xtbbVo0SLdf//9Zuwbb7yR774XL16soUOHmtdzixYtUmZmZoFLblcGgYGBMgxD8fHxFjksLzmzxp988sk860v7HuN33XWXDMPQhx9+aNGGDz74QJLMe/u6u7vLxcVFa9as0fTp02VnZyfpymDd559/rkaNGuXZhujoaNWtW7fAPhw+fFiXL1/m2hGVDvnxitWrV2vv3r2aO3euxUzCvAQGBmrJkiU6duzYdW8TkfMFzJxZmNcq7XuM33XXXfryyy+1detW89pTyp0fn3vuuVy3wzh79qyeeeYZPfnkk+rVq5c5WCddmW27evVqvfXWW9cdtCc/oiKysbHJ9WW+119/PdfAaF5xH330kf74449ct5aQpEGDBmncuHGyt7eXm5vbdfPdgAEDcn25WZIefvhh9ejRQ8OHD1dAQEC+z//ll18UFRWlnj173tCMcSsrK7322mv69ttvrzuYX1w57x/37dun5s2bXzd+6tSp6ty5sxYvXpyrrjj3GC/udWCO/M51Xp83Llq0SH/++ad5v3lJOnfunNzc3HItjZ7fZ8DJycn69ddfNXLkyCL1EwBwc2NgvIqqU6dOnvcvjIyMlKR87214tQcffFAdOnTQ+PHjdeLECfn5+emTTz4p1IyYkrR161Y999xz6tevnxo0aKD09HTt2LFDn3zyidq0aVOoN8i9evXSmjVrCnXfGWdnZ40ePTrPb6sX9x66rVq10lNPPaV33nlHmZmZuvfee7V161Z99NFHmjBhgrms7/79+/XYY4/pscce05133qlLly5pzZo1+uabbzRixAi1bt3a3Gf//v3l6Oio9u3by93dXYcPH9bixYtVvXp1zZo1y4z75ZdfFBQUpP79+6tRo0aytrbWvn379P7776t+/foaPXq0GTtu3Dj9+uuv6tq1q7y9vXXixAm99dZbSk1N1auvvpqrXzExMapbt675QQFQGVSl/ChJ27dv1/bt2yVdebOZmppqDhZ36tRJnTp1KvD5VTE/BgQE6JFHHtGECRN09uxZ3XnnnVqxYoVOnDihpUuXWhz/0Ucflbe3t3nfyHfeeUfHjh3T+vXrVatWLUnF+52JiYlRhw4dLO6pB1R0zzzzjFJSUtSpUyfdeuutSkhI0MqVK/XTTz9p3rx55mo0Hh4eGj16tObNm6eHHnpIDzzwgL777jt98cUXqlOnTp65JD09XV27dtWjjz6qI0eO6M0331THjh3NZbzL0xtvvKGkpCRzpYrPP//cXBp31KhRBS7t2bFjR7m5uWnz5s3XHRiX/u9e4wcOHMhVV9x7jP/222967733JMn8olPO34F69eqZH9w++eSTmjt3rp555hl9++23atKkifbv368lS5aoSZMmevjhhyVd+XD7+eef18SJE9WuXTsNHjxYWVlZWrp0qX7//Xe9//77udrwww8/6Pvvv9f48eML/FsSExOj6tWrWwwYApXBzZgft2/frunTp6tbt25yc3PTrl27tGzZMj3wwAMW7yHzExISIltbW23evFkjRoy4bnzOvca/++471ahRw6KuuPcY//777/XZZ59JujKLPzk52cyPLVq00IMPPijpyv10ly1bpgcffFCjRo1SvXr1tG3bNn3wwQe6//77zQG31q1bW1xzSjKXc27SpInFNWFkZKTefPNNBQYGqnr16rly58MPP2zRT/IjKqKePXvqvffek7Ozs/z8/BQXF6fNmzfneo/Ts2dPTZ8+XUOHDlX79u118OBBrVy5Mt/rmscff1zjxo3TmjVrNHLkyAJvwSJdmUWd3yoVvr6+ud6P+fn56ZFHHlHdunV1/PhxLVq0SK6uroqKiip85/PRq1cv9erVq1CxR48eNXPO1Vq1aqWQkJA8n3P77beradOm2rx5s5566qnrHuPee+/Vvffeq23btuWqK849xot6HVjYc12vXj31799fzZo1k4ODg77++mutWrVKLVu21DPPPGPGvf/++4qKilLv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VXnZunWrWrduLXt7e915551avnx5kY/LwPh1/P333+rQoYOqVaumL774QocPH9a8efNUu3bt8m5apbF3716dOXPG3GJiYiRJjzzySDm3rOKbPXu2Fi1apDfeeEM//vijZs+erTlz5uj1118v76ZVGk8//bRiYmL03nvv6eDBg+rWrZuCgoL0xx9/lHfTKj1e26WD133pIBegLJEfSx+5smyQO1GSyI1FR64rHnLX9aWmpqpFixZauHBhnvVz5szRa6+9pqioKO3evVs1atRQcHBwhfswFcV3s7xObubf9ev1PTU1VR07dtTs2bPLuGWlq6B+//PPP9q/f78mTZqk/fv365NPPtGRI0f00EMPlUNLq67Vq1crPDxcU6ZM0f79+9WiRQsFBwfr7Nmzecbv3LlTjz32mIYNG6Zvv/1WvXv3Vu/evfXDDz+UccsLVtR+bd26VY899pi++uorxcXFycfHR926datQebaofcpx4sQJPf/887rnnnvKqKVFU9R+paen6/7779eJEyf08ccf68iRI3r77bd16623lnHL81fUPkVHR2v8+PGaMmWKfvzxRy1dulSrV6/Wf/7znzJuecGu97fqWsePH1dISIjuu+8+HThwQGPGjNHTTz+tTZs2Fe3ABgr04osvGh07dizvZlQpo0ePNu644w4jOzu7vJtS4YWEhBhPPfWURVmfPn2MgQMHllOLKpd//vnHsLGxMdatW2dR3rp1a+O///1vObWq6uK1XTJ43Zc8cgHKG/mx5JErSx+5E6WN3Hh95LqiI3cVnSRjzZo15uPs7GzD09PTeOWVV8yypKQkw97e3vjggw/KoYUoaTfr6+Rm/l2/tu9XO378uCHJ+Pbbb8u0TWWhoH7n2LNnjyHJ+O2338qmUTeBu+++2wgNDTUfZ2VlGd7e3kZERESe8Y8++qgREhJiURYQEGA888wzpdrOoipqv66VmZlp1KpVy1ixYkVpNbHIitOnzMxMo3379saSJUuMIUOGGL169SqDlhZNUfu1aNEi4/bbbzfS09PLqolFVtQ+hYaGGl26dLEoCw8PNzp06FCq7bwRhcnZ48aNM5o0aWJR1r9/fyM4OLhIx2LG+HV89tlnatOmjR555BG5u7urVatWevvtt8u7WZVWenq63n//fT311FOysrIq7+ZUeO3bt1dsbKx+/vlnSdJ3332nr7/+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",
      "text/plain": [
       "<Figure size 2000x500 with 12 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, axes = plt.subplots(2,6, figsize=(20, 5))\n",
    "for i, fname in enumerate(glob(f\"{DATA_DIR}/*_loops.csv\")):\n",
    "    basename = os.path.basename(fname).replace(\"_benchmarking_data_loops.csv\", \"\")\n",
    "    axes[i // 6, i % 6].set_title(f'{basename} (N={len(pd.read_csv(fname))})')\n",
    "    df_loops = pd.read_csv(fname)\n",
    "    axes[i // 6, i % 6].hist(df_loops['binding_score'], bins=50)\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "32e9d424",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "################2fjg_benchmarking_data_loops.csv################\n",
      "H1 248 H2 191 H3 248 H4 153 HFW1 400 HFW2 267 HFW3 229 HFW4 324 \n",
      "################aayl49_benchmarking_data_loops.csv################\n",
      "H1 826 H2 529 H3 959 H4 1 HFW1 1 HFW2 1 HFW3 367 HFW4 1 \n",
      "################aayl51_benchmarking_data_loops.csv################\n",
      "H1 821 H2 750 H3 972 H4 1 HFW1 1 HFW2 1 HFW3 362 HFW4 1 \n",
      "################1mlc_benchmarking_data_loops.csv################\n",
      "H1 226 H2 159 H3 133 H4 95 HFW1 55 HFW2 222 HFW3 209 HFW4 55 \n",
      "################1mhp_benchmarking_data_loops.csv################\n",
      "H1 9 H2 15 H3 8 H4 1 HFW1 1 HFW2 1 HFW3 7 HFW4 1 \n",
      "################1n8z_benchmarking_data_loops.csv################\n",
      "H1 7 H2 14 H3 416 H4 1 HFW1 1 HFW2 1 HFW3 1 HFW4 1 \n",
      "################4fqi_h3_benchmarking_data_loops.csv################\n",
      "H1 8 H2 16 H3 2 H4 16 HFW1 1 HFW2 1 HFW3 2 HFW4 8 \n",
      "################4fqi_h1_benchmarking_data_loops.csv################\n",
      "H1 8 H2 16 H3 2 H4 16 HFW1 1 HFW2 1 HFW3 2 HFW4 8 \n",
      "################3gbn_h1_benchmarking_data_loops.csv################\n",
      "H1 4 H2 4 H3 2 H4 32 HFW1 1 HFW2 1 HFW3 2 HFW4 1 \n",
      "################3gbn_h9_benchmarking_data_loops.csv################\n",
      "H1 4 H2 4 H3 2 H4 32 HFW1 1 HFW2 1 HFW3 2 HFW4 1 \n",
      "################aayl49_ML_benchmarking_data_loops.csv################\n",
      "H1 576 H2 302 H3 1510 H4 1 HFW1 1 HFW2 1 HFW3 293 HFW4 1 \n"
     ]
    }
   ],
   "source": [
    "for fname in glob(f\"{DATA_DIR}/*_loops.csv\"):\n",
    "    loops_sequences = []\n",
    "    loops_ids = []\n",
    "    df_loops = pd.read_csv(fname)\n",
    "    print(f\"################{os.path.basename(fname)}################\")\n",
    "    for loop_type in ['H1', 'H2', 'H3', 'H4', 'HFW1', 'HFW2', 'HFW3', 'HFW4']:\n",
    "        if loop_type not in df_loops.columns:\n",
    "            continue\n",
    "        print(loop_type, df_loops[loop_type].nunique(), end=' ')\n",
    "\n",
    "        if loop_type in ['H1', 'H2', 'H3', 'H4']:\n",
    "            loops_sequences.extend(df_loops[loop_type])\n",
    "            loops_ids.extend([f\"{i}_{loop_type}\" for i in df_loops.index])\n",
    "    print()\n",
    "    loops_df = pd.DataFrame({'loop_id': loops_ids, 'loop_sequence': loops_sequences})\n",
    "    loops_df.to_csv(fname.replace('_loops.csv', '_loop_cdrcluster_input.csv'), index=False)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "becc7a2d",
   "metadata": {},
   "source": [
    "# Run regression"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "ad939fc9",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "X_full shape: (4312, 1024) (4312, 1024) (4312, 1024) (4312, 1024) (4312, 960), y_full shape: (4312,)\n"
     ]
    }
   ],
   "source": [
    "item_id = 'aayl49'\n",
    "binding_scores_path = f'{DATA_DIR}/{item_id}_benchmarking_data.csv'\n",
    "binding_scores_df = pd.read_csv(binding_scores_path)\n",
    "\n",
    "cdrcluster_path = f'{DATA_DIR}/{item_id}_benchmarking_data_cdrcluster_output_v220.parquet'\n",
    "cdrcluster_df = pd.read_parquet(cdrcluster_path)\n",
    "\n",
    "esmc_path = f\"{DATA_DIR}/ESMC/{item_id}_esmc_embeddings.npy\"\n",
    "esmc_embeddings = np.load(esmc_path)\n",
    "\n",
    "igbert_embeddings_path = f\"{DATA_DIR}/IgBert/continue_finetune_igbert_v16/{item_id}_benchmarking_data_igbert.npy\"\n",
    "igbert_embeddings = np.load(igbert_embeddings_path)\n",
    "\n",
    "plm_embeddings_path = f'{DATA_DIR}/IgBert/baseline/{item_id}_benchmarking_data_igbert.npy'\n",
    "plm_embeddings = np.load(plm_embeddings_path)\n",
    "\n",
    "no_igloo_embeddings_path = f'{DATA_DIR}/IgBert/no_igloo_v14/{item_id}_benchmarking_data_igbert.npy'\n",
    "no_igloo_embeddings = np.load(no_igloo_embeddings_path)\n",
    "\n",
    "with_igloo_embeddings_path = f'{DATA_DIR}/IgBert/with_igloo_v52/{item_id}_benchmarking_data_igbert.npy'\n",
    "with_igloo_embeddings = np.load(with_igloo_embeddings_path)\n",
    "\n",
    "y_full = binding_scores_df['binding_score'].values\n",
    "\n",
    "mask_out_values = {\n",
    "    '3gbn_h1': 7.0,\n",
    "    '3gbn_h9': 7.0,\n",
    "}\n",
    "\n",
    "if item_id in mask_out_values:\n",
    "    mask = binding_scores_df['binding_score'] != mask_out_values[item_id]\n",
    "    print(f\"Masking out (N={np.sum(~mask)}) binding scores equal to {mask_out_values[item_id]}\")\n",
    "    y_full = y_full[mask]\n",
    "    plm_embeddings = plm_embeddings[mask]\n",
    "    igbert_embeddings = igbert_embeddings[mask]\n",
    "    no_igloo_embeddings = no_igloo_embeddings[mask]\n",
    "    with_igloo_embeddings = with_igloo_embeddings[mask]\n",
    "    esmc_embeddings = esmc_embeddings[mask]\n",
    "else:\n",
    "    mask = np.ones(len(y_full), dtype=bool)\n",
    "    \n",
    "y_full = StandardScaler().fit_transform(y_full.reshape(-1, 1)).flatten()\n",
    "\n",
    "print(f\"X_full shape: {plm_embeddings.shape} {igbert_embeddings.shape} {no_igloo_embeddings.shape} {with_igloo_embeddings.shape} {esmc_embeddings.shape}, y_full shape: {y_full.shape}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "id": "e8eb06ba",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "X_full shape: (4312, 1536)\n"
     ]
    }
   ],
   "source": [
    "if cdrcluster_df['id'].str.contains('HFW').sum() > 0:\n",
    "    print(\"Removing HFW loops from cdrcluster_df\")\n",
    "    # Remove HFW loops from the cdrcluster_df\n",
    "    cdrcluster_df = cdrcluster_df[~cdrcluster_df['id'].str.contains('HFW')]\n",
    "cdrcluster_df['sequence_id'] = cdrcluster_df['id'].str.split('_').str[0].astype(int)\n",
    "cdrcluster_df['loop_type'] = cdrcluster_df['id'].str.split('_').str[1]\n",
    "loop_tokens = cdrcluster_df.groupby('sequence_id').agg(\n",
    "    encoded=('encoded', lambda x: np.array(list(x)).flatten()),\n",
    "    quantized=('quantized', lambda x: np.array(list(x)).flatten()),\n",
    "    quantized_indices=('quantized_indices', list)).sort_index()\n",
    "\n",
    "X_encoded_only = np.stack(loop_tokens['encoded'].values)[mask]\n",
    "X_quantized_full = np.concatenate((plm_embeddings,np.stack(loop_tokens['quantized'].values)[mask]), axis=1)\n",
    "X_full = np.concatenate((plm_embeddings, X_encoded_only), axis=1)\n",
    "print(f\"X_full shape: {X_full.shape}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "b14bc516",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Outer CV Folds: 100%|██████████| 10/10 [00:01<00:00,  7.40it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "--- Cross-Validation Complete ---\n",
      "Average Test Loss across 10 folds: 0.4960, std: 0.1230\n",
      "Average R2 Score across 10 folds: 0.4906, std: 0.0640\n",
      "Average Test Pearson Correlation across 10 folds: 0.7171, std: 0.0442\n",
      "Average Test Spearman Correlation across 10 folds: 0.6733, std: 0.0697\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "res_without_cdrcluster = train_regression_model(esmc_embeddings, y_full, pca_components=plm_embeddings.shape[1], verbose=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "id": "d28cf63c",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Outer CV Folds: 100%|██████████| 10/10 [09:51<00:00, 59.18s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "--- Cross-Validation Complete ---\n",
      "Average Test Loss across 10 folds: 0.6512, std: 0.1247\n",
      "Average R2 Score across 10 folds: 0.3438, std: 0.0387\n",
      "Average Test Pearson Correlation across 10 folds: 0.5977, std: 0.0253\n",
      "Average Test Spearman Correlation across 10 folds: 0.6281, std: 0.0296\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "res_without_cdrcluster = train_regression_model(igbert_embeddings, y_full, pca_components=plm_embeddings.shape[1], verbose=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "id": "69aff399",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Outer CV Folds: 100%|██████████| 10/10 [16:14<00:00, 97.47s/it] "
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "--- Cross-Validation Complete ---\n",
      "Average Test Loss across 10 folds: 0.6669, std: 0.1311\n",
      "Average R2 Score across 10 folds: 0.3289, std: 0.0367\n",
      "Average Test Pearson Correlation across 10 folds: 0.5804, std: 0.0280\n",
      "Average Test Spearman Correlation across 10 folds: 0.6112, std: 0.0320\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "res_without_cdrcluster = train_regression_model(plm_embeddings, y_full, pca_components=plm_embeddings.shape[1], verbose=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "34a452ce",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Outer CV Folds: 100%|██████████| 10/10 [11:40<00:00, 70.06s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "--- Cross-Validation Complete ---\n",
      "Average Test Loss across 10 folds: 0.6561, std: 0.1270\n",
      "Average R2 Score across 10 folds: 0.3391, std: 0.0399\n",
      "Average Test Pearson Correlation across 10 folds: 0.5938, std: 0.0252\n",
      "Average Test Spearman Correlation across 10 folds: 0.6287, std: 0.0343\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "res_without_cdrcluster = train_regression_model(with_igloo_embeddings, y_full, pca_components=plm_embeddings.shape[1], verbose=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "26a9f093",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Outer CV Folds: 100%|██████████| 10/10 [14:56<00:00, 89.64s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "--- Cross-Validation Complete ---\n",
      "Average Test Loss across 10 folds: 0.6521, std: 0.1357\n",
      "Average R2 Score across 10 folds: 0.3441, std: 0.0466\n",
      "Average Test Pearson Correlation across 10 folds: 0.5981, std: 0.0297\n",
      "Average Test Spearman Correlation across 10 folds: 0.6308, std: 0.0320\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "res_with_cdrcluster = train_regression_model(no_igloo_embeddings, y_full, pca_components=no_igloo_embeddings.shape[1], verbose=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 104,
   "id": "898001b5",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Outer CV Folds:  40%|████      | 4/10 [01:20<02:01, 20.21s/it]\n"
     ]
    },
    {
     "ename": "KeyboardInterrupt",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[31m---------------------------------------------------------------------------\u001b[39m",
      "\u001b[31mKeyboardInterrupt\u001b[39m                         Traceback (most recent call last)",
      "\u001b[36mCell\u001b[39m\u001b[36m \u001b[39m\u001b[32mIn[104]\u001b[39m\u001b[32m, line 1\u001b[39m\n\u001b[32m----> \u001b[39m\u001b[32m1\u001b[39m res_with_cdrcluster = \u001b[43mtrain_regression_model\u001b[49m\u001b[43m(\u001b[49m\u001b[43mX_full\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43my_full\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mpca_components\u001b[49m\u001b[43m=\u001b[49m\u001b[43mX_full\u001b[49m\u001b[43m.\u001b[49m\u001b[43mshape\u001b[49m\u001b[43m[\u001b[49m\u001b[32;43m1\u001b[39;49m\u001b[43m]\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mverbose\u001b[49m\u001b[43m=\u001b[49m\u001b[38;5;28;43;01mFalse\u001b[39;49;00m\u001b[43m)\u001b[49m\n",
      "\u001b[36mFile \u001b[39m\u001b[32m~/cdrcluster/regression/ridge_regression_task.py:156\u001b[39m, in \u001b[36mtrain_regression_model\u001b[39m\u001b[34m(X_full, y_full, seed, use_wandb, pca_components, verbose)\u001b[39m\n\u001b[32m    153\u001b[39m \u001b[38;5;28;01mfor\u001b[39;00m current_lambda \u001b[38;5;129;01min\u001b[39;00m lambda_values:\n\u001b[32m    154\u001b[39m     \u001b[38;5;66;03m# Use scikit-learn Ridge model\u001b[39;00m\n\u001b[32m    155\u001b[39m     model_inner = Ridge(alpha=current_lambda, random_state=seed)\n\u001b[32m--> \u001b[39m\u001b[32m156\u001b[39m     \u001b[43mmodel_inner\u001b[49m\u001b[43m.\u001b[49m\u001b[43mfit\u001b[49m\u001b[43m(\u001b[49m\u001b[43mX_train_inner\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43my_train_inner\u001b[49m\u001b[43m)\u001b[49m\n\u001b[32m    158\u001b[39m     y_pred_inner = model_inner.predict(X_val_inner)\n\u001b[32m    159\u001b[39m     val_loss_inner = mean_squared_error(y_val_inner, y_pred_inner)\n",
      "\u001b[36mFile \u001b[39m\u001b[32m~/micromamba/envs/pyenv/lib/python3.11/site-packages/sklearn/base.py:1363\u001b[39m, in \u001b[36m_fit_context.<locals>.decorator.<locals>.wrapper\u001b[39m\u001b[34m(estimator, *args, **kwargs)\u001b[39m\n\u001b[32m   1356\u001b[39m     estimator._validate_params()\n\u001b[32m   1358\u001b[39m \u001b[38;5;28;01mwith\u001b[39;00m config_context(\n\u001b[32m   1359\u001b[39m     skip_parameter_validation=(\n\u001b[32m   1360\u001b[39m         prefer_skip_nested_validation \u001b[38;5;129;01mor\u001b[39;00m global_skip_validation\n\u001b[32m   1361\u001b[39m     )\n\u001b[32m   1362\u001b[39m ):\n\u001b[32m-> \u001b[39m\u001b[32m1363\u001b[39m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43mfit_method\u001b[49m\u001b[43m(\u001b[49m\u001b[43mestimator\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43m*\u001b[49m\u001b[43margs\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43m*\u001b[49m\u001b[43m*\u001b[49m\u001b[43mkwargs\u001b[49m\u001b[43m)\u001b[49m\n",
      "\u001b[36mFile \u001b[39m\u001b[32m~/micromamba/envs/pyenv/lib/python3.11/site-packages/sklearn/linear_model/_ridge.py:1248\u001b[39m, in \u001b[36mRidge.fit\u001b[39m\u001b[34m(self, X, y, sample_weight)\u001b[39m\n\u001b[32m   1237\u001b[39m xp, _ = get_namespace(X, y, sample_weight)\n\u001b[32m   1238\u001b[39m X, y = validate_data(\n\u001b[32m   1239\u001b[39m     \u001b[38;5;28mself\u001b[39m,\n\u001b[32m   1240\u001b[39m     X,\n\u001b[32m   (...)\u001b[39m\u001b[32m   1246\u001b[39m     y_numeric=\u001b[38;5;28;01mTrue\u001b[39;00m,\n\u001b[32m   1247\u001b[39m )\n\u001b[32m-> \u001b[39m\u001b[32m1248\u001b[39m \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28;43msuper\u001b[39;49m\u001b[43m(\u001b[49m\u001b[43m)\u001b[49m\u001b[43m.\u001b[49m\u001b[43mfit\u001b[49m\u001b[43m(\u001b[49m\u001b[43mX\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43my\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43msample_weight\u001b[49m\u001b[43m=\u001b[49m\u001b[43msample_weight\u001b[49m\u001b[43m)\u001b[49m\n",
      "\u001b[36mFile \u001b[39m\u001b[32m~/micromamba/envs/pyenv/lib/python3.11/site-packages/sklearn/linear_model/_ridge.py:990\u001b[39m, in \u001b[36m_BaseRidge.fit\u001b[39m\u001b[34m(self, X, y, sample_weight)\u001b[39m\n\u001b[32m    986\u001b[39m     \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[32m    987\u001b[39m         \u001b[38;5;66;03m# for dense matrices or when intercept is set to 0\u001b[39;00m\n\u001b[32m    988\u001b[39m         params = {}\n\u001b[32m--> \u001b[39m\u001b[32m990\u001b[39m     \u001b[38;5;28mself\u001b[39m.coef_, \u001b[38;5;28mself\u001b[39m.n_iter_, \u001b[38;5;28mself\u001b[39m.solver_ = \u001b[43m_ridge_regression\u001b[49m\u001b[43m(\u001b[49m\n\u001b[32m    991\u001b[39m \u001b[43m        \u001b[49m\u001b[43mX\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m    992\u001b[39m \u001b[43m        \u001b[49m\u001b[43my\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m    993\u001b[39m \u001b[43m        \u001b[49m\u001b[43malpha\u001b[49m\u001b[43m=\u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[43m.\u001b[49m\u001b[43malpha\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m    994\u001b[39m \u001b[43m        \u001b[49m\u001b[43msample_weight\u001b[49m\u001b[43m=\u001b[49m\u001b[43msample_weight\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m    995\u001b[39m \u001b[43m        \u001b[49m\u001b[43mmax_iter\u001b[49m\u001b[43m=\u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[43m.\u001b[49m\u001b[43mmax_iter\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m    996\u001b[39m \u001b[43m        \u001b[49m\u001b[43mtol\u001b[49m\u001b[43m=\u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[43m.\u001b[49m\u001b[43mtol\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m    997\u001b[39m \u001b[43m        \u001b[49m\u001b[43msolver\u001b[49m\u001b[43m=\u001b[49m\u001b[43msolver\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m    998\u001b[39m \u001b[43m        \u001b[49m\u001b[43mpositive\u001b[49m\u001b[43m=\u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[43m.\u001b[49m\u001b[43mpositive\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m    999\u001b[39m \u001b[43m        \u001b[49m\u001b[43mrandom_state\u001b[49m\u001b[43m=\u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[43m.\u001b[49m\u001b[43mrandom_state\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m   1000\u001b[39m \u001b[43m        \u001b[49m\u001b[43mreturn_n_iter\u001b[49m\u001b[43m=\u001b[49m\u001b[38;5;28;43;01mTrue\u001b[39;49;00m\u001b[43m,\u001b[49m\n\u001b[32m   1001\u001b[39m \u001b[43m        \u001b[49m\u001b[43mreturn_intercept\u001b[49m\u001b[43m=\u001b[49m\u001b[38;5;28;43;01mFalse\u001b[39;49;00m\u001b[43m,\u001b[49m\n\u001b[32m   1002\u001b[39m \u001b[43m        \u001b[49m\u001b[43mreturn_solver\u001b[49m\u001b[43m=\u001b[49m\u001b[38;5;28;43;01mTrue\u001b[39;49;00m\u001b[43m,\u001b[49m\n\u001b[32m   1003\u001b[39m \u001b[43m        \u001b[49m\u001b[43mcheck_input\u001b[49m\u001b[43m=\u001b[49m\u001b[38;5;28;43;01mFalse\u001b[39;49;00m\u001b[43m,\u001b[49m\n\u001b[32m   1004\u001b[39m \u001b[43m        \u001b[49m\u001b[43mfit_intercept\u001b[49m\u001b[43m=\u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[43m.\u001b[49m\u001b[43mfit_intercept\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m   1005\u001b[39m \u001b[43m        \u001b[49m\u001b[43m*\u001b[49m\u001b[43m*\u001b[49m\u001b[43mparams\u001b[49m\u001b[43m,\u001b[49m\n\u001b[32m   1006\u001b[39m \u001b[43m    \u001b[49m\u001b[43m)\u001b[49m\n\u001b[32m   1007\u001b[39m     \u001b[38;5;28mself\u001b[39m._set_intercept(X_offset, y_offset, X_scale)\n\u001b[32m   1009\u001b[39m \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28mself\u001b[39m\n",
      "\u001b[36mFile \u001b[39m\u001b[32m~/micromamba/envs/pyenv/lib/python3.11/site-packages/sklearn/linear_model/_ridge.py:749\u001b[39m, in \u001b[36m_ridge_regression\u001b[39m\u001b[34m(X, y, alpha, sample_weight, solver, max_iter, tol, verbose, positive, random_state, return_n_iter, return_intercept, return_solver, X_scale, X_offset, check_input, fit_intercept)\u001b[39m\n\u001b[32m    747\u001b[39m \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[32m    748\u001b[39m     \u001b[38;5;28;01mtry\u001b[39;00m:\n\u001b[32m--> \u001b[39m\u001b[32m749\u001b[39m         coef = \u001b[43m_solve_cholesky\u001b[49m\u001b[43m(\u001b[49m\u001b[43mX\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43my\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43malpha\u001b[49m\u001b[43m)\u001b[49m\n\u001b[32m    750\u001b[39m     \u001b[38;5;28;01mexcept\u001b[39;00m linalg.LinAlgError:\n\u001b[32m    751\u001b[39m         \u001b[38;5;66;03m# use SVD solver if matrix is singular\u001b[39;00m\n\u001b[32m    752\u001b[39m         solver = \u001b[33m\"\u001b[39m\u001b[33msvd\u001b[39m\u001b[33m\"\u001b[39m\n",
      "\u001b[36mFile \u001b[39m\u001b[32m~/micromamba/envs/pyenv/lib/python3.11/site-packages/sklearn/linear_model/_ridge.py:206\u001b[39m, in \u001b[36m_solve_cholesky\u001b[39m\u001b[34m(X, y, alpha)\u001b[39m\n\u001b[32m    203\u001b[39m n_features = X.shape[\u001b[32m1\u001b[39m]\n\u001b[32m    204\u001b[39m n_targets = y.shape[\u001b[32m1\u001b[39m]\n\u001b[32m--> \u001b[39m\u001b[32m206\u001b[39m A = \u001b[43msafe_sparse_dot\u001b[49m\u001b[43m(\u001b[49m\u001b[43mX\u001b[49m\u001b[43m.\u001b[49m\u001b[43mT\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mX\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mdense_output\u001b[49m\u001b[43m=\u001b[49m\u001b[38;5;28;43;01mTrue\u001b[39;49;00m\u001b[43m)\u001b[49m\n\u001b[32m    207\u001b[39m Xy = safe_sparse_dot(X.T, y, dense_output=\u001b[38;5;28;01mTrue\u001b[39;00m)\n\u001b[32m    209\u001b[39m one_alpha = np.array_equal(alpha, \u001b[38;5;28mlen\u001b[39m(alpha) * [alpha[\u001b[32m0\u001b[39m]])\n",
      "\u001b[36mFile \u001b[39m\u001b[32m~/micromamba/envs/pyenv/lib/python3.11/site-packages/sklearn/utils/extmath.py:206\u001b[39m, in \u001b[36msafe_sparse_dot\u001b[39m\u001b[34m(a, b, dense_output)\u001b[39m\n\u001b[32m    202\u001b[39m \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[32m    203\u001b[39m     ret = a @ b\n\u001b[32m    205\u001b[39m \u001b[38;5;28;01mif\u001b[39;00m (\n\u001b[32m--> \u001b[39m\u001b[32m206\u001b[39m     \u001b[43msparse\u001b[49m\u001b[43m.\u001b[49m\u001b[43missparse\u001b[49m\u001b[43m(\u001b[49m\u001b[43ma\u001b[49m\u001b[43m)\u001b[49m\n\u001b[32m    207\u001b[39m     \u001b[38;5;129;01mand\u001b[39;00m sparse.issparse(b)\n\u001b[32m    208\u001b[39m     \u001b[38;5;129;01mand\u001b[39;00m dense_output\n\u001b[32m    209\u001b[39m     \u001b[38;5;129;01mand\u001b[39;00m \u001b[38;5;28mhasattr\u001b[39m(ret, \u001b[33m\"\u001b[39m\u001b[33mtoarray\u001b[39m\u001b[33m\"\u001b[39m)\n\u001b[32m    210\u001b[39m ):\n\u001b[32m    211\u001b[39m     \u001b[38;5;28;01mreturn\u001b[39;00m ret.toarray()\n\u001b[32m    212\u001b[39m \u001b[38;5;28;01mreturn\u001b[39;00m ret\n",
      "\u001b[36mFile \u001b[39m\u001b[32m~/micromamba/envs/pyenv/lib/python3.11/site-packages/scipy/sparse/_base.py:1401\u001b[39m, in \u001b[36missparse\u001b[39m\u001b[34m(x)\u001b[39m\n\u001b[32m   1395\u001b[39m \u001b[38;5;250m    \u001b[39m\u001b[33;03m\"\"\"A namespace class to separate sparray from spmatrix\"\"\"\u001b[39;00m\n\u001b[32m   1398\u001b[39m sparray.\u001b[34m__doc__\u001b[39m = _spbase.\u001b[34m__doc__\u001b[39m\n\u001b[32m-> \u001b[39m\u001b[32m1401\u001b[39m \u001b[38;5;28;01mdef\u001b[39;00m\u001b[38;5;250m \u001b[39m\u001b[34missparse\u001b[39m(x):\n\u001b[32m   1402\u001b[39m \u001b[38;5;250m    \u001b[39m\u001b[33;03m\"\"\"Is `x` of a sparse array or sparse matrix type?\u001b[39;00m\n\u001b[32m   1403\u001b[39m \n\u001b[32m   1404\u001b[39m \u001b[33;03m    Parameters\u001b[39;00m\n\u001b[32m   (...)\u001b[39m\u001b[32m   1430\u001b[39m \u001b[33;03m    False\u001b[39;00m\n\u001b[32m   1431\u001b[39m \u001b[33;03m    \"\"\"\u001b[39;00m\n\u001b[32m   1432\u001b[39m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28misinstance\u001b[39m(x, _spbase)\n",
      "\u001b[31mKeyboardInterrupt\u001b[39m: "
     ]
    }
   ],
   "source": [
    "res_with_cdrcluster = train_regression_model(X_full, y_full, pca_components=X_full.shape[1], verbose=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 110,
   "id": "e9a90a4b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "--- Cross-Validation Complete ---\n",
      "Average Test Loss across 10 folds: 0.1713, std: 0.0155\n",
      "Average R2 Score across 10 folds: 0.8273, std: 0.0197\n",
      "Average Test Pearson Correlation across 10 folds: 0.9105, std: 0.0102\n",
      "Average Test Spearman Correlation across 10 folds: 0.9532, std: 0.0069\n"
     ]
    }
   ],
   "source": [
    "res_with_cdrcluster = train_regression_model(X_encoded_only, y_full, pca_components=X_full.shape[1], verbose=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9fb8622d",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "pyenv",
   "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.11.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
