{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "documented-falls",
   "metadata": {},
   "source": [
    "# RFP Data Preprocessing\n",
    "\n",
    "This notebook prepares a pool of starting RFP wild variants with known structure for optimization."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "external-kuwait",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import pypdb\n",
    "import requests\n",
    "import json\n",
    "import time\n",
    "import os\n",
    "from pathlib import Path\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "import torch\n",
    "import numpy as np\n",
    "from botorch.utils.multi_objective import pareto\n",
    "from sklearn.linear_model import LinearRegression\n",
    "import statsmodels.api as sm\n",
    "\n",
    "from Bio.PDB.PDBList import PDBList\n",
    "from Bio import PDB\n",
    "from Bio.SeqUtils import seq1\n",
    "\n",
    "from lambo.candidate import pdb_to_residues, FoldedCandidate\n",
    "from lambo.tasks.proxy_rfp.foldx import FoldxManager, extract_chain\n",
    "from lambo.utils import ResidueTokenizer\n",
    "\n",
    "import warnings\n",
    "warnings.filterwarnings(\"ignore\")\n",
    "\n",
    "sns.set(style='whitegrid', font_scale=1.75)\n",
    "\n",
    "FPBASE_ENDPOINT = \"https://www.fpbase.org/api/proteins/?\""
   ]
  },
  {
   "cell_type": "markdown",
   "id": "initial-immune",
   "metadata": {},
   "source": [
    "## Merge name and sequence csv files\n",
    "Keep only 'red' proteins (at least 580 nm emission wavelength)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "average-genealogy",
   "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>Name</th>\n",
       "      <th>Ex max (nm)</th>\n",
       "      <th>Em max (nm)</th>\n",
       "      <th>Stokes Shift (nm)</th>\n",
       "      <th>Extinction Coefficient</th>\n",
       "      <th>Quantum Yield</th>\n",
       "      <th>Brightness</th>\n",
       "      <th>pKa</th>\n",
       "      <th>Oligomerization</th>\n",
       "      <th>Maturation (min)</th>\n",
       "      <th>Lifetime (ns)</th>\n",
       "      <th>Molecular Weight (kDa)</th>\n",
       "      <th>Switch Type</th>\n",
       "      <th>Aliases</th>\n",
       "      <th>Seq</th>\n",
       "      <th>num_mutations</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>RRvT</td>\n",
       "      <td>556.0</td>\n",
       "      <td>583.0</td>\n",
       "      <td>27.0</td>\n",
       "      <td>134000</td>\n",
       "      <td>0.88</td>\n",
       "      <td>117.92</td>\n",
       "      <td>3.9</td>\n",
       "      <td>td</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>54.55</td>\n",
       "      <td>b</td>\n",
       "      <td>NaN</td>\n",
       "      <td>MVSKGEEVIKEFMRFKVRMEGSMNGHEFEIEGEGEGRPYEGTQTAK...</td>\n",
       "      <td>358</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>tdTomato</td>\n",
       "      <td>554.0</td>\n",
       "      <td>581.0</td>\n",
       "      <td>27.0</td>\n",
       "      <td>138000</td>\n",
       "      <td>0.69</td>\n",
       "      <td>95.22</td>\n",
       "      <td>4.7</td>\n",
       "      <td>td</td>\n",
       "      <td>60.0</td>\n",
       "      <td>NaN</td>\n",
       "      <td>54.19</td>\n",
       "      <td>b</td>\n",
       "      <td>NaN</td>\n",
       "      <td>MVSKGEEVIKEFMRFKVRMEGSMNGHEFEIEGEGEGRPYEGTQTAK...</td>\n",
       "      <td>356</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>FusionRed-MQV</td>\n",
       "      <td>566.0</td>\n",
       "      <td>585.0</td>\n",
       "      <td>19.0</td>\n",
       "      <td>144000</td>\n",
       "      <td>0.53</td>\n",
       "      <td>76.32</td>\n",
       "      <td>4.6</td>\n",
       "      <td>m</td>\n",
       "      <td>195.0</td>\n",
       "      <td>2.77</td>\n",
       "      <td>25.59</td>\n",
       "      <td>b</td>\n",
       "      <td>FR-MQV</td>\n",
       "      <td>MVSELIKENMPMKLYMEGTVNNHHFKCTSEGEGKPYEGTQTQRIKV...</td>\n",
       "      <td>181</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>pcDronpa2 (Red)</td>\n",
       "      <td>569.0</td>\n",
       "      <td>583.0</td>\n",
       "      <td>14.0</td>\n",
       "      <td>105000</td>\n",
       "      <td>0.68</td>\n",
       "      <td>71.40</td>\n",
       "      <td>6.1</td>\n",
       "      <td>t</td>\n",
       "      <td>NaN</td>\n",
       "      <td>NaN</td>\n",
       "      <td>25.34</td>\n",
       "      <td>mp</td>\n",
       "      <td>NaN</td>\n",
       "      <td>MSVIKPDMKIKLRMEGAVNGHPFAIEGVGLGKPFEGKQSMDLKVKE...</td>\n",
       "      <td>174</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>mScarlet</td>\n",
       "      <td>569.0</td>\n",
       "      <td>594.0</td>\n",
       "      <td>25.0</td>\n",
       "      <td>100000</td>\n",
       "      <td>0.70</td>\n",
       "      <td>70.00</td>\n",
       "      <td>5.3</td>\n",
       "      <td>m</td>\n",
       "      <td>174.0</td>\n",
       "      <td>3.90</td>\n",
       "      <td>26.35</td>\n",
       "      <td>b</td>\n",
       "      <td>NaN</td>\n",
       "      <td>MVSKGEAVIKEFMRFKVHMEGSMNGHEFEIEGEGEGRPYEGTQTAK...</td>\n",
       "      <td>165</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "              Name  Ex max (nm)  Em max (nm)  Stokes Shift (nm)  \\\n",
       "0             RRvT        556.0        583.0               27.0   \n",
       "1         tdTomato        554.0        581.0               27.0   \n",
       "2    FusionRed-MQV        566.0        585.0               19.0   \n",
       "3  pcDronpa2 (Red)        569.0        583.0               14.0   \n",
       "4         mScarlet        569.0        594.0               25.0   \n",
       "\n",
       "  Extinction Coefficient  Quantum Yield  Brightness  pKa Oligomerization  \\\n",
       "0                 134000           0.88      117.92  3.9              td   \n",
       "1                 138000           0.69       95.22  4.7              td   \n",
       "2                 144000           0.53       76.32  4.6               m   \n",
       "3                 105000           0.68       71.40  6.1               t   \n",
       "4                 100000           0.70       70.00  5.3               m   \n",
       "\n",
       "   Maturation (min)  Lifetime (ns)  Molecular Weight (kDa) Switch Type  \\\n",
       "0               NaN            NaN                   54.55           b   \n",
       "1              60.0            NaN                   54.19           b   \n",
       "2             195.0           2.77                   25.59           b   \n",
       "3               NaN            NaN                   25.34          mp   \n",
       "4             174.0           3.90                   26.35           b   \n",
       "\n",
       "  Aliases                                                Seq  num_mutations  \n",
       "0     NaN  MVSKGEEVIKEFMRFKVRMEGSMNGHEFEIEGEGEGRPYEGTQTAK...            358  \n",
       "1     NaN  MVSKGEEVIKEFMRFKVRMEGSMNGHEFEIEGEGEGRPYEGTQTAK...            356  \n",
       "2  FR-MQV  MVSELIKENMPMKLYMEGTVNNHHFKCTSEGEGKPYEGTQTQRIKV...            181  \n",
       "3     NaN  MSVIKPDMKIKLRMEGAVNGHPFAIEGVGLGKPFEGKQSMDLKVKE...            174  \n",
       "4     NaN  MVSKGEAVIKEFMRFKVHMEGSMNGHEFEIEGEGEGRPYEGTQTAK...            165  "
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "fpbase_names = pd.read_csv('../lambo/assets/fpbase/fpbase_names.csv')\n",
    "fpbase_seqs =  pd.read_csv('../lambo/assets/fpbase/fpbase_sequences.csv')\n",
    "select_cols = ['Name', 'Seq', 'num_mutations']\n",
    "fpbase_seqs = fpbase_seqs[select_cols]\n",
    "\n",
    "fpbase_data = fpbase_names.merge(fpbase_seqs, on='Name', how='inner')  # combine csv files\n",
    "rfp_data = fpbase_data[fpbase_data['Em max (nm)'] >= 580]  # only keep \"red\" proteins\n",
    "rfp_data.reset_index(drop=True, inplace=True)\n",
    "\n",
    "rfp_data.head()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "discrete-dancing",
   "metadata": {},
   "source": [
    "## Get PDB ids for proteins with known structure from FPBase\n",
    "If multiple structures are available use the highest-resolution structure.\n",
    "\n",
    "Record crystal pH value for FoldX repair."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "parallel-excess",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "---- RRvT ----\n",
      "---- tdTomato ----\n",
      "---- FusionRed-MQV ----\n",
      "---- pcDronpa2 ----\n",
      "---- mScarlet ----\n",
      "---- GRvT ----\n",
      "---- plobRFP ----\n",
      "---- AzaleaB5 ----\n",
      "---- mRuby3 ----\n",
      "---- RFP611 ----\n",
      "---- mScarlet-I ----\n",
      "---- ccalRFP1 ----\n",
      "---- pporRFP ----\n",
      "---- pcDronpa ----\n",
      "---- DsRed ----\n",
      "---- tdKatushka2 ----\n",
      "---- TagRFP ----\n",
      "---- dTomato ----\n",
      "---- M355NA ----\n",
      "---- cgfTagRFP ----\n",
      "---- amilFP593 ----\n",
      "---- mEos4a ----\n",
      "---- mRuby2 ----\n",
      "---- mEos4b ----\n",
      "---- mRuby ----\n",
      "---- mApple ----\n",
      "---- GRvT ----\n",
      "---- CyRFP1 ----\n",
      "---- E2-Red/Green ----\n",
      "---- eqFP611 ----\n",
      "---- TagRFP-T ----\n",
      "---- td-RFP611 ----\n",
      "---- smURFP ----\n",
      "---- TDsmURFP ----\n",
      "---- CyOFP1 ----\n",
      "---- mEos2 ----\n",
      "---- Katushka2S ----\n",
      "---- DsRed.T3 ----\n",
      "---- E2-Crimson ----\n",
      "---- FR-1 ----\n",
      "---- DsRed2 ----\n",
      "---- PATagRFP1314 ----\n",
      "---- PATagRFP1297 ----\n",
      "---- mStrawberry ----\n",
      "---- cgfmKate2 ----\n",
      "---- PATagRFP ----\n",
      "---- mKate2 ----\n",
      "---- d1EosFP ----\n",
      "---- FusionRed-M ----\n",
      "---- mEosFP ----\n",
      "---- KikGR1 ----\n",
      "---- mNeptune2.5 ----\n",
      "---- EosFP ----\n",
      "---- Katushka ----\n",
      "---- mNeptune2 ----\n",
      "---- mEos3.1 ----\n",
      "---- Kaede ----\n",
      "---- d2EosFP ----\n",
      "---- BDFP1.6 ----\n",
      "---- DsRed-Max ----\n",
      "---- FusionRed ----\n",
      "---- eforCP ----\n",
      "---- mEos3.2 ----\n",
      "---- mKikGR ----\n",
      "---- mBeRFP ----\n",
      "---- mCyRFP1 ----\n",
      "---- RFP630 ----\n",
      "---- mCherry2 ----\n",
      "---- mClavGR2 ----\n",
      "---- mMaple ----\n",
      "---- IrisFP ----\n",
      "---- RFP637 ----\n",
      "---- mCardinal ----\n",
      "---- mCherry ----\n",
      "---- eqFP650 ----\n",
      "---- DsRed-Express2 ----\n",
      "---- mKate ----\n",
      "---- mScarlet-H ----\n",
      "---- td-RFP639 ----\n",
      "---- miRFP670-2 ----\n",
      "---- iRFP713/V256C ----\n",
      "---- miRFP680 ----\n",
      "---- mNeptune ----\n",
      "---- DsRed.T4 ----\n",
      "---- mCRISPRed ----\n",
      "---- Neptune ----\n",
      "---- mRaspberry ----\n",
      "---- PAmCherry2 ----\n",
      "---- DsRed-Express ----\n",
      "---- moxMaple3 ----\n",
      "---- iRFP670 ----\n",
      "---- mRFP1 ----\n",
      "---- mMaple3 ----\n",
      "---- RFP639 ----\n",
      "---- emiRFP670 ----\n",
      "---- miRFP670 ----\n",
      "---- mTangerine ----\n",
      "---- KillerRed ----\n",
      "---- mRFP1-Q66C ----\n",
      "---- miRFP670nano ----\n",
      "---- mEosFP-F173S ----\n",
      "---- miRFP682 ----\n",
      "---- LSSmCherry1 ----\n",
      "---- iRFP682 ----\n",
      "---- PSmOrange ----\n",
      "---- mGarnet2 ----\n",
      "---- miRFP ----\n",
      "---- Jred ----\n",
      "---- mMaroon1 ----\n",
      "---- mRhubarb713 ----\n",
      "---- mGarnet ----\n",
      "---- PAmCherry1 ----\n",
      "---- miRFP670v1 ----\n",
      "---- rsFusionRed1 ----\n",
      "---- emiRFP703 ----\n",
      "---- miRFP703 ----\n",
      "---- mKelly2 ----\n",
      "---- mStable ----\n",
      "---- dKeima ----\n",
      "---- mEos2-A69T ----\n",
      "---- iRFP702 ----\n",
      "---- PSmOrange2 ----\n",
      "---- miRFP702 ----\n",
      "---- laRFP ----\n",
      "---- mKelly1 ----\n",
      "---- miRFP713 ----\n",
      "---- iFP2.0 ----\n",
      "---- pHuji ----\n",
      "---- mIFP ----\n",
      "---- iFP1.4 ----\n",
      "---- HcRed-Tandem ----\n",
      "---- iRFP713 ----\n",
      "---- mRhubarb720 ----\n",
      "---- HcRed7 ----\n",
      "---- miRFP720 ----\n",
      "---- RDSmCherry0.1 ----\n",
      "---- mCarmine ----\n",
      "---- iRFP720 ----\n",
      "---- mRhubarb719 ----\n",
      "---- Maroon0.1 ----\n",
      "---- eechRFP ----\n",
      "---- PAmCherry3 ----\n",
      "---- RDSmCherry1 ----\n",
      "---- PAmKate ----\n",
      "---- LSS-mKate2 ----\n",
      "---- Wi-Phy ----\n",
      "---- rsFusionRed2 ----\n",
      "---- miRFP709 ----\n",
      "---- eqFP670 ----\n",
      "---- KFP1 ----\n",
      "---- mPlum ----\n",
      "---- rsTagRFP ----\n",
      "---- TagRFP675 ----\n",
      "---- mRojoB ----\n",
      "---- AQ143 ----\n",
      "---- mKeima ----\n",
      "---- TagRFP657 ----\n",
      "---- SNIFP ----\n",
      "---- tKeima ----\n",
      "---- rsFusionRed3 ----\n",
      "---- AsRed2 ----\n",
      "---- LSS-mKate1 ----\n",
      "---- rsCherry ----\n",
      "---- mNeptune681 ----\n",
      "---- mGrape1 ----\n",
      "---- mGinger2 ----\n",
      "---- mGrape3 ----\n",
      "---- mNeptune684 ----\n",
      "---- mGinger1 ----\n",
      "---- RDSmCherry0.2 ----\n",
      "---- mGrape2 ----\n",
      "---- mRojoA ----\n",
      "---- mRouge ----\n",
      "---- RDSmCherry0.5 ----\n",
      "---- rsCherryRev ----\n",
      "---- Sandercyanin ----\n",
      "---- HcRed ----\n",
      "---- mRtms5 ----\n",
      "---- anm2CP ----\n",
      "---- Ultramarine ----\n",
      "---- AdRed ----\n",
      "---- AdRed-C148S ----\n",
      "---- amilFP597 ----\n",
      "---- AQ14 ----\n",
      "---- asCP562 ----\n",
      "---- asulCP ----\n",
      "---- BDFP2.0 ----\n",
      "---- cp-mKate ----\n",
      "---- dis2RFP ----\n",
      "---- DrCBD ----\n",
      "---- d-RFP618 ----\n",
      "---- DspR1 ----\n",
      "---- DsRed.M1 ----\n",
      "---- FP586 ----\n",
      "---- Katushka-9-5 ----\n",
      "---- mc1 ----\n",
      "---- mcavRFP ----\n",
      "---- mKeima ----\n",
      "---- mKeima ----\n",
      "---- mKeima ----\n",
      "---- mKeima ----\n",
      "---- mMaple2 ----\n",
      "---- mPlum-E16P ----\n",
      "---- mRed7 ----\n",
      "---- mRed7Q1 ----\n",
      "---- mRed7Q1S1 ----\n",
      "---- mRed7Q1S1BM ----\n",
      "---- mRFP1.1 ----\n",
      "---- mRFP1.2 ----\n",
      "---- RCaMP ----\n",
      "---- RFP618 ----\n",
      "---- rsCherryRev1.4 ----\n",
      "---- SAASoti ----\n",
      "---- ShyRFP ----\n"
     ]
    }
   ],
   "source": [
    "def fpbase_name_to_pdb_ids(name):\n",
    "    name = name.split(' ')[0]\n",
    "    print(f'---- {name} ----')\n",
    "    query = f'{FPBASE_ENDPOINT}name__iexact={name}&format=json'\n",
    "    response = requests.get(query)\n",
    "    if not response.status_code == 200:\n",
    "        print('query failed')\n",
    "        return []\n",
    "    \n",
    "    query_results = json.loads(response.text)[0]['pdb']\n",
    "    \n",
    "    def get_resolution(info):\n",
    "        try:\n",
    "            return info['rcsb_entry_info']['resolution_combined'][0]\n",
    "        except KeyError:\n",
    "            return float('NaN')\n",
    "        \n",
    "    def get_pH(info):\n",
    "        try:\n",
    "            return info['expt1_crystal_grow']['ph']\n",
    "        except KeyError:\n",
    "            return float('NaN')\n",
    "    \n",
    "    if len(query_results) > 0:\n",
    "        entry_info = [pypdb.get_info(pdb_id) for pdb_id in query_results]\n",
    "        resolution = [get_resolution(info) for info in entry_info]\n",
    "        pH = [get_pH(info) for info in entry_info]\n",
    "        query_results = [\n",
    "            (pdb_id, res, ph) for pdb_id, res, ph in zip(query_results, resolution, pH)\n",
    "        ]\n",
    "        query_results.sort(key=lambda datum: datum[1])\n",
    "    \n",
    "    return query_results\n",
    "\n",
    "\n",
    "for row_idx, datum in rfp_data.iterrows():\n",
    "    query_results = fpbase_name_to_pdb_ids(datum.Name)\n",
    "    time.sleep(0.1)\n",
    "    if len(query_results) == 0:\n",
    "        continue\n",
    "        \n",
    "    rfp_data.loc[row_idx, 'pdb_id'] = query_results[0][0]\n",
    "    rfp_data.loc[row_idx, 'pdb_resolution'] = query_results[0][1]\n",
    "    rfp_data.loc[row_idx, 'crystal_pH'] = query_results[0][2]"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ambient-instruction",
   "metadata": {},
   "source": [
    "## Clean up dataframe"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "moral-leisure",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "AdRed: 6AA7 (1.8 nm)\n",
      "DrCBD: 1ztu (2.5 nm)\n",
      "DsRed: 1ZGO (1.4 nm)\n",
      "DsRed-Max: 2V4E (2.4 nm)\n",
      "DsRed.M1: 2VAD (1.59 nm)\n",
      "DsRed.T4: 2VAE (1.64 nm)\n",
      "HcRed: 1YZW (2.1 nm)\n",
      "HcRed7: 6DEJ (1.6279 nm)\n",
      "IrisFP (Orange): 2VVH (1.8 nm)\n",
      "Katushka: 3PJ5 (1.6 nm)\n",
      "KikGR1 (Red): 4P76 (2.9 nm)\n",
      "KillerRed: 3GB3 (1.75 nm)\n",
      "LSS-mKate1: 3NT9 (1.99 nm)\n",
      "LSS-mKate2: 3NT3 (1.5 nm)\n",
      "Neptune: 3IP2 (1.6 nm)\n",
      "PSmOrange (Far-red): 4Q7T (1.94 nm)\n",
      "PSmOrange2 (Far-red): 4Q7U (1.3 nm)\n",
      "RCaMP: 3U0K (2.1 nm)\n",
      "RFP630: 3E5V (2.1 nm)\n",
      "Sandercyanin: 5EZ2 (1.849 nm)\n",
      "TagRFP: 3M22 (2.2 nm)\n",
      "TagRFP-T: 5JVA (1.95 nm)\n",
      "TagRFP675: 4KGE (2.3 nm)\n",
      "Wi-Phy: 3S7Q (1.748 nm)\n",
      "asulCP: 1XQM (2.1 nm)\n",
      "cp-mKate: 3RWA (1.67 nm)\n",
      "eqFP611: 1UIS (2.0 nm)\n",
      "eqFP650: 4EDO (1.8 nm)\n",
      "eqFP670: 4EDS (1.6 nm)\n",
      "iFP1.4: 5AJG (1.11 nm)\n",
      "iFP2.0: 4CQH (1.14 nm)\n",
      "laRFP: 4JF9 (2.33 nm)\n",
      "mCRISPRed: 6XWY (1.75 nm)\n",
      "mCardinal: 4OQW (2.21 nm)\n",
      "mCherry: 2H5Q (1.36 nm)\n",
      "mEos2 (Red): 3S05 (2.204 nm)\n",
      "mEos2-A69T (Orange): 5DTL (2.7 nm)\n",
      "mEosFP (Red): 3P8U (2.25 nm)\n",
      "mKate: 3BXA (1.75 nm)\n",
      "mPlum: 2QLG (1.8 nm)\n",
      "mPlum-E16P: 4H3L (1.65 nm)\n",
      "mRojoA: 3NEZ (1.7 nm)\n",
      "mRouge: 3NED (0.95 nm)\n",
      "mRuby: 3U0L (1.25 nm)\n",
      "mScarlet: 5LK4 (1.47 nm)\n",
      "mStrawberry: 2H5R (1.6 nm)\n",
      "miRFP670nano: 6MGH (1.95 nm)\n",
      "pcDronpa (Red): 4HQ8 (1.95 nm)\n",
      "rsTagRFP (ON): 3U8C (2.188 nm)\n",
      "smURFP: 6FZN (2.5 nm)\n"
     ]
    }
   ],
   "source": [
    "rfp_data.crystal_pH.fillna(7.0, inplace=True)\n",
    "rfp_known_structures = rfp_data.dropna(subset=['pdb_id'])\n",
    "rfp_known_structures.drop_duplicates(subset=['pdb_id'], inplace=True, keep=False)\n",
    "rfp_known_structures.sort_values('Name', inplace=True)\n",
    "rfp_known_structures.rename(columns={'Seq': 'fpbase_seq'}, inplace=True)\n",
    "\n",
    "for _, datum in rfp_known_structures.iterrows():\n",
    "    print(f'{datum.Name}: {datum.pdb_id} ({datum.pdb_resolution} nm)')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "premium-marine",
   "metadata": {},
   "source": [
    "## Download structures from RCSB PDB"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "vital-drunk",
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Downloading PDB structure '6AA7'...\n",
      "Downloading PDB structure '1ztu'...\n",
      "Downloading PDB structure '1ZGO'...\n",
      "Downloading PDB structure '2V4E'...\n",
      "Downloading PDB structure '2VAD'...\n",
      "Downloading PDB structure '2VAE'...\n",
      "Downloading PDB structure '1YZW'...\n",
      "Downloading PDB structure '6DEJ'...\n",
      "Downloading PDB structure '2VVH'...\n",
      "Downloading PDB structure '3PJ5'...\n",
      "Downloading PDB structure '4P76'...\n",
      "Downloading PDB structure '3GB3'...\n",
      "Downloading PDB structure '3NT9'...\n",
      "Downloading PDB structure '3NT3'...\n",
      "Downloading PDB structure '3IP2'...\n",
      "Downloading PDB structure '4Q7T'...\n",
      "Downloading PDB structure '4Q7U'...\n",
      "Downloading PDB structure '3U0K'...\n",
      "Downloading PDB structure '3E5V'...\n",
      "Downloading PDB structure '5EZ2'...\n",
      "Downloading PDB structure '3M22'...\n",
      "Downloading PDB structure '5JVA'...\n",
      "Downloading PDB structure '4KGE'...\n",
      "Downloading PDB structure '3S7Q'...\n",
      "Downloading PDB structure '1XQM'...\n",
      "Downloading PDB structure '3RWA'...\n",
      "Downloading PDB structure '1UIS'...\n",
      "Downloading PDB structure '4EDO'...\n",
      "Downloading PDB structure '4EDS'...\n",
      "Downloading PDB structure '5AJG'...\n",
      "Downloading PDB structure '4CQH'...\n",
      "Downloading PDB structure '4JF9'...\n",
      "Downloading PDB structure '6XWY'...\n",
      "Downloading PDB structure '4OQW'...\n",
      "Downloading PDB structure '2H5Q'...\n",
      "Downloading PDB structure '3S05'...\n",
      "Downloading PDB structure '5DTL'...\n",
      "Downloading PDB structure '3P8U'...\n",
      "Downloading PDB structure '3BXA'...\n",
      "Downloading PDB structure '2QLG'...\n",
      "Downloading PDB structure '4H3L'...\n",
      "Downloading PDB structure '3NEZ'...\n",
      "Downloading PDB structure '3NED'...\n",
      "Downloading PDB structure '3U0L'...\n",
      "Downloading PDB structure '5LK4'...\n",
      "Downloading PDB structure '2H5R'...\n",
      "Downloading PDB structure '6MGH'...\n",
      "Downloading PDB structure '4HQ8'...\n",
      "Downloading PDB structure '3U8C'...\n",
      "Downloading PDB structure '6FZN'...\n"
     ]
    }
   ],
   "source": [
    "pdb_list = PDBList()\n",
    "pdb_list.download_pdb_files(\n",
    "    rfp_known_structures.pdb_id,\n",
    "    pdir='../lambo/assets/pdb',\n",
    "    file_format=\"pdb\"\n",
    ")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "focused-mission",
   "metadata": {},
   "source": [
    "## Extract longest chain in the structure\n",
    "Break ties with chain ID (i.e. use chain A by default)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "interpreted-shakespeare",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "A    41\n",
       "B     5\n",
       "C     3\n",
       "D     1\n",
       "Name: longest_chain, dtype: int64"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "for row_idx, datum in rfp_known_structures.iterrows():\n",
    "    pdb_path = f'../lambo/assets/pdb/pdb{datum.pdb_id.lower()}.ent'\n",
    "    parser = PDB.PDBParser()\n",
    "    pdb_path = Path(pdb_path)\n",
    "    struct = parser.get_structure(pdb_path.stem, pdb_path)\n",
    "    chain_residues = {\n",
    "        chain.get_id(): seq1(''.join(x.resname for x in chain)) for chain in struct.get_chains()\n",
    "    }\n",
    "    chain_lengths = [\n",
    "        (-len(seq.replace('X', '')), chain_id) for chain_id, seq in chain_residues.items()\n",
    "    ]\n",
    "    chain_lengths.sort()\n",
    "    longest_chain = chain_lengths[0][1]\n",
    "    rfp_known_structures.loc[row_idx, 'longest_chain'] = longest_chain\n",
    "    extract_chain(pdb_path, longest_chain)\n",
    "\n",
    "rfp_known_structures.longest_chain.value_counts()"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "reserved-plate",
   "metadata": {},
   "source": [
    "## Repair single-chain structures with FoldX"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "regional-congress",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "---- AdRed-A ----\n",
      "file exists, skipping\n",
      "---- DrCBD-A ----\n",
      "file exists, skipping\n",
      "---- DsRed-A ----\n",
      "file exists, skipping\n",
      "---- DsRed-Max-B ----\n",
      "file exists, skipping\n",
      "---- DsRed.M1-A ----\n",
      "file exists, skipping\n",
      "---- DsRed.T4-A ----\n",
      "file exists, skipping\n",
      "---- HcRed-A ----\n",
      "file exists, skipping\n",
      "---- HcRed7-A ----\n",
      "file exists, skipping\n",
      "---- IrisFP (Orange)-C ----\n",
      "file exists, skipping\n",
      "---- Katushka-A ----\n",
      "file exists, skipping\n",
      "---- KikGR1 (Red)-A ----\n",
      "file exists, skipping\n",
      "---- KillerRed-A ----\n",
      "file exists, skipping\n",
      "---- LSS-mKate1-A ----\n",
      "file exists, skipping\n",
      "---- LSS-mKate2-C ----\n",
      "file exists, skipping\n",
      "---- Neptune-A ----\n",
      "file exists, skipping\n",
      "---- PSmOrange (Far-red)-B ----\n",
      "file exists, skipping\n",
      "---- PSmOrange2 (Far-red)-A ----\n",
      "file exists, skipping\n",
      "---- RCaMP-A ----\n",
      "file exists, skipping\n",
      "---- RFP630-A ----\n",
      "file exists, skipping\n",
      "---- Sandercyanin-A ----\n",
      "file exists, skipping\n",
      "---- TagRFP-A ----\n",
      "file exists, skipping\n",
      "---- TagRFP-T-A ----\n",
      "file exists, skipping\n",
      "---- TagRFP675-A ----\n",
      "file exists, skipping\n",
      "---- Wi-Phy-A ----\n",
      "file exists, skipping\n",
      "---- asulCP-A ----\n",
      "file exists, skipping\n",
      "---- cp-mKate-A ----\n",
      "file exists, skipping\n",
      "---- eqFP611-A ----\n",
      "file exists, skipping\n",
      "---- eqFP650-A ----\n",
      "file exists, skipping\n",
      "---- eqFP670-A ----\n",
      "file exists, skipping\n",
      "---- iFP1.4-A ----\n",
      "file exists, skipping\n",
      "---- iFP2.0-A ----\n",
      "file exists, skipping\n",
      "---- laRFP-B ----\n",
      "file exists, skipping\n",
      "---- mCRISPRed-A ----\n",
      "file exists, skipping\n",
      "---- mCardinal-A ----\n",
      "file exists, skipping\n",
      "---- mCherry-A ----\n",
      "file exists, skipping\n",
      "---- mEos2 (Red)-B ----\n",
      "file exists, skipping\n",
      "---- mEos2-A69T (Orange)-A ----\n",
      "file exists, skipping\n",
      "---- mEosFP (Red)-C ----\n",
      "file exists, skipping\n",
      "---- mKate-A ----\n",
      "file exists, skipping\n",
      "---- mPlum-B ----\n",
      "file exists, skipping\n",
      "---- mPlum-E16P-A ----\n",
      "file exists, skipping\n",
      "---- mRojoA-A ----\n",
      "file exists, skipping\n",
      "---- mRouge-A ----\n",
      "file exists, skipping\n",
      "---- mRuby-A ----\n",
      "file exists, skipping\n",
      "---- mScarlet-A ----\n",
      "file exists, skipping\n",
      "---- mStrawberry-A ----\n",
      "file exists, skipping\n",
      "---- miRFP670nano-D ----\n",
      "file exists, skipping\n",
      "---- pcDronpa (Red)-A ----\n",
      "file exists, skipping\n",
      "---- rsTagRFP (ON)-A ----\n",
      "file exists, skipping\n",
      "---- smURFP-A ----\n",
      "file exists, skipping\n"
     ]
    }
   ],
   "source": [
    "for _, datum in rfp_known_structures.iterrows():\n",
    "    pdb_path = f'../lambo/assets/pdb/pdb{datum.pdb_id.lower()}_{datum.longest_chain}.pdb'\n",
    "    work_dir = f'../lambo/assets/foldx/{datum.pdb_id.lower()}_{datum.longest_chain}/'\n",
    "    print(f'---- {datum.Name}-{datum.longest_chain} ----')\n",
    "    if os.path.exists(Path(work_dir) / 'wt_input_Repair.pdb'):\n",
    "        print('file exists, skipping')\n",
    "        continue\n",
    "    else:\n",
    "        os.makedirs(work_dir, exist_ok=True)\n",
    "        FoldxManager(work_dir=work_dir, wt_pdb=pdb_path, skip_minimization=False,\n",
    "                     ph=datum.crystal_pH)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "geological-advice",
   "metadata": {},
   "source": [
    "## Validate repaired FoldX sequences\n",
    "Compare against FPBase and corresponding NCSB PDB chain. They won't match exactly."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "isolated-lucas",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "---- AdRed-6AA7-A ----\n",
      "FPBase (231 residues): MALSKHGLTKDMTMKYRMEGCVDGHKFVITGHGNGSPFEGKQTINLCVVEGGPLPFSEDILSAVFDYGNRVFTDYPQGMVDFFKNSCPAGYTWQRSLLFEDGAVCTASADITVSVEENCFYHESKFHGVNFPADGPVMKKMTINWEPCCEKIIPVPRQGILKGDVAMYLLLKDGGRYRCQFDTVYKAKTDSKKMPEWHFIQHKLTREDRSDAKNQKWQLAEHSVASRSALP\n",
      "\n",
      "FoldX (226 residues): LSKHGLTKDMTMKYRMEGCVDGHKFVITGHGNGSPFEGKQTINLCVVEGGPLPFSEDILSAVFNRVFTDYPQGMVDFFKNSCPAGYTWQRSLLFEDGAVCTASADITVSVEENCFYHESKFHGVNFPADGPVMKKMTINWEPCCEKIIPVPRQGILKGDVAMYLLLKDGGRYRCQFDTVYKAKTDSKKMPEWHFIQHKLTREDRSDAKNQKWQLAEHSVASRSALA\n",
      "\n",
      "\n",
      "---- DrCBD-1ztu-A ----\n",
      "FPBase (321 residues): MSRDPLPFFPPLYLGGPEITTENCEREPIHIPGSIQPHGALLTADGHSGEVLQMSLNAATFLGQEPTVLRGQTLAALLPEQWPALQAALPPGCPDALQYRATLDWPAAGHLSLTVHRVGELLILEFEPTEAWDSTGPHALRNAMFALESAPNLRALAEVATQTVRELTGFDRVMLYKFAPDATGEVIAEARREGLHAFLGHRFPASDIPAQARALYTRHLLRLTADTRAAAVPLDPVLNPQTNAPTPLGGAVLRATSPMHMQYLRNMGVGSSLSVSVVVGGQLWGLIACHHQTPYVLPPDLRTTLEYLGRLLSLQVQVKEA\n",
      "\n",
      "FoldX (313 residues): PLPFFPPLYLGGPEITTENCEREPIHIPGSIQPHGALLTADGHSGEVLQMSLNAATFLGQEPTVLRGQTLAALLPEQWPALQAALPPGCPDALQYRATLDWPGHLSLTVHRVGELLILEFEPTEPHALRNAMFALESAPNLRALAEVATQTVRELTGFDRVMLYKFAPDATGEVIAEARREGLHAFLGHRFPASDIPAQARALYTRHLLRLTADTRAAAVPLDPVLNTQTNAPTPLGGAVLRATSPMHMQYLRNMGVGSSLSVSVVVGGQLWGLIACHHQTPYVLPPDLRTTLEYLGRLLSLQVQVKEAHHHH\n",
      "\n",
      "\n",
      "---- DsRed-1ZGO-A ----\n",
      "FPBase (225 residues): MRSSKNVIKEFMRFKVRMEGTVNGHEFEIEGEGEGRPYEGHNTVKLKVTKGGPLPFAWDILSPQFQYGSKVYVKHPADIPDYKKLSFPEGFKWERVMNFEDGGVVTVTQDSSLQDGCFIYKVKFIGVNFPSDGPVMQKKTMGWEASTERLYPRDGVLKGEIHKALKLKDGGHYLVEFKSIYMAKKPVQLPGYYYVDSKLDITSHNEDYTIVEQYERTEGRHHLFL\n",
      "\n",
      "FoldX (217 residues): NVIKEFMRFKVRMEGTVNGHEFEIEGEGEGRPYEGHNTVKLKVTKGGPLPFAWDILSPQFSKVYVKHPADIPDYKKLSFPEGFKWERVMNFEDGGVVTVTQDSSLQDGCFIYKVKFIGVNFPSDGPVMQKKTMGWEASTERLYPRDGVLKGEIHKALKLKDGGHYLVEFKSIYMAKKPVQLPGYYYVDSKLDITSHNEDYTIVEQYERTEGRHHLFL\n",
      "\n",
      "\n",
      "---- DsRed-Max-2V4E-B ----\n",
      "FPBase (225 residues): MDSTENVIKPFMRFKVHMEGSVNGHEFEIEGEGEGKPYEGTQTAKLQVTKGGPLPFAWDILSPQFMYGSKVYTKHPADIPDYKKLSFPEGFKWERVMNFEDGGVVTVTQDSSLQDGTFIYHVKFIGVNFPSDGPVMQKKTLGWEPSTERLYPRDGVLKGEIHKALKLKGGGHYLCEFKSIYMAKKPVKLPGYYYVDSKLDITSHNEDYTVVEQYERTEARHHLFQ\n",
      "\n",
      "FoldX (217 residues): NVIKPFMRFKVHMEGSVNGHEFEIEGEGEGKPYEGTQTAKLQVTKGGPLPFAWDILSPQFSKVYTKHPADIPDYKKLSFPEGFKWERVMNFEDGGVVTVTQDSSLQDGVFIYHVKFIGVNFPSDGPVMQKKTLGWEPSTERLYPRDGVLKGEIHKALKLKGGGHYLCEFKSIYMAKKPVKLPGYYYVDSKLDITSHNEDYTVVEQYERTEARHHLFL\n",
      "\n",
      "\n",
      "---- DsRed.M1-2VAD-A ----\n",
      "FPBase (225 residues): MDNTEDVIKEFMQFKVRMEGSVNGHYFEIEGEGEGKPYEGTQTAKLQVTKGGPLPFAWDILSPQFQYGSKAYVKHPADIPDYMKLSFPEGFTWERSMNFEDGGVVEVQQDSSLQDGTFIYKVKFKGVNFPADGPVMQKKTAGWEPSTEKLYPQDGVLKGEISHALKLKDGGHYTCDFKTVYKAKKPVQLPGNHYVDSKLDITNHNEDYTVVEQYEHAEARHSGSQ\n",
      "\n",
      "FoldX (217 residues): TEDVIKEFMQFKVRMEGSVNGHYFEIEGEGEGKPYEGTQTAKLQVTKGGPLPFAWDILSPQFSKAYVKHPADIPDYMKLSFPEGFTWERSMNFEDGGVVEVQQDSSLQDGTFIYKVKFKGVNFPADGPVMQKKTAGWEPSTEKLYPQDGVLKGEISHALKLKDGGHYTCDFKTVYKAKKPVQLPGNHYVDSKLDITNHNEDYTVVEQYEHAEARHSG\n",
      "\n",
      "\n",
      "---- DsRed.T4-2VAE-A ----\n",
      "FPBase (225 residues): MASSEDVIKEFMRFKVRMEGSVNGHEFEIEGEGEGRPYEGTQTAKLKVTKGGPLPFAWDILSPQFQYGSKVYVKHPADIPDYKKLSFPEGFKWERVMNFEDGGVVTVTQDSSLQDGCFIYKVKFIGVNFPSDGPVMQKKTMGWEPSTERLYPRDGVLKGEIHKALKLKDGGHYLVEFKSIYMAKKPVQLPGYYYVDSKLDITSHNEDYTIVEQYERAEGRHHLFL\n",
      "\n",
      "FoldX (216 residues): VIKEFMRFKVRMEGSVNGHEFEIEGEGEGRPYEGTQTAKLKVTKGGPLPFAWDILSPQFSKVYVKHPADIPDYKKLSFPEGFKWERVMNFEDGGVVTVTQDSSLQDGCFIYKVKFIGVNFPSDGPVMQKKTMGWEPSTERLYPRDGVLKGEIHKALKLKDGGHYLVEFKSIYMAKKPVQLPGYYYVDSKLDITSHNEDYTIVEQYERAEGRHHLFL\n",
      "\n",
      "\n",
      "---- HcRed-1YZW-A ----\n",
      "FPBase (227 residues): MAGLLKESMRIKMYMEGTVNGHYFKCEGEGDGNPFAGTQSMRIHVTEGAPLPFAFDILAPCCEYGSRTFVHHTAEIPDFFKQSFPEGFTWERTTTYEDGGILTAHQDTSLEGNCLIYKVKVHGTNFPADGPVMKNKSGGWEPSTEVVYPENGVLCGRNVMALKVGDRHLICHHYTSYRSKKAVRALTMPGFHFTDIRLQMLRKKKDEYFELYEASVARYSDLPEKAN\n",
      "\n",
      "FoldX (220 residues): GLLKESMRIKMYMEGTVNGHYFKCEGEGDGNPFAGTQSMRIHVTEGAPLPFAFDILAPCCSRTFVHHTAEIPDFFKQSFPEGFTWERTTTYEDGGILTAHQDTSLEGNCLIYKVKVHGTNFPADGPVMKNKSGGWEPSTEVVYPENGVLCGRNVMALKVGDRHLICHHYTSYRSKKAVRALTMPGFHFTDIRLQMLRKKKDEYFELYEASVARYSDLPEK\n",
      "\n",
      "\n",
      "---- HcRed7-6DEJ-A ----\n",
      "FPBase (227 residues): MAGLLKESMRIKMYMEGTVNGHYFKCEGEGDGNPFAGTQSMRIHVTEGAPLPFAFDILAPCCEYGSKTFVHHTAEIPDFFKQSFPEGFTWERTTTYEDGGILTAHQDTSLEGNCLIYKVKVHGTNFPADGPVMKNKSGGWEPSTEVVYPENGVLCGRNVMALKVGDRHLICHHYTSYRSKKAVRALTMPGFHFTDYRLQMLRKKKDEYFELYEASVARYSDLPEKAN\n",
      "\n",
      "FoldX (223 residues): AGLLKESMRIKMYMEGTVNGHYFKCEGEGDGNPFAGTQSMRIHVTEGAPLPFAFDILAPCCSKTFVHHTAEIPDFFKQSFPEGFTWERTTTYEDGGILTAHQDTSLEGNCLIYKVKVHGTNFPADGPVMKNKSGGWEPSTEVVYPENGVLCGRNVMALKVGDRHLICHHYTSYRSKKAVRALTMPGFHFTDYRLQMLRKKKDEYFELYEASVARYSDLPEKAN\n",
      "\n",
      "\n",
      "---- IrisFP (Orange)-2VVH-C ----\n",
      "FPBase (226 residues): MSAIKPDMKINLRMEGNVNGHHFVIDGDGTGKPFEGKQSMDLEVKEGGPLPFAFDILTTAFHYGNRVFAEYPDHIQDYFKQSFPKGYSWERSLTFEDGGICIARNDITMEGDTFYNKVRFHGVNFPANGPVMQKKTLKWEPSTEKMYVRDGVLTGDITMALLLEGNAHYRCDSRTTYKAKEKGVKLPGYHLVDHCIEILSHDKDYNKVKLYEHAVAHSGLPDNARR\n",
      "\n",
      "FoldX (222 residues): HHMSAIKPDMKINLRMEGNVNGHHFVIDGDGTGKPFEGKQSMDLEVKEGGPLPFAFDILTTAFNRVFAEYPDHIQDYFKQSFPKGYSWERSLTFEDGGICIARNDITMEGDTFYNKVRFHGVNFPANGPVMQKKTLKWEPSTEKMYVRDGVLTGDITMALLLEGNAHYRCDSRTTYKAKEKGVKLPGYHLVDHCIEILSHDKDYNKVKLYEHAVAHSGLPDN\n",
      "\n",
      "\n",
      "---- Katushka-3PJ5-A ----\n",
      "FPBase (231 residues): MSVLITENMHMKLYMEGTVNDHHFKCTSEGEGKPYEGTQTMKIKVVEGGPLPFAFDILATSFMYGSKTFINHTQGIPDFFKQSFPEGFTWERITTYEDGGVLTATQDTSLQNGCLIYNVKINGVNFPSNGPVMQKKTLGWEASTEMLYPADSGLRGHSQMALKLVGGGYLHCSLKTTYRSKKPAKNLKMPGFYFVDRRLERIKEADKETYVEQHEMAVARYCDLPSKLGHS\n",
      "\n",
      "FoldX (223 residues): EDSELISENMHMKLYMEGTVNDHHFKCTSEGEGKPYEGTQTMKIKVVEGGPLPFAFDILATSFSKTFINHTQGIPDFFKQSFPEGFTWERITTYEDGGVLTATQDTSLQNGCLIYNVKINGVNFPSNGPVMQKKTLGWEASTEMLYPADSGLRGHSQMALKLVGGGYLHCSLKTTYRSKKPAKNLKMPGFYFVDRKLERIKEADKETYVEQHEMAVARYCDLP\n",
      "\n",
      "\n",
      "---- KikGR1 (Red)-4P76-A ----\n",
      "FPBase (227 residues): MSVITSEMKIELRMEGAVNGHKFVITGKGSGQPFEGIQNVDLTVIEGGPLPFAFDILTTAFHYGNRVFVEYPEEIVDYFKQSFPEGYSWERSMSYEDGGICLATNNITMKKDGSNCFVNEIRFDGVNFPANGPVMQRKTVKWEPSTEKMYVRDGVLKGDVNMALLLQGGGHYRCDFRTTYKAKKVVQLPDYHFVDHQMEITSHDKDYNKVKLYEHAKAHSGLPRLAK\n",
      "\n",
      "FoldX (223 residues): VSVITSEMKIELRMEGAVNGHKFVITGKGSGQPFEGIQNVDLTVIEGGPLPFAFDILTTAFNRVFVEYPEEIVDYFKQSFPEGYSWERSMSYEDGGICLATNNITMKKDGSNCFVNEIRFDGVNFPANGPVMQRKTVKWEPSTEKMYVRDGVLKGDVNMALLLQGGGHYRCDFRTTYKAKKVVQLPDYHFVDHSMEITSHDKDYNKVKLYEHAKAHSGLPRLA\n",
      "\n",
      "\n",
      "---- KillerRed-3GB3-A ----\n",
      "FPBase (237 residues): MEGGPALFQSDMTFKIFIDGEVNGQKFTIVADGSSKFPHGDFNVHAVCETGKLPMSWKPICHLIQYGEPFFARYPDGISHFAQECFPEGLSIDRTVRFENDGTMTSHHTYELDDTCVVSRITVNCDGFQPDGPIMRDQLVDILPNETHMFPHGPNAVRQLAFIGFTTADGGLMMGHFDSKMTFNGSRAIEIPGPHFVTIITKQMRDTSDKRDHVCQREVAYAHSVPRITSAIGSDED\n",
      "\n",
      "FoldX (229 residues): EGGPALFQSDMTFKIFIDGEVNGQKFTIVADGSSKFPHGDFNVHAVCETGKLPMSWKPICHLIEPFFARYPDGISHFAQECFPEGLSIDRTVRFENDGTMTSHHTYELDDTCVVSRITVNCDGFQPDGPIMRDQLVDILPNETHMFPHGPNAVRQLAFIGFTTADGGLMMGHFDSKMTFNGSRAIEIPGPHFVTIITKQMRDTSDKRDHVCQREVAYAHSVPRITSAIG\n",
      "\n",
      "\n",
      "---- LSS-mKate1-3NT9-A ----\n",
      "FPBase (233 residues): MSELIKENMHMKLYMEGTVNNHHFKCTSEGEGKPYEGTQTMRIKVVEGGPLPFAFDILATSFMYGSYTFINHTQGIPDFFKQSFPEGFTWERVTTYEDGGVLTATQDTSLQDGCLIYNVKIRGVNFTSNGPVMQKKTLGWEAGTEMLYPADGGLEGRSDEALKLVGGGHLICNLKSTYRSKKPAKNLKVPGVYYVDRRLERIKEADKETYVEQHEVAVARYCDLPSKLGHKLN\n",
      "\n",
      "FoldX (223 residues): ELIKENMHMKLYMEGTVNNHHFKCTSEGEGKPYEGTQTMRIKVVEGGPLPFAFDILATSFSYTFINHTQGIPDFFKQSFPEGFTWERVTTYEDGGVLTATQDTSLQDGCLIYNVKIRGVNFTSNGPVMQKKTLGWEAGTEMLYPADGGLEGRSDEALKLVGGGHLICNLKSTYRSKKPAKNLKVPGVYYVDRRLERIKEADKETYVEQHEVAVARYCDLPSKL\n",
      "\n",
      "\n",
      "---- LSS-mKate2-3NT3-C ----\n",
      "FPBase (233 residues): MSELIKENMHMKLYMEGTVNNHHFKCTSEGEGKPYEGTQTMRIKVVEGGPLPFAFDILATSFMYGSYTFINHTQGIPDFFKQSFPEGFTWERVTTYEDGGVLTATQDTSLQDGCLIYNVKIRGVNFTSNGPVMQKKTLGWEAGTEMLYPADGGLEGRSDDALKLVGGGHLICNLKSTYRSKKPAKNLKVPGVYYVDRRLERIKEADKETYVEQHEVAVARYCDLPSKLGHKLN\n",
      "\n",
      "FoldX (224 residues): SELIKENMHMKLYMEGTVNNHHFKCTSEGEGKPYEGTQTMRIKVVEGGPLPFAFDILATSFSYTFINHTQGIPDFFKQSFPEGFTWERVTTYEDGGVLTATQDTSLQDGCLIYNVKIRGVNFTSNGPVMQKKTLGWEAGTEMLYPADGGLEGRSDDALKLVGGGHLICNLKSTYRSKKPAKNLKVPGVYYVDRRLERIKEADKETYVEQHEVAVARYCDLPSKL\n",
      "\n",
      "\n",
      "---- Neptune-3IP2-A ----\n",
      "FPBase (244 residues): MVSKGEELIKENMHMKLYMEGTVNNHHFKCTSEGEGKPYEGTQTGRIKVVEGGPLPFAFDILATCFMYGSKTFINHTQGIPDFFKQSFPEGFTWERVTTYEDGGVLTATQDTSLQDGCLIYNVKIRGVNFPSNGPVMQKKTLGWEASTEMLYPADGGLEGRCDMALKLVGGGHLICNLKTTYRSKKPAKNLKMPGVYFVDRRLERIKEADKETYVEQHEVAVARYCDLPSKLGHKLNGMDELYK\n",
      "\n",
      "FoldX (228 residues): EELIKEDMHMKLYMEGTVNNHHFKCTSEGEGKPYEGTQTGRIKVVEGGPLPFAFDILATCFSKTFINHTQGIPDFFKQSFPEGFTWERVTTYEDGGVLTATQDTSLQDGCLIYNVKIRGVNFPSNGPVMQKKTLGWEASTEMLYPADGGLEGRCDMALKLVGGGHLICNLKTTYRSKKPAKNLKMPGVYFVDRRLERIKEADNETYVEQHEVAVARYCDLPSKLGHKL\n",
      "\n",
      "\n",
      "---- PSmOrange (Far-red)-4Q7T-B ----\n",
      "FPBase (236 residues): MVSKGEENNMAIIKEFMRFKVRMEGTVNGHEFEIEGEGEGRPYEGFQTAKLKVTKGGPLPFAWDILSPLFTYGSKAYVKHPADIPDYFKLSFPEGFKWERVMNYEDGGVVTVTQDSSLQDGEFIYKVKMRGTNFPSDGPVMQKKTMGWEASSERMYPEDGALKGEIRMRLKLKDGGHYTSEVKTTYKAKKSVQLPGAYIVGIKLDITSHNEDYTIVEQYERAEGRHSTGGMDELYK\n",
      "\n",
      "FoldX (216 residues): AIIKEFMRFKVRMEGTVNGHEFEIEGEGEGRPYEGFQTAKLKVTKGGPLPFAWDILSPLSKAYVKHPADIPDYFKLSFPEGFKWERVMNYEDGGVVTVTQDSSLQDGEFIYKVKMRGTNFPSDGPVMQKKTMGWEASSERMYPEDGALKGEIRMRLKLKDGGHYTSEVKTTYKAKKSVQLPGAYIVGIKLDITSHNEDYTIVEQYERAEGRHSTGG\n",
      "\n",
      "\n",
      "---- PSmOrange2 (Far-red)-4Q7U-A ----\n",
      "FPBase (236 residues): MVSKGEENNMAIIKEFMRFKVHMEGTVNGHEFEIEGEGEGHPYEGFQTAKLKVTKGGPLPFAWDILSPLITYGSKAYVKHPADIPDYFKLSFPEGFKWERVMNYEDGGVVTVTQDSSLQDGEFIYKVKMRGTNFPSDGPVMQKKTMGWEASSERMYPEDGALKGEIRMRLKLKDGGHYTSEVKTTYKAKKSVLLPGAYIVGIKLDITSHNEDYTIVEQYERSEARHSTGGMDELYK\n",
      "\n",
      "FoldX (217 residues): AIIKEFMRFKVHMEGTVNGHEFEIEGEGEGHPYEGFQTAKLKVTKGGPLPFAWDILSPLSKAYVKHPADIPDYFKLSFPEGFKWERVMNYEDGGVVTVTQDSSLQDGEFIYKVKMRGTNFPSDGPVMQKKTMGWEASSERMYPEDGALKGEIRMRLKLKDGGHYTSEVKTTYKAKKSVLLPGAYIVGIKLDITSHNEDYTIVEQYERSEARHSTGGM\n",
      "\n",
      "\n",
      "---- RCaMP-3U0K-A ----\n",
      "FPBase (442 residues): MGSHHHHHHGMASMTGGQQMGRDLYDDDDKDLATMVDSSRRKWNKTGHAVRAIGRLSSAINTEMMYPADGGLRGYTHMALKVDGGGHLSCSFVTTYRSKKTVGNIKMPGIHYVSHRLERLEESDNEMFVVQREHAVAKFVGLGGGGGTGGSMNSLIKENMRMKVVLEGSVNGHQFKCTGEGEGNPYMGTQTMRIKVIEGGPLPFAFDILATSFMYGSRTFIKYPKGIPDFFKQSFPEGFTWERVTRYEDGGVITVMQDTSLEDGCLVYHAQVRGVNFPSNGAVMQKKTKGWEPTRDQLTEEQIAEFKEAFSLFDKDGDGTITTKELGTVMRSLGQNPTEAELQDMINEVDADGDGTIDFPEFLIMMARKMKDTDSEEEIREAFRVFDKDGNGYISAAELRHVMTNLGEKLTDEEVDEMIREADIDGDGQVNYEEFVQMMTAK\n",
      "\n",
      "FoldX (396 residues): MVDSSRRKWNKTGHAVRAIGRLSSAINTEMMYPADGGLRGYTHMALKVDGGGHLSCSFVTTYRSKKTVGNIKMPGIHYVSHRLERLEESDNEMFVVQREHAVAKFVGLGGGGGTGGSMNSLIKENMRMKVVLEGSVNGHQFKCTGEGEGNPYMGTQTMRIKVIEGGPLPFAFDILATSSRTFIKYPKGIPDFFKQSFPEGFTWERVTRYEDGGVITVMQDTSLEDGCLVYHAQVRGVNFPSNGAVMQKKTKGWEPTRDQLTEEQIAEFKEAFSLFDKDGDGTITTKELGTVMRSLGQNPTEAELQDMINEVDADGDGTIDFPEFLIMMARKEEEIREAFRVFDKDGNGYISAAELRHVMTNLGEKLTDEEVDEMIREADIDGDGQVNYEEFVQMMT\n",
      "\n",
      "\n",
      "---- RFP630-3E5V-A ----\n",
      "FPBase (231 residues): MNSLIKENMRMMVVMEGSVNGYQFKCTGEGDGNPYMGTQTMRIKVVEGGPLPFAFDILATSFMYGSKTFIKHTKGIPDFFKQSFPEGFTWERVTRYEDGGVFTVMQDTSLEDGCLVYHAKVTGVNFPSNGAVMQKKTKGWEPSTEMLYPADGGLRGYSQMALNVDGGGYLSCSFETTYRSKKTVENFKMPGFHFVDHRLERLEESDKEMFVVQHEHAVAKFCDLPSKLGRL\n",
      "\n",
      "FoldX (227 residues): MNSLIKENMRMMVVEGSVNGYQFKCTGEGDGNPYMGTQTMRIKVVEGGPLPFAFDILATSFSKTFIKHTKGIPDFFKQSFPEGFTWERVTRYEDGGVFTVMQDTSLEDGCLVYHAKVRGVNFPSNGAVMQKKTKGWEPSTEMLYPADGGLRGYSQMALNVDGGGYLSCSFETTYRSKKTVENFKMPGFHFVDHRLERLEESDKEMFVVQHEHAVAKFCDLPSKLGRL\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "---- Sandercyanin-5EZ2-A ----\n",
      "FPBase (170 residues): MFIKPGRCPKPAVQEDFDAARYLGVWYDIQRLPNKFQKGECATATYSLSPGVGFSVFNRERLANGTIKSVIGSAIAEDPCEPAKLQFFHENAAPVPYWVLSTDYDNYALVYSCINLGASHAAYASIVSRQPTLPEETIKKLQGTMSSFGVGVDTLLTTNQDAAYCSAMNQ\n",
      "\n",
      "FoldX (169 residues): MFIKPGRCPKPAVQEDFDAARYLGVWYDIQRLPNKFQKGECATATYSLSPGVGFSVFNRERLANGTIKSVIGSAIAEDPCEPAKLQFFHENAAPVPYWVLSTDYDNYALVYSCINLGASHAAYASIVSRQPTLPEETIKKLQGTMSSFGVGVDTLLTTNQDAAYCSAMN\n",
      "\n",
      "\n",
      "---- TagRFP-3M22-A ----\n",
      "FPBase (231 residues): MSELIKENMHMKLYMEGTVNNHHFKCTSEGEGKPYEGTQTMRIKVVEGGPLPFAFDILATSFMYGSRTFINHTQGIPDFFKQSFPEGFTWERVTTYEDGGVLTATQDTSLQDGCLIYNVKIRGVNFPSNGPVMQKKTLGWEANTEMLYPADGGLEGRSDMALKLVGGGHLICNFKTTYRSKKPAKNLKMPGVYYVDHRLERIKEADKETYVEQHEVAVARYCDLPSKLGHK\n",
      "\n",
      "FoldX (223 residues): ELIKENMHMKLYMEGTVNNHHFKCTSEGEGKPYEGTQTMRIKVVEGGPLPFAFDILATSFSRTFINHTQGIPDFFKQSFPEGFTWERVTTYEDGGVLTATQDTSLQDGCLIYNVKIRGVNFPSNGPVMQKKTLGWEANTEMLYPADGGLEGRSDMALKLVGGGHLICNFKTTYRSKKPAKNLKMPGVYYVDHRLERIKEADKETYVEQHEVAVARYCDLPSKL\n",
      "\n",
      "\n",
      "---- TagRFP-T-5JVA-A ----\n",
      "FPBase (244 residues): MVSKGEELIKENMHMKLYMEGTVNNHHFKCTSEGEGKPYEGTQTMRIKVVEGGPLPFAFDILATSFMYGSRTFINHTQGIPDFFKQSFPEGFTWERVTTYEDGGVLTATQDTSLQDGCLIYNVKIRGVNFPSNGPVMQKKTLGWEANTEMLYPADGGLEGRTDMALKLVGGGHLICNFKTTYRSKKPAKNLKMPGVYYVDHRLERIKEADKETYVEQHEVAVARYCDLPSKLGHKLNGMDELYK\n",
      "\n",
      "FoldX (225 residues): GEELIKENMHMKLYMEGTVNNHHFKCTSEGEGKPYEGTQTMRIKVVEGGPLPFAFDILATSFSRTFINHTQGIPDFFKQSFPEGFTWERVTTYEDGGVLTATQDTSLQDGCLIYNVKIRGVNFPSNGPVMQKKTLGWEANTEMLYPADGGLEGRTDMALKLVGGGHLICNFKTTYRSKKPAKNLKMPGVYYVDHRLERIKEADKETYVEQHEVAVARYCDLPSKL\n",
      "\n",
      "\n",
      "---- TagRFP675-4KGE-A ----\n",
      "FPBase (233 residues): MSELIKENMHMKLYMEGTVNNHHFKCTSEGEGKPYEGTQTQRIKVVEGGPLPFAFDILATSFMYGSKTFINHTQGIPDFWKQSFPEGFTWERVTTYEDGGVLTATQDTSLQDGCLIYNVKIRGVNFPSNGPVMQKKTLGWEANTEMMYPADGGLEGRNYMALKLVGGGHLICSLKTTYRSKKPAKNLKMPGVYYVDRRLERIKEADKETYVEQHEVAVARYCDLPSKLGHKLN\n",
      "\n",
      "FoldX (224 residues): ELIKENMHMKLYMEGTVNNHHFKCTSEGEGKPYEGTQTQRIKVVEGGPLPFAFDILATSFSKTFINHTQGIPDFWKQSFPEGFTWERVTTYEDGGVLTATQDTSLQDGCLIYNVKIRGVNFPSNGPVMQKKTLGWEANTEMMYPADGGLEGRNYMALKLVGGGHLICSLKTTYRSKKPAKNLKMPGVYYVDRRLERIKEADKETYVEQHEVAVARYCDLPSKLG\n",
      "\n",
      "\n",
      "---- Wi-Phy-3S7Q-A ----\n",
      "FPBase (335 residues): MASMTGGQQMGRGSMSRDPLPFFPPLYLGGPEITTENCEREPIHIPGSIQPHGALLTADGHSGEVLQMSLNAATFLGQEPTVLRGQTLAALLPEQWPALQAALPPGCPDALQYRATLDWPAAGHLSLTVHRVGELLILEFEPTEAWDSTGPHALRNAMSALESAPNLRALAEVATQTVRELTGFDRVMLYKFAPDATGEVIAEARREGLHAFLGHRFPASHIPAQARALYTRHLLRLTADTRAAAVPLDPVLNPQTNAPTPLGGAVLRATSPMHMQFLRNMGVGSSLSVSVVVGGQLWGLIACHHQTPYVLPPDLRTTLEYLGRELSEQVQVKEA\n",
      "\n",
      "FoldX (310 residues): PFFPPLYLGGPEITTENCEREPIHIPGSIQPHGALLTADGHSGEVLQMSLNAATFLGQEPTVLRGQTLAALLPEQWPALQAALPPGCPDALQYRATLDWPAAGHLSLTVHRVGELLILEFEPTEHALRNAMSALESAPNLRALAEVATQTVRELTGFDRVMLYKFAPDATGEVIAEARREGLHAFLGHRFPASHIPAQARALYTRHLLRLTADTRAAAVPLDPVLNPQTNAPTPLGGAVLRATSPMHMQFLRNMGVGSSLSVSVVVGGQLWGLIACHHQTPYVLPPDLRTTLEYLGRELSEQVQVKEALE\n",
      "\n",
      "\n",
      "---- asulCP-1XQM-A ----\n",
      "FPBase (232 residues): MASFLKKTMPFKTTIEGTVNGHYFKCTGKGEGNPFEGTQEMKIEVIEGGPLPFAFHILSTSCMYGSKTFIKYVSGIPDYFKQSFPEGFTWERTTTYEDGGFLTAHQDTSLDGDCLVYKVKILGNNFPADGPVMQNKAGRWEPATEIVYEVDGVLRGQSLMALKCPGGRHLTCHLHTTYRSKKPASALKMPGFHFEDHRIEIMEEVEKGKCYKQYEAAVGRYCDAAPSKLGHN\n",
      "\n",
      "FoldX (227 residues): SLLTETMPFKTTIEGTVNGHCFKCIGKGEGNPFEGTQEMKIEVIEGGPLPFAFHILSTSCSKTFIKYVSGIPDYFKQSFPEGFTWERTTTYEDGGFLTAHQDTSLDGDCLVYKVKILGNNFPADGPVMQNKVGRWEPGTEIVYEVDGVLRGQSLMALKCPGGRHLTCHLHTTYRSKKPASALKMPGFHFEDHRIEIMEEVEKGKCYKQYEAAVGRYCDAAPSKLGHN\n",
      "\n",
      "\n",
      "---- cp-mKate-3RWA-A ----\n",
      "FPBase (235 residues): GHLICNLKTTYRSKKPAKNLKMPGVYYVDRRLERIKEADKETYVEQHEVAVARYCDLPSKLGHAGGTGGSMSELITENMHMKLYMEGTVNNHHFKCTSEGEGKPYEGTQTMRIKVVEGGPLPFAFDILATSFMYGSKTFINHTQGIPDFFKQSFPEGFTWERVTTYEDGGVLTATQDTSLQDGCLIYNVKIRGVNFPSNGPVMQKKTLGWEASTEMLYPADGGLEGRSDMALKLV\n",
      "\n",
      "FoldX (232 residues): GHLICNLKTTYRSKKPAKNLKMPGVYYVDRRLERIKEADKETYVEQHEVAVARYCDLPSKLGHAGGTGGSMSELITENMHMKLYMEGTVNNHHFKCTSEGEGKPYEGTQTMRIKVVEGGPLPFAFDILATSFSKTFINHTQGIPDFFKQSFPEGFTWERVTTYEDGGVLTATQDTSLQDGCLIYNVKIRGVNFPSNGPVMQKKTLGWEASTEMLYPADGGLEGRSDMALKLV\n",
      "\n",
      "\n",
      "---- eqFP611-1UIS-A ----\n",
      "FPBase (231 residues): MNSLIKENMRMMVVMEGSVNGYQFKCTGEGDGNPYMGTQTMRIKVVEGGPLPFAFDILATSFMYGSKTFIKHTKGIPDFFKQSFPEGFTWERVTRYEDGGVFTVMQDTSLEDGCLVYHAKVTGVNFPSNGAVMQKKTKGWEPNTEMLYPADGGLRGYSQMALNVDGGGYLSCSFETTYRSKKTVENFKMPGFHFVDHRLERLEESDKEMFVVQHEHAVAKFCDLPSKLGRL\n",
      "\n",
      "FoldX (224 residues): IHMNSLIKENMRMMVVMEGSVNGYQFKCTGEGDGNPYMGTQTMRIKVVEGGPLPFAFDILATSFSKTFIKHTKGIPDFFKQSFPEGFTWERVTRYEDGGVFTVMQDTSLEDGCLVYHAKVTGVNFPSNGAVMQKKTKGWEPNTEMLYPADGGLRGYSQMALNVDGGGYLSCSFETTYRSKKTVENFKMPGFHFVDHRLERLEESDKEMFVVQHEHAVAKFCDLP\n",
      "\n",
      "\n",
      "---- eqFP650-4EDO-A ----\n",
      "FPBase (234 residues): MGEDSELISENMHMKLYMEGTVNGHHFKCTSEGEGKPYEGTQTAKIKVVEGGPLPFAFDILATSFMYGSKTFINHTQGIPDFFKQSFPEGFTWERITTYEDGGVLTATQDTSLQNGCLIYNVKINGVNFPSNGPVMQKKTLGWEASTEMLYPADSGLRGHSQMALKLVGGGYLHCSLKTTYRSKKPAKNLKMPGFYFVDRKLERIKEADKETYVEQHEMAVARYCDLPSKLGHS\n",
      "\n",
      "FoldX (218 residues): ELISENMHMKLYMEGTVNGHHFKCTSEGEGKPYEGTQTAKIKVVEGGPLPFAFDILATSFSKTFINHTQGIPDFFKQSFPEGFTWERITTYEDGGVLTATQDTSLQNGCLIYNVKINGVNFPSNGPVMQKKTLGWEASTEMLYPADSGLRGHSQMALKLVGGGYLHCSLKTTYRSKKPAKNLKMPGFYFVDRKLERIKEADKETYVEQHEMAVARYCD\n",
      "\n",
      "\n",
      "---- eqFP670-4EDS-A ----\n",
      "FPBase (234 residues): MGEDSELISENMHTKLYMEGTVNGHHFKCTSEGEGKPYEGTQTCKIKVVEGGPLPFAFDILATSFMYGSKTFINHTQGIPDFFKQSFPEGFTWERITTYEDGGVLTATQDTSLQNGCLIYNVKINGVNFPSNGPVMQKKTLGWEANTEMLYPADSGLRGHNQMALKLVGGGYLHCSLKTTYRSKKPAKNLKMPGFYFVDRKLERIKEADKETYVEQHEMAVARYCDLPSKLGHS\n",
      "\n",
      "FoldX (218 residues): ELISENMHTKLYMEGTVNGHHFKCTSEGEGKPYEGTQTCKIKVVEGGPLPFAFDILATSFSKTFINHTQGIPDFFKQSFPEGFTWERITTYEDGGVLTATQDTSLQNGCLIYNVKINGVNFPSNGPVMQKKTLGWEANTEMLYPADSGLRGHNQMALKLVGGGYLHCSLKTTYRSKKPAKNLKMPGFYFVDRKLERIKEADKETYVEQHEMAVARYCD\n",
      "\n",
      "\n",
      "---- iFP1.4-5AJG-A ----\n",
      "FPBase (321 residues): MARDPLPFFPPLYLGGPEITTENCEREPIHIPGSIQPHGALLTADGHSGEVLQVSLNAATFLGQEPTVLRGQTLAALLPEQWPALQAALPPGCPDALQYRATLDWPAAGHLSLTVHRVAELLILEFEPTEAWDSIGPHALRNAMFALESAPNLRALAEVATQTVRELTGFDRVMLYKFAPDATGEMIAEARREGMQAFLGHRFPASHTPAQARALYTRHLLRLTADTRAAAVPLDPVLNPQTNAPTPLGGAVLRATSPMHMQYLRNMGVGSSLSVSVVVGGQLWGLIVCHHQTPYVLPPDLRTTLEELGRKLSGQVQRKEA\n",
      "\n",
      "FoldX (301 residues): LPFFPPLYLGGPEITTENCEREPIHIPGSIQPHGALLTADGHSGEVLQVSLNAATFLGQEPTVLRGQTLAALLPEQWPALQAALLQYRATLDWPAAGHLSLTVHRVAELLILEFEPTHALRNAMFALESAPNLRALAEVATQTVRELTGFDRVMLYKFAPDATGEMIAEARREGMQAFLGHRFPASHTPAQARALYTRHLLRLTADTRAAAVPLDPVLNPQTNAPTPLGGAVLRATSPMHMQYLRNMGVGSSLSVSVVVGGQLWGLIVCHHQTPYVLPPDLRTTLEYLGRKLSGQVQRKEA\n",
      "\n",
      "\n",
      "---- iFP2.0-4CQH-A ----\n",
      "FPBase (321 residues): MARDPQPFFPPLYLGGPEITTENCEREPIHIPGSIQPHGALLTADGHSGEVLQVSLNAATFLGQEPTVLRGQTLAALLPDQWPALQTALPPGCQDALQYRATLDWPAAGHLSLTVHRVAELLILEFEPTEAWDSIGPHALRNAMFALESAPNLRALAEVATQTVRELSGFDRVMLYKFAPDATGEVIAEARREGMQAYLGHRFPASTTPAQARALYTRHLLRLTADTRAAAVPLDPVLNPQTNAPTPLGGAVLRATSPMHMQYLRNMGVGSSLSVSVVVGGQLWGLIVCHHQTPYVLPPDLRTTLEYLGRLLSLQVQRKEA\n",
      "\n",
      "FoldX (306 residues): PFFPPLYLGGPEITTENCEREPIHIPGSIQPHGALLTADGHSGEVLQVSLNAATFLGQEPTVLRGQTLAALLPDQWPALQTALPPGCQDALQYRATLDWPAAGHLSLTVHRVAELLILEFEPTHALRNAMFALESAPNLRALAEVATQTVRELSGFDRVMLYKFAPDATGEVIAEARREGMQAYLGHRFPASTTPAQARALYTRHLLRLTADTRAAAVPLDPVLNPQTNAPTPLGGAVLRATSPMHMQYLRNMGVGSSLSVSVVVGGQLWGLIVCHHQTPYVLPPDLRTTLEYLGRLLSLQVQRKE\n",
      "\n",
      "\n",
      "---- laRFP-4JF9-B ----\n",
      "FPBase (228 residues): MHHHHHHGSPLPATHDLHISGSINGHEFDLEGSGKGNAKEGYQELHLKSNKGDLSFSPWILVPNIGYGFYQYLPFPDGAMSPYQAAMHDGSGYVMHRSMQFEDGAMLHSDHRYIYKGNHIKGEFRLTGSGFPADGPVMTNSLTAADWCVDKLLYPNDNTIIGKFDWTYTTTSGKRYQSDVQTNVTFGKPIAADILKKQPMFVFRKVELKHTKTELNFKQWQKAFQDIA\n",
      "\n",
      "FoldX (217 residues): SPLPATHDLHISGSINGHEFDLEGSGKGNAKEGYQELHLKSNKGDLSFSPWILVPNIFYQYLPFPDGAMSPYQAAMHDGSGYVMHRSMQFEDGAMLHSDHRYIYKGNHIKGEFRLTGSGFPADGPVMTNSLTAADWCVDKLLYPNDNTIIGKFDWTYTTTSGKRYQSDVQTNVTFGKPIAADILKKQPMFVFRKVELKHTKTELNFKQWQKAFQDIA\n",
      "\n",
      "\n",
      "---- mCRISPRed-6XWY-A ----\n",
      "FPBase (237 residues): MVSKGEELIKENMRMKVVMEGSVNGHQFKCTGEGEGRPYEGVQTMRIKVIEGGPLPFAFDILATSFMYGSRTFIKYPADIPDFFKQSFPEGFTWERVTRYEDGGVVTVTQDTSLEDGELVYNVKVRGVNFPSNGPVMQKKTKGWEADTEMMYPADGGLRGYLDRALKVDGGGHLHCNFVTTYRSKKTVGDIKMPGVHAVDHRLERIEESDNETYVVQREVAVAKYSNLGGGMDELYK\n",
      "\n",
      "FoldX (217 residues): PLIKENMRMKVVMEGSVNGHQFKCTGEGEGRPYEGVQTMRIKVIEGGPLPFAFDILATSFSRTFIKYPADIPDFFKQSFPEGFTWERVTRYEDGGVVTVTQDTSLEDGELVYNVKVRGVNFPSNGPVMQKKTKGWEADTEMMYPADGGLRGYLDRALKVDGGGHLHCNFVTTYRSKKTVGDIKMPGVHAVDHRLERIEESDNETYVVQREVAVAKYS\n",
      "\n",
      "\n",
      "---- mCardinal-4OQW-A ----\n",
      "FPBase (244 residues): MVSKGEELIKENMHMKLYMEGTVNNHHFKCTTEGEGKPYEGTQTQRIKVVEGGPLPFAFDILATCFMYGSKTFINHTQGIPDFFKQSFPEGFTWERVTTYEDGGVLTVTQDTSLQDGCLIYNVKLRGVNFPSNGPVMQKKTLGWEATTETLYPADGGLEGRCDMALKLVGGGHLHCNLKTTYRSKKPAKNLKMPGVYFVDRRLERIKEADNETYVEQHEVAVARYCDLPSKLGHKLNGMDELYK\n",
      "\n",
      "FoldX (225 residues): GEELIKENMHMKLYMEGTVNNHHFKCTTEGEGKPYEGTQTQRIKVVEGGPLPFAFDILATCFSKTFINHTQGIPDFFKQSFPEGFTWERVTTYEDGGVLTVTQDTSLQDGCLIYNVKLRGVNFPSNGPVMQKKTLGWEATTETLYPADGGLEGRCDMALXLVGGGHLHCNLKTTYRSXKPAKNLKMPGVYFVDRRLERIKEADNETYVEQHEVAVARYCDLPSKL\n",
      "\n",
      "\n",
      "---- mCherry-2H5Q-A ----\n",
      "FPBase (236 residues): MVSKGEEDNMAIIKEFMRFKVHMEGSVNGHEFEIEGEGEGRPYEGTQTAKLKVTKGGPLPFAWDILSPQFMYGSKAYVKHPADIPDYLKLSFPEGFKWERVMNFEDGGVVTVTQDSSLQDGEFIYKVKLRGTNFPSDGPVMQKKTMGWEASSERMYPEDGALKGEIKQRLKLKDGGHYDAEVKTTYKAKKPVQLPGAYNVNIKLDITSHNEDYTIVEQYERAEGRHSTGGMDELYK\n",
      "\n",
      "FoldX (217 residues): NMAIIKEFMRFKVHMEGSVNGHEFEIEGEGEGRPYEGTQTAKLKVTKGGPLPFAWDILSPQFSKAYVKHPADIPDYLKLSFPEGFKWERVMNFEDGGVVTVTQDSSLQDGEFIYKVKLRGTNFPSDGPVMQKKTMGWEASSERMYPEDGALKGEIKQRLKLKDGGHYDAEVKTTYKAKKPVQLPGAYNVNIKLDITSHNEDYTIVEQYERAEGRHST\n",
      "\n",
      "\n",
      "---- mEos2 (Red)-3S05-B ----\n",
      "FPBase (226 residues): MSAIKPDMKIKLRMEGNVNGHHFVIDGDGTGKPFEGKQSMDLEVKEGGPLPFAFDILTTAFHYGNRVFAKYPDNIQDYFKQSFPKGYSWERSLTFEDGGICIARNDITMEGDTFYNKVRFYGTNFPANGPVMQKKTLKWEPSTEKMYVRDGVLTGDIHMALLLEGNAHYRCDFRTTYKAKEKGVKLPGYHFVDHCIEILSHDKDYNKVKLYEHAVAHSGLPDNARR\n",
      "\n",
      "FoldX (221 residues): MSAIKPDMKIKLRMEGNVNGHHFVIDGDGTGKPFEGKQSMDLEVKEGGPLPFAFDILTTAFNRVFAKYPDNIQDYFKQSFPKGYSWERSLTFEDGGICIARNDITMEGDTFYNKVRFYGTNFPANGPVMQKKTLKWEPSTEKMYVRDGVLTGDIHMALLLEGNAHYRCDFRTTYKAKEKGVKLPGYHFVDHCIEILSHDKDYNKVKLYEHAVAHSGLPDNA\n",
      "\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\n",
      "---- mEos2-A69T (Orange)-5DTL-A ----\n",
      "FPBase (226 residues): MSAIKPDMKIKLRMEGNVNGHHFVIDGDGTGKPFEGKQSMDLEVKEGGPLPFAFDILTTAFHYGNRVFTKYPDNIQDYFKQSFPKGYSWERSLTFEDGGICIARNDITMEGDTFYNKVRFYGTNFPANGPVMQKKTLKWEPSTEKMYVRDGVLTGDIHMALLLEGNAHYRCDFRTTYKAKEKGVKLPGYHFVDHCIEILSHDKDYNKVKLYEHAVAHSGLPDNARR\n",
      "\n",
      "FoldX (219 residues): SAIKPDMKIKLRMEGNVNGHHFVIDGDGTGKPFEGKQSMDLEVKEGGPLPFAFDILTTAFNRVFTKYPDNIQDYFKQSFPKGYSWERSLTFEDGGICIARNDITMEGDTFYNKVRFYGTNFPANGPVMQKKTLKWEPSTEKMYVRDGVLTGDIHMALLLEGNAHYRCDFRTTYKAKEKGVKLPGYHFVDHCIEILSHDKDYNKVKLYEHAVAHSGLPDN\n",
      "\n",
      "\n",
      "---- mEosFP (Red)-3P8U-C ----\n",
      "FPBase (226 residues): MSAIKPDMKINLRMEGNVNGHHFVIDGDGTGKPFEGKQSMDLEVKEGGPLPFAFDILTTAFHYGNRVFAEYPDHIQDYFKQSFPKGYSWERSLTFEDGGICIARNDITMEGDTFYNKVRFHGTNFPANGPVMQKKTLKWEPSTEKMYVRDGVLTGDIHMALLLEGNAHYRCDFRTTYKAKEKGVKLPGYHFVDHCIEILSHDKDYNKVKLYEHAVAHSGLPDNARR\n",
      "\n",
      "FoldX (222 residues): HHMSAIKPDMKINLRMEGNVNGHHFVIDGDGTGKPFEGKQSMDLEVKEGGPLPFAFDILTTAFNRVFAEYPDHIQDYFKQSFPKGYSWERSLTFEDGGICIARNDITMEGDTFYNKVRFHGTNFPANGPVMQKKTLKWEPSTEKMYVRDGVLTGDIHMALLLEGNAHYRCDFRTTYKAKEKGVKLPGYHFVDHCIEILSHDKDYNKVKLYEHAVAHSGLPDN\n",
      "\n",
      "\n",
      "---- mKate-3BXA-A ----\n",
      "FPBase (231 residues): MSELIKENMHMKLYMEGTVNNHHFKCTSEGEGKPYEGTQTMRIKVVEGGPLPFAFDILATSFMYGSKTFINHTQGIPDFFKQSFPEGFTWERVTTYEDGGVLTATQDTSLQDGCLIYNVKIRGVNFPSNGPVMQKKTLGWEASTEMLYPADGGLEGRSDMALKLVGGGHLICNLKTTYRSKKPAKNLKMPGVYYVDRRLERIKEADKETYVEQHEVAVARYCDLPSKLGHK\n",
      "\n",
      "FoldX (223 residues): ELITENMHMKLYMEGTVNNHHFKCTSEGEGKPYEGTQTMRIKVVEGGPLPFAFDILATSFSKTFINHTQGIPDFFKQSFPEGFTWERVTTYEDGGVLTATQDTSLQDGCLIYNVKIRGVNFPSNGPVMQKKTLGWEASTEMLYPADGGLEGRSDMALKLVGGGHLICNLKTTYRSKKPAKNLKMPGVYYVDRRLERIKEADKETYVEQHEVAVARYCDLPSKL\n",
      "\n",
      "\n",
      "---- mPlum-2QLG-B ----\n",
      "FPBase (226 residues): MVSKGEEVIKEFMRFKEHMEGSVNGHEFEIEGEGEGRPYEGTQTARLKVTKGGPLPFAWDILSPQIMYGSKAYVKHPADIPDYLKLSFPEGFKWERVMNFEDGGVVTVTQDSSLQDGEFIYKVKVRGTNFPSDGPVMQKKTMGWEASSERMYPEDGALKGEMKMRLRLKDGGHYDAEVKTTYMAKKPVQLPGAYKTDIKLDITSHNEDYTIVEQYERAEGRHSTGA\n",
      "\n",
      "FoldX (216 residues): EVIKEFMRFKEHMEGSVNGHEFEIEGEGEGRPYEGTQTARLKVTKGGPLPFAWDILSPQISKAYVKHPADIPDYLKLSFPEGFKWERVMNFEDGGVVTVTQDSSLQDGEFIYKVKVRGTNFPSDGPVMQKKTMGWEASSERMYPEDGALKGEMKMRLRLKDGGHYDAEVKTTYMAKKPVQLPGAYKTDIKLDITSHNEDYTIVEQYERAEGRHSTG\n",
      "\n",
      "\n",
      "---- mPlum-E16P-4H3L-A ----\n",
      "FPBase (226 residues): MVSKGEEVIKEFMRFKPHMEGSVNGHEFEIEGEGEGRPYEGTQTARLKVTKGGPLPFAWDILSPQIMYGSKAYVKHPADIPDYLKLSFPEGFKWERVMNFEDGGVVTVTQDSSLQDGEFIYKVKVRGTNFPSDGPVMQKKTMGWEASSERMYPEDGALKGEMKMRLRLKDGGHYDAEVKTTYMAKKPVQLPGAYKTDIKLDITSHNEDYTIVEQYERAEGRHSTGA\n",
      "\n",
      "FoldX (213 residues): VIKEFMRFKPHMEGSVNGHEFEIEGEGEGRPYEGTQTARLKVTKGGPLPFAWDILSPQISKAYVKHPADIPDYLKLSFPEGFKWERVMNFEDGGVVTVTQDSSLQDGEFIYKVKVRGTNFPSDGPVMQKKTMGWEASSERMYPEDGALKGEMKMRLRLKDGGHYDAEVKTTYMAKKPVQLPGAYKTDIKLDITSHNEDYTIVEQYERAEGRHS\n",
      "\n",
      "\n",
      "---- mRojoA-3NEZ-A ----\n",
      "FPBase (236 residues): MVSKGEEDNMAIIKEFMRFKTHMEGSVNGHEFEIEGEGEGRPYEGTQTAKLKVTKGGPLPFAWDILSPQFMYGSKAYVKHPADIPDYLKLSFPEGFKWERVMNFEDGGVVTVTQDSSLQDGEFIYKVKLHGTNFPSDGPVMQKKTMGWEASSERMYPEDGALKGEIKLRLKLKDGGHYDAEVKTTYKAKKPVQLPGAYNANYKLDITSHNEDYTIVEQYERCEGRHSTGGMDELYK\n",
      "\n",
      "FoldX (215 residues): MAIIKEFMRFKTHMEGSVNGHEFEIEGEGEGRPYEGTQTAKLKVTKGGPLPFAWDILSPQFSKAYVKHPADIPDYLKLSFPEGFKWERVMNFEDGGVVTVTQDSSLQDGEFIYKVKLHGTNFPSDGPVMQKKTMGWEASSERMYPEDGALKGEIKLRLKLKDGGHYDAEVKTTYKAKKPVQLPGAYNANYKLDITSHNEDYTIVEQYERCEGRHS\n",
      "\n",
      "\n",
      "---- mRouge-3NED-A ----\n",
      "FPBase (236 residues): MVSKGEEDNMAIIKEFMRFKTHMEGSVNGHEFEIEGEGEGRPYEGTQTAKLKVTKGGPLPFAWDILSPQFMYGSKAYVKHPADIPDYLKLSFPEGFKWERVMNFEDGGVVTVTQDSSLQDGEFIYKVKLRGTNFPSDGPVMQKKTMGWEACSERMYPEDGALKGEMKMRLKLKDGGHYDAEVKTTYKAKKPVQLPGAYNTNTKLDITSHNEDYTIVEQYERNEGRHSTGGMDELYK\n",
      "\n",
      "FoldX (228 residues): EEDNMAIIKEFMRFKTHMEGSVNGHEFEIEGEGEGRPYEGTQTAKLKVTKGGPLPFAWDILSPQFSKAYVKHPADIPDYLKLSFPEGFKWERVMNFEDGGVVTVTQDSSLQDGEFIYKVKLRGTNFPSDGPVMQKKTMGWEACSERMYPEDGALKGEMKMRLKLKDGGHYDAEVKTTYKAKKPVQLPGAYNTNTKLDITSHNEDYTIVEQYERNEGRHSTGGMDELYK\n",
      "\n",
      "\n",
      "---- mRuby-3U0L-A ----\n",
      "FPBase (227 residues): MNSLIKENMRMKVVLEGSVNGHQFKCTGEGEGNPYMGTQTMRIKVIEGGPLPFAFDILATSFMYGSRTFIKYPKGIPDFFKQSFPEGFTWERVTRYEDGGVITVMQDTSLEDGCLVYHAQVRGVNFPSNGAVMQKKTKGWEPNTEMMYPADGGLRGYTHMALKVDGGGHLSCSFVTTYRSKKTVGNIKMPGIHAVDHRLERLEESDNEMFVVQREHAVAKFAGLGGG\n",
      "\n",
      "FoldX (216 residues): SLIKENMRMKVVLEGSVNGHQFKCTGEGEGNPYMGTQTMRIKVIEGGPLPFAFDILATSFSRTFIKYPKGIPDFFKQSFPEGFTWERVTRYEDGGVITVMQDTSLEDGCLVYHAQVRGVNFPSNGAVMQKKTKGWEPNTEMMYPADGGLRGYTHMALKVDGGGHLSCSFVTTYRSKKTVGNIKMPGIHAVSHRLERLEESDNEMFVVQREHAVAKF\n",
      "\n",
      "\n",
      "---- mScarlet-5LK4-A ----\n",
      "FPBase (232 residues): MVSKGEAVIKEFMRFKVHMEGSMNGHEFEIEGEGEGRPYEGTQTAKLKVTKGGPLPFSWDILSPQFMYGSRAFTKHPADIPDYYKQSFPEGFKWERVMNFEDGGAVTVTQDTSLEDGTLIYKVKLRGTNFPPDGPVMQKKTMGWEASTERLYPEDGVLKGDIKMALRLKDGGRYLADFKTTYKAKKPVQMPGAYNVDRKLDITSHNEDYTVVEQYERSEGRHSTGGMDELYK\n",
      "\n",
      "FoldX (216 residues): AVIKEFMRFKVHMEGSMNGHEFEIEGEGEGRPYEGTQTAKLKVTKGGPLPFSWDILSPQFSRAFTKHPADIPDYYKQSFPEGFKWERVMNFEDGGAVTVTQDTSLEDGTLIYKVKLRGTNFPPDGPVMQKKTMGWEASTERLYPEDGVLKGDIKMALRLKDGGRYLADFKTTYKAKKPVQMPGAYNVDRKLDITSHNEDYTVVEQYERSEGRHSTG\n",
      "\n",
      "\n",
      "---- mStrawberry-2H5R-A ----\n",
      "FPBase (236 residues): MVSKGEENNMAIIKEFMRFKVRMEGSVNGHEFEIEGEGEGRPYEGTQTAKLKVTKGGPLPFAWDILTPNFTYGSKAYVKHPADIPDYLKLSFPEGFKWERVMNFEDGGVVTVTQDSSLQDGEFIYKVKLRGTNFPSDGPVMQKKTMGWEASSERMYPEDGALKGEIKMRLKLKDGGHYDAEVKTTYKAKKPVQLPGAYIVGIKLDITSHNEDYTIVELYERAEGRHSTGGMDELYK\n",
      "\n",
      "FoldX (222 residues): AIIKEFMRFKVRMEGSVNGHEFEIEGEGEGRPYEGTQTAKLKVTKGGPLPFAWDILTPNFSKAYVKHPADIPDYLKLSFPEGFKWERVMNFEDGGVVTVTQDSSLQDGEFIYKVKLRGTMFPSDGPVMQKKTMGWEASSERMYPEDGALKGEIKMRLKLKDGGHYDAEVKTTYKAKKPVQLPGAYIVGIKLDITSHNEDYTIVELYERAEGRHSTGGMDELY\n",
      "\n",
      "\n",
      "---- miRFP670nano-6MGH-D ----\n",
      "FPBase (147 residues): MANLDKMLNTTVTEVRQFLQVDRVCVFQFEEDYSGVVVVEAVDDRWISILKTQVRDRYFMETRGEEYSHGRYQAIADIYTANLTECYRDLLTQFQVRAILAVPILQGKKLWGLLVAHQLAAPRQWQTWEIDFLKQQAVVVGIAIQQS\n",
      "\n",
      "FoldX (152 residues): SAAGTMANLDKMLNTTVTEVRQFLQVDRVCVFQFEEDYSGVVVVEAVDDRWISILKTQVRDRYFMETRGEEYSHGRYQAIADIYTANLTECYRDLLTQFQVRAILAVPILQGKKLWGLLVAHQLAAPRQWQTWEIDFLKQQAVVVGIAIQQS\n",
      "\n",
      "\n",
      "---- pcDronpa (Red)-4HQ8-A ----\n",
      "FPBase (224 residues): MSVIKPDMKIKLRMEGAVNGHPFAIEGVGLGKPFEGKQSMDLKVKEGGPLPFAYDILTTAFHYGNRVFAKYPENIVDYFKQSFPEGYSWERSMSYEDGGICIATNDITLDGDCYIYEIRFDGVNFPANGPVMQKRTVKWEPSTEKLYVRDGVLKGDVNMALSLEGGGHYRCDFKTTYKAKKVVQLPDYHFVDHHIEIKSHDKDYSNVNLHEHAEAHSGLPRQAK\n",
      "\n",
      "FoldX (217 residues): SVIKPDMKIKLRMEGAVNGHPFAIEGVGLGKPFEGKQSMDLKVKEGGPLPFAYDILTTAFNRVFAKYPENIVDYFKQSFPEGYSWERSMSYEDGGICIATNDITLDGDCYIYEIRFDGVNFPANGPVMQKRTVKWEPSTEKLYVRDGVLKGDVNMALSLEGGGHYRCDFKTTYKAKKVVQLPDYHFVDHHIEIKSHDKDYSNVNLHEHAEAHSGLPR\n",
      "\n",
      "\n",
      "---- rsTagRFP (ON)-3U8C-A ----\n",
      "FPBase (237 residues): MVSKGEELIKENMHMKLYMEGTVNNHHFKCTSEGEGKPYEGTQTMRIKVVEGGPLPFAFDILATSFMYGSRTFINHTQGIPDFWKQSFPEGFTWERVTTYEDGGVLTATQDTSLQDGCLIYNVKLRGVNFPSNGPVMQKKTLGWEAATEMLYPADGGLEGRGDMALKLVGGGHLICNLKTTYRSKNPAKNLKMPGVYFVDHRLERIKEADKETYVEQHEVAVARYCDLPSKLGHKLN\n",
      "\n",
      "FoldX (223 residues): ELIKENMHMKLYMEGTVNNHHFKCTSEGEGKPYEGTQTMRIKVVEGGPLPFAFDILATSFSRTFINHTQGIPDFWKQSFPEGFTWERVTTYEDGGVLTATQDTSLQDGCLIYNVKLRGVNFPSNGPVMQKKTLGWEAATEMLYPADGGLEGRGDMALKLVGGGHLICNLKTTYRSKNPAKNLKMPGVYFVDHRLERIKEADKETYVEQHEVAVARYCDLPSKL\n",
      "\n",
      "\n",
      "---- smURFP-6FZN-A ----\n",
      "FPBase (133 residues): MAKTSEQRVNIATLLTENKKKIVDKASQDLWRRHPDLIAPGGIAFSQRDRALCLRDYGWFLHLITFCLLAGDKGPIESIGLISIREMYNSLGVPVPAMMESIRCLKEASLSLLDEEDANETAPYFDYIIKAMS\n",
      "\n",
      "FoldX (132 residues): KTSEQRVNIATLLTENKKKIVDKASQDLWRRHPDLIAPGGIAFSQRDRALCLRDRGWFLHLITFCLLAGDKGPIESIGLISIREMYNSLVPAMMESIRCLKEASLSLLDEEDANETAPYFDYIIKAMSHHHH\n",
      "\n"
     ]
    }
   ],
   "source": [
    "for row_idx, datum in rfp_known_structures.iterrows():\n",
    "    fpbase_seq = datum.fpbase_seq\n",
    "    \n",
    "    pdb_path = f'../lambo/assets/pdb/pdb{datum.pdb_id.lower()}.ent'\n",
    "    rcsb_seq, _ = pdb_to_residues(pdb_path, datum.longest_chain)\n",
    "    rcsb_seq = rcsb_seq.replace('X', '')\n",
    "    \n",
    "    pdb_path = f'../lambo/assets/foldx/{datum.pdb_id.lower()}_{datum.longest_chain}/wt_input_Repair.pdb'\n",
    "    foldx_seq, _ = pdb_to_residues(pdb_path, datum.longest_chain)\n",
    "    rfp_known_structures.loc[row_idx, 'foldx_seq'] = str(foldx_seq)\n",
    "    \n",
    "    print(f'\\n---- {datum.Name}-{datum.pdb_id}-{datum.longest_chain} ----')\n",
    "    print(f'FPBase ({len(fpbase_seq)} residues): {fpbase_seq}\\n')\n",
    "    print(f'FoldX ({len(foldx_seq)} residues): {foldx_seq}\\n')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "authorized-display",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 576x360 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(8, 5))\n",
    "ax = fig.add_subplot(1, 1, 1)\n",
    "\n",
    "plt.hist(rfp_known_structures.fpbase_seq.apply(lambda seq: len(seq)), label='FPBase',\n",
    "         zorder=1, bins=4)\n",
    "plt.hist(rfp_known_structures.foldx_seq.apply(lambda seq: len(seq)), label='FoldX',\n",
    "         alpha=0.6, zorder=2, bins=4)\n",
    "plt.xticks(rotation='15')\n",
    "ax.legend()\n",
    "ax.set_xlabel('# residues')\n",
    "ax.set_ylabel('count')\n",
    "ax.set_title('RFP sequences w/ known structure')\n",
    "plt.tight_layout()\n",
    "# plt.savefig('./figures/rfp_known_structures_seq_len_plot.pdf')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "anonymous-question",
   "metadata": {},
   "source": [
    "## Estimate total energy and SASA"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "improving-praise",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "---- AdRed-A ----\n",
      "stability: 39.8155\n",
      "surface area: 11189.00587945787\n",
      "\n",
      "---- DrCBD-A ----\n",
      "stability: -15.2839\n",
      "surface area: 14996.217369270882\n",
      "\n",
      "---- DsRed-A ----\n",
      "stability: 42.7597\n",
      "surface area: 10620.198764571534\n",
      "\n",
      "---- DsRed-Max-B ----\n",
      "stability: 26.73\n",
      "surface area: 10688.863449360433\n",
      "\n",
      "---- DsRed.M1-A ----\n",
      "stability: 71.4708\n",
      "surface area: 10374.487803665845\n",
      "\n",
      "---- DsRed.T4-A ----\n",
      "stability: 55.6143\n",
      "surface area: 10820.911361864575\n",
      "\n",
      "---- HcRed-A ----\n",
      "stability: 21.6813\n",
      "surface area: 10652.483894396457\n",
      "\n",
      "---- HcRed7-A ----\n",
      "stability: 15.5598\n",
      "surface area: 11192.017485573826\n",
      "\n",
      "---- IrisFP (Orange)-C ----\n",
      "stability: 27.9424\n",
      "surface area: 10900.521355458579\n",
      "\n",
      "---- Katushka-A ----\n",
      "stability: 31.9418\n",
      "surface area: 10636.995603853218\n",
      "\n",
      "---- KikGR1 (Red)-A ----\n",
      "stability: 24.2531\n",
      "surface area: 11160.594798330538\n",
      "\n",
      "---- KillerRed-A ----\n",
      "stability: 2.43349\n",
      "surface area: 11227.42559725746\n",
      "\n",
      "---- LSS-mKate1-A ----\n",
      "stability: 8.37683\n",
      "surface area: 11052.782023768505\n",
      "\n",
      "---- LSS-mKate2-C ----\n",
      "stability: 16.7079\n",
      "surface area: 11019.136559191835\n",
      "\n",
      "---- Neptune-A ----\n",
      "stability: 0.645142\n",
      "surface area: 11232.097987480178\n",
      "\n",
      "---- PSmOrange (Far-red)-B ----\n",
      "stability: 19.711\n",
      "surface area: 10885.430840810766\n",
      "\n",
      "---- PSmOrange2 (Far-red)-A ----\n",
      "stability: 48.8253\n",
      "surface area: 10601.949051784903\n",
      "\n",
      "---- RCaMP-A ----\n",
      "stability: -19.0144\n",
      "surface area: 18901.558164379694\n",
      "\n",
      "---- RFP630-A ----\n",
      "stability: -29.6978\n",
      "surface area: 11558.627625771045\n",
      "\n",
      "---- Sandercyanin-A ----\n",
      "stability: 8.77335\n",
      "surface area: 9306.655760888065\n",
      "\n",
      "---- TagRFP-A ----\n",
      "stability: -20.094\n",
      "surface area: 11085.721786104212\n",
      "\n",
      "---- TagRFP-T-A ----\n",
      "stability: 18.4644\n",
      "surface area: 10979.47307229432\n",
      "\n",
      "---- TagRFP675-A ----\n",
      "stability: 0.552243\n",
      "surface area: 10951.373096804287\n",
      "\n",
      "---- Wi-Phy-A ----\n",
      "stability: 55.0519\n",
      "surface area: 14477.743004623882\n",
      "\n",
      "---- asulCP-A ----\n",
      "stability: 7.8855\n",
      "surface area: 10837.722174950379\n",
      "\n",
      "---- cp-mKate-A ----\n",
      "stability: 10.4719\n",
      "surface area: 11212.517659408302\n",
      "\n",
      "---- eqFP611-A ----\n",
      "stability: -4.58788\n",
      "surface area: 10861.83917644234\n",
      "\n",
      "---- eqFP650-A ----\n",
      "stability: 21.8716\n",
      "surface area: 10068.947661114807\n",
      "\n",
      "---- eqFP670-A ----\n",
      "stability: 18.0918\n",
      "surface area: 10228.785762940597\n",
      "\n",
      "---- iFP1.4-A ----\n",
      "stability: 56.5245\n",
      "surface area: 14216.2696178\n",
      "\n",
      "---- iFP2.0-A ----\n",
      "stability: 48.796\n",
      "surface area: 14511.916696589324\n",
      "\n",
      "---- laRFP-B ----\n",
      "stability: 19.391\n",
      "surface area: 10095.73359636244\n",
      "\n",
      "---- mCRISPRed-A ----\n",
      "stability: 29.2803\n",
      "surface area: 10534.905692699042\n",
      "\n",
      "---- mCardinal-A ----\n",
      "stability: -3.6588\n",
      "surface area: 11126.950502426336\n",
      "\n",
      "---- mCherry-A ----\n",
      "stability: 52.9056\n",
      "surface area: 10438.681599984826\n",
      "\n",
      "---- mEos2 (Red)-B ----\n",
      "stability: 34.5908\n",
      "surface area: 10888.10637191101\n",
      "\n",
      "---- mEos2-A69T (Orange)-A ----\n",
      "stability: 35.4954\n",
      "surface area: 10918.826636736068\n",
      "\n",
      "---- mEosFP (Red)-C ----\n",
      "stability: 10.9213\n",
      "surface area: 10962.984347853731\n",
      "\n",
      "---- mKate-A ----\n",
      "stability: 24.6321\n",
      "surface area: 10846.729435247486\n",
      "\n",
      "---- mPlum-B ----\n",
      "stability: 14.1378\n",
      "surface area: 10470.561200463651\n",
      "\n",
      "---- mPlum-E16P-A ----\n",
      "stability: 32.1073\n",
      "surface area: 10082.31531378502\n",
      "\n",
      "---- mRojoA-A ----\n",
      "stability: 35.4368\n",
      "surface area: 10522.74796789069\n",
      "\n",
      "---- mRouge-A ----\n",
      "stability: 27.9617\n",
      "surface area: 11462.557420831374\n",
      "\n",
      "---- mRuby-A ----\n",
      "stability: 26.3238\n",
      "surface area: 10244.621174339316\n",
      "\n",
      "---- mScarlet-A ----\n",
      "stability: 61.8757\n",
      "surface area: 10591.87684184371\n",
      "\n",
      "---- mStrawberry-A ----\n",
      "stability: 34.8595\n",
      "surface area: 10995.838872497563\n",
      "\n",
      "---- miRFP670nano-D ----\n",
      "stability: 38.1018\n",
      "surface area: 8405.448891572149\n",
      "\n",
      "---- pcDronpa (Red)-A ----\n",
      "stability: 35.1194\n",
      "surface area: 10407.111760541642\n",
      "\n",
      "---- rsTagRFP (ON)-A ----\n",
      "stability: -13.1871\n",
      "surface area: 11003.08031896231\n",
      "\n",
      "---- smURFP-A ----\n",
      "stability: 27.3902\n",
      "surface area: 8050.659999043711\n",
      "\n"
     ]
    }
   ],
   "source": [
    "for row_idx, datum in rfp_known_structures.iterrows():\n",
    "    print(f'---- {datum.Name}-{datum.longest_chain} ----')\n",
    "    work_dir = './tmp'\n",
    "    pdb_path = f'../lambo/assets/foldx/{datum.pdb_id.lower()}_{datum.longest_chain}/wt_input_Repair.pdb'\n",
    "    tokenizer = ResidueTokenizer()\n",
    "    base_candidate = FoldedCandidate(work_dir, pdb_path, [], tokenizer=tokenizer,\n",
    "                                     skip_minimization=True, chain=datum.longest_chain)\n",
    "    rfp_known_structures.loc[row_idx, 'foldx_total_energy'] = base_candidate.wild_total_energy\n",
    "    rfp_known_structures.loc[row_idx, 'SASA'] = base_candidate.wild_surface_area\n",
    "    print(f'stability: {-base_candidate.wild_total_energy}')\n",
    "    print(f'surface area: {base_candidate.wild_surface_area}\\n')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "narrow-purse",
   "metadata": {},
   "source": [
    "## Evaluate fitness landscape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "interested-archives",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "---- Non-dominated RFP variants ----\n",
      "|     | Name     |    SASA |   stability |\n",
      "|----:|:---------|--------:|------------:|\n",
      "| 192 | DsRed.M1 | 10374.5 |     71.4708 |\n",
      "|   4 | mScarlet | 10591.9 |     61.8757 |\n",
      "| 129 | iFP1.4   | 14216.3 |     56.5245 |\n",
      "| 145 | Wi-Phy   | 14477.7 |     55.0519 |\n",
      "| 126 | iFP2.0   | 14511.9 |     48.796  |\n",
      "| 189 | DrCBD    | 14996.2 |    -15.2839 |\n",
      "| 209 | RCaMP    | 18901.6 |    -19.0144 |\n",
      "\n",
      "\n",
      "                            OLS Regression Results                            \n",
      "==============================================================================\n",
      "Dep. Variable:                      y   R-squared:                       0.036\n",
      "Model:                            OLS   Adj. R-squared:                  0.015\n",
      "Method:                 Least Squares   F-statistic:                     1.770\n",
      "Date:                Tue, 22 Mar 2022   Prob (F-statistic):              0.190\n",
      "Time:                        12:18:06   Log-Likelihood:                -28.717\n",
      "No. Observations:                  50   AIC:                             61.43\n",
      "Df Residuals:                      48   BIC:                             65.26\n",
      "Df Model:                           1                                         \n",
      "Covariance Type:            nonrobust                                         \n",
      "==============================================================================\n",
      "                 coef    std err          t      P>|t|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const         -0.0804      0.107     -0.749      0.458      -0.296       0.136\n",
      "x1            -0.2696      0.203     -1.330      0.190      -0.677       0.138\n",
      "==============================================================================\n",
      "Omnibus:                        0.089   Durbin-Watson:                   1.677\n",
      "Prob(Omnibus):                  0.957   Jarque-Bera (JB):                0.136\n",
      "Skew:                           0.088   Prob(JB):                        0.934\n",
      "Kurtosis:                       2.814   Cond. No.                         3.93\n",
      "==============================================================================\n",
      "\n",
      "Notes:\n",
      "[1] Standard Errors assume that the covariance matrix of the errors is correctly specified.\n"
     ]
    }
   ],
   "source": [
    "# post-processing\n",
    "mutant_surface_area = torch.tensor(rfp_known_structures.SASA.values)\n",
    "sa_min = mutant_surface_area.min()\n",
    "sa_range = mutant_surface_area.max() - sa_min\n",
    "x_data = 2 * (mutant_surface_area - sa_min) / sa_range - 1\n",
    "\n",
    "mutant_stability = -torch.tensor(rfp_known_structures.foldx_total_energy.values)\n",
    "stab_min = mutant_stability.min()\n",
    "stab_range = mutant_stability.max() - stab_min\n",
    "y_data = 2 * (mutant_stability - stab_min) / stab_range - 1\n",
    "\n",
    "obj = torch.stack([x_data, y_data], dim=-1)\n",
    "pareto_mask = pareto.is_non_dominated(obj)\n",
    "\n",
    "print('---- Non-dominated RFP variants ----')\n",
    "select_cols = ['Name', 'SASA', 'foldx_total_energy']\n",
    "select_df = rfp_known_structures.loc[pareto_mask.numpy(), select_cols]\n",
    "select_df['stability'] = -select_df.foldx_total_energy\n",
    "select_df = select_df.drop(columns='foldx_total_energy')\n",
    "select_df = select_df.sort_values('SASA')\n",
    "print(select_df.to_markdown())\n",
    "print('\\n')\n",
    "\n",
    "ref_x = 2 * (\n",
    "    rfp_known_structures[rfp_known_structures.Name == 'DsRed'].SASA.item() - sa_min\n",
    ") / sa_range - 1\n",
    "ref_y = 2 * (\n",
    "    -rfp_known_structures[rfp_known_structures.Name == 'DsRed'].foldx_total_energy.item() - stab_min\n",
    ") / stab_range - 1\n",
    "\n",
    "# fit OLS model\n",
    "lin_reg = LinearRegression().fit(x_data.view(-1, 1), y_data)\n",
    "r_squared = lin_reg.score(x_data.view(-1, 1), y_data)\n",
    "reg_x = np.linspace(-1, 1, 100)\n",
    "reg_y = lin_reg.coef_ * reg_x + lin_reg.intercept_\n",
    "\n",
    "# detailed OLS results\n",
    "X2 = sm.add_constant(x_data.view(-1, 1).numpy())\n",
    "est = sm.OLS(y_data.numpy(), X2)\n",
    "est2 = est.fit()\n",
    "print(est2.summary())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "occupied-collins",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA4kAAAIhCAYAAADjFv9iAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAAAsTAAALEwEAmpwYAACmZklEQVR4nOzdd3hT9f4H8PfJbpq00MWmZbUUShldQJllqAxlCChLBS8OUHAiiiKOK+hVf8pQuFz1gqAyRJQhyJLdllVWWYVSoECBUtq0zT6/P3obiUnpTjrer+fhwZ5zcvLJtyXm3e8SRFEUQURERERERARA4u4CiIiIiIiIqOpgSCQiIiIiIiIbhkQiIiIiIiKyYUgkIiIiIiIiG4ZEIiIiIiIismFIJCIiIiIiIhuZuwsgIqosISEhDsc8PT0RFBSEvn374qmnnoKHh4fDNfPmzcP8+fPve+8FCxagb9++RV4vl8vh5+eHyMhIPP3002jdunU5XgmRo2+++QZz587F119/jd69e9/32pCQEDRq1Ajbt293UXVERFSdMSQSUY33wAMPQK1WQxRFXLt2DUePHsXJkyexefNmrFixAp6enk4f17RpU0RERDg916BBg/ten5eXhxMnTuC3337D77//jvnz56NXr14V9pqItm/fDg8PD3Tp0sXdpdRa48aNQ0JCArZt24bGjRu7uxynrly5gj59+iA6OhrLli1zdzlEVE0wJBJRjff666/bfYBLTU3F6NGjcfr0aSxduhTPPfec08dFRERgzpw5JX6ev19vMpkwe/ZsrFq1Cm+//Ta2b98OuVxe9hdC9D9ZWVk4fPgwevbsCZVK5e5yiIiohuGcRCKqdYKCgvDkk08CAHbv3l1pzyOXy/Hmm29CrVYjIyMDx44dq7Tnotpl586dsFgsiIuLc3cpRERUAzEkElGt1KpVKwDA7du3K/V51Go1mjVrBgC4du1aiR6ze/duTJw4ET169EBYWBi6deuGkSNH4rPPPkN+fr7D9UlJSXjxxRfRrVs3hIWFoUePHnjrrbeQnp7u9P56vR6ff/454uLi0K5dO/Tt2xdffvkljEYj4uLiHOZy/vzzzwgJCcG8efOc3u+NN95ASEgI4uPjHc5lZWXh008/xYABAxAeHo6IiAiMHz8eO3bscLj2ypUrCAkJwbhx42AwGGw1hoWFIS4uDp9//jmMRqPTGvLy8rB48WIMGzYMnTp1QocOHfDggw9i9uzZuHjxYrnaTBRFbNiwAWPHjkVsbKzt+rFjx2LhwoVO6/m7J554AiEhIUhLS7M7vmLFCoSEhKB169bIzMy0O7do0SKEhIRg+fLlDvfbvn07JBJJsXMRi5OSkoJevXqhTZs2WLVqle34vT8Ha9aswSOPPILw8HB07twZr732Gm7cuOH0fvn5+Vi4cCEGDRpk+36PHj0av/76q8O1FdUm48aNQ0hICK5cuYKtW7fiscceQ4cOHRAZGYnnn38eFy5cKFWbZGZm4vPPP8fAgQPRsWNHdOrUCf369cO0adOwb98+AH/9rCYkJAAA+vTpg5CQENufQvf+29i9ezfGjRuHyMhIhISEIDs72+5n3pn7/dszmUz44Ycf8PjjjyMyMhLh4eHo168fZsyYgRMnTgAomC/dp08fAEBCQoJdjW+88YbdayltDfe2+2+//YaRI0eiY8eOiIyMtF0jiiLWr1+P8ePHIyoqCu3atcNDDz2EefPmOX0vI6Kqg8NNiahWys3NBQD4+vq67LkUCkWx165YsQKzZ8+GVCq1feC6e/cuUlNTsWjRIowePdpusZ3ly5fjgw8+AACEhYUhIiICFy9exOrVq7F9+3Z8//33aNGihe16o9GIiRMn4uDBg/D29kavXr1gNBrxn//8B6dOnYIoihX2ui9evIinnnoK165dQ6NGjdCtWzfk5uYiKSkJzz77LF5//XVMnDjR4XEmkwkTJkzA2bNnERUVhZYtW+LgwYP4+uuvcePGDYchwBkZGZgwYQLOnTsHLy8vREdHQ6FQ4MqVK/jxxx8RGBhoC+plabN//etfWLJkCeRyOSIjI+Hr64vbt28jJSUFhw8fxvPPP19sW0RHR+PAgQOIj49H06ZNbccLQ4YoikhISMCDDz7ocC46OtruXkajEXv27EF4eDj8/PyKfe6iHDt2DJMmTUJubi6++OIL9OvXz+GaTz75BP/9738RGRmJwMBAHD16FL/++iuOHz+OdevWQalU2q7V6XQYP348Tp48ibp166JXr17Iz8/HgQMHcOjQIRw5cgSzZs2qlDYBgB9++AHffPMNOnbsiJ49e+LUqVPYtm0bjhw5gvXr15fo33pubi5GjRqFtLQ01KtXD127doVMJsP169exfft2eHp6omvXrlCr1Rg6dCh2796NW7du2eY9F2X9+vVYtWqV7RcMaWlpEASh2HqKkpeXh0mTJiExMREeHh6IiIiAl5cXrl69it9++w0ajQZhYWEIDQ3FAw88gM2bN8PPzw/du3e33aOo+daltXjxYqxatQqdOnVC7969bb8Ms1qteO2117B+/Xqo1WqEhYXB29sbJ06cwPz587Fr1y4sXbrU6eJhROR+DIlEVCsVDjO990NTZTh//jwuX74MwPlqq3+3ZMkSCIKAH3/8EeHh4XbnkpKS4OXlZfv66NGj+PDDD+Hr64uvvvoK7dq1s51btWoVZs6ciRkzZmDlypW249999x0OHjyINm3a4JtvvkHdunUBAGlpaRgzZgwyMjLK9XoLWSwWvPjii7h27RpeeeUVTJw4EVKpFABw6dIlTJgwAZ9++im6d++O4OBgu8ceOXIEHTt2xNatW+Ht7W2rb9iwYfjll18wefJkNGnSxHb966+/jnPnzuGBBx7AP//5T2g0Gtu5K1euQKfTlbnNDAYDli5dCk9PT/zyyy92YcZqtSIxMbFE7RETEwMAOHDgAEaMGGE7npiYiJYtWyIlJQXx8fG2QGQ2m3H48GH4+PigZcuWdveKj49Hbm5uuYaa7tu3D5MnT4YgCFi8eHGRi9/8/PPP+Pnnn23fo9zcXDz11FNISkrChg0bMGzYMNu1n3/+OU6ePImYmBgsXLjQ9n1ISUnBuHHjsGLFCsTGxtpWBa7INgGAZcuW4b///a8tQJpMJkybNg1bt27FihUr8MILLxTbLps3b0ZaWhp69+6NBQsW2H5mASA7O9v2b9nHxwdz5szBuHHjcOvWLYd5z3+3cuVKfP755xgwYIDd8bt37xZbkzMffvghEhMTERkZiS+//NIuAN+6dQtXr14FAPTt2xetW7fG5s2b0bx581LNsS6pX375xa7dC33zzTdYv349oqKi8NlnnyEgIABAwS85Zs+ejdWrV2PBggV49dVXK7wmIio/DjclolpDFEWkp6dj3rx5WLduHTp27Ijx48cXef3atWvthmf9fZjW/eTl5WH//v2YMmUKLBYLunbtisDAwGIfl5mZCa1W6xAQAaB9+/Z2vRWLFy+GxWLB7Nmz7cIOAIwYMQJxcXFISkrCqVOnbMd/+OEHAMD06dNtAREoWJm1JD1iJbVjxw6cPXsW/fr1w6RJk+w+bAcGBuKNN96AxWKxC7CFJBIJPvjgA1tALKzv4YcfhiiKOHjwoO34sWPHsH//fjRs2BCffPKJXUAEgMaNG9ttP1LaNsvNzYXRaETTpk3tAmJhnYVBpzjh4eFQqVS2njCgIDwV9kK1atXK7tzx48eRl5eHqKgohx6nwm0syhoSN23ahEmTJkGlUmHp0qX3XR31xRdftAvxnp6emDBhAgDYBeS8vDysXr0aEokEs2bNsvs+tGjRApMnTwYA/Pe//7Udr8g2AYDx48fbBRW5XI5nn30WAOzucz+Fw1u7dOli9zMLAF5eXmjbtm2J7vN3vXr1cgiIZXXjxg2sXbsWarUa8+bNc+gh9fPzQ/v27SvkuUri0UcfdQiIZrMZS5YsgYeHh11ABApGVLz99tvw9/fHypUrYbVaXVYrEZUcQyIR1XiF84Vat26N3r17Y/78+ejZsyeWLVtW5PYXQEEwGTp0qMOfooZp3RsqO3bsiCeffBIXL15EWFgYPv744xLV2rZtW2RnZ+Ott97C+fPni7zOarVi//798PDwQI8ePZxeUzg3qHDBnPT0dKSnp8PX1xedO3d2uH7w4MElqrEk9uzZAwDo37+/0/OFbXj8+HGHcw0aNHDaU1Q4ZPTe3s7COWIPPfSQ3dBHZ8rSZj4+PmjYsCGSk5Px6aef2nqSSkuhUKBDhw7IyMiwzZEsnMMZExOD6OhonD9/3jZHtjDUOAuhO3bsQJMmTWzzakvjxx9/xMsvvwx/f38sX74cYWFh973eWTs5+z6cPHkSer0ebdq0sRuqW+iRRx4BUNCTazabAVRsm5Sm1vspDIFLlizBxo0bbUPFy6siFxhKSEiAxWJBjx494OPjU2H3LStnr+3UqVO4c+cOOnbsaBcQC6lUKrRt29Y2lJ6Iqh4ONyWiGq9wvpDJZMKFCxdw6tQp7Ny5E4sWLcKUKVOKfFxpt8C4d59EmUwGX19fREZGIjY2FhJJyX4nN2vWLEyePBmrV6/G6tWr4evri06dOqFv374YMGCAbV7jnTt3kJeXBwDFftC/c+cOgL8+KDds2NDpdRqNBl5eXsjOzi5RrfdTONzttddew2uvvVZsbfdytgclAFugv3fxmsL5T/fOObzfc5W2zQBgzpw5ePnll7F48WIsXrwY9evXR2RkJB544AH07du3xN/bwjl4CQkJaNasGRISEmxB6e7du/j+++8RHx+PAQMGFDn37tSpU7h27RqeeOKJEj3nva5fv45Zs2ZBoVBg6dKldkN2i+Lse+Hs+1D4s9WoUSOn99FoNKhTpw6ysrKQlZVlm0tZEW1yv1oLezRNJlOxrxUo6EGcOHEivv32W7z00kuQyWQICQlB586dMWzYMKe/vCiJon6my6LwZz4oKKjC7lkezl7blStXABT8Eqe4YfbO3gOIyP0YEomoxvv7fKH169fj1VdfxYIFC9CjRw+nQzvLorSh0png4GBs2LABe/bswa5du5CYmIg//vgDf/zxB/7973/jhx9+gJeXl22IllqtxgMPPHDfexb2OFXkojT3cjZcrPBY9+7d77u4yr1DXguVNHSVVlnaDCjoudq8eTN27dqF3bt3IzExEevXr8f69esRHR2Nb775pkT7Xxb2gMXHx2PUqFFITExEhw4doFQqbUMo4+Pj0b9//yLn3pVnqGnh/fbv34+PPvoIX3zxRbF1l/Z7UZLFWO69piLapDTPXRKvv/46Ro0ahW3btmH//v04fPgwTp48iW+//RbvvPMOHn/88VLfs7he7qLcbyhmRb3e8tQAOH9the81gYGB6NSp030fX6dOnTLXRkSVhyGRiGqdQYMGISEhAT/99BP+9a9/YenSpe4uyY5CoUBcXJwtCFy+fBlvvPEGDh48iP/85z946aWXULduXSiVSkgkEnz00Ucl+sBYOOyrqK0xdDqd017EwiBR2Av3d8629qhfvz6Agnl+xQWy8ijsxSjJkLWytFkhjUaDAQMG2OaVnT59Gi+//DISEhKwdu1ajBw5sth73DsHr3DuXWHgqFu3rm0OXuHcu+7duzudj+jt7W23zUBJKRQKfP3113j22Wexbds2vPTSS/j8889LFHCLU/izVdiD9He5ubnIysqCQqGwm2taEW1SGQIDAzFhwgRMmDABJpMJ69atw9tvv41//vOfGDx4sMPc17IqbPuihrVev37d4VhpfuYrq4bi1KtXDwAqbbEcIqp8nJNIRLXSlClToFKpEB8fj0OHDrm7nPtq0qSJbbGQs2fPAigYzhodHQ2dTof9+/eX6D6NGjVCgwYNcPv2bacLeWzYsMHp4/z9/QHA6X6Dd+7csVsYp1BsbCwA4I8//ihRbWXVtWtXAAWLsRS1h2KhsrRZUVq3bo3HHnsMwF/fk+IUDqO8efOmbQGhe+fXxcTE4MKFC7bvw9/n3t24cQMnT55E9+7dIZOV7Xe8KpUKX3/9NTp37ow//vgDL7/8sm2OYHm0bdsWKpUKJ0+eREpKisP5devWAQA6dOhgV3t528QV5HI5Hn30UbRu3RpGo9FuX8fCgGWxWMp077p160Iul+PKlStOh8QWzu29V3R0NKRSKf7880+HfSSLqh9Akd/nstRQnPDwcGi1WiQkJCArK6vUjyci92NIJKJaKSAgAKNGjQIAfPXVV26upkB+fj6WLl3qdFn8P//8E4D9/J9nn30WEokEM2bMwIEDBxwec+fOHSxfvhx6vd52rLCXZs6cOXYf3i5fvowFCxY4ratdu3ZQq9XYtWsXkpKSbMd1Oh1mzpxpt8VEof79+6Nly5b47bffsGDBAocAZ7FYsHv3bruVSssiPDwcMTExuHr1KqZPn+7QG3LlyhWcOXPG9nVp2yw9PR1r1qxx6EW1WCzYu3cvgNLNNyucT7dy5UqoVCq7VSgLA1Dhiq9/n3u3bds2ALBtjl5WhUExJiYGW7ZsqZCgqFarMXz4cIiiiPfee8/u+3Dx4kUsXLgQAJzOpSxPm1S0rVu34siRIw7HU1NTkZqaColEYrcQS+F/O/sFSkncO/9y2bJltuOiKOLrr792Wku9evXwyCOPIC8vD1OnTnUIirdv37b7d1oYAi9fvuw0zJalhpK8rqeffhq5ubmYMmWKXbAulJqaitWrV5f63kTkGhxuSkS11qRJk/DTTz9h9+7dOHnyZJmXt68oJpMJH374IT7++GOEhoaiSZMmMJvNSE5ORlpaGnx8fPDUU0/Zro+MjMQ777yD999/H0888QRatWqFoKAgmM1mXLt2DSkpKTCZTBg8eDBUKhUA4KmnnsLOnTtx+PBh9O/fH507d4bRaMSBAwfQuXNnSKVSh+Gonp6emDhxIubNm4exY8ciKioKcrkcx44dg5eXF/r06WMLMIVkMhkWLFiAiRMn4ssvv8Ty5csREhICb29vXL9+Hampqbhz5w5mzJhRpqGT9/rkk0/wxBNPYOPGjdi7dy8iIiKgUChw+fJlJCcnY/r06bbFM0rbZnfv3sWbb76J9957D23btkWDBg1gMBiQlJSEjIwMBAYG2u3xV5zC0GMwGNClSxfbQkQAbHPwDAZDkfMR5XJ5hezt6eHhgUWLFmHSpEnYvHkzXnnlFXz66adl7qEEgJdffhlHjx7FgQMH0K9fP0RFRSE/Px8HDhyAwWDA6NGjbXsk3qs8bVLR4uPjsXTpUvj7+6Nt27bQarW4ffs2EhMTYTKZMGHCBLs5tnFxcVi7di1eeeUVxMbGQqvVAijYx7CkpkyZggkTJmDu3Ln4/fffUb9+fZw+fRoZGRkYM2YMli9f7vCYt956CxcvXkRCQgL69OmDiIgIaLVapKen4+TJk3j88cdtYVuhUKBbt27YsWMHHnnkEbRp0wZyuRydOnXC8OHDy1xDcSZNmoQLFy5g3bp1GDBgAEJDQ9GoUSPk5OTgypUrSE1NRevWrfHoo4+W+t5EVPnYk0hEtZafn5+tZ60q9Caq1Wq88847iIuLw927d7Fjxw7s3bsXKpUK//jHP7Bu3TqHFSkff/xxrFmzBkOHDkVeXh527tyJQ4cOwWKx4OGHH8aiRYtsH1yBgg+M33zzDZ555hl4enpi+/btOHv2LJ544gl8+eWXRc73mjJlCt588000atQICQkJOHnyJPr164effvoJXl5eTh8TFBSEX375BdOmTUP9+vVx9OhRbN++HRkZGWjbti3eeecdPPzww+Vut3r16mH16tV48cUXUb9+fezbtw+7du1Cfn4+Ro8ejd69e5e5zZo0aYI33ngDXbp0wY0bN7B161YkJibC19cXL730ElavXl3k63cmPDwcHh4eABx7xerUqWMLs3/fCzA3Nxfx8fGIioqy+36WR2FQjI6Oxu+//47XXnutzMMmgYJ5m8uXL8fUqVNRt25dbN++HYmJiWjbti0++eQTzJo1y+njytomlWHYsGGYMGECGjZsiBMnTuD333/HxYsXERMTg4ULF2L69Ol21/fv3x8zZsxA/fr1sWPHDtuqxKXRuXNnLF68GB07dsTp06exb98+NGvWDD/++GORq/BqNBosXboUb731Flq2bIlDhw5h+/btyMzMxODBgzFkyBC76z/88EM88sgjyMrKwvr167F69Wq7fS7LUkNxJBIJPv74YyxYsACxsbG4evUqtm7diuTkZHh6euLpp5/GP//5zzLdm4gqnyBW1nJ3RERU7cTFxeHq1at2QzTJ/TZv3owXX3wRM2fOxLhx49xdDhER1XDsSSQiIqriPD09MWXKlEpdKZaIiKgQ5yQSERFVcd26dUO3bt3cXQYREdUS7EkkIiIiIiIiG85JJCIiIiIiIhsON60kVqsVubm5kMvllb4aGxERERERUUmJogiTyQRPT09IJI6DSxkSK0lubi7Onj3r7jKIiIiIiIicCg4Odrq1EkNiJZHL5QAKGv7ejYHd7cSJE2Xe84hKj+3tWmxv12Obuxbb27XY3q7F9nYttrdrVbX2NhqNOHv2rC2z/B1DYiUpHGKqUCigVCrdXI29qlZPTcf2di22t+uxzV2L7e1abG/XYnu7Ftvbtapiexc1LY6rmxIREREREZENQyIRERERERHZMCQSERERERGRDUMiERERERER2TAkEhERERERkU2NWN103bp1OHToEE6cOIGzZ8/CZDLhiy++wIMPPliq++h0OsybNw9btmzBzZs34e/vj/79++OFF16ARqOppOqJiIiIiIiqjhoREr/44gtcvXoVPj4+8PPzw7Vr10p9j7y8PIwdOxbJycmIjY3FwIEDcfr0aXz33XeIj4/HihUroFarK6F6IiIiIiKiqqNGDDf94IMPsGPHDuzfvx/Dhw8v0z2WLFmC5ORkPP300/jmm2/w6quvYsmSJZg8eTKSk5OxZMmSCq6aiIiIiIio6qkRIbFr165o2LBhmR8viiJWrVoFtVqNyZMn25175plnUKdOHaxevRqiKJa3VKLaw6gD9s4CFvoDn0oK/t47q+A4EREREVVZNSIklldqaioyMjLQqVMnhyGlSqUS0dHRuHHjBi5duuSmComqGaMOWNEZSPwYyL8FQCz4O/HjguMMikRERERVFkMiYAt/QUFBTs8HBgbaXUdExUj8BMhKASx6++MWfcHxxE/cUxcRERERFYshEUBOTg4AFLmCqVartbuOiIqRtNAxIBay6IGkr1xbDxERERGVWI1Y3bSylWcu4okTJyqwkopx6NAhd5dQq9TG9u6UfxvCfc6L+bdwuJLapTa2t7uxzV2L7e1abG/XYnu7FtvbtapTezMk4q+eQp3O+TypwuOF15VGWFgYlEpl2YurYIcOHUJERIS7y6g1am17x/v+by6ic4KHX6W0S61tbzdim7sW29u12N6uxfZ2Lba3a1W19jYYDPftzOJwU/w15zA1NdXp+cK5iIXXEVEx2j8PSFXOz0lVQPvnXFsPEREREZUYQyIKFqwJCAjA4cOHkZeXZ3fOYDAgISEBAQEBDIlEJRX1GlCnhWNQlKoKjke95p66iIiIiKhYtS4kpqenIyUlBfn5+bZjgiBgxIgRyMvLw4IFC+yuX7RoEbKysjBixAgIwv1mWRGRjUIDjD4ARL0OePgDkBT8HfV6wXGF80WiiIiIiMj9asScxFWrVtkmgiYnJwMAli9fjp07dwIA+vbti759+wIApk+fjoSEBCxduhQxMTG2ezz99NPYvn07lixZguTkZLRt2xanT5/Grl27EBoaiqefftq1L4qoulNogNjZBX+IiIiIqNqoESHx0KFDWLt2rd2xhIQE2383atTIFhKLolarsWzZMsyfPx+bN29GQkIC/Pz88OSTT2LKlClQq9WVUjsREREREVFVUiNC4pw5czBnzpwSXbts2bIiz2m1WsyYMQMzZsyoqNKIiIiIiIiqlVo3J5GIiIiIiIiKxpBIRERERERENgyJREREREREZMOQSERERERERDYMiURERERERGTDkEhEREREREQ2DIlERERERERkw5BIRERERERENgyJREREREREZMOQSERERERERDYMiURERERERGTDkEhEREREREQ2DIlERERERERkw5BIRERERERENgyJREREREREZMOQSERERERERDYydxdAROTAqAMSPwGSFgL5twEPX6D980DUa4BC4+7qiIiIiGo0hkQiqlqMOmBFZyArBbDoC47l3wISPwbOrQFGH2BQJCIiIqpEHG5KRFVL4if2AbGQRV9wPPET99RFREREVEswJBJR1ZK00DEgFrLogaSvXFsPERERUS3DkEhEVUv+7fKdJyIiIqJyYUgkoqrFw7d854mIiIioXBgSiahqaf88IFU5PydVAe2fc209RERERLUMQyIRVS1RrwF1WjgGRamq4HjUa+6pi4iIiKiWYEgkoqpFoSnY5iLqdcDDH4Ck4O+o17n9BREREZELcJ9EIqp6FBogdnbBHyIiIiJyKfYkEhERERERkQ1DIhEREREREdkwJBIREREREZENQyIRERERERHZMCQSERERERGRDVc3JSIiospn1AGJnwBJC4H824CHL9D++YK9T7m1DRFRlcKQSERERJXLqANWdAayUgCLvuBY/i0g8WPg3BrugUpEVMVwuCkR1Tg5+VbsPKHH+oP5SDxngMkiurskotot8RP7gFjIoi84nviJe+oiIiKnGBKJqEbZcjQfM1fcxflrZpjMInYnGzBjWRZOXzW5uzSi2itpoWNALGTRA0lfubYeIiK6Lw43JaIa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yn15MFtEu3O3si34I0mPuHZFDB8hIiIiKqTQFKxg+nwGDvdKBJ7PKPi6igdEgKubEhE5GBjhgUVbdHh/VTZ6tVXCRytBynUz9iQb8PD/Fq8hIiIiqqn4SYeI6G9kUgHPPahB8mUzDpw14PglEfXrSvH6EC/Ur8uhpkRERFSzMSQSETkhEQS0bSpH26Zyd5dCRERE5FKck0hEREREREQ2DIlERERERERkw5BIRERERERENgyJREREREREZMOQSERERERERDYMiURERERERGTDkEhEREREREQ2DIlERERERERkw5BIRERERERENgyJREREREREZMOQSERERERERDYMiURERERERGTDkEhEREREREQ2DIlERERERERkw5BIRERERERENgyJREREREREZCNzdwHltX37duzduxcnT55EcnIy9Ho9Xn/9dUycOLHU9zIajVi8eDF+++03pKenw9vbGz179sS0adPg7+9fCdUTERERERFVLdU+JH777bdISEiAVquFv78/Ll++XKb7WK1WPPfcc9izZw/at2+Pfv36IS0tDT///DP27duHlStXMigSkUuJooiU62bczRPhq5Ug0F8KQRDcXRYRERHVcNU+JE6dOhX+/v5o2rQp1q5dixkzZpTpPmvXrsWePXswcOBAfPrpp7YPYmvWrMGbb76Jf/3rX5g7d25Flk5EVKQzV034/s9cSCQC6teR4MptCxQyAU/29kRgQLV/6yYiIqIqrNrPSYyMjERgYGC5f7u+atUqAMArr7xid6/hw4ejZcuW2LhxI3Q6Xbmeg4ioJC7dNGPRFh1GdFXj3VFeeO5BLd4f7Y0HO6nwxYYcZNy1uLtEIiIiqsGqfUisCAaDAUlJSWjWrBkaNWrkcL579+4wGo1ISkpyQ3VEVNtsPJSPQZEeCA9S2H5pJREExLRSomdbJf44qndzhURERFSTMSQCSEtLg9VqRVBQkNPzgYGBAIDU1FTXFUVEtZJVFHEs1YSuIUqn57u2VuLwBaOLqyIiIqLahBNbAOTk5AAANBqN0/NarRYAyjTc9MSJE2UvrJIcOnTI3SXUKmxv16ru7W2xAhZrEE4cOwxno+j1Jgn0xsZV6nVWpVpqA7a3a7G9XYvt7Vpsb9eqTu1dJUJiTEwMsrKySnz9tm3b0Lhx48or6G9EUSzzY8PCwqBUOu8RcIdDhw4hIiLC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18+ZMwdz5syxO6ZQKGzDSomIiIiIiGqzWjcnkYiIiIiIiIrGkEhEREREREQ2DIlERERERERkw5BIRERERERENgyJREREREREZMOQSERERERERDYMiURERERERGTDkEhEREREREQ2DIlERERERERkw5BIRERERERENgyJREREREREZMOQSERERERERDYMiURERERERGTDkEhEREREREQ2DIlERERERERkw5BIRERERERENgyJREREREREZMOQSERERERERDYMiURERERERGTDkEhEREREREQ2DIlERERERERkI3N3AVTAYDAgMzMTOTk5sFgslfY8MpkMycnJlXZ/ssf2di22t+uxzV2L7e1abO/SkUql0Gq18PHxgVKpdHc5RFQODIlVgMFgQFpaGurWrYugoCDI5XIIglApz5WbmwtPT89KuTc5Ynu7Ftvb9djmrsX2di22d8mJogiTyYTs7GykpaWhadOmDIpE1RiHm1YBmZmZqFu3Lvz8/KBQKCotIBIRERFVBkEQoFAo4Ofnh7p16yIzM9PdJRFROTAkVgE5OTnw8vJydxlERERE5ebl5YWcnBx3l0FE5cCQWAVYLBbI5XJ3l0FERERUbnK5vFLXVyCiyseQWEVwiCkRERHVBPxMQ1T9MSQSERERERGRDUMiERERERER2TAkUpX1888/IyQkBD///LO7SwEAjBs3DiEhIe4uo1LEx8cjJCQE8+bNc3cpVM1duXIFISEheOONN9xdCgBg3rx5CAkJQXx8vLtLqRQhISEYN26cu8ugWoD/nyCqXbhPIlEVNm/ePMyfPx9Lly5FTEyMu8shohKIj4/H+PHjMWXKFLzwwgvuLodc4MqVK+jTp4/dMQ8PD2i1WrRs2RJRUVEYNmwY6tev7/Sxixcvxr59+3D9+nXI5XL4+voiJCQEUVFRGD9+PCQSSZHPI5fL4efnh+joaDz77LNo3rx55b1QIqo1GBKJSmju3LnIz893dxlEVApjxozBgAED0LBhQ3eXQrVAUFAQBg0aBAAwGAy4desWjhw5gi+++AJfffUVXnnlFTz55JO265OTkzFu3Djk5OQgMjISvXr1gkwmQ1paGpKSkrB161Y8/vjjDpvS3/s8Op0OR44cwbp167B161asWrUKLVq0cNlrJqKaiSGRqIT4IZOo+vHx8YGPj4+7y6BaIigoyGnv8c6d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Y4Wh6axYAchkFa+4qDxJTeUnjCtWVPzXxCrPOmpubo6WLVsKr48YO3asMHuuXEhICE6dOoWUlBQcO3YM+fn5MDMzg4uLC/z9/fH222+rnESmKra2tpg0aRK2bt2K7du3Y+7cufydIKJ6MZA19YvydFRpaSmuXr2KHj16KLxrSJW0tDRhzE5DKy4uVni/IDUsxrtxMd6NjzFvXHod7y++qHjNReVJavbsqXiC2EAJol7HW031uba5cOGC/rzaRQsw3o1L2+JdU67CJ4lERESk/VQlgs1kVlMiouaGE9cQERERERGRgEkiERERERERCZgkEhERERERkYBJIhEREREREQmYJBIREREREZGASSIREREREREJmCRqCb6ukoiIiHQBr2mImj8miVrAyMgIEomkqXeDiIiISG0SiQRGRkZNvRtEpAYmiVpAJBLh8ePHTb0bRERERGp7/PgxRCJRU+8GEamBSaIWsLW1RX5+PnJzcyEWi9lNg4iIiJoVmUwGsViM3Nxc5Ofnw9bWtql3iYjUYNzUO0CAmZkZnJyc8OjRI2RkZKCsrKzB6hKLxTA1NW2w7ZMixrtxMd6NjzFvXIx342K868bIyAgikQhOTk4wMzNr6t0hIjUwSdQSZmZmaNu2Ldq2bdug9Vy4cAGenp4NWgf9i/FuXIx342PMGxfj3bgYbyLSV+xuSkRERERERIJm/SQxPz8fMTExOHnyJG7cuIEHDx6gRYsW6NmzJ2bMmIH+/fvXaXtisRihoaE4cuQI7t27B2trawwcOBALFy6Evb19Ax0FERERERGR9mjWSeKvv/6KlStXwsHBAT4+PmjdujXu37+PmJgYnD59GkuWLMG7775bq22Vl5cjICAACQkJ8PT0xNChQ5GZmYnIyEicPXsWP//8MxNFIiIiIiLSec06SXRxcUFISAheffVVGBr+23M2ICAAEydORGBgIEaNGoXWrVvXuK0DBw4gISEBvr6++O6772BgYAAA2L9/Pz799FOsWbMGq1evbrBjISIiIiIi0gbNekyij48PBg0apJAgAkDHjh3xxhtvQCKR4NKlS7XaVkREBADgo48+EhJEABg3bhxcXV0RHR2NoqIize08ERERERGRFmrWSWJ1TExMAADGxjU/LC0tLUVqaio6dOgAR0dHpfX9+/eHWCxGamqqxveTiIiIiIhImzTr7qZVKSoq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\n",
      "text/plain": [
       "<Figure size 936x576 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig = plt.figure(figsize=(13, 8))\n",
    "ax = fig.add_subplot(1, 1, 1)\n",
    "\n",
    "# trend not shown bc not statistically significant\n",
    "# ax.plot(reg_x, reg_y, color='black', linestyle='--', linewidth=2, zorder=1)\n",
    "ax.scatter(x_data[~pareto_mask], y_data[~pareto_mask], \n",
    "           s=64, facecolors='none', edgecolors='cornflowerblue', zorder=2, label='dominated')\n",
    "ax.scatter(x_data[pareto_mask], y_data[pareto_mask], \n",
    "           s=64, label='non-dominated', color='darkorange', zorder=3)\n",
    "ax.scatter(ref_x, ref_y, color='red', s=64, marker='x', label='DSRed',\n",
    "           linewidth=4, zorder=2)\n",
    "\n",
    "ax.set_xlabel('SASA')\n",
    "ax.set_ylabel('Stability')\n",
    "ax.legend(loc='lower left', ncol=3)\n",
    "ax.set_xlim((-1.1, 1.1))\n",
    "ax.set_ylim((-2, 1.1))\n",
    "\n",
    "ax.set_title('RFP sequences w/ known structure')\n",
    "plt.tight_layout()\n",
    "# plt.savefig('./figures/rfp_known_structures_fitness_landscape_plot.pdf')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "thick-supply",
   "metadata": {},
   "source": [
    "## Save results\n",
    "\n",
    "Running this cell will overwrite the dataframe included in the repo."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "quarterly-threshold",
   "metadata": {},
   "outputs": [],
   "source": [
    "# rfp_known_structures.to_csv('../lambo/assets/fpbase/rfp_known_structures.csv', index=None)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "monetary-audit",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}