{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "continued-quarterly",
   "metadata": {},
   "outputs": [],
   "source": [
    "import itertools\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import torch\n",
    "import statsmodels.api as sm\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "import os\n",
    "\n",
    "from pathlib import Path\n",
    "\n",
    "from botorch.utils.multi_objective import pareto\n",
    "from sklearn.linear_model import LinearRegression\n",
    "\n",
    "from lambo.utils import FoldxMutation, AMINO_ACIDS, ResidueTokenizer\n",
    "from lambo.candidate import FoldedCandidate, pdb_to_residues\n",
    "\n",
    "import warnings\n",
    "# suppress noisy BioPython warnings\n",
    "warnings.filterwarnings(\"ignore\")\n",
    "\n",
    "sns.set(style='whitegrid', font_scale=1.75)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "exceptional-explosion",
   "metadata": {},
   "source": [
    "## Load starting pool of RFP variants\n",
    "Test a single mutation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "b537edfb",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "valid protein names\n",
      "0                    AdRed\n",
      "1                    DrCBD\n",
      "2                    DsRed\n",
      "3                DsRed-Max\n",
      "4                 DsRed.M1\n",
      "5                 DsRed.T4\n",
      "6                    HcRed\n",
      "7                   HcRed7\n",
      "8          IrisFP (Orange)\n",
      "9                 Katushka\n",
      "10            KikGR1 (Red)\n",
      "11               KillerRed\n",
      "12              LSS-mKate1\n",
      "13              LSS-mKate2\n",
      "14                 Neptune\n",
      "15     PSmOrange (Far-red)\n",
      "16    PSmOrange2 (Far-red)\n",
      "17                   RCaMP\n",
      "18                  RFP630\n",
      "19            Sandercyanin\n",
      "20                  TagRFP\n",
      "21                TagRFP-T\n",
      "22               TagRFP675\n",
      "23                  Wi-Phy\n",
      "24                  asulCP\n",
      "25                cp-mKate\n",
      "26                 eqFP611\n",
      "27                 eqFP650\n",
      "28                 eqFP670\n",
      "29                  iFP1.4\n",
      "30                  iFP2.0\n",
      "31                   laRFP\n",
      "32               mCRISPRed\n",
      "33               mCardinal\n",
      "34                 mCherry\n",
      "35             mEos2 (Red)\n",
      "36     mEos2-A69T (Orange)\n",
      "37            mEosFP (Red)\n",
      "38                   mKate\n",
      "39                   mPlum\n",
      "40              mPlum-E16P\n",
      "41                  mRojoA\n",
      "42                  mRouge\n",
      "43                   mRuby\n",
      "44                mScarlet\n",
      "45             mStrawberry\n",
      "46            miRFP670nano\n",
      "47          pcDronpa (Red)\n",
      "48           rsTagRFP (ON)\n",
      "49                  smURFP\n",
      "Name: Name, dtype: object\n"
     ]
    }
   ],
   "source": [
    "rfp_known_structures = pd.read_csv('../lambo/assets/fpbase/rfp_known_structures.csv')\n",
    "print('valid protein names')\n",
    "print(rfp_known_structures.Name)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "organizational-gravity",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "---- wild type DsRed.M1-A ----\n",
      "\n",
      "residues: TEDVIKEFMQFKVRMEGSVNGHYFEIEGEGEGKPYEGTQTAKLQVTKGGPLPFAWDILSPQFSKAYVKHPADIPDYMKLSFPEGFTWERSMNFEDGGVVEVQQDSSLQDGTFIYKVKFKGVNFPADGPVMQKKTAGWEPSTEKLYPQDGVLKGEISHALKLKDGGHYTCDFKTVYKAKKPVQLPGNHYVDSKLDITNHNEDYTVVEQYEHAEARHSG\n",
      "\n",
      "stability: 71.485\n",
      "\n",
      "surface area: 10385.128377983554\n",
      "\n",
      "---- mutant 7d013b57203f414fa78798afdf927a15 ----\n",
      "\n",
      "residues: GEDVIKEFMQFKVRMEGSVNGHYFEIEGEGEGKPYEGTQTAKLQVTKGGPLPFAWDILSPQFSKAYVKHPADIPDYMKLSFPEGFTWERSMNFEDGGVVEVQQDSSLQDGTFIYKVKFKGVNFPADGPVMQKKTAGWEPSTEKLYPQDGVLKGEISHALKLKDGGHYTCDFKTVYKAKKPVQLPGNHYVDSKLDITNHNEDYTVVEQYEHAEARHSG\n",
      "\n",
      "stability: 70.5536\n",
      "\n",
      "surface area: 10439.58313654544\n",
      "\n"
     ]
    }
   ],
   "source": [
    "protein_name = 'DsRed.M1'\n",
    "pdb_id = rfp_known_structures[rfp_known_structures.Name == protein_name].pdb_id.item().lower()\n",
    "chain_id = rfp_known_structures[rfp_known_structures.Name == protein_name].longest_chain.item()\n",
    "\n",
    "work_dir = './tmp'\n",
    "parent_pdb_path = f'../lambo/assets/foldx/{pdb_id}_{chain_id}/wt_input_Repair.pdb'\n",
    "tokenizer = ResidueTokenizer()\n",
    "base_candidate = FoldedCandidate(work_dir, parent_pdb_path, [], \n",
    "                                   tokenizer=tokenizer, skip_minimization=True,\n",
    "                                   chain=chain_id, wild_name=protein_name)\n",
    "\n",
    "# substitute G at the first position\n",
    "mutation_list = [base_candidate.new_mutation(seq_idx=0, mutant_residue='G', mutation_type='sub')]\n",
    "# run FoldX to get new structure\n",
    "new_candidate = base_candidate.new_candidate(mutation_list)\n",
    "\n",
    "print(f'---- wild type {protein_name}-{chain_id} ----\\n')\n",
    "print(f'residues: {new_candidate.wild_residue_seq}\\n')\n",
    "print(f'stability: {-new_candidate.wild_total_energy}\\n')\n",
    "print(f'surface area: {new_candidate.wild_surface_area}\\n')\n",
    "\n",
    "print(f'---- mutant {new_candidate.uuid} ----\\n')\n",
    "print(f'residues: {new_candidate.mutant_residue_seq}\\n')\n",
    "print(f'stability: {-new_candidate.mutant_total_energy}\\n')\n",
    "print(f'surface area: {new_candidate.mutant_surface_area}\\n')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "distributed-header",
   "metadata": {},
   "source": [
    "## Exhaustively evaluate all 1-edit mutants\n",
    "\n",
    "Residue substitutions only"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "91266cf5",
   "metadata": {},
   "outputs": [],
   "source": [
    "# the full mutation sweep is pretty slow (~ 1 day), saving results is recommended\n",
    "asset_path = Path(f'./assets/{protein_name}-{chain_id}_1-edit_obj-vals.csv')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "12a98a03",
   "metadata": {},
   "outputs": [],
   "source": [
    "if os.path.exists(asset_path):\n",
    "    df = pd.read_csv(asset_path)\n",
    "\n",
    "else:\n",
    "    wild_seq, _ = pdb_to_residues(parent_pdb_path, chain_id)\n",
    "    records = []\n",
    "    pos_range = range(len(wild_seq))\n",
    "    for res, pos in itertools.product(AMINO_ACIDS, pos_range):\n",
    "        mutation_list = [base_candidate.new_mutation(pos, res)]\n",
    "        print(mutation_list[0])\n",
    "        candidate = base_candidate.new_candidate(mutation_list)\n",
    "        records.append({\n",
    "            'seq_idx': pos,\n",
    "            'wt_residue': wild_seq[pos],\n",
    "            'mutant_residue': res,\n",
    "            'mutant_uuid': candidate.uuid,\n",
    "            'mutant_surface_area': candidate.mutant_surface_area,\n",
    "            'mutant_total_energy': candidate.mutant_total_energy\n",
    "        })\n",
    "\n",
    "        # comment out to run full loop\n",
    "        if pos == 10:\n",
    "            break\n",
    "            \n",
    "    df = pd.DataFrame(records)\n",
    "    os.makedirs(asset_path.parent, exist_ok=True)\n",
    "    df.to_csv(asset_path, index=None)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "knowing-tourism",
   "metadata": {},
   "source": [
    "## Evaluate fitness landscape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "specialized-solomon",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "                            OLS Regression Results                            \n",
      "==============================================================================\n",
      "Dep. Variable:                      y   R-squared:                       0.420\n",
      "Model:                            OLS   Adj. R-squared:                  0.356\n",
      "Method:                 Least Squares   F-statistic:                     6.525\n",
      "Date:                Tue, 22 Mar 2022   Prob (F-statistic):             0.0310\n",
      "Time:                        11:53:32   Log-Likelihood:                -6.5436\n",
      "No. Observations:                  11   AIC:                             17.09\n",
      "Df Residuals:                       9   BIC:                             17.88\n",
      "Df Model:                           1                                         \n",
      "Covariance Type:            nonrobust                                         \n",
      "==============================================================================\n",
      "                 coef    std err          t      P>|t|      [0.025      0.975]\n",
      "------------------------------------------------------------------------------\n",
      "const          0.2748      0.147      1.872      0.094      -0.057       0.607\n",
      "x1            -0.5980      0.234     -2.554      0.031      -1.128      -0.068\n",
      "==============================================================================\n",
      "Omnibus:                        3.597   Durbin-Watson:                   2.489\n",
      "Prob(Omnibus):                  0.166   Jarque-Bera (JB):                1.149\n",
      "Skew:                          -0.741   Prob(JB):                        0.563\n",
      "Kurtosis:                       3.560   Cond. No.                         1.61\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(df.mutant_surface_area)\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(df.mutant_total_energy)\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",
    "ref_x = 2 * (base_candidate.wild_surface_area - sa_min) / sa_range - 1\n",
    "ref_y = 2 * (-base_candidate.wild_total_energy - stab_min) / 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": 7,
   "id": "twenty-concord",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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axZbtmxh//795MyZkzfffJPBgwcnOOQaYMKECRQvXpzly5fj7e2Nk5MT9erVY/jw4ZpFExERERGR55IukrQpU6YwZcqUJLX19vZ+ap2LiwtjxoxhzJgxSerLxsaGHj160KNHjyS1FxEREREReZZX7pk0ERERERERa6YkTURERERExIooSRMREREREbEiStJERERERESsiJI0ERERERERK6IkTURERERExIooSRMREREREbEiStJERERERESsiJI0ERERERERK6IkTURE0r9PP4Vly+KXLVsWWy4iImJl7CwdgIiISKoaPz42GbP5/88lu3SJTdC6d4eYGDCZYtuIiIhYCSVpIiKSfn366T+zZTExsYnZsmXwyy+xr+PaGAwwbpzl4hQREfkXLXcUEZH0q3jxf2bQIDYxW7funwQNYuuLF3/5sYmIiDyFkjQREUm/unSBxYvjJ2r/ZmMTW9+ly8uNS0RE5D8oSRMRkfStSxd4443E6954QwmaiIhYHSVpIiKSvsU9g5aYX35JuOujiIiIhSlJExGR9Ovfuzgm5t+biYiIiFgJJWmSqLVr17Jp0yYiIyMtHYqIyPM7cybhJiGtWyfcTOTMmZcfm4iIyFMoSZMEwsPD+fbbb2nRogV58+Zl6NChHDhwAJPJZOnQRESSZ9y4f7bWj9skZO3a+JuJ/LuNiIiIFdA5aZJAREQERqORbdu2cebMGWbMmMGMGTMoVqwYRqORfv36kTt3bkuHKSKSNOPHx56DVrz4P5uExP3/zBklaCIiYnU0kyYJuLi40KdPH06dOsXBgwcZNmwYbm5unD17lk8++YSbN2+a28Y87TkPERFrMm5cwl0cu3RRgiYiIlZJM2nyVAaDgUqVKlGpUiW+/PJLfv/9d7Zu3Ur58uXNberXr0+2bNkwGo20aNGCjBkzWjBiEREREZG0T0maJImdnR1NmzaladOm5rKbN2+ye/duoqOjWbt2LVmyZKFjx44YjUZq1aqFzdMOjxURERERkafSb9Hy3HLnzs2VK1eYNm0ar732Gg8ePGD+/PnUrVuXggULEhgYaOkQRURERETSHCVp8kLy5MnD8OHDCQwM5OTJk3z44YcUKFCAv//+G09PT3O7rVu3cuPGDQtGKiIiIiKSNihJkxRTqlQpJk2axMWLFwkMDCRz5sxA7G6RnTp1Il++fDRp0gRvb29C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5M+fnw0bNsT71CckJIQ5c+ZgZ2cX73y369evc/78+XhJpMFgoGPHjoSGhjJ79ux4/X///ffcv3+fjh07mre2BejUqRMA33zzDREREebyvXv3smvXLry8vHRGmoiIiFi9MmXKMHnyZIKCgti+fTu9e/fm7bffNv/ec/36dZo1a4aPj89zbYomIsmT7GfSevXqxejRo9m1axe1atVKtM3u3bs5ePAgkydPfuEAk8LOzo7PPvuMvn370q1bN1q2bImzszN+fn5cvXqVYcOGxUuWRo0axf79+1m0aBFVq1Y1l/ft25dt27Yxf/58Tp06RenSpTl9+jT+/v6ULFmSvn37xrtvtWrV6NixI76+vrRt25Y6depw584dNm3ahLOzM+PHj38p719EREQkJdjY2FC3bl3q1q0L/LNL3tKlS9m8eTObN2/GycmJtm3b0qNHDxo0aICd3Qud6CQiiXjmT9X169fjvfby8qJbt24MHDiQ5s2b07x5c/NW+9evX+fXX39l06ZNdO/e/ZlLDFNStWrVWLJkCTNmzODXX38lMjIST09Phg4dSqtWrZLUh5OTE97e3syaNYstW7awf/9+cubMyZtvvsngwYMTHHINMGHCBIoXL87y5cvx9vbGycmJevXqMXz4cM2iiYiISLrw5ptv4uTkhI+PD3/88QeLFy9m8eLFuLm50bNnT7744ot4q41E5MUYTM9YbFyiRIlEf+hMJtNTfxjj6gwGA3/++WfKRPoKiNuuU1vwp18a19ShcU0dGtfUoXFNHRrX1JHYuJ4/f54lS5bg7e3NX3/9RcuWLfnll18AiI6O5urVq8/csE30PZtarGFcU+J3+mfOpGnjCxERERGJU6RIET7++GPGjh3LgQMHsLW1Nddt376dRo0aUbt2bYxGIx06dCBbtmwWjFYkbXpmkubt7f0y4hARERGRNMRgMCR4tOXcuXM4Ojri7++Pv78/gwcPpmXLlhiNRpo3b27xlUIiaYVOKhQRERGRFPH2228THBzMwoULadiwIZGRkaxevZp27dpRrVo1S4cnkmYoSRMRERGRFOPi4kKvXr347bffuHLlCl999RUVKlSgWbNm5jY3b95k7NixnD592oKRiliv594zNSwsjH379hEUFMTjx48TPezQYDAwaNCgFwpQRERERNKmvHnz8t577/Hee+8RGRlpLl+2bBmTJk1i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1KlTx7x88lX1ar97ERERERF56QwGA/v27eObb76hcuXKPHz4kJ9++on69evj4eHB6tWrLR2iRSlJExERERGRly537twMHTqUAwcO8Oeff/LRRx/h4eHB1atXyZEjh7ndqVOnuH79ugUjffmUpImIiIiIiEWVLFmSzz77jAsXLrB7925q1aplrhsxYgT58uWjUaNG/Pzzzwl2aU+PlKSJiIiIiIhVsLGxoUaNGuZn0mJiYsicOTP29vb8/vvvvPnmm7i5udGtWzc2bdpEZGSkhSNOHUrSRERERETEKtnY2LB8+XJu3rzJvHnzqFWrFk+ePGHp0qW0aNGCefPmWTrEVKEkTURERERErFq2bNno168f/v7+XLx4kUmTJlGmTBk6dOhgbuPn52fBCFOWkjQREREREUkzChYsyIcffsjx48dxc3MDYpdF3r5928KRpRwlaSIiIiIikua1bdvW0iGkGCVpIiIiIiKSptnY2ODk5GTpMFKMkjQREREREREroiRNRERERETEiihJExERERERsSJK0kRERERERKyIkjQREREREREroiRNRERERETEiihJExERERERsSJK0kRERERERKyIkjQREREREREroiRNRERERETEiihJExERERERsSJK0kRERERERKyIkjQREREREREroiRNRERERETEiihJExERERERsSJK0kRERERERKyIkjQREREREREroiRNRERERETEiihJExERERERsSJK0kRERERERKyIkjQREREREREroiRNRERERETEiihJExERERERsSJK0kRERERERKyIkjQREREREREroiRNRERERETEiihJExERERERsSJ2lg4gJQQFBTF9+nQCAgIIDQ3Fw8ODzp07061bN2xskpaHzpw5k1mzZiVa5+TkxOHDhxOt++WXX/j55585d+4c9vb2VKhQgXfffZeyZcs+9/sREREREZFXV5pP0s6dO0eXLl0ICwujadOmuLm54e/vz8SJEzlz5gwTJ05MVn9t27Ylb9688crs7e0TbTt37lymT5+Ou7s7Xbp0ITQ0lI0bN9K1a1d+/PFHqlat+tzvS0REREREXk1pPkkbP348jx49Yt68edSpUweAYcOG0a9fP1asWEGLFi2oVq1akvtr27ZtkpKroKAgZs6cScGCBVm5ciUuLi4A9OjRg44dOzJ27Fh+/fVX7OzS/BCLiIiIiMhLlKafSbt48SIHDhygatWq5gQNYme+RowYAYCvr2+q3Hv16tVERUUxcOBAc4IGULRoUdq0acPly5fZt29fqtxbRERERETSrzSdpO3fvx+AmjVrJqgrW7YsWbNmNbdJqgMHDjBv3jx++uknduzYQURExH/eu0aNGgnqateube5LREREREQkOdL0WrygoCAAPDw8EtQZDAY8PDw4evQoT548wdHRMUl9zpw5M95rV1dXvvjiiwTJWFBQEE5OTri6uiboIy6euPhERERERESSKk3PpIWEhADEW274b3Hljx49emZfJUuW5IsvvmDbtm0cO3YMPz8/hg4dyqNHjxg4cCCnT59OcO9n3TcuPhERERERkaSyipm0qlWrcv/+/SS337p1K/ny5XtmO5PJlOQ+GzZsGO+1h4cH77zzDjlz5uTjjz9m3rx5TJs2LUl9Jee+iTlx4sQLXZ9SDh06ZOkQ0iWNa+rQuKYOjWvq0LimDo1r6tC4ph6NbepID+NqFUlau3btePz4cZLbZ8qUCQBnZ2fg6TNlcTNZce2eR5s2bfj0008JDAyMV+7s7Jxq9y1TpgwZMmR4rmtTyqFDh6hUqZJFY0iPNK6pQ+OaOjSuqUPjmjo0rqlD45p6NLapwxrGNTw8/IUnXawiSRs1atRzXVewYEEALl26lKDOZDJx6dIlcuXKhZOT03PH5uDgQKZMmXjy5EmCex8+fJjbt28neC4tLp64+ERERERERJIqTT+TVqVKFQB2796doO748ePcv3/f3OZ5Xbp0iQcPHiQ44NrLywuAPXv2JLjG398/XhsREREREZGkStNJWqFChfDy8iIgIICdO3eayyMjI5k+fToAHTt2jHfNrVu3OH/+fLylihERERw/fjxB/w8fPmTs2LEAtGjRIl5du3btsLOz47vvvovX119//cXatWspUKBAsg7RFhERERERAStZ7vgixo8fT5cuXRg0aBDNmjUjV65c7Nq1izNnztCxY8cEidK0adNYs2YNkydPpl27dgCEhYXRoUMHSpYsScmSJcmRIwe3bt3C39+fe/fuUaNGDXr06BGvn0KFCjF48GC++eYbWrVqRZMmTQgNDWXjxo1ERUUxceJE7OzS/PCKiIiIiMhLluazCE9PT3x9fZk+fTr+/v6Ehobi4eHB2LFj6d69e5L6yJgxIz169ODo0aPs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yfJc70dERERERF5taT5Jg9hljzNmzEhS2ylTpjBlypSn1nt7eyepn549e9KzZ88ktRUREREREUmqNP1MmoiIiIiISHqjJE1ERERERMSKKEkTERERERGxIkrSRERERERErIiSNBERERERESuiJE1ERERERMSKKEkTERERERGxIkrSRERERERErIiSNBERERERESuiJE1ERERERMSKKEkTERERERGxIkrSRERERERErIiSNBERERERESuiJE1ERERERMSKKEkTERERERGxIkrSRERERERErIiSNBERERERESuiJE1ERERERMSKKEkTERERERGxIkrSRERERERErIjBZDKZLB2ExAoPD+fEiROUKVOGDBkyPLPt3bt3efToEdHR0SkeS0REBA4ODine76tO45o6NK6pQ+OaOjSuqUPjmjo0rqlHY5s6rGFcTSYTkZGR2NvbYzAY4tXZ2tri4uJC9uzZ//P3fbvUDlJSXnh4OJcvXyZbtmwULFgw0W+AF/X48WMyZcqUon2KxjW1aFxTh8Y1dWhcU4fGNXVoXFOPxjZ1WMO4xsTE8OTJExwdHbGx+WfhYlzy9vDhQy5fvkyBAgWemqhpuWMadPfuXbJly0bOnDlxcHBI8QRNRERERERSlsFgwMHBgZw5c5ItWzbu3r371LZK0tKgR48ekTlzZkuHISIiIiLyf+3dd1gU1/oH8O8ufQURBOyCiouiVAU0drBFihQLKpoYEw3GGjVq4tUYk5trNLGADbtoLEhRAR9RUUGl2bBhF1FsiPS2LDu/P/a3K+sufVd28f08T557mTk7Z+b1TDkzp5B6aN68OQoKCqpcT5U0FVRRUQENDY3G3g1CCCGEEEJIPWhoaFQ7rgRV0lQUNXEkhBBCCCFENdX0LE+VNEIIIYQQQghRIlRJI4QQQgghhBAlQpU0Qj6B8+fPY+zYsRgwYAAsLCzwxx9/AACcnZ3h7OzcyHtH6issLAwWFhYICwtr7F0BAEyePBkWFhaNvRsKkZSUBAsLCwQEBDT2rhAV9+LFC1hYWGDJkiWNvSsAgICAAFhYWCApKamxd0UhLCwsMHny5MbeDdKEKdu9WF5onjSisi5duoTDhw/j+vXryMnJQbNmzcDlcuHm5gYfHx+oq0sXb2dnZ+Tk5OD69es1br+oqAi7d+/G6dOn8ezZMwgEAhgaGqJjx45wcHCA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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",
    "ax.plot(reg_x, reg_y, color='black', linestyle='--', linewidth=2, zorder=1, label='OLS fit')\n",
    "ax.scatter(x_data[~pareto_mask], y_data[~pareto_mask], linewidth=2,\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=protein_name,\n",
    "           linewidth=4, zorder=2)\n",
    "\n",
    "ax.set_xlabel('SASA')\n",
    "ax.set_ylabel('Stability')\n",
    "ax.set_title(f'{protein_name} 1-edit Mutants')\n",
    "ax.legend(ncol=4)\n",
    "plt.tight_layout()\n",
    "\n",
    "# plt.savefig(f'./figures/{protein_name}-{chain_id}_1-edit_obj-vals.pdf')"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "941f7c61",
   "metadata": {},
   "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
}
