{
  "nbformat": 4,
  "nbformat_minor": 0,
  "metadata": {
    "colab": {
      "provenance": []
    },
    "kernelspec": {
      "name": "python3",
      "display_name": "Python 3"
    },
    "language_info": {
      "name": "python"
    }
  },
  "cells": [
    {
      "cell_type": "code",
      "source": [
        "!pip install scikit-learn matplotlib seaborn\n"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 0
        },
        "id": "0eVvFGmjSOMX",
        "outputId": "31ac0fd6-bc26-431c-9aa5-b6a15460ddf2"
      },
      "execution_count": 7,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Requirement already satisfied: scikit-learn in /usr/local/lib/python3.12/dist-packages (1.6.1)\n",
            "Requirement already satisfied: matplotlib in /usr/local/lib/python3.12/dist-packages (3.10.0)\n",
            "Requirement already satisfied: seaborn in /usr/local/lib/python3.12/dist-packages (0.13.2)\n",
            "Requirement already satisfied: numpy>=1.19.5 in /usr/local/lib/python3.12/dist-packages (from scikit-learn) (2.0.2)\n",
            "Requirement already satisfied: scipy>=1.6.0 in /usr/local/lib/python3.12/dist-packages (from scikit-learn) (1.16.1)\n",
            "Requirement already satisfied: joblib>=1.2.0 in /usr/local/lib/python3.12/dist-packages (from scikit-learn) (1.5.2)\n",
            "Requirement already satisfied: threadpoolctl>=3.1.0 in /usr/local/lib/python3.12/dist-packages (from scikit-learn) (3.6.0)\n",
            "Requirement already satisfied: contourpy>=1.0.1 in /usr/local/lib/python3.12/dist-packages (from matplotlib) (1.3.3)\n",
            "Requirement already satisfied: cycler>=0.10 in /usr/local/lib/python3.12/dist-packages (from matplotlib) (0.12.1)\n",
            "Requirement already satisfied: fonttools>=4.22.0 in /usr/local/lib/python3.12/dist-packages (from matplotlib) (4.59.2)\n",
            "Requirement already satisfied: kiwisolver>=1.3.1 in /usr/local/lib/python3.12/dist-packages (from matplotlib) (1.4.9)\n",
            "Requirement already satisfied: packaging>=20.0 in /usr/local/lib/python3.12/dist-packages (from matplotlib) (25.0)\n",
            "Requirement already satisfied: pillow>=8 in /usr/local/lib/python3.12/dist-packages (from matplotlib) (11.3.0)\n",
            "Requirement already satisfied: pyparsing>=2.3.1 in /usr/local/lib/python3.12/dist-packages (from matplotlib) (3.2.3)\n",
            "Requirement already satisfied: python-dateutil>=2.7 in /usr/local/lib/python3.12/dist-packages (from matplotlib) (2.9.0.post0)\n",
            "Requirement already satisfied: pandas>=1.2 in /usr/local/lib/python3.12/dist-packages (from seaborn) (2.2.2)\n",
            "Requirement already satisfied: pytz>=2020.1 in /usr/local/lib/python3.12/dist-packages (from pandas>=1.2->seaborn) (2025.2)\n",
            "Requirement already satisfied: tzdata>=2022.7 in /usr/local/lib/python3.12/dist-packages (from pandas>=1.2->seaborn) (2025.2)\n",
            "Requirement already satisfied: six>=1.5 in /usr/local/lib/python3.12/dist-packages (from python-dateutil>=2.7->matplotlib) (1.17.0)\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "from sklearn.preprocessing import StandardScaler\n",
        "from sklearn.decomposition import PCA\n",
        "from sklearn.cluster import KMeans\n",
        "import seaborn as sns\n",
        "import matplotlib.pyplot as plt\n",
        "\n",
        "# Load the generated proteins\n",
        "df = pd.read_csv(\"proteins.csv\")\n",
        "\n",
        "# ───────────────────────────────────────────────────────\n",
        "# 🧠 Add Heuristic Scoring Function\n",
        "# ───────────────────────────────────────────────────────\n",
        "\n",
        "def compute_score(row):\n",
        "    score = 0\n",
        "    if row[\"Stability\"] == \"Stable\":\n",
        "        score += 1\n",
        "    score += max(0, 1 - abs(row[\"GRAVY\"]))                  # Closer to 0 is better\n",
        "    score += max(0, 1 - abs(row[\"pI\"] - 7)) * 0.5            # pI near 7 preferred\n",
        "    score += (1 - row[\"Instability\"] / 100)                 # Lower instability\n",
        "    return round(score, 3)\n",
        "\n",
        "df[\"Score\"] = df.apply(compute_score, axis=1)\n",
        "\n",
        "# ───────────────────────────────────────────────────────\n",
        "# 📊 Top N Candidates\n",
        "# ───────────────────────────────────────────────────────\n",
        "\n",
        "TOP_N = 10\n",
        "top_proteins = df.sort_values(\"Score\", ascending=False).head(TOP_N)\n",
        "\n",
        "# Save CSV and FASTA\n",
        "top_proteins.to_csv(\"top_proteins.csv\", index=False)\n",
        "with open(\"top_proteins.fasta\", \"w\") as fasta_file:\n",
        "    for _, row in top_proteins.iterrows():\n",
        "        fasta_file.write(f\">{row['Protein ID']}\\n{row['Sequence']}\\n\")\n",
        "\n",
        "print(f\"\\n✅ Top {TOP_N} proteins saved to 'top_proteins.csv' and 'top_proteins.fasta'.\")\n",
        "\n",
        "# ───────────────────────────────────────────────────────\n",
        "# 📈 Optional: PCA + KMeans Clustering (Unsupervised ML)\n",
        "# ───────────────────────────────────────────────────────\n",
        "\n",
        "# Features for ML\n",
        "features = [\"MW (Da)\", \"pI\", \"GRAVY\", \"Aromaticity\", \"Instability\"]\n",
        "X = df[features].copy()\n",
        "\n",
        "# Standardize\n",
        "scaler = StandardScaler()\n",
        "X_scaled = scaler.fit_transform(X)\n",
        "\n",
        "# PCA for 2D visualization\n",
        "pca = PCA(n_components=2)\n",
        "X_pca = pca.fit_transform(X_scaled)\n",
        "df[\"PCA1\"] = X_pca[:, 0]\n",
        "df[\"PCA2\"] = X_pca[:, 1]\n",
        "\n",
        "# KMeans clustering\n",
        "kmeans = KMeans(n_clusters=3, random_state=42)\n",
        "df[\"Cluster\"] = kmeans.fit_predict(X_scaled)\n",
        "\n",
        "# ───────────────────────────────────────────────────────\n",
        "# 📊 Plot: Clusters and Top Proteins Highlighted\n",
        "# ───────────────────────────────────────────────────────\n",
        "\n",
        "plt.figure(figsize=(10, 6))\n",
        "sns.scatterplot(data=df, x=\"PCA1\", y=\"PCA2\", hue=\"Cluster\", palette=\"Set2\", s=80)\n",
        "sns.scatterplot(data=top_proteins, x=\"PCA1\", y=\"PCA2\", color=\"red\", s=150, marker=\"*\", label=\"Top Candidates\")\n",
        "plt.title(\"Protein Clusters (PCA) with Top Candidates Highlighted\")\n",
        "plt.legend()\n",
        "plt.grid(True)\n",
        "plt.tight_layout()\n",
        "plt.show()\n"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 1523
        },
        "id": "hYf7KYk4SQJ3",
        "outputId": "78d68760-179c-4525-ca74-aa49c557b58c"
      },
      "execution_count": 8,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "\n",
            "✅ Top 10 proteins saved to 'top_proteins.csv' and 'top_proteins.fasta'.\n"
          ]
        },
        {
          "output_type": "error",
          "ename": "ValueError",
          "evalue": "Could not interpret value `PCA1` for `x`. An entry with this name does not appear in `data`.",
          "traceback": [
            "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
            "\u001b[0;31mValueError\u001b[0m                                Traceback (most recent call last)",
            "\u001b[0;32m/tmp/ipython-input-1727115295.py\u001b[0m in \u001b[0;36m<cell line: 0>\u001b[0;34m()\u001b[0m\n\u001b[1;32m     66\u001b[0m \u001b[0mplt\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mfigure\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mfigsize\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m10\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;36m6\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     67\u001b[0m \u001b[0msns\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mscatterplot\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mdata\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mdf\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mx\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m\"PCA1\"\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0my\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m\"PCA2\"\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mhue\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m\"Cluster\"\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mpalette\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m\"Set2\"\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0ms\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m80\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 68\u001b[0;31m \u001b[0msns\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mscatterplot\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mdata\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mtop_proteins\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mx\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m\"PCA1\"\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0my\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m\"PCA2\"\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mcolor\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m\"red\"\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0ms\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m150\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mmarker\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m\"*\"\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mlabel\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m\"Top Candidates\"\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     69\u001b[0m \u001b[0mplt\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mtitle\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m\"Protein Clusters (PCA) with Top Candidates Highlighted\"\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     70\u001b[0m \u001b[0mplt\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mlegend\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m/usr/local/lib/python3.12/dist-packages/seaborn/relational.py\u001b[0m in \u001b[0;36mscatterplot\u001b[0;34m(data, x, y, hue, size, style, palette, hue_order, hue_norm, sizes, size_order, size_norm, markers, style_order, legend, ax, **kwargs)\u001b[0m\n\u001b[1;32m    613\u001b[0m ):\n\u001b[1;32m    614\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 615\u001b[0;31m     p = _ScatterPlotter(\n\u001b[0m\u001b[1;32m    616\u001b[0m         \u001b[0mdata\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mdata\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    617\u001b[0m         \u001b[0mvariables\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mdict\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mx\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mx\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0my\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0my\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mhue\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mhue\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0msize\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0msize\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mstyle\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mstyle\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m/usr/local/lib/python3.12/dist-packages/seaborn/relational.py\u001b[0m in \u001b[0;36m__init__\u001b[0;34m(self, data, variables, legend)\u001b[0m\n\u001b[1;32m    394\u001b[0m         )\n\u001b[1;32m    395\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 396\u001b[0;31m         \u001b[0msuper\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m__init__\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mdata\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mdata\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mvariables\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mvariables\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    397\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    398\u001b[0m         \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mlegend\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mlegend\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m/usr/local/lib/python3.12/dist-packages/seaborn/_base.py\u001b[0m in \u001b[0;36m__init__\u001b[0;34m(self, data, variables)\u001b[0m\n\u001b[1;32m    632\u001b[0m         \u001b[0;31m# information for numeric axes would be information about log scales.\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    633\u001b[0m         \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_var_ordered\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34m{\u001b[0m\u001b[0;34m\"x\"\u001b[0m\u001b[0;34m:\u001b[0m \u001b[0;32mFalse\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m\"y\"\u001b[0m\u001b[0;34m:\u001b[0m \u001b[0;32mFalse\u001b[0m\u001b[0;34m}\u001b[0m  \u001b[0;31m# alt., used DefaultDict\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 634\u001b[0;31m         \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0massign_variables\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mdata\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mvariables\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    635\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    636\u001b[0m         \u001b[0;31m# TODO Lots of tests assume that these are called to initialize the\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m/usr/local/lib/python3.12/dist-packages/seaborn/_base.py\u001b[0m in \u001b[0;36massign_variables\u001b[0;34m(self, data, variables)\u001b[0m\n\u001b[1;32m    677\u001b[0m             \u001b[0;31m# to centralize / standardize data consumption logic.\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    678\u001b[0m             \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0minput_format\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34m\"long\"\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 679\u001b[0;31m             \u001b[0mplot_data\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mPlotData\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mdata\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mvariables\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    680\u001b[0m             \u001b[0mframe\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mplot_data\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mframe\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    681\u001b[0m             \u001b[0mnames\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mplot_data\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnames\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m/usr/local/lib/python3.12/dist-packages/seaborn/_core/data.py\u001b[0m in \u001b[0;36m__init__\u001b[0;34m(self, data, variables)\u001b[0m\n\u001b[1;32m     56\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     57\u001b[0m         \u001b[0mdata\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mhandle_data_source\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mdata\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 58\u001b[0;31m         \u001b[0mframe\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mnames\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mids\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_assign_variables\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mdata\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mvariables\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     59\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     60\u001b[0m         \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mframe\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mframe\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m/usr/local/lib/python3.12/dist-packages/seaborn/_core/data.py\u001b[0m in \u001b[0;36m_assign_variables\u001b[0;34m(self, data, variables)\u001b[0m\n\u001b[1;32m    230\u001b[0m                 \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    231\u001b[0m                     \u001b[0merr\u001b[0m \u001b[0;34m+=\u001b[0m \u001b[0;34m\"An entry with this name does not appear in `data`.\"\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 232\u001b[0;31m                 \u001b[0;32mraise\u001b[0m \u001b[0mValueError\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0merr\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    233\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    234\u001b[0m             \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;31mValueError\u001b[0m: Could not interpret value `PCA1` for `x`. An entry with this name does not appear in `data`."
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 1000x600 with 1 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "from sklearn.preprocessing import StandardScaler\n",
        "from sklearn.decomposition import PCA\n",
        "from sklearn.cluster import KMeans\n",
        "import seaborn as sns\n",
        "import matplotlib.pyplot as plt\n",
        "\n",
        "# ───────────────────────────────────────────────────────\n",
        "# 🧠 Heuristic Scoring Function\n",
        "# ───────────────────────────────────────────────────────\n",
        "\n",
        "def compute_score(row):\n",
        "    score = 0\n",
        "    if row[\"Stability\"] == \"Stable\":\n",
        "        score += 1\n",
        "    score += max(0, 1 - abs(row[\"GRAVY\"]))                  # Closer to 0 is better\n",
        "    score += max(0, 1 - abs(row[\"pI\"] - 7)) * 0.5            # Neutral pI is ideal\n",
        "    score += (1 - row[\"Instability\"] / 100)                 # Lower instability is better\n",
        "    return round(score, 3)\n",
        "\n",
        "# Apply scoring\n",
        "df[\"Score\"] = df.apply(compute_score, axis=1)\n",
        "\n",
        "# ───────────────────────────────────────────────────────\n",
        "# 📊 ML Features: Normalize + PCA + Clustering\n",
        "# ───────────────────────────────────────────────────────\n",
        "\n",
        "features = [\"MW (Da)\", \"pI\", \"GRAVY\", \"Aromaticity\", \"Instability\"]\n",
        "X = df[features]\n",
        "\n",
        "# Scale features\n",
        "scaler = StandardScaler()\n",
        "X_scaled = scaler.fit_transform(X)\n",
        "\n",
        "# PCA\n",
        "pca = PCA(n_components=2)\n",
        "X_pca = pca.fit_transform(X_scaled)\n",
        "df[\"PCA1\"] = X_pca[:, 0]\n",
        "df[\"PCA2\"] = X_pca[:, 1]\n",
        "\n",
        "# KMeans clustering\n",
        "kmeans = KMeans(n_clusters=3, random_state=42)\n",
        "df[\"Cluster\"] = kmeans.fit_predict(X_scaled)\n",
        "\n",
        "# ───────────────────────────────────────────────────────\n",
        "# 🔝 Top N Selection (after PCA so PCA1/2 exist)\n",
        "# ───────────────────────────────────────────────────────\n",
        "\n",
        "TOP_N = 10\n",
        "top_proteins = df.sort_values(\"Score\", ascending=False).head(TOP_N).copy()\n",
        "\n",
        "# Optional: Save top protein data\n",
        "top_proteins.to_csv(\"top_proteins.csv\", index=False)\n",
        "\n",
        "with open(\"top_proteins.fasta\", \"w\") as fasta_file:\n",
        "    for _, row in top_proteins.iterrows():\n",
        "        fasta_file.write(f\">{row['Protein ID']}\\n{row['Sequence']}\\n\")\n",
        "\n",
        "print(f\"\\n✅ Top {TOP_N} proteins saved to 'top_proteins.csv' and 'top_proteins.fasta'.\")\n",
        "\n",
        "# ───────────────────────────────────────────────────────\n",
        "# 📈 Plot PCA Clusters & Highlight Top Proteins\n",
        "# ───────────────────────────────────────────────────────\n",
        "\n",
        "plt.figure(figsize=(10, 6))\n",
        "sns.scatterplot(data=df, x=\"PCA1\", y=\"PCA2\", hue=\"Cluster\", palette=\"Set2\", s=80)\n",
        "sns.scatterplot(data=top_proteins, x=\"PCA1\", y=\"PCA2\", color=\"red\", s=150, marker=\"*\", label=\"Top Candidates\")\n",
        "plt.title(\"Protein Clusters (PCA) with Top Candidates Highlighted\")\n",
        "plt.legend()\n",
        "plt.grid(True)\n",
        "plt.tight_layout()\n",
        "plt.show()\n"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 663
        },
        "id": "w6i8b4mQTH96",
        "outputId": "fcfc2846-f129-4463-d99e-072f1b852a76"
      },
      "execution_count": 9,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "\n",
            "✅ Top 10 proteins saved to 'top_proteins.csv' and 'top_proteins.fasta'.\n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 1000x600 with 1 Axes>"
            ],
            "image/png": "iVBORw0KGgoAAAANSUhEUgAAA90AAAJOCAYAAACqS2TfAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjAsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvlHJYcgAAAAlwSFlzAAAPYQAAD2EBqD+naQAAzSZJREFUeJzs3XecFPX9x/HXzGy5flyv9N5BEBUFQREES9QYbCF2E6Mxxmg0mqgkkphY4s+usYWiohjUiAWwIlgo0nvvHQ64trsz8/vjuJPj2h53xxXez8eDB7czn5n5zux3Dz77bYbrui4iIiIiIiIiUuvM+i6AiIiIiIiISFOlpFtERERERESkjijpFhEREREREakjSrpFRERERERE6oiSbhEREREREZE6oqRbREREREREpI4o6RYRERERERGpI0q6RUREREREROqIkm4RERERERGROqKkW0TkGKxfvx7DMHjttdfq5fpffPEFhmHwxRdf1Mv165PjOHTr1o0xY8bUd1FKef7552nRogWFhYV1eh3DMHjwwQfDjr311lvrtDwnqlatWnHNNdeUvK7OZ3LQoEEMGjSozsrWUNTkPgcNGkS3bt2qjCvvd/GDDz6IYRjHdN3iY3fv3n1Mx9eGE/n3u0hTpaRbRBqM1157DcMwSv5ERETQoUMHbr31Vnbs2FGr1/rb3/7Gu+++W6vnrC2TJ09m+PDhJCcn4/P5yMzMZOTIkXz22WfHrQyzZs3iwQcfZP/+/cftmuF644032LRpU6lksrp1Z8eOHdx555106tSJqKgooqOj6dOnDw899FCF99yvXz8Mw+C5554rd/8111xDIBDghRdeqJX7DFddvFeDBg0q9Twr+hNu8l9Ttm3z6quvMmjQIBITE/H7/bRq1Yprr72WOXPmHJcyNAR5eXk8+OCD9ZKMFSeCkyZNKnf/NddcQ0xMzHEuVf1qyP+OiEjD4qnvAoiIHO0vf/kLrVu3pqCggK+//prnnnuODz/8kMWLFxMVFVUr1/jb3/7GpZdeykUXXXRMx7ds2ZL8/Hy8Xm+tlAfAdV2uu+46XnvtNXr37s0dd9xBeno627ZtY/LkyZx99tnMnDmT/v3719o1KzJr1ixGjx7NNddcQ7Nmzer8etXxyCOPcPnllxMfH19mXzh1Z/bs2YwYMYJDhw7x85//nD59+gAwZ84cHn74Yb766iumTp1a6ryrVq1i9uzZtGrVigkTJnDzzTeXuXZERARXX301jz/+OL/5zW+OuaWtKvn5+Xg8P/7zXRfv1X333ccNN9xQ8nr27Nk8+eST3HvvvXTu3Llke48ePWrlepXJz8/nkksu4eOPP2bgwIHce++9JCYmsn79et566y3+85//sHHjRrKzs+u8LJUZOHAg+fn5+Hy+OrtGXl4eo0ePBmgULeVHf46Olz/96U/cc889dX6dmv47IiInDiXdItLgDB8+nL59+wJwww03kJSUxOOPP857773HFVdcUe4xubm5REdHH7cyFrem1qbHHnuM1157jdtvv53HH3+8VNJ23333MW7cuFLJVmOUl5dXoy9OfvjhBxYsWMBjjz1W7v6q6s7+/fu5+OKLsSyLH374gU6dOpU6fsyYMfz73/8uc97x48eTmprKY489xqWXXsr69etp1apVmbiRI0fyz3/+k88//5yzzjrrmO+zMrVd78pzzjnnlLnmk08+yTnnnHPck7277rqLjz/+mH/961/cfvvtpfY98MAD/Otf/zqu5amIaZrH5b1pTOryC4jKeDyeRv+7UkSaFnUvF5EGrzh5WbduHfBjN8Y1a9YwYsQIYmNjueqqq4Ci5Pv3v/89zZs3x+/307FjRx599FFc1y05n2EY5Obm8p///Kekm+yRYzO3bNnCddddR1paGn6/n65du/LKK6+UKlN54wiLy7VlyxYuuugiYmJiSElJ4c4778S27UrvMT8/n7///e906tSJRx99tNxW0lGjRtGvX78Kz3H0GNNi5Y2rfOqpp+jatStRUVEkJCTQt29fXn/9daBoTONdd90FQOvWrUue0fr160uOHz9+PH369CEyMpLExEQuv/xyNm3aVOa63bp1Y+7cuQwcOJCoqCjuvfdeoKhVediwYSQnJxMZGUnr1q257rrrKn1GAO+++y4+n4+BAwdWGQtl684LL7zAli1bePzxx8sk3ABpaWn86U9/KrP99ddf59JLL+X8888nPj6+5FkdrU+fPiQmJvLee+9VWq4nn3wSy7JKdQl/7LHHMAyDO+64o2SbbdvExsZy9913l2w7slt3OO8VFD23bt26ldTnjz/+uNLyhevZZ5+la9eu+P1+MjMzueWWW8p0cz+yHvTv37/k/X7++eerPP/mzZt54YUXOOecc8ok3ACWZXHnnXeWtHJv2LCBX//613Ts2JHIyEiSkpL42c9+VuZ5FA9HmDlzJnfccQcpKSlER0dz8cUXs2vXrlKxruvy0EMPkZ2dTVRUFIMHD2bJkiVlylLRONwXX3yRtm3bEhkZSb9+/ZgxY0aZYwOBAPfffz99+vQhPj6e6OhoBgwYwOeff14Ss379elJSUgAYPXp0uV38ly9fzqWXXkpiYiIRERH07duX999/v9S1gsEgo0ePpn379kRERJCUlMQZZ5zBtGnTypSrpsr73bNhwwYuvPBCoqOjSU1N5Xe/+x2ffPJJhWOYly5dyuDBg4mKiiIrK4t//vOfVV63vDHd+fn53HbbbSQnJxMbG8uFF17Ili1bKhwmsX///pLeI/Hx8Vx77bXk5eWV7K+Nf0egqI5fdNFFpZ5HXc8LISLHn74GFJEGb82aNQAkJSWVbAuFQgwbNowzzjiDRx99lKioKFzX5cILL+Tzzz/n+uuvp1evXnzyySfcddddbNmypaRFbNy4cdxwww3069ePm266CYC2bdsCRWN9Tz311JIJqFJSUvjoo4+4/vrrOXDgQLn/8T+SbdsMGzaMU045hUcffZTp06fz2GOP0bZt23K7JBf7+uuv2bt3L7fffjuWZdXkcVXp3//+N7fddhuXXnopv/3tbykoKGDhwoV89913XHnllVxyySWsXLmSN954g3/9618kJycDlPyHf8yYMfz5z39m5MiR3HDDDezatYunnnqKgQMH8sMPP5Tq4rxnzx6GDx/O5Zdfzs9//nPS0tLYuXMnQ4cOJSUlhXvuuYdmzZqxfv16/vvf/1ZZ9lmzZtGtW7ewu/UfXXfef/99IiMjufTSS8N+Xt999x2rV6/m1VdfxefzcckllzBhwoSSLxCOdtJJJzFz5sxKzzlgwAAcx+Hrr7/m/PPPB2DGjBmYplkqKfvhhx84dOhQhV8yVPVeQVHd+u9//8uvf/1rYmNjefLJJ/npT3/Kxo0bS32mquvBBx9k9OjRDBkyhJtvvpkVK1bw3HPPMXv2bGbOnFnqPdq3bx8jRoxg5MiRXHHFFbz11lvcfPPN+Hy+Sr9s+eijjwiFQowaNSqsMs2ePZtZs2Zx+eWXk52dzfr163nuuecYNGgQS5cuLdPL4je/+Q0JCQk88MADrF+/nieeeIJbb72ViRMnlsTcf//9PPTQQ4wYMYIRI0Ywb948hg4dSiAQqLI8L7/8Mr/85S/p378/t99+O2vXruXCCy8kMTGR5s2bl8QdOHCAl156iSuuuIIbb7yRgwcP8vLLLzNs2DC+//57evXqRUpKCs899xw333wzF198MZdccgnwYxf/JUuWcPrpp5OVlcU999xDdHQ0b731FhdddBHvvPMOF198MVD0vv39738v+R144MAB5syZw7x588r0cCjPwYMHy51kLJxEMTc3l7POOott27bx29/+lvT0dF5//fVSXy4cad++fZx77rlccskljBw5kkmTJnH33XfTvXt3hg8fXuX1jnTNNdfw1ltvMWrUKE499VS+/PJLzjvvvArjR44cSevWrfn73//OvHnzeOmll0hNTeUf//gHUDv/juTn53P22WezceNGbrvtNjIzMxk3btxxnb9DRI4TV0SkgXj11VddwJ0+fbq7a9cud9OmTe6bb77pJiUluZGRke7mzZtd13Xdq6++2gXce+65p9Tx7777rgu4Dz30UKntl156qWsYhrt69eqSbdHR0e7VV19dpgzXX3+9m5GR4e7evbvU9ssvv9yNj4938/LyXNd13XXr1rmA++qrr5bEFJfrL3/5S6lje/fu7fbp06fSe/+///s/F3AnT55caVyxzz//3AXczz//vGRby5Yty72nM8880z3zzDNLXv/kJz9xu3btWun5H3nkERdw161bV2r7+vXrXcuy3DFjxpTavmjRItfj8ZTafuaZZ7qA+/zzz5eKnTx5sgu4s2fPrvwmy5Gdne3+9Kc/LbM93LqTkJDg9uzZs1rXvPXWW93mzZu7juO4ruu6U6dOdQH3hx9+KDf+pptuciMjIys9p23bblxcnPuHP/zBdV3XdRzHTUpKcn/2s5+5lmW5Bw8edF3XdR9//HHXNE133759JccC7gMPPFDyuqL3qjjW5/OVqvsLFixwAfepp54K4+6LvP3226Xq286dO12fz+cOHTrUtW27JO7pp592AfeVV14p2VZcDx577LGSbYWFhW6vXr3c1NRUNxAIVHjd3/3ud5U+66MVfz6P9M0337iAO3bs2JJtxfVlyJAhJe9r8fUsy3L3799f6j7PO++8UnH33nuvC5T6vB39mQwEAm5qaqrbq1cvt7CwsCTuxRdfdIFSn8lQKFQqxnVdd9++fW5aWpp73XXXlWzbtWtXmfe/2Nlnn+12797dLSgoKNnmOI7bv39/t3379iXbevbs6Z533nlljq9K8f1V9ic6OrrUMUf/7nnsscdcwH333XdLtuXn57udOnUq8/usuN4c+b4VFha66enppX4HlPe7+IEHHnCP/C/u3LlzXcC9/fbbS5XvmmuuKfM8i4898rm7rutefPHFblJSUqltNf135IknnnAB96233iqJyc3Nddu1a1fmeYhI46bu5SLS4AwZMoSUlBSaN2/O5ZdfTkxMDJMnTyYrK6tU3NEtxx9++CGWZXHbbbeV2v773/8e13X56KOPKr2u67q88847XHDBBbiuy+7du0v+DBs2jJycHObNm1dl+X/1q1+Vej1gwADWrl1b6TEHDhwAIDY2tsrz11SzZs3YvHkzs2fPrvax//3vf3Ech5EjR5Z6Punp6bRv375Mi5Xf7+faa68tc32ADz74gGAwWK3r79mzh4SEhAr3V1V3Dhw4UK1nHAqFmDhxIpdddllJd9WzzjqL1NRUJkyYUO4xCQkJ5Ofnl+qKejTTNOnfvz9fffUVAMuWLWPPnj3cc889uK7LN998AxS1fnfr1q1GE6QNGTKkpAUOilpG4+LiqqyTlZk+fTqBQIDbb78d0/zxvxI33ngjcXFxTJkypVS8x+Phl7/8Zclrn8/HL3/5S3bu3MncuXMrvE51PxeRkZElPweDQfbs2UO7du1o1qxZuZ/dm266qVQ35AEDBmDbNhs2bCh1n0dPjFdVjxcoGkKxc+dOfvWrX5Ua23zNNdeUmQTQsqySGMdx2Lt3L6FQiL59+4b1O2fv3r189tlnjBw5sqQlevfu3ezZs4dhw4axatUqtmzZAhR9/pYsWcKqVauqPG957r//fqZNm1bmz9ChQ6s89uOPPyYrK4sLL7ywZFtERAQ33nhjufExMTH8/Oc/L3nt8/no169ftetu8XCKX//616W2/+Y3v6nwmPJ+j+/Zs6ekTlakOv+OfPjhh2RkZJTqeRMVFVXSci4iTYe6l4tIg/PMM8/QoUMHPB4PaWlpdOzYsdR/7KHoP/FHz1a8YcMGMjMzy/wHvXi25eL/SFdk165d7N+/nxdffJEXX3yx3JidO3dWeo6IiIhSXXuhKAnbt29fpcfFxcUBRV0369rdd9/N9OnT6devH+3atWPo0KFceeWVnH766VUeu2rVKlzXpX379uXuP7rbd1ZWVpnJlM4880x++tOfMnr0aP71r38xaNAgLrroIq688kr8fn+VZXCPGJ9/tKrqTlxcXLWe8dSpU9m1axf9+vVj9erVJdsHDx7MG2+8wT/+8Y8ydbO4fFXNXj5gwAAefPBB8vPzmTFjBhkZGZx00kn07NmTGTNmcM455/D1118zcuTIsMtbnhYtWpTZFk6drEzxZ6ljx46ltvt8Ptq0aVPms5aZmVlmosMOHToARWOVTz311HKvU93PRfHcCK+++ipbtmwpVVdycnLKxB/9bIq/0Cl+NsX3cXR9T0lJqfTLn8qO9Xq9tGnTpkz8f/7zHx577DGWL19e6suo1q1bV3odgNWrV+O6Ln/+85/585//XG7Mzp07ycrK4i9/+Qs/+clP6NChA926dePcc89l1KhRYc9E3717d4YMGVJm+/jx46s8dsOGDbRt27bMZ6Ndu3blxmdnZ5eJTUhIYOHChWGV9cjrmqZZ5llWdF2ovG4U18vyVOffkQ0bNtCuXbsy93j050pEGj8l3SLS4PTr169kBuqK+P3+MslOTTmOA8DPf/5zrr766nJjqvqP6bGOxy6e1GvRokXHvPxMRUmebdulytW5c2dWrFjBBx98wMcff8w777zDs88+y/3331+yHFFFHMfBMAw++uijcu/16HV6j2x5PLKckyZN4ttvv+V///sfn3zyCddddx2PPfYY3377baVr/SYlJVWaLFZVdzp16sT8+fMJBAJhzaxc3JpdUeL75ZdfMnjw4FLb9u3bR1RUVLn3fqQzzjiDYDDIN998w4wZMxgwYABQlIzPmDGD5cuXs2vXrpLtx6qiOlnZlxcNxZGfi169elUZ/5vf/IZXX32V22+/ndNOO434+HgMw+Dyyy8v+XwfqaE8m/Hjx3PNNddw0UUXcdddd5GamoplWfz9738vmZegMsX3dueddzJs2LByY4oTzIEDB7JmzRree+89pk6dyksvvcS//vUvnn/++VLLxDUE9fn+HOu1a+PfERFpepR0i0iT0bJlS6ZPn87BgwdLtXYvX768ZH+x8hLUlJQUYmNjsW273JacunTGGWeQkJDAG2+8wb333ntMyXtCQkKZmaOhqDXl6Ja16OhoLrvsMi677DICgQCXXHIJY8aM4Y9//CMREREVJvBt27bFdV1at25d0lJ5rE499VROPfVUxowZw+uvv85VV13Fm2++Wel//Dt16lQyE/mxuOCCC/jmm2945513Klx+rlhubi7vvfcel112WbkTr912221MmDChTNK9bt26UmtZV6Rfv374fD5mzJjBjBkzSmYhHzhwIP/+97/59NNPS15Xpq7WA69M8WdpxYoVpepWIBBg3bp1ZT4/W7duLbOs38qVKwHKXXqt2PDhw7Esi/Hjx4c1mdqkSZO4+uqrSy0pV1BQUO7nIhzF97lq1apS97lr164qewoceeyRy8cFg0HWrVtHz549S5W7TZs2/Pe//y31fj7wwAOlzlnRe11cNq/XG9bvrsTERK699lquvfbakon6HnzwwTpPulu2bMnSpUtxXbfUvRzZi6Surus4DuvWrSvV86Cm163pvyMtW7Zk8eLFZZ7HihUralQuEWl4NKZbRJqMESNGYNs2Tz/9dKnt//rXvzAMo9Rst9HR0WX+I25ZFj/96U955513WLx4cZnzH72UUG2Kiori7rvvZtmyZdx9993ltqaMHz+e77//vsJztG3blm+//bbUrMoffPBBmaW89uzZU+q1z+ejS5cuuK5b0q21ODk6+hldcsklWJbF6NGjy5TRdd0y5y7Pvn37yhxb3IpZ1QzIp512GosXLz7mJXV+9atfkZGRwe9///uSpO9IO3fu5KGHHgJg8uTJ5Obmcsstt3DppZeW+XP++efzzjvvlCnLvHnz6N+/f5VliYiI4OSTT+aNN95g48aNpVq68/PzefLJJ2nbti0ZGRmVnqei96ouDRkyBJ/Px5NPPlnqvXz55ZfJyckpMyt0KBTihRdeKHkdCAR44YUXSElJoU+fPhVep3nz5tx4441MnTqVp556qsx+x3F47LHH2Lx5M1D0GT66bj311FNVLtlX2X16vV6eeuqpUud94oknqjy2b9++pKSk8Pzzz5f6TL722mvl/u6B0q2o3333XcnY/mLFs68ffXxqaiqDBg3ihRdeYNu2bWXKcuTvrqM/ozExMbRr1+64LFM1bNgwtmzZUmoZs4KCAv7973/X+XWhaIm7I5VXp6qjpv+OjBgxgq1btzJp0qSSbXl5eRV2SxeRxkst3SLSZFxwwQUMHjyY++67j/Xr19OzZ0+mTp3Ke++9x+23315qMqk+ffowffp0Hn/8cTIzM2ndujWnnHIKDz/8MJ9//jmnnHIKN954I126dGHv3r3MmzeP6dOns3fv3jor/1133cWSJUt47LHH+Pzzz7n00ktJT09n+/btvPvuu3z//ffMmjWrwuNvuOEGJk2axLnnnsvIkSNZs2YN48ePL3XfAEOHDiU9PZ3TTz+dtLQ0li1bxtNPP815551X0kOgOBG67777uPzyy/F6vVxwwQW0bduWhx56iD/+8Y+sX7+eiy66iNjYWNatW8fkyZO56aabuPPOOyu9z//85z88++yzXHzxxbRt25aDBw/y73//m7i4OEaMGFHpsT/5yU/461//ypdffhnWxE1HS0hIYPLkyYwYMYJevXrx85//vORe582bxxtvvMFpp50GFHUtT0pKqjCBvvDCC/n3v//NlClTSpZvmjt3Lnv37uUnP/lJWOUZMGAADz/8MPHx8XTv3h0oSqA6duzIihUryl13/WgVvVdHj6GuTSkpKfzxj39k9OjRnHvuuVx44YWsWLGCZ599lpNPPrnU5FdQNKb7H//4B+vXr6dDhw5MnDiR+fPn8+KLL1a5/Ntjjz3GmjVruO222/jvf//L+eefT0JCAhs3buTtt99m+fLlXH755QCcf/75jBs3jvj4eLp06cI333zD9OnTj3lptJSUFO68807+/ve/c/755zNixAh++OEHPvroo5Ll2Sri9Xp56KGH+OUvf8lZZ53FZZddxrp163j11VfL9Dw5//zz+e9//8vFF1/Meeedx7p163j++efp0qULhw4dKomLjIykS5cuTJw4kQ4dOpCYmEi3bt3o1q0bzzzzDGeccQbdu3fnxhtvpE2bNuzYsYNvvvmGzZs3s2DBAgC6dOnCoEGDStaUnzNnDpMmTeLWW289pmdUHb/85S95+umnueKKK/jtb39LRkYGEyZMICIiAqi7Xht9+vThpz/9KU888QR79uwpWTKs+Iu3Y71uTf8dufHGG3n66af5xS9+wdy5c8nIyGDcuHFllrYTkSbgOM2SLiJSpeJlfKpaSurqq68uszRNsYMHD7q/+93v3MzMTNfr9brt27d3H3nkkVLL/biu6y5fvtwdOHCgGxkZWWbpnx07dri33HKL27x5c9fr9brp6enu2Wef7b744oslMRUtGVZeuY5evqYqkyZNcocOHeomJia6Ho/HzcjIcC+77DL3iy++KIkpb8kw1y1akicrK8v1+/3u6aef7s6ZM6fMsj0vvPCCO3DgQDcpKcn1+/1u27Zt3bvuusvNyckpda6//vWvblZWlmuaZpklqd555x33jDPOcKOjo93o6Gi3U6dO7i233OKuWLGiJObMM88sd2myefPmuVdccYXbokUL1+/3u6mpqe7555/vzpkzJ6zn06NHD/f6668vtS3culNs69at7u9+9zu3Q4cObkREhBsVFeX26dPHHTNmjJuTk+Pu2LHD9Xg87qhRoyo8R15enhsVFeVefPHFJdvuvvtut0WLFmXqW0WmTJniAu7w4cNLbb/hhhtcwH355ZfLHEM5S0ZV9F4B7i233FLmHBUtL1eRo5cMK/b000+7nTp1cr1er5uWlubefPPNpZY3c90f68GcOXPc0047zY2IiHBbtmzpPv3002FfPxQKuS+99JI7YMAANz4+3vV6vW7Lli3da6+9ttRyYvv27XOvvfZaNzk52Y2JiXGHDRvmLl++vMz9VlRfyvtc2bbtjh492s3IyHAjIyPdQYMGuYsXLy5zzoo+k88++6zbunVr1+/3u3379nW/+uqrMp9Jx3Hcv/3tb27Lli1dv9/v9u7d2/3ggw/cq6++2m3ZsmWp882aNcvt06eP6/P5ytSFNWvWuL/4xS/c9PR01+v1ullZWe7555/vTpo0qSTmoYcecvv16+c2a9bMjYyMdDt16uSOGTOm0qXbjry/t99+u9z95f3+O/o+Xdd1165d65533nluZGSkm5KS4v7+979333nnHRdwv/3221LHlvf74+hnEs6SYa5btBTXLbfc4iYmJroxMTHuRRdd5K5YscIF3IcffrjMsbt27Sp1fHGdOfL3YE3/HXFd192wYYN74YUXulFRUW5ycrL729/+1v3444+1ZJhIE2O4biOYSUVEROSwcePGccstt7Bx48YaLaVV2woLC2nVqhX33HMPv/3tb+u7OA3GoEGD2L17d7ldbUWgqLv+7373OzZv3lxmaci6NH/+fHr37s348eO56qqrjtt1ReTEozHdIiLSqFx11VW0aNGCZ555pr6LUsqrr76K1+sts76viPwoPz+/1OuCggJeeOEF2rdvX6cJ99HXhaJk3zTNKicrFBGpKY3pFhGRRsU0zQbZavqrX/1KCbdIFS655BJatGhBr169yMnJYfz48Sxfvrxkeb668s9//pO5c+cyePBgPB4PH330ER999BE33XQTzZs3r9Nri4go6RYRERGR42LYsGG89NJLTJgwAdu26dKlC2+++SaXXXZZnV63f//+TJs2jb/+9a8cOnSIFi1a8OCDD3LffffV6XVFRAA0pltERERERESkjmhMt4iIiIiIiEgdUdItIiIiIiIiUkdOqDHdjuOwdetWYmNjMQyjvosjIiIiIiIijYzruhw8eJDMzExMs+p27BMq6d66datmqBQREREREZEa27RpE9nZ2VXGnVBJd2xsLFD0cOLi4uq5NDUTDAaZOnUqQ4cOxev11ndxpJFR/ZGaUP2RmlD9kZpQ/ZGaUP2Rmjiy/uTn59O8efOS/LIqJ1TSXdylPC4urkkk3VFRUcTFxemXhlSb6o/UhOqP1ITqj9SE6o/UhOqP1ER59SfcIcuaSE1ERERERESkjjSapPu5556jR48eJa3Up512Gh999FF9F0tERERERESkQo0m6c7Ozubhhx9m7ty5zJkzh7POOouf/OQnLFmypL6LJiIiIiIiIlKuRjOm+4ILLij1esyYMTz33HN8++23dO3atVavZds2wWCwVs9Z24LBIB6Ph4KCAmzbru/iSDV4vV4sy6rvYoiIiIiIyHHQaJLuI9m2zdtvv01ubi6nnXZarZ3XdV22b9/O/v37a+2cdcV1XdLT09m0aZPWHG+EmjVrRnp6ut47EREREZEmrlEl3YsWLeK0006joKCAmJgYJk+eTJcuXSqMLywspLCwsOT1gQMHgKJW4vJasnfs2MGBAwdISUkhKiqqQSdEruuSm5tLdHR0gy6nlOa6Lnl5eezatQvbtklLS6uXchTX/4beo0MaJtUfqQnVH6kJ1R+pCdUfqYkj609165Dhuq5bF4WqC4FAgI0bN5KTk8OkSZN46aWX+PLLLytMvB988EFGjx5dZvvrr79OVFRUqW2GYZCRkUF6enrY662JHKuDBw+yfft2tm3bRiP6CIqIiIiInPDy8vK48sorycnJCWsp6kaVdB9tyJAhtG3blhdeeKHc/eW1dDdv3pzdu3eXeTiFhYVs3LiRli1bEhkZWaflrg2u63Lw4EFiY2PV0t0I5efns2HDBlq0aIHf7z/u1w8Gg0ybNo1zzjlH61RKtan+SE2o/khNqP5ITaj+SE0cWX/y8/NJTk4OO+luVN3Lj+Y4Tqmk+mh+v7/chMbr9Zb5oNm2jWEYWJaFaTb8Sd0dxwGKWugbQ3mlNMuyMAwDj8dTr7/0y/ssiIRL9UdqQvVHakL1R2pC9Udqwuv1EgqFqnVMo0m6//jHPzJ8+HBatGjBwYMHef311/niiy/45JNP6rtoIiIiIiIiIuVqNEn3zp07+cUvfsG2bduIj4+nR48efPLJJ5xzzjn1XbQSjusQsG1CrkNeKECUx4fHMPFZFqah1mgREREREZETTaNJul9++eX6LkKlCu0gK/bv5KNNS1h7cHfJ9jaxyQxv3pWOzVLxW3XXjeWZZ57hkUceYfv27fTs2ZOnnnqKfv361dn1REREREREpGpqfq0FhXaQDzcu4ZmlX5ZKuAHWHtzNM0u/5MONSyi062Z5gokTJ3LHHXfwwAMPMG/ePHr27MmwYcPYuXNnnVxPREREREREwqOku4Yc12HF/p18vHlppXEfb17KypydOK5T62V4/PHHufHGG7n22mvp0qULzz//PFFRUbzyyiu1fi0REREREakh2y79tzRpSrprKGDbfLRpSVixH21aQsCp3Q9WIBBg7ty5DBkypGSbaZoMGTKEb775plavJSIiIiIixybo2AQcmzU5u3AAZs/GBfJDddMbVhoOJd01FHKdMl3KK7LmwG5CTu22dO/evRvbtklLSyu1PS0tje3bt9fqtUREREREpPoK7RDf7ljH/bP/xxfbVmEYBlx/PRgGX21bRU4gn1AtN85Jw6Gku4byQoFqxedXM15ERERERBqvQjvEtM3LGL/6e/YF8uiTlI0z82tYtAhn1kzS/NE8NO8jcpUnNFmNZvbyhirK46tWfGQ146uSnJyMZVns2LGj1PYdO3aQnp5eq9cSEREREZEwhUJg21iuw0lxaZzUrahnalpsItZbjwBgvfU23R9/nN95IwkV5OM4BqZhFB1vWeBRutYU6F2sIY9h0iY2Oawu5m3jkvGYtdu5wOfz0adPHz799FMuuugiABzH4dNPP+XWW2+t1WuJiIiIiEg1+P14du4kc8IEKB5mGgjAuHFFP48di5WRQabvcMOcacJVV0FqalHSLk2Cku4a8lkWw5t35ZmlX1YZO7x5V3ymVetluOOOO7j66qvp27cv/fr144knniA3N5drr7221q8lIiIiIiJh8HgIOQ5WcjJut26Yo0bBUb1TycmBe+8t+jktDXf8eIzk5JLjpWnQmO4aMg2Tjs1SOTe7S6Vx52Z3oUN8GqZR+4/8sssu49FHH+X++++nV69ezJ8/n48//rjM5GoiIiIiInL8uLg8s+wrDvY/FXvxIhg6tPzAoUOxFy8icMbpRa3d0qToHa0FfsvLiBZduaXrmbSNSy61r21cMrd2PZMRLbrht+ru26pbb72VDRs2UFhYyHfffccpp5xSZ9cSEREREZGqhRyHA4ECRi/8hFVmEHfKFIiIKB0UEYE7ZQorjSDrCnLqp6BSp9RnoZb4LS/dEjLoEJ9KyHHIDwWI9PjwmCY+06qTFm4REREREWm4fKbF4MwOvLbyW/YHCnCWLMEqKCgdVFCAs3Qpuelx9ExoXj8FlTqlTLAWmYZJhOUlxusnJTKWGK+fCMurhFtERERE5ARkmSZ9kluQGhFDr4QMrIkTi3aMGoW9ciWMGlUUN3EivZpl4LpuPZZW6oqyQRERERERkTriMUz+0HMoEf5ImDYNZ8IEGDuW9anxMHYszvjxMHUqHp8fXx0OR5X6o3dVRERERESkjpimSbTHh5ubiztpEsH0NMYtn8my/dsZkd2VwSNH4p5xBkZuLkRFQfE63dJkKOkWERERERGpQ6ZtQ3Q0+P24uFzT4VQcFxzXwfR4ISuraImwYBC83vourtQyJd0iIiIiIiJ16fCa24bHQ+m5y61S+7U2d9OkMd0iIiIiIiJ1Kdwu4+pa3iQp6RYRERERERGpI0q6RUREREREROqIBg3UItdxIBQAOwSFeeCPAssDHh+Gqe83RERERERETjRKumuJGyjE3bwc97spsG3Njzsy2mKcch5kd8Lw+evk2l999RWPPPIIc+fOZdu2bUyePJmLLrqoTq4lIiIiIiIi4VPzay1wA4W4332A++6TpRNugG1rcN99smh/oLBOrp+bm0vPnj155pln6uT8IiIiIiIicmzU0l1DruMUtXDP/rDyuNkfYmS1w23Vvda7mg8fPpzhw4fX6jlFRERERESk5tTSXVOhQFGX8jA4339YNOZbRERERERETghKumvKDpXtUl6RrauL4kVEREREROSEoKS7pgrz6jZeREREREREGi0l3TXlj6rbeBEREREREWm0lHTXlOWBjLbhxWa2K4oXERERERGRE4KS7pry+IrW4Q6D2W8EeHy1XoRDhw4xf/585s+fD8C6deuYP38+GzdurPVriYiIiIiISPiUdNeQYZoY2Z0wTh5RedzJIyC7U60vFwYwZ84cevfuTe/evQG444476N27N/fff3+tX0tERERERETCp77OtcDw+eGU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5nD22WfTrVs3XnjhBTp16sTBgwd57733+P3vf8+XX35Z69esTEpKynG9noiIiIiISHWopbu2OQ7MmgWLFsE33xS9riNpaWmkp6eTnp5OfHw8hmGUvE5NTeXxxx8vaY3u1asXH3/8ccmx69evxzAM3nzzTfr3709ERATdunWrNGl2XZdrrrmG9u3bM2PGDM477zzatm1Lr169eOCBB3jvvfdKYu+++246dOhAVFQUbdq04c9//jPBYLBkf3Fr8rhx42jVqhXx8fFcfvnlHDx4sCQmNzeXX/ziF8TExJCRkcFjjz1WpkxHdy9ftWoVAwcOJCIigi5dujBt2rQyx1RWttdee43Ro0ezYMGCkh4Dr732GgD79+/nhhtuICUlhbi4OM466ywWLFhQct4FCxYwePBgYmNjiYuLo0+fPvXS+i8iIiIiIg2HWrqPVShU/phtjwcmTiz6eeJEOPVUKCwsG2dZRbF15P/+7/947LHHeOGFF+jduzevvPIKF154IUuWLKF9+/YlcXfddRdPPPEEXbp04fHHH+eCCy5g3bp1JCUllTnn/PnzWbJkCa+//jqmWfb7mmbNmpX8HBsby2uvvUZmZiaLFi3ixhtvJDY2lj/84Q8lMWvWrOHdd9/lgw8+YN++fYwcOZKHH36YMWPGlJTtyy+/5L333iM1NZV7772XefPmVdj123EcLrnkEtLS0vjuu+/IyckpNf47nLJddtllLF68mI8//pjp06cDEB8fD8DPfvYzIiMj+eijj4iPj+eFF17g7LPPZuXKlSQmJnLVVVfRu3dvnnvuOSzLYv78+Xi93irfKxERERERabqUdNeE3w87d8KECT+2aAcCMG5c0c9jx0JGBvh8Ra9NE666ClJTi5L2OvToo49y9913c/nllwPwj3/8g88//5wnnniCZ555piTu1ltv5ac//SkAzz33HB9//DEvv/xyqeS42KpVqwDo1KlTldf/05/+VPJzq1atuPPOO3nzzTdLnddxHF577TViY2MBGDVqFJ9++iljxozh0KFDvPzyy4wfP56zzz4bgP/85z9kZ2dXeM3p06ezfPlyPvnkEzIzMwH429/+xvDhw8MuW2RkJDExMXg8HtLT00vivv76a77//nt27tyJ3+8Hip7xu+++y6RJk7jpppvYuHEjd911V8nzOfLLDREREREROTEp6T5Wxa3UycnQvTv8/OewY0fpmJwcuPfeop/T0oqS8+Tk0sfXgQMHDrB161ZOP/30UttPP/30Ut2hAU477bSSnz0eD3379mXZsmXlntd13bDLMHHiRJ588knWrFnDoUOHCIVCxMXFlYpp1apVScINkJGRwc6dO4GiVvBAIMApp5xSsj8xMZGOHTtWeM1ly5bRvHnzkoT76PurTtmOtmDBAg4dOlSmB0B+fj5r1qwB4I477uCGG25g3LhxDBkyhJ/97Ge0bdu20vOKiIiIiEjTpjHdNWWacOaZsGQJDB1afszQoUX7Bw4sim+kOnToABRN4FaZb775hquuuooRI0bwwQcf8MMPP3DfffcRCARKxR3d9dowDJw6HANfnbId7dChQ2RkZDB//vxSf1asWMFdd90FFI1TX7JkCeeddx6fffYZXbp0YfLkyXV6PyIiIiIi0rA13gywIfF6ISEBpkyBiIjS+yIiirYnJBTFHQdxcXFkZmYyc+bMUttnzpxJly5dSm379ttvS34OhULMnTuXzp07l3veXr160aVLFx577LFyk+P9+/cDMGvWLFq2bMl9991H3759ad++PRs2bKjWPbRt2xav18t3331Xsm3fvn2sXLmywmM6d+7Mpk2b2LZtW7n3F27ZfD4f9lHj9U866SS2b9+Ox+OhXbt2pf4kF/deoOiLid/97ndMnTqVSy65hFdffbVa9y0iIiIiIk2Lku7aYhiwdCkUFJTeXlAAy5YV7T+O7rrrLv7xj38wceJEVqxYwT333MP8+fP57W9/WyrumWeeYfLkySxfvpxbbrmFffv2cd1115V7TsMwePXVV1m5ciUDBgzgww8/ZO3atSxcuJAxY8bwk5/8BCgay7xx40befPNN1qxZw5NPPlntFt+YmBiuv/567rrrLj777DMWL17MNddcU+4EbsWGDBlChw4duPrqq1mwYAEzZszgvvvuKxUTTtlatWrFunXrmD9/Prt376awsJAhQ4Zw2mmncdFFFzF16lTWr1/PrFmzuO+++5gzZw75+fnceuutfPHFF2zYsIGZM2cye/bsCr/AEBERERGRE4OS7tpi2/Dmm0U/jxoFq1YV/Q1F28ub6bwO3Xbbbdxxxx38/ve/p3v37nz88ce8//77ZSb3evjhh3n44Yfp2bMnX3/9Ne+//36pltuj9evXjzlz5tCuXTtuvPFGOnfuXDIrevHSXRdeeCG/+93vuPXWW+nVqxezZs3iz3/+c7Xv4ZFHHmHAgAFccMEFDBkyhDPOOIM+ffpUGG+aJpMnTyY/P59+/fpxww03lMyEXiycsv30pz/l3HPPZfDgwaSkpPDGG29gGAYffvghAwcO5Nprr6VDhw5cfvnlbNiwgbS0NCzLYs+ePfziF7+gQ4cOjBw5kuHDhzN69Ohq37eIiIiIiDQdhlud2bEauQMHDhAfH09OTk6ZibMKCgpYt24drVu3JuLoLuLhOvlkuOMOuOIKcN2i1u3XX4d//Qtmz66FO/iR4zgcOHCAuLi4Slt/K7J+/Xpat27NDz/8UOESXFJ3aqW+1UAwGOTDDz9kxIgRWtZMqk31R2pC9UdqQvVHakL1R2riyPqTn59fYV5ZHs1eXhtcF/LyYNIkyMoq2lbcnXzkSDj9dMjNhaio497NXEREREREGh7bcQi5Dl4XTI8HJxTCNU2sRjzxspRP72htCIUgOroo4T56KTCPp2h7dHSdr80tIiIiIiINX8AO8c3Odfxr4ae4BjB7Ni7wzc51BOxQtZbqlYZPSXdtKE60K1p7u6r99aBVq1a4rquu5SIiIiIix1F+KMA/F0xj3KrvSImMxTRMuP56TNNk+f7t/H3+J+TZwfouptSiRpN0//3vf+fkk08mNjaW1NRULrroIlasWFHfxSoSbpdxdS0XERERETlhFdpBnl82g025+wDok5SNM/NrWLQIZ9ZM+iZmszUvh6cXf0GhrV6yTUXDaXqtwpdffsktt9zCySefTCgU4t5772Xo0KEsXbqU6OjoWruOunLI8aB6JiIiInICCYXAtjFdh8uyu0N2dwDSYhOx3noEAOutt+n++OM80G0IAGYgAObhFZAsq0H1mpXqaTTv3Mcff1zq9WuvvUZqaipz585l4MCBNT5/8QyGeXl5REZG1vh8IpXJy8sD0MyZIiIiIicKvx/vzp1kTpgAjlO0LRCAceOKfh47Fisjg0yfr+i1acJVV0FqquaGauQaTdJ9tJycHAASExNr5XyWZdGsWTN27twJQFRUFEYD7g7uOA6BQICCgoJjWjJM6ofruuTl5bFz506aNWuGZVn1XSQRERERqWseD0HHxpOcjNutG+aoUbBjR+mYnBy4996in9PScMaPx0hOxjh8vDRejfLdcxyH22+/ndNPP51u3bpVGFdYWEhhYWHJ6wMHDgBFa6wFg2UnJ0hKSsK2bXYc/QFogFzXpaCggIiIiAb95YCULy4ujqSkpHLr4fFQfN36ur40bqo/UhOqP1ITqj9SE/VdfwrtINO2reGUfn2Jnv8D1g03wmeflQ086yzsl/5NIDoKq7AAn0c9IxuCI+tPdeuQ4TbCwaU333wzH330EV9//TXZ2dkVxj344IOMHj26zPbXX3+dqKioCo8zDEMtkFJnbNvWmG4RERERkUYqLy+PK6+8kpycHOLi4qqMb3RJ96233sp7773HV199RevWrSuNLa+lu3nz5uzevTush9OQBYNBpk2bxjnnnKNxwVJtqj9SE6o/UhOqP1ITqj9SEw2h/gTsEA/Pn8rw7C6ctOsQ1umnl4mxZ81iYWosXRMz8VmNsmNyk3Rk/cnPzyc5OTnspLvRvIuu6/Kb3/yGyZMn88UXX1SZcAP4/X78fn+Z7V6vt8n8om5K9yLHn+qP1ITqj9SE6o/UhOqP1ER91h/DMrm5+5kkeSLwP/sXyM+HUaOw//xnrL/+FcaNw/v22/R98EEcy8RjqvdtQ+P1eglVc2K7RjMD1y233ML48eN5/fXXiY2NZfv27Wzfvp38/Pz6LpqIiIiIiEiVPKZFakQsfn8ETJuGM2ECjB3L+tR4GDsWZ8J4mDoV0+tVwt2ENJqW7ueeew6AQYMGldr+6quvcs011xz/AomIiIiIiFSTxzQhNxd30iSMzEy25O4n6DrkBwNEjLwMTj8DcnMhKgo0YXKT0GiS7kY29FxERERERKSsUAiiozH8fvB4yPI2K70/K6toibBgEDSMokloNN3LRUREREREGr3iNbcrWnu7qv3S6CjpFhEREREROV7C7TKuruVNhpJuERERERERkTqipFtERERERESkjijpFhEREREREakjSrpFRERERERE6oiSbhEREREREZE6oqRbREREREREpI4o6RYRERERERGpI0q6RUREREREROqIkm4RERERERGROqKkW0RERERERKSOKOkWERERERERqSNKukVERERERETqiJJuERERERERkTriqe8CyI/cUAAcB0wLHBtME8Pjq+9iiYiIiIiIyDFS0t0AuMEA2EHc+Z/hLv0G8g9CZAxG51Oh9xCwvBheJd8iIiIiIiKNjZLueuYGA7BtDc67T0Io8OOOwjzcb97Hnf0R5oW34mZ1UOItIiIi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AgAAwKW1YcMGff/731cwGFRJSYkCgd7/3S9YsED79+8f9f5PPfWUenp6tHbt2v7bfN+X53k6ePCgFixYELfaAQCYahjpBgBgiklPT1dlZaXKysr6A7ck3XPPPTp48KCeffbZQffxfV+tra2SeqeWP/zww9qxY0f/n507d+raa6/Vj3/84wl7HQAATAWEbgAAponPfvazuvvuu/W5z31Of/VXf6X33ntPJ06c0ObNm3XjjTf2HyH2/vvv60/+5E+0dOnSAX8+97nP6cknn+w/87u6ulo7duxQdXW1XNftD+gdHR0JfqUAAEweHBkGAMAUMtSRYefzPE+PP/64fvzjH2vv3r0KBAKaP3++/viP/1j333+/vvrVr+qVV17R3r17B923rq5Os2bN0i9/+Ut98pOf1KZNm/Tkk08Oard161atX7/+Er8yAACSE6EbAAAAAIA4YXo5AAAAAABxQugGAAAAACBOCN0AAAAAAMQJoRsAAAAAgDghdAMAAAAAECeEbgAAAAAA4oTQDQAAAABAnBC6AQAAAACIE0I3AAAAAABxQugGAAAAACBOCN0AAAAAAMQJoRsAAAAAgDj5/wFBW9PjxwcDZgAAAABJRU5ErkJggg==\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "def updated_score(row):\n",
        "    score = 0\n",
        "    score += 1 if row[\"Stability\"] == \"Stable\" else 0\n",
        "    score += max(0, 1 - abs(row[\"GRAVY\"]))\n",
        "    score += max(0, 1 - abs(row[\"pI\"] - 7)) * 0.5\n",
        "    score += (1 - row[\"Instability\"] / 100)\n",
        "    score += 0.5 if \"PB1FF56B0\" in row[\"Protein ID\"] else 0  # reward confirmed hits\n",
        "    return round(score, 3)\n"
      ],
      "metadata": {
        "id": "T11frEnHSQ39"
      },
      "execution_count": 10,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "# Apply scoring\n",
        "df[\"Score\"] = df.apply(compute_score, axis=1)\n",
        "\n",
        "# ───────────────────────────────────────────────────────\n",
        "# 📊 ML Features: Normalize + PCA + Clustering\n",
        "# ───────────────────────────────────────────────────────\n",
        "\n",
        "features = [\"MW (Da)\", \"pI\", \"GRAVY\", \"Aromaticity\", \"Instability\"]\n",
        "X = df[features]\n",
        "\n",
        "# Scale features\n",
        "scaler = StandardScaler()\n",
        "X_scaled = scaler.fit_transform(X)\n",
        "\n",
        "# PCA\n",
        "pca = PCA(n_components=2)\n",
        "X_pca = pca.fit_transform(X_scaled)\n",
        "df[\"PCA1\"] = X_pca[:, 0]\n",
        "df[\"PCA2\"] = X_pca[:, 1]\n",
        "\n",
        "# KMeans clustering\n",
        "kmeans = KMeans(n_clusters=3, random_state=42)\n",
        "df[\"Cluster\"] = kmeans.fit_predict(X_scaled)\n",
        "\n",
        "# ───────────────────────────────────────────────────────\n",
        "# 🔝 Top N Selection (after PCA so PCA1/2 exist)\n",
        "# ───────────────────────────────────────────────────────\n",
        "\n",
        "TOP_N = 10\n",
        "top_proteins = df.sort_values(\"Score\", ascending=False).head(TOP_N).copy()\n",
        "\n",
        "# Optional: Save top protein data\n",
        "top_proteins.to_csv(\"top_proteins.csv\", index=False)\n",
        "\n",
        "with open(\"top_proteins.fasta\", \"w\") as fasta_file:\n",
        "    for _, row in top_proteins.iterrows():\n",
        "        fasta_file.write(f\">{row['Protein ID']}\\n{row['Sequence']}\\n\")\n",
        "\n",
        "print(f\"\\n✅ Top {TOP_N} proteins saved to 'top_proteins.csv' and 'top_proteins.fasta'.\")\n",
        "\n",
        "# ───────────────────────────────────────────────────────\n",
        "# 📈 Plot PCA Clusters & Highlight Top Proteins\n",
        "# ───────────────────────────────────────────────────────\n",
        "\n",
        "plt.figure(figsize=(10, 6))\n",
        "sns.scatterplot(data=df, x=\"PCA1\", y=\"PCA2\", hue=\"Cluster\", palette=\"Set2\", s=80)\n",
        "sns.scatterplot(data=top_proteins, x=\"PCA1\", y=\"PCA2\", color=\"red\", s=150, marker=\"*\", label=\"Top Candidates\")\n",
        "plt.title(\"Protein Clusters (PCA) with Top Candidates Highlighted\")\n",
        "plt.legend()\n",
        "plt.grid(True)\n",
        "plt.tight_layout()\n",
        "plt.show()"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 548
        },
        "id": "VPsGjQjaf39_",
        "outputId": "0b9913d6-18fe-4ddd-9269-58c20bafaa50"
      },
      "execution_count": 11,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "\n",
            "✅ Top 10 proteins saved to 'top_proteins.csv' and 'top_proteins.fasta'.\n"
          ]
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 1000x600 with 1 Axes>"
            ],
            "image/png": "iVBORw0KGgoAAAANSUhEUgAAA90AAAJOCAYAAACqS2TfAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjAsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvlHJYcgAAAAlwSFlzAAAPYQAAD2EBqD+naQAAzSZJREFUeJzs3XecFPX9x/HXzGy5flyv9N5BEBUFQREES9QYbCF2E6Mxxmg0mqgkkphY4s+usYWiohjUiAWwIlgo0nvvHQ64trsz8/vjuJPj2h53xxXez8eDB7czn5n5zux3Dz77bYbrui4iIiIiIiIiUuvM+i6AiIiIiIiISFOlpFtERERERESkjijpFhEREREREakjSrpFRERERERE6oiSbhEREREREZE6oqRbREREREREpI4o6RYRERERERGpI0q6RUREREREROqIkm4RERERERGROqKkW0TkGKxfvx7DMHjttdfq5fpffPEFhmHwxRdf1Mv165PjOHTr1o0xY8bUd1FKef7552nRogWFhYV1eh3DMHjwwQfDjr311lvrtDwnqlatWnHNNdeUvK7OZ3LQoEEMGjSozsrWUNTkPgcNGkS3bt2qjCvvd/GDDz6IYRjHdN3iY3fv3n1Mx9eGE/n3u0hTpaRbRBqM1157DcMwSv5ERETQoUMHbr31Vnbs2FGr1/rb3/7Gu+++W6vnrC2TJ09m+PDhJCcn4/P5yMzMZOTIkXz22WfHrQyzZs3iwQcfZP/+/cftmuF644032LRpU6lksrp1Z8eOHdx555106tSJqKgooqOj6dOnDw899FCF99yvXz8Mw+C5554rd/8111xDIBDghRdeqJX7DFddvFeDBg0q9Twr+hNu8l9Ttm3z6quvMmjQIBITE/H7/bRq1Yprr72WOXPmHJcyNAR5eXk8+OCD9ZKMFSeCkyZNKnf/NddcQ0xMzHEuVf1qyP+OiEjD4qnvAoiIHO0vf/kLrVu3pqCggK+//prnnnuODz/8kMWLFxMVFVUr1/jb3/7GpZdeykUXXXRMx7ds2ZL8/Hy8Xm+tlAfAdV2uu+46XnvtNXr37s0dd9xBeno627ZtY/LkyZx99tnMnDmT/v3719o1KzJr1ixGjx7NNddcQ7Nmzer8etXxyCOPcPnllxMfH19mXzh1Z/bs2YwYMYJDhw7x85//nD59+gAwZ84cHn74Yb766iumTp1a6ryrVq1i9uzZtGrVigkTJnDzzTeXuXZERARXX301jz/+OL/5zW+OuaWtKvn5+Xg8P/7zXRfv1X333ccNN9xQ8nr27Nk8+eST3HvvvXTu3Llke48ePWrlepXJz8/nkksu4eOPP2bgwIHce++9JCYmsn79et566y3+85//sHHjRrKzs+u8LJUZOHAg+fn5+Hy+OrtGXl4eo0ePBmgULeVHf46Olz/96U/cc889dX6dmv47IiInDiXdItLgDB8+nL59+wJwww03kJSUxOOPP857773HFVdcUe4xubm5REdHH7cyFrem1qbHHnuM1157jdtvv53HH3+8VNJ23333MW7cuFLJVmOUl5dXoy9OfvjhBxYsWMBjjz1W7v6q6s7+/fu5+OKLsSyLH374gU6dOpU6fsyYMfz73/8uc97x48eTmprKY489xqWXXsr69etp1apVmbiRI0fyz3/+k88//5yzzjrrmO+zMrVd78pzzjnnlLnmk08+yTnnnHPck7277rqLjz/+mH/961/cfvvtpfY98MAD/Otf/zqu5amIaZrH5b1pTOryC4jKeDyeRv+7UkSaFnUvF5EGrzh5WbduHfBjN8Y1a9YwYsQIYmNjueqqq4Ci5Pv3v/89zZs3x+/307FjRx599FFc1y05n2EY5Obm8p///Kekm+yRYzO3bNnCddddR1paGn6/n65du/LKK6+UKlN54wiLy7VlyxYuuugiYmJiSElJ4c4778S27UrvMT8/n7///e906tSJRx99tNxW0lGjRtGvX78Kz3H0GNNi5Y2rfOqpp+jatStRUVEkJCTQt29fXn/9daBoTONdd90FQOvWrUue0fr160uOHz9+PH369CEyMpLExEQuv/xyNm3aVOa63bp1Y+7cuQwcOJCoqCjuvfdeoKhVediwYSQnJxMZGUnr1q257rrrKn1GAO+++y4+n4+BAwdWGQtl684LL7zAli1bePzxx8sk3ABpaWn86U9/KrP99ddf59JLL+X8888nPj6+5FkdrU+fPiQmJvLee+9VWq4nn3wSy7JKdQl/7LHHMAyDO+64o2SbbdvExsZy9913l2w7slt3OO8VFD23bt26ldTnjz/+uNLyhevZZ5+la9eu+P1+MjMzueWWW8p0cz+yHvTv37/k/X7++eerPP/mzZt54YUXOOecc8ok3ACWZXHnnXeWtHJv2LCBX//613Ts2JHIyEiSkpL42c9+VuZ5FA9HmDlzJnfccQcpKSlER0dz8cUXs2vXrlKxruvy0EMPkZ2dTVRUFIMHD2bJkiVlylLRONwXX3yRtm3bEhkZSb9+/ZgxY0aZYwOBAPfffz99+vQhPj6e6OhoBgwYwOeff14Ss379elJSUgAYPXp0uV38ly9fzqWXXkpiYiIRERH07duX999/v9S1gsEgo0ePpn379kRERJCUlMQZZ5zBtGnTypSrpsr73bNhwwYuvPBCoqOjSU1N5Xe/+x2ffPJJhWOYly5dyuDBg4mKiiIrK4t//vOfVV63vDHd+fn53HbbbSQnJxMbG8uFF17Ili1bKhwmsX///pLeI/Hx8Vx77bXk5eWV7K+Nf0egqI5fdNFFpZ5HXc8LISLHn74GFJEGb82aNQAkJSWVbAuFQgwbNowzzjiDRx99lKioKFzX5cILL+Tzzz/n+uuvp1evXnzyySfcddddbNmypaRFbNy4cdxwww3069ePm266CYC2bdsCRWN9Tz311JIJqFJSUvjoo4+4/vrrOXDgQLn/8T+SbdsMGzaMU045hUcffZTp06fz2GOP0bZt23K7JBf7+uuv2bt3L7fffjuWZdXkcVXp3//+N7fddhuXXnopv/3tbykoKGDhwoV89913XHnllVxyySWsXLmSN954g3/9618kJycDlPyHf8yYMfz5z39m5MiR3HDDDezatYunnnqKgQMH8sMPP5Tq4rxnzx6GDx/O5Zdfzs9//nPS0tLYuXMnQ4cOJSUlhXvuuYdmzZqxfv16/vvf/1ZZ9lmzZtGtW7ewu/UfXXfef/99IiMjufTSS8N+Xt999x2rV6/m1VdfxefzcckllzBhwoSSLxCOdtJJJzFz5sxKzzlgwAAcx+Hrr7/m/PPPB2DGjBmYplkqKfvhhx84dOhQhV8yVPVeQVHd+u9//8uvf/1rYmNjefLJJ/npT3/Kxo0bS32mquvBBx9k9OjRDBkyhJtvvpkVK1bw3HPPMXv2bGbOnFnqPdq3bx8jRoxg5MiRXHHFFbz11lvcfPPN+Hy+Sr9s+eijjwiFQowaNSqsMs2ePZtZs2Zx+eWXk52dzfr163nuuecYNGgQS5cuLdPL4je/+Q0JCQk88MADrF+/nieeeIJbb72ViRMnlsTcf//9PPTQQ4wYMYIRI0Ywb948hg4dSiAQqLI8L7/8Mr/85S/p378/t99+O2vXruXCCy8kMTGR5s2bl8QdOHCAl156iSuuuIIbb7yRgwcP8vLLLzNs2DC+//57evXqRUpKCs899xw333wzF198MZdccgnwYxf/JUuWcPrpp5OVlcU999xDdHQ0b731FhdddBHvvPMOF198MVD0vv39738v+R144MAB5syZw7x588r0cCjPwYMHy51kLJxEMTc3l7POOott27bx29/+lvT0dF5//fVSXy4cad++fZx77rlccskljBw5kkmTJnH33XfTvXt3hg8fXuX1jnTNNdfw1ltvMWrUKE499VS+/PJLzjvvvArjR44cSevWrfn73//OvHnzeOmll0hNTeUf//gHUDv/juTn53P22WezceNGbrvtNjIzMxk3btxxnb9DRI4TV0SkgXj11VddwJ0+fbq7a9cud9OmTe6bb77pJiUluZGRke7mzZtd13Xdq6++2gXce+65p9Tx7777rgu4Dz30UKntl156qWsYhrt69eqSbdHR0e7VV19dpgzXX3+9m5GR4e7evbvU9ssvv9yNj4938/LyXNd13XXr1rmA++qrr5bEFJfrL3/5S6lje/fu7fbp06fSe/+///s/F3AnT55caVyxzz//3AXczz//vGRby5Yty72nM8880z3zzDNLXv/kJz9xu3btWun5H3nkERdw161bV2r7+vXrXcuy3DFjxpTavmjRItfj8ZTafuaZZ7qA+/zzz5eKnTx5sgu4s2fPrvwmy5Gdne3+9Kc/LbM93LqTkJDg9uzZs1rXvPXWW93mzZu7juO4ruu6U6dOdQH3hx9+KDf+pptuciMjIys9p23bblxcnPuHP/zBdV3XdRzHTUpKcn/2s5+5lmW5Bw8edF3XdR9//HHXNE133759JccC7gMPPFDyuqL3qjjW5/OVqvsLFixwAfepp54K4+6LvP3226Xq286dO12fz+cOHTrUtW27JO7pp592AfeVV14p2VZcDx577LGSbYWFhW6vXr3c1NRUNxAIVHjd3/3ud5U+66MVfz6P9M0337iAO3bs2JJtxfVlyJAhJe9r8fUsy3L3799f6j7PO++8UnH33nuvC5T6vB39mQwEAm5qaqrbq1cvt7CwsCTuxRdfdIFSn8lQKFQqxnVdd9++fW5aWpp73XXXlWzbtWtXmfe/2Nlnn+12797dLSgoKNnmOI7bv39/t3379iXbevbs6Z533nlljq9K8f1V9ic6OrrUMUf/7nnsscdcwH333XdLtuXn57udOnUq8/usuN4c+b4VFha66enppX4HlPe7+IEHHnCP/C/u3LlzXcC9/fbbS5XvmmuuKfM8i4898rm7rutefPHFblJSUqltNf135IknnnAB96233iqJyc3Nddu1a1fmeYhI46bu5SLS4AwZMoSUlBSaN2/O5ZdfTkxMDJMnTyYrK6tU3NEtxx9++CGWZXHbbbeV2v773/8e13X56KOPKr2u67q88847XHDBBbiuy+7du0v+DBs2jJycHObNm1dl+X/1q1+Vej1gwADWrl1b6TEHDhwAIDY2tsrz11SzZs3YvHkzs2fPrvax//3vf3Ech5EjR5Z6Punp6bRv375Mi5Xf7+faa68tc32ADz74gGAwWK3r79mzh4SEhAr3V1V3Dhw4UK1nHAqFmDhxIpdddllJd9WzzjqL1NRUJkyYUO4xCQkJ5Ofnl+qKejTTNOnfvz9fffUVAMuWLWPPnj3cc889uK7LN998AxS1fnfr1q1GE6QNGTKkpAUOilpG4+LiqqyTlZk+fTqBQIDbb78d0/zxvxI33ngjcXFxTJkypVS8x+Phl7/8Zclrn8/HL3/5S3bu3MncuXMrvE51PxeRkZElPweDQfbs2UO7du1o1qxZuZ/dm266qVQ35AEDBmDbNhs2bCh1n0dPjFdVjxcoGkKxc+dOfvWrX5Ua23zNNdeUmQTQsqySGMdx2Lt3L6FQiL59+4b1O2fv3r189tlnjBw5sqQlevfu3ezZs4dhw4axatUqtmzZAhR9/pYsWcKqVauqPG957r//fqZNm1bmz9ChQ6s89uOPPyYrK4sLL7ywZFtERAQ33nhjufExMTH8/Oc/L3nt8/no169ftetu8XCKX//616W2/+Y3v6nwmPJ+j+/Zs6ekTlakOv+OfPjhh2RkZJTqeRMVFVXSci4iTYe6l4tIg/PMM8/QoUMHPB4PaWlpdOzYsdR/7KHoP/FHz1a8YcMGMjMzy/wHvXi25eL/SFdk165d7N+/nxdffJEXX3yx3JidO3dWeo6IiIhSXXuhKAnbt29fpcfFxcUBRV0369rdd9/N9OnT6devH+3atWPo0KFceeWVnH766VUeu2rVKlzXpX379uXuP7rbd1ZWVpnJlM4880x++tOfMnr0aP71r38xaNAgLrroIq688kr8fn+VZXCPGJ9/tKrqTlxcXLWe8dSpU9m1axf9+vVj9erVJdsHDx7MG2+8wT/+8Y8ydbO4fFXNXj5gwAAefPBB8vPzmTFjBhkZGZx00kn07NmTGTNmcM455/D1118zcuTIsMtbnhYtWpTZFk6drEzxZ6ljx46ltvt8Ptq0aVPms5aZmVlmosMOHToARWOVTz311HKvU93PRfHcCK+++ipbtmwpVVdycnLKxB/9bIq/0Cl+NsX3cXR9T0lJqfTLn8qO9Xq9tGnTpkz8f/7zHx577DGWL19e6suo1q1bV3odgNWrV+O6Ln/+85/585//XG7Mzp07ycrK4i9/+Qs/+clP6NChA926dePcc89l1KhRYc9E3717d4YMGVJm+/jx46s8dsOGDbRt27bMZ6Ndu3blxmdnZ5eJTUhIYOHChWGV9cjrmqZZ5llWdF2ovG4U18vyVOffkQ0bNtCuXbsy93j050pEGj8l3SLS4PTr169kBuqK+P3+MslOTTmOA8DPf/5zrr766nJjqvqP6bGOxy6e1GvRokXHvPxMRUmebdulytW5c2dWrFjBBx98wMcff8w777zDs88+y/3331+yHFFFHMfBMAw++uijcu/16HV6j2x5PLKckyZN4ttvv+V///sfn3zyCddddx2PPfYY3377baVr/SYlJVWaLFZVdzp16sT8+fMJBAJhzaxc3JpdUeL75ZdfMnjw4FLb9u3bR1RUVLn3fqQzzjiDYDDIN998w4wZMxgwYABQlIzPmDGD5cuXs2vXrpLtx6qiOlnZlxcNxZGfi169elUZ/5vf/IZXX32V22+/ndNOO434+HgMw+Dyyy8v+XwfqaE8m/Hjx3PNNddw0UUXcdddd5GamoplWfz9738vmZegMsX3dueddzJs2LByY4oTzIEDB7JmzRree+89pk6dyksvvcS//vUvnn/++VLLxDUE9fn+HOu1a+PfERFpepR0i0iT0bJlS6ZPn87BgwdLtXYvX768ZH+x8hLUlJQUYmNjsW273JacunTGGWeQkJDAG2+8wb333ntMyXtCQkKZmaOhqDXl6Ja16OhoLrvsMi677DICgQCXXHIJY8aM4Y9//CMREREVJvBt27bFdV1at25d0lJ5rE499VROPfVUxowZw+uvv85VV13Fm2++Wel//Dt16lQyE/mxuOCCC/jmm2945513Klx+rlhubi7vvfcel112WbkTr912221MmDChTNK9bt26UmtZV6Rfv374fD5mzJjBjBkzSmYhHzhwIP/+97/59NNPS15Xpq7WA69M8WdpxYoVpepWIBBg3bp1ZT4/W7duLbOs38qVKwHKXXqt2PDhw7Esi/Hjx4c1mdqkSZO4+uqrSy0pV1BQUO7nIhzF97lq1apS97lr164qewoceeyRy8cFg0HWrVtHz549S5W7TZs2/Pe//y31fj7wwAOlzlnRe11cNq/XG9bvrsTERK699lquvfbakon6HnzwwTpPulu2bMnSpUtxXbfUvRzZi6Surus4DuvWrSvV86Cm163pvyMtW7Zk8eLFZZ7HihUralQuEWl4NKZbRJqMESNGYNs2Tz/9dKnt//rXvzAMo9Rst9HR0WX+I25ZFj/96U955513WLx4cZnzH72UUG2Kiori7rvvZtmyZdx9993ltqaMHz+e77//vsJztG3blm+//bbUrMoffPBBmaW89uzZU+q1z+ejS5cuuK5b0q21ODk6+hldcsklWJbF6NGjy5TRdd0y5y7Pvn37yhxb3IpZ1QzIp512GosXLz7mJXV+9atfkZGRwe9///uSpO9IO3fu5KGHHgJg8uTJ5Obmcsstt3DppZeW+XP++efzzjvvlCnLvHnz6N+/f5VliYiI4OSTT+aNN95g48aNpVq68/PzefLJJ2nbti0ZGRmVnqei96ouDRkyBJ/Px5NPPlnqvXz55ZfJyckpMyt0KBTihRdeKHkdCAR44YUXSElJoU+fPhVep3nz5tx4441MnTqVp556qsx+x3F47LHH2Lx5M1D0GT66bj311FNVLtlX2X16vV6eeuqpUud94oknqjy2b9++pKSk8Pzzz5f6TL722mvl/u6B0q2o3333XcnY/mLFs68ffXxqaiqDBg3ihRdeYNu2bWXKcuTvrqM/ozExMbRr1+64LFM1bNgwtmzZUmoZs4KCAv7973/X+XWhaIm7I5VXp6qjpv+OjBgxgq1btzJp0qSSbXl5eRV2SxeRxkst3SLSZFxwwQUMHjyY++67j/Xr19OzZ0+mTp3Ke++9x+23315qMqk+ffowffp0Hn/8cTIzM2ndujWnnHIKDz/8MJ9//jmnnHIKN954I126dGHv3r3MmzeP6dOns3fv3jor/1133cWSJUt47LHH+Pzzz7n00ktJT09n+/btvPvuu3z//ffMmjWrwuNvuOEGJk2axLnnnsvIkSNZs2YN48ePL3XfAEOHDiU9PZ3TTz+dtLQ0li1bxtNPP815551X0kOgOBG67777uPzyy/F6vVxwwQW0bduWhx56iD/+8Y+sX7+eiy66iNjYWNatW8fkyZO56aabuPPOOyu9z//85z88++yzXHzxxbRt25aDBw/y73//m7i4OEaMGFHpsT/5yU/461//ypdffhnWxE1HS0hIYPLkyYwYMYJevXrx85//vORe582bxxtvvMFpp50GFHUtT0pKqjCBvvDCC/n3v//NlClTSpZvmjt3Lnv37uUnP/lJWOUZMGAADz/8MPHx8XTv3h0oSqA6duzIihUryl13/WgVvVdHj6GuTSkpKfzxj39k9OjRnHvuuVx44YWsWLGCZ599lpNPPrnU5FdQNKb7H//4B+vXr6dDhw5MnDiR+fPn8+KLL1a5/Ntjjz3GmjVruO222/jvf//L+eefT0JCAhs3buTtt99m+fLlXH755QCcf/75jBs3jvj4eLp06cI333zD9OnTj3lptJSUFO68807+/ve/c/755zNixAh++OEHPvroo5Ll2Sri9Xp56KGH+OUvf8lZZ53FZZddxrp163j11VfL9Dw5//zz+e9//8vFF1/Meeedx7p163j++efp0qULhw4dKomLjIykS5cuTJw4kQ4dOpCYmEi3bt3o1q0bzzzzDGeccQbdu3fnxhtvpE2bNuzYsYNvvvmGzZs3s2DBAgC6dOnCoEGDStaUnzNnDpMmTeLWW289pmdUHb/85S95+umnueKKK/jtb39LRkYGEyZMICIiAqi7Xht9+vThpz/9KU888QR79uwpWTKs+Iu3Y71uTf8dufHGG3n66af5xS9+wdy5c8nIyGDcuHFllrYTkSbgOM2SLiJSpeJlfKpaSurqq68uszRNsYMHD7q/+93v3MzMTNfr9brt27d3H3nkkVLL/biu6y5fvtwdOHCgGxkZWWbpnx07dri33HKL27x5c9fr9brp6enu2Wef7b744oslMRUtGVZeuY5evqYqkyZNcocOHeomJia6Ho/HzcjIcC+77DL3iy++KIkpb8kw1y1akicrK8v1+/3u6aef7s6ZM6fMsj0vvPCCO3DgQDcpKcn1+/1u27Zt3bvuusvNyckpda6//vWvblZWlmuaZpklqd555x33jDPOcKOjo93o6Gi3U6dO7i233OKuWLGiJObMM88sd2myefPmuVdccYXbokUL1+/3u6mpqe7555/vzpkzJ6zn06NHD/f6668vtS3culNs69at7u9+9zu3Q4cObkREhBsVFeX26dPHHTNmjJuTk+Pu2LHD9Xg87qhRoyo8R15enhsVFeVefPHFJdvuvvtut0WLFmXqW0WmTJniAu7w4cNLbb/hhhtcwH355ZfLHEM5S0ZV9F4B7i233FLmHBUtL1eRo5cMK/b000+7nTp1cr1er5uWlubefPPNpZY3c90f68GcOXPc0047zY2IiHBbtmzpPv3002FfPxQKuS+99JI7YMAANz4+3vV6vW7Lli3da6+9ttRyYvv27XOvvfZaNzk52Y2JiXGHDRvmLl++vMz9VlRfyvtc2bbtjh492s3IyHAjIyPdQYMGuYsXLy5zzoo+k88++6zbunVr1+/3u3379nW/+uqrMp9Jx3Hcv/3tb27Lli1dv9/v9u7d2/3ggw/cq6++2m3ZsmWp882aNcvt06eP6/P5ytSFNWvWuL/4xS/c9PR01+v1ullZWe7555/vTpo0qSTmoYcecvv16+c2a9bMjYyMdDt16uSOGTOm0qXbjry/t99+u9z95f3+O/o+Xdd1165d65533nluZGSkm5KS4v7+979333nnHRdwv/3221LHlvf74+hnEs6SYa5btBTXLbfc4iYmJroxMTHuRRdd5K5YscIF3IcffrjMsbt27Sp1fHGdOfL3YE3/HXFd192wYYN74YUXulFRUW5ycrL729/+1v3444+1ZJhIE2O4biOYSUVEROSwcePGccstt7Bx48YaLaVV2woLC2nVqhX33HMPv/3tb+u7OA3GoEGD2L17d7ldbUWgqLv+7373OzZv3lxmaci6NH/+fHr37s348eO56qqrjtt1ReTEozHdIiLSqFx11VW0aNGCZ555pr6LUsqrr76K1+sts76viPwoPz+/1OuCggJeeOEF2rdvX6cJ99HXhaJk3zTNKicrFBGpKY3pFhGRRsU0zQbZavqrX/1KCbdIFS655BJatGhBr169yMnJYfz48Sxfvrxkeb668s9//pO5c+cyePBgPB4PH330ER999BE33XQTzZs3r9Nri4go6RYRERGR42LYsGG89NJLTJgwAdu26dKlC2+++SaXXXZZnV63f//+TJs2jb/+9a8cOnSIFi1a8OCDD3LffffV6XVFRAA0pltERERERESkjmhMt4iIiIiIiEgdUdItIiIiIiIiUkdOqDHdjuOwdetWYmNjMQyjvosjIiIiIiIijYzruhw8eJDMzExMs+p27BMq6d66datmqBQREREREZEa27RpE9nZ2VXGnVBJd2xsLFD0cOLi4uq5NDUTDAaZOnUqQ4cOxev11ndxpJFR/ZGaUP2RmlD9kZpQ/ZGaUP2Rmjiy/uTn59O8efOS/LIqJ1TSXdylPC4urkkk3VFRUcTFxemXhlSb6o/UhOqP1ITqj9SE6o/UhOqP1ER59SfcIcuaSE1ERERERESkjjSapPu5556jR48eJa3Up512Gh999FF9F0tERERERESkQo0m6c7Ozubhhx9m7ty5zJkzh7POOouf/OQnLFmypL6LJiIiIiIiIlKuRjOm+4ILLij1esyYMTz33HN8++23dO3atVavZds2wWCwVs9Z24LBIB6Ph4KCAmzbru/iSDV4vV4sy6rvYoiIiIiIyHHQaJLuI9m2zdtvv01ubi6nnXZarZ3XdV22b9/O/v37a+2cdcV1XdLT09m0aZPWHG+EmjVrRnp6ut47EREREZEmrlEl3YsWLeK0006joKCAmJgYJk+eTJcuXSqMLywspLCwsOT1gQMHgKJW4vJasnfs2MGBAwdISUkhKiqqQSdEruuSm5tLdHR0gy6nlOa6Lnl5eezatQvbtklLS6uXchTX/4beo0MaJtUfqQnVH6kJ1R+pCdUfqYkj609165Dhuq5bF4WqC4FAgI0bN5KTk8OkSZN46aWX+PLLLytMvB988EFGjx5dZvvrr79OVFRUqW2GYZCRkUF6enrY662JHKuDBw+yfft2tm3bRiP6CIqIiIiInPDy8vK48sorycnJCWsp6kaVdB9tyJAhtG3blhdeeKHc/eW1dDdv3pzdu3eXeTiFhYVs3LiRli1bEhkZWaflrg2u63Lw4EFiY2PV0t0I5efns2HDBlq0aIHf7z/u1w8Gg0ybNo1zzjlH61RKtan+SE2o/khNqP5ITaj+SE0cWX/y8/NJTk4OO+luVN3Lj+Y4Tqmk+mh+v7/chMbr9Zb5oNm2jWEYWJaFaTb8Sd0dxwGKWugbQ3mlNMuyMAwDj8dTr7/0y/ssiIRL9UdqQvVHakL1R2pC9Udqwuv1EgqFqnVMo0m6//jHPzJ8+HBatGjBwYMHef311/niiy/45JNP6rtoIiIiIiIiIuVqNEn3zp07+cUvfsG2bduIj4+nR48efPLJJ5xzzjn1XbQSjusQsG1CrkNeKECUx4fHMPFZFqah1mgREREREZETTaNJul9++eX6LkKlCu0gK/bv5KNNS1h7cHfJ9jaxyQxv3pWOzVLxW3XXjeWZZ57hkUceYfv27fTs2ZOnnnqKfv361dn1REREREREpGpqfq0FhXaQDzcu4ZmlX5ZKuAHWHtzNM0u/5MONSyi062Z5gokTJ3LHHXfwwAMPMG/ePHr27MmwYcPYuXNnnVxPREREREREwqOku4Yc12HF/p18vHlppXEfb17KypydOK5T62V4/PHHufHGG7n22mvp0qULzz//PFFRUbzyyiu1fi0REREREakh2y79tzRpSrprKGDbfLRpSVixH21aQsCp3Q9WIBBg7ty5DBkypGSbaZoMGTKEb775plavJSIiIiIixybo2AQcmzU5u3AAZs/GBfJDddMbVhoOJd01FHKdMl3KK7LmwG5CTu22dO/evRvbtklLSyu1PS0tje3bt9fqtUREREREpPoK7RDf7ljH/bP/xxfbVmEYBlx/PRgGX21bRU4gn1AtN85Jw6Gku4byQoFqxedXM15ERERERBqvQjvEtM3LGL/6e/YF8uiTlI0z82tYtAhn1kzS/NE8NO8jcpUnNFmNZvbyhirK46tWfGQ146uSnJyMZVns2LGj1PYdO3aQnp5eq9cSEREREZEwhUJg21iuw0lxaZzUrahnalpsItZbjwBgvfU23R9/nN95IwkV5OM4BqZhFB1vWeBRutYU6F2sIY9h0iY2Oawu5m3jkvGYtdu5wOfz0adPHz799FMuuugiABzH4dNPP+XWW2+t1WuJiIiIiEg1+P14du4kc8IEKB5mGgjAuHFFP48di5WRQabvcMOcacJVV0FqalHSLk2Cku4a8lkWw5t35ZmlX1YZO7x5V3ymVetluOOOO7j66qvp27cv/fr144knniA3N5drr7221q8lIiIiIiJh8HgIOQ5WcjJut26Yo0bBUb1TycmBe+8t+jktDXf8eIzk5JLjpWnQmO4aMg2Tjs1SOTe7S6Vx52Z3oUN8GqZR+4/8sssu49FHH+X++++nV69ezJ8/n48//rjM5GoiIiIiInL8uLg8s+wrDvY/FXvxIhg6tPzAoUOxFy8icMbpRa3d0qToHa0FfsvLiBZduaXrmbSNSy61r21cMrd2PZMRLbrht+ru26pbb72VDRs2UFhYyHfffccpp5xSZ9cSEREREZGqhRyHA4ECRi/8hFVmEHfKFIiIKB0UEYE7ZQorjSDrCnLqp6BSp9RnoZb4LS/dEjLoEJ9KyHHIDwWI9PjwmCY+06qTFm4REREREWm4fKbF4MwOvLbyW/YHCnCWLMEqKCgdVFCAs3Qpuelx9ExoXj8FlTqlTLAWmYZJhOUlxusnJTKWGK+fCMurhFtERERE5ARkmSZ9kluQGhFDr4QMrIkTi3aMGoW9ciWMGlUUN3EivZpl4LpuPZZW6oqyQRERERERkTriMUz+0HMoEf5ImDYNZ8IEGDuW9anxMHYszvjxMHUqHp8fXx0OR5X6o3dVRERERESkjpimSbTHh5ubiztpEsH0NMYtn8my/dsZkd2VwSNH4p5xBkZuLkRFQfE63dJkKOkWERERERGpQ6ZtQ3Q0+P24uFzT4VQcFxzXwfR4ISuraImwYBC83vourtQyJd0iIiIiIiJ16fCa24bHQ+m5y61S+7U2d9OkMd0iIiIiIiJ1Kdwu4+pa3iQp6RYRERERERGpI0q6RUREREREROqIBg3UItdxIBQAOwSFeeCPAssDHh+Gqe83RERERERETjRKumuJGyjE3bwc97spsG3Njzsy2mKcch5kd8Lw+evk2l999RWPPPIIc+fOZdu2bUyePJmLLrqoTq4lIiIiIiIi4VPzay1wA4W4332A++6TpRNugG1rcN99smh/oLBOrp+bm0vPnj155pln6uT8IiIiIiIicmzU0l1DruMUtXDP/rDyuNkfYmS1w23Vvda7mg8fPpzhw4fX6jlFRERERESk5tTSXVOhQFGX8jA4339YNOZbRERERERETghKumvKDpXtUl6RrauL4kVEREREROSEoKS7pgrz6jZeREREREREGi0l3TXlj6rbeBEREREREWm0lHTXlOWBjLbhxWa2K4oXERERERGRE4KS7pry+IrW4Q6D2W8EeHy1XoRDhw4xf/585s+fD8C6deuYP38+GzdurPVriYiIiIiISPiUdNeQYZoY2Z0wTh5RedzJIyC7U60vFwYwZ84cevfuTe/evQG444476N27N/fff3+tX0tERERERETCp77OtcDw+eGU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5nD22WfTrVs3XnjhBTp16sTBgwd57733+P3vf8+XX35Z69esTEpKynG9noiIiIiISHWopbu2OQ7MmgWLFsE33xS9riNpaWmkp6eTnp5OfHw8hmGUvE5NTeXxxx8vaY3u1asXH3/8ccmx69evxzAM3nzzTfr3709ERATdunWrNGl2XZdrrrmG9u3bM2PGDM477zzatm1Lr169eOCBB3jvvfdKYu+++246dOhAVFQUbdq04c9//jPBYLBkf3Fr8rhx42jVqhXx8fFcfvnlHDx4sCQmNzeXX/ziF8TExJCRkcFjjz1WpkxHdy9ftWoVAwcOJCIigi5dujBt2rQyx1RWttdee43Ro0ezYMGCkh4Dr732GgD79+/nhhtuICUlhbi4OM466ywWLFhQct4FCxYwePBgYmNjiYuLo0+fPvXS+i8iIiIiIg2HWrqPVShU/phtjwcmTiz6eeJEOPVUKCwsG2dZRbF15P/+7/947LHHeOGFF+jduzevvPIKF154IUuWLKF9+/YlcXfddRdPPPEEXbp04fHHH+eCCy5g3bp1JCUllTnn/PnzWbJkCa+//jqmWfb7mmbNmpX8HBsby2uvvUZmZiaLFi3ixhtvJDY2lj/84Q8lMWvWrOHdd9/lgw8+YN++fYwcOZKHH36YMWPGlJTtyy+/5L333iM1NZV7772XefPmVdj123EcLrnkEtLS0vjuu+/IyckpNf47nLJddtllLF68mI8//pjp06cDEB8fD8DPfvYzIiMj+eijj4iPj+eFF17g7LPPZuXKlSQmJnLVVVfRu3dvnnvuOSzLYv78+Xi93irfKxERERERabqUdNeE3w87d8KECT+2aAcCMG5c0c9jx0JGBvh8Ra9NE666ClJTi5L2OvToo49y9913c/nllwPwj3/8g88//5wnnniCZ555piTu1ltv5ac//SkAzz33HB9//DEvv/xyqeS42KpVqwDo1KlTldf/05/+VPJzq1atuPPOO3nzzTdLnddxHF577TViY2MBGDVqFJ9++iljxozh0KFDvPzyy4wfP56zzz4bgP/85z9kZ2dXeM3p06ezfPlyPvnkEzIzMwH429/+xvDhw8MuW2RkJDExMXg8HtLT00vivv76a77//nt27tyJ3+8Hip7xu+++y6RJk7jpppvYuHEjd911V8nzOfLLDREREREROTEp6T5Wxa3UycnQvTv8/OewY0fpmJwcuPfeop/T0oqS8+Tk0sfXgQMHDrB161ZOP/30UttPP/30Ut2hAU477bSSnz0eD3379mXZsmXlntd13bDLMHHiRJ588knWrFnDoUOHCIVCxMXFlYpp1apVScINkJGRwc6dO4GiVvBAIMApp5xSsj8xMZGOHTtWeM1ly5bRvHnzkoT76PurTtmOtmDBAg4dOlSmB0B+fj5r1qwB4I477uCGG25g3LhxDBkyhJ/97Ge0bdu20vOKiIiIiEjTpjHdNWWacOaZsGQJDB1afszQoUX7Bw4sim+kOnToABRN4FaZb775hquuuooRI0bwwQcf8MMPP3DfffcRCARKxR3d9dowDJw6HANfnbId7dChQ2RkZDB//vxSf1asWMFdd90FFI1TX7JkCeeddx6fffYZXbp0YfLkyXV6PyIiIiIi0rA13gywIfF6ISEBpkyBiIjS+yIiirYnJBTFHQdxcXFkZmYyc+bMUttnzpxJly5dSm379ttvS34OhULMnTuXzp07l3veXr160aVLFx577LFyk+P9+/cDMGvWLFq2bMl9991H3759ad++PRs2bKjWPbRt2xav18t3331Xsm3fvn2sXLmywmM6d+7Mpk2b2LZtW7n3F27ZfD4f9lHj9U866SS2b9+Ox+OhXbt2pf4kF/deoOiLid/97ndMnTqVSy65hFdffbVa9y0iIiIiIk2Lku7aYhiwdCkUFJTeXlAAy5YV7T+O7rrrLv7xj38wceJEVqxYwT333MP8+fP57W9/WyrumWeeYfLkySxfvpxbbrmFffv2cd1115V7TsMwePXVV1m5ciUDBgzgww8/ZO3atSxcuJAxY8bwk5/8BCgay7xx40befPNN1qxZw5NPPlntFt+YmBiuv/567rrrLj777DMWL17MNddcU+4EbsWGDBlChw4duPrqq1mwYAEzZszgvvvuKxUTTtlatWrFunXrmD9/Prt376awsJAhQ4Zw2mmncdFFFzF16lTWr1/PrFmzuO+++5gzZw75+fnceuutfPHFF2zYsIGZM2cye/bsCr/AEBERERGRE4OS7tpi2/Dmm0U/jxoFq1YV/Q1F28ub6bwO3Xbbbdxxxx38/ve/p3v37nz88ce8//77ZSb3evjhh3n44Yfp2bMnX3/9Ne+//36pltuj9evXjzlz5tCuXTtuvPFGOnfuXDIrevHSXRdeeCG/+93vuPXWW+nVqxezZs3iz3/+c7Xv4ZFHHmHAgAFccMEFDBkyhDPOOIM+ffpUGG+aJpMnTyY/P59+/fpxww03lMyEXiycsv30pz/l3HPPZfDgwaSkpPDGG29gGAYffvghAwcO5Nprr6VDhw5cfvnlbNiwgbS0NCzLYs+ePfziF7+gQ4cOjBw5kuHDhzN69Ohq37eIiIiIiDQdhlud2bEauQMHDhAfH09OTk6ZibMKCgpYt24drVu3JuLoLuLhOvlkuOMOuOIKcN2i1u3XX4d//Qtmz66FO/iR4zgcOHCAuLi4Slt/K7J+/Xpat27NDz/8UOESXFJ3aqW+1UAwGOTDDz9kxIgRWtZMqk31R2pC9UdqQvVHakL1R2riyPqTn59fYV5ZHs1eXhtcF/LyYNIkyMoq2lbcnXzkSDj9dMjNhaio497NXEREREREGh7bcQi5Dl4XTI8HJxTCNU2sRjzxspRP72htCIUgOroo4T56KTCPp2h7dHSdr80tIiIiIiINX8AO8c3Odfxr4ae4BjB7Ni7wzc51BOxQtZbqlYZPSXdtKE60K1p7u6r99aBVq1a4rquu5SIiIiIix1F+KMA/F0xj3KrvSImMxTRMuP56TNNk+f7t/H3+J+TZwfouptSiRpN0//3vf+fkk08mNjaW1NRULrroIlasWFHfxSoSbpdxdS0XERERETlhFdpBnl82g025+wDok5SNM/NrWLQIZ9ZM+iZmszUvh6cXf0GhrV6yTUXDaXqtwpdffsktt9zCySefTCgU4t5772Xo0KEsXbqU6OjoWruOunLI8aB6JiIiInICCYXAtjFdh8uyu0N2dwDSYhOx3noEAOutt+n++OM80G0IAGYgAObhFZAsq0H1mpXqaTTv3Mcff1zq9WuvvUZqaipz585l4MCBNT5/8QyGeXl5REZG1vh8IpXJy8sD0MyZIiIiIicKvx/vzp1kTpgAjlO0LRCAceOKfh47Fisjg0yfr+i1acJVV0FqquaGauQaTdJ9tJycHAASExNr5XyWZdGsWTN27twJQFRUFEYD7g7uOA6BQICCgoJjWjJM6ofruuTl5bFz506aNWuGZVn1XSQRERERqWseD0HHxpOcjNutG+aoUbBjR+mYnBy4996in9PScMaPx0hOxjh8vDRejfLdcxyH22+/ndNPP51u3bpVGFdYWEhhYWHJ6wMHDgBFa6wFg2UnJ0hKSsK2bXYc/QFogFzXpaCggIiIiAb95YCULy4ujqSkpHLr4fFQfN36ur40bqo/UhOqP1ITqj9SE/VdfwrtINO2reGUfn2Jnv8D1g03wmeflQ086yzsl/5NIDoKq7AAn0c9IxuCI+tPdeuQ4TbCwaU333wzH330EV9//TXZ2dkVxj344IOMHj26zPbXX3+dqKioCo8zDEMtkFJnbNvWmG4RERERkUYqLy+PK6+8kpycHOLi4qqMb3RJ96233sp7773HV199RevWrSuNLa+lu3nz5uzevTush9OQBYNBpk2bxjnnnKNxwVJtqj9SE6o/UhOqP1ITqj9SEw2h/gTsEA/Pn8rw7C6ctOsQ1umnl4mxZ81iYWosXRMz8VmNsmNyk3Rk/cnPzyc5OTnspLvRvIuu6/Kb3/yGyZMn88UXX1SZcAP4/X78fn+Z7V6vt8n8om5K9yLHn+qP1ITqj9SE6o/UhOqP1ER91h/DMrm5+5kkeSLwP/sXyM+HUaOw//xnrL/+FcaNw/v22/R98EEcy8RjqvdtQ+P1eglVc2K7RjMD1y233ML48eN5/fXXiY2NZfv27Wzfvp38/Pz6LpqIiIiIiEiVPKZFakQsfn8ETJuGM2ECjB3L+tR4GDsWZ8J4mDoV0+tVwt2ENJqW7ueeew6AQYMGldr+6quvcs011xz/AomIiIiIiFSTxzQhNxd30iSMzEy25O4n6DrkBwNEjLwMTj8DcnMhKgo0YXKT0GiS7kY29FxERERERKSsUAiiozH8fvB4yPI2K70/K6toibBgEDSMokloNN3LRUREREREGr3iNbcrWnu7qv3S6CjpFhEREREROV7C7TKuruVNhpJuERERERERkTqipFtERERERESkjijpFhEREREREakjSrpFRERERERE6oiSbhEREREREZE6oqRbREREREREpI4o6RYRERERERGpI0q6RUREREREROqIkm4RERERERGROqKkW0RERERERKSOKOkWERERERERqSNKukVERERERETqiJJuERERERERkTriqe8CyI/cUAAcB0wLHBtME8Pjq+9iiYiIiIiIyDFS0t0AuMEA2EHc+Z/hLv0G8g9CZAxG51Oh9xCwvBheJd8iIiIiIiKNjZLueuYGA7BtDc67T0Io8OOOwjzcb97Hnf0R5oW34mZ1UOItIiIi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AgAAwKW1YcMGff/731cwGFRJSYkCgd7/3S9YsED79+8f9f5PPfWUenp6tHbt2v7bfN+X53k6ePCgFixYELfaAQCYahjpBgBgiklPT1dlZaXKysr6A7ck3XPPPTp48KCeffbZQffxfV+tra2SeqeWP/zww9qxY0f/n507d+raa6/Vj3/84wl7HQAATAWEbgAAponPfvazuvvuu/W5z31Of/VXf6X33ntPJ06c0ObNm3XjjTf2HyH2/vvv60/+5E+0dOnSAX8+97nP6cknn+w/87u6ulo7duxQdXW1XNftD+gdHR0JfqUAAEweHBkGAMAUMtSRYefzPE+PP/64fvzjH2vv3r0KBAKaP3++/viP/1j333+/vvrVr+qVV17R3r17B923rq5Os2bN0i9/+Ut98pOf1KZNm/Tkk08Oard161atX7/+Er8yAACSE6EbAAAAAIA4YXo5AAAAAABxQugGAAAAACBOCN0AAAAAAMQJoRsAAAAAgDghdAMAAAAAECeEbgAAAAAA4oTQDQAAAABAnBC6AQAAAACIE0I3AAAAAABxQugGAAAAACBOCN0AAAAAAMQJoRsAAAAAgDj5/wFBW9PjxwcDZgAAAABJRU5ErkJggg==\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "!pip install openai\n",
        "!pip install biopython"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 0
        },
        "id": "K6QeL_4PJYxd",
        "outputId": "b861747f-166a-44e6-de7a-97f115c35fd7"
      },
      "execution_count": 2,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Requirement already satisfied: openai in /usr/local/lib/python3.12/dist-packages (1.107.0)\n",
            "Requirement already satisfied: anyio<5,>=3.5.0 in /usr/local/lib/python3.12/dist-packages (from openai) (4.10.0)\n",
            "Requirement already satisfied: distro<2,>=1.7.0 in /usr/local/lib/python3.12/dist-packages (from openai) (1.9.0)\n",
            "Requirement already satisfied: httpx<1,>=0.23.0 in /usr/local/lib/python3.12/dist-packages (from openai) (0.28.1)\n",
            "Requirement already satisfied: jiter<1,>=0.4.0 in /usr/local/lib/python3.12/dist-packages (from openai) (0.10.0)\n",
            "Requirement already satisfied: pydantic<3,>=1.9.0 in /usr/local/lib/python3.12/dist-packages (from openai) (2.11.7)\n",
            "Requirement already satisfied: sniffio in /usr/local/lib/python3.12/dist-packages (from openai) (1.3.1)\n",
            "Requirement already satisfied: tqdm>4 in /usr/local/lib/python3.12/dist-packages (from openai) (4.67.1)\n",
            "Requirement already satisfied: typing-extensions<5,>=4.11 in /usr/local/lib/python3.12/dist-packages (from openai) (4.15.0)\n",
            "Requirement already satisfied: idna>=2.8 in /usr/local/lib/python3.12/dist-packages (from anyio<5,>=3.5.0->openai) (3.10)\n",
            "Requirement already satisfied: certifi in /usr/local/lib/python3.12/dist-packages (from httpx<1,>=0.23.0->openai) (2025.8.3)\n",
            "Requirement already satisfied: httpcore==1.* in /usr/local/lib/python3.12/dist-packages (from httpx<1,>=0.23.0->openai) (1.0.9)\n",
            "Requirement already satisfied: h11>=0.16 in /usr/local/lib/python3.12/dist-packages (from httpcore==1.*->httpx<1,>=0.23.0->openai) (0.16.0)\n",
            "Requirement already satisfied: annotated-types>=0.6.0 in /usr/local/lib/python3.12/dist-packages (from pydantic<3,>=1.9.0->openai) (0.7.0)\n",
            "Requirement already satisfied: pydantic-core==2.33.2 in /usr/local/lib/python3.12/dist-packages (from pydantic<3,>=1.9.0->openai) (2.33.2)\n",
            "Requirement already satisfied: typing-inspection>=0.4.0 in /usr/local/lib/python3.12/dist-packages (from pydantic<3,>=1.9.0->openai) (0.4.1)\n",
            "Collecting biopython\n",
            "  Downloading biopython-1.85-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.metadata (13 kB)\n",
            "Requirement already satisfied: numpy in /usr/local/lib/python3.12/dist-packages (from biopython) (2.0.2)\n",
            "Downloading biopython-1.85-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (3.3 MB)\n",
            "\u001b[2K   \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m3.3/3.3 MB\u001b[0m \u001b[31m71.5 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
            "\u001b[?25hInstalling collected packages: biopython\n",
            "Successfully installed biopython-1.85\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "# ╔══════════════════════════════════════════════╗\n",
        "# ║     🧠 Multi-Agent Protein Generator v2      ║\n",
        "# ╚══════════════════════════════════════════════╝\n",
        "\n",
        "from openai import OpenAI\n",
        "from Bio.SeqUtils.ProtParam import ProteinAnalysis\n",
        "import pandas as pd\n",
        "import math\n",
        "import uuid\n",
        "import re\n",
        "\n",
        "# ───────────────────────────────────────────────────────\n",
        "# 🔑 OpenAI Client Setup\n",
        "# ───────────────────────────────────────────────────────\n",
        "\n",
        "client = OpenAI(api_key=\"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\")  # Replace with your actual key\n",
        "\n",
        "# ───────────────────────────────────────────────────────\n",
        "# ⚙️ Configuration\n",
        "# ───────────────────────────────────────────────────────\n",
        "\n",
        "protein_type = \"Enzyme\"\n",
        "total_length = 100             # Total length of each protein\n",
        "num_agents = 4                 # Number of agents per protein\n",
        "segment_length = math.ceil(total_length / num_agents)\n",
        "num_proteins = 100             # 🔁 Number of proteins to generate\n",
        "\n",
        "VALID_AMINO_ACIDS = set(\"ACDEFGHIKLMNPQRSTVWY\")\n",
        "\n",
        "# ───────────────────────────────────────────────────────\n",
        "# 🧠 Segment Generator\n",
        "# ───────────────────────────────────────────────────────\n",
        "\n",
        "def generate_segment(agent_id: int, protein_type: str, segment_length: int) -> str:\n",
        "    prompt = f\"\"\"\n",
        "You are Agent {agent_id}, a protein designer. Generate a protein segment of {segment_length} amino acids.\n",
        "It should be part of a larger {protein_type} protein. Use only standard amino acid 1-letter codes (ACDEFGHIKLMNPQRSTVWY).\n",
        "Only return the amino acid sequence, no extra commentary.\n",
        "\"\"\"\n",
        "    response = client.chat.completions.create(\n",
        "        model=\"gpt-4\",\n",
        "        messages=[{\"role\": \"user\", \"content\": prompt}]\n",
        "    )\n",
        "    return response.choices[0].message.content.strip().upper()\n",
        "\n",
        "# ───────────────────────────────────────────────────────\n",
        "# 🧪 Polisher Agent\n",
        "# ───────────────────────────────────────────────────────\n",
        "\n",
        "def polish_protein(segments: list, protein_type: str) -> str:\n",
        "    prompt = f\"\"\"\n",
        "You are a protein engineer. A team of agents created a raw protein of type '{protein_type}' composed of the following segments:\n",
        "\n",
        "{segments}\n",
        "\n",
        "Please polish and optimize this full protein sequence for:\n",
        "- Functionality as a {protein_type}\n",
        "- Folding compatibility\n",
        "- Avoiding problematic motifs (like long repeats or instability)\n",
        "\n",
        "Return ONLY the final 1-letter amino acid sequence.\n",
        "\"\"\"\n",
        "    response = client.chat.completions.create(\n",
        "        model=\"gpt-4\",\n",
        "        messages=[{\"role\": \"user\", \"content\": prompt}]\n",
        "    )\n",
        "    final_seq = response.choices[0].message.content.strip().upper()\n",
        "    final_seq = re.sub(r\"[^ACDEFGHIKLMNPQRSTVWY]\", \"\", final_seq)  # Clean sequence\n",
        "    return final_seq\n",
        "\n",
        "# ───────────────────────────────────────────────────────\n",
        "# 🧬 Validation + Analysis\n",
        "# ───────────────────────────────────────────────────────\n",
        "\n",
        "def analyze_sequence(seq: str) -> dict:\n",
        "    seq = seq.upper().strip().replace(\"\\n\", \"\")\n",
        "    invalid = set(seq) - VALID_AMINO_ACIDS\n",
        "    if invalid:\n",
        "        raise ValueError(f\"Invalid characters in sequence: {invalid}\")\n",
        "\n",
        "    analysis = ProteinAnalysis(seq)\n",
        "    instability = analysis.instability_index()\n",
        "    return {\n",
        "        \"Length\": len(seq),\n",
        "        \"MW (Da)\": round(analysis.molecular_weight(), 2),\n",
        "        \"pI\": round(analysis.isoelectric_point(), 2),\n",
        "        \"GRAVY\": round(analysis.gravy(), 3),\n",
        "        \"Aromaticity\": round(analysis.aromaticity(), 3),\n",
        "        \"Instability\": round(instability, 2),\n",
        "        \"Stability\": \"Stable\" if instability < 40 else \"Unstable\"\n",
        "    }\n",
        "\n",
        "# ───────────────────────────────────────────────────────\n",
        "# 🚀 Generate Proteins in Batch\n",
        "# ───────────────────────────────────────────────────────\n",
        "\n",
        "records = []\n",
        "\n",
        "for i in range(num_proteins):\n",
        "    print(f\"\\n🚧 Generating Protein {i+1}/{num_proteins}...\\n\")\n",
        "    segments = []\n",
        "\n",
        "    for agent_id in range(1, num_agents + 1):\n",
        "        seg = generate_segment(agent_id, protein_type, segment_length)\n",
        "        segments.append(seg)\n",
        "\n",
        "    raw_seq = \"\".join(segments)\n",
        "    final_seq = polish_protein(segments, protein_type)\n",
        "\n",
        "    metrics = analyze_sequence(final_seq)\n",
        "    protein_id = f\"P{str(uuid.uuid4())[:8].upper()}\"\n",
        "\n",
        "    record = {\n",
        "        \"Protein ID\": protein_id,\n",
        "        \"Sequence\": final_seq,\n",
        "        **metrics\n",
        "    }\n",
        "\n",
        "    records.append(record)\n",
        "\n",
        "# ───────────────────────────────────────────────────────\n",
        "# 💾 Save to CSV\n",
        "# ───────────────────────────────────────────────────────\n",
        "\n",
        "df = pd.DataFrame(records)\n",
        "df.to_csv(\"proteins.csv\", index=False)\n",
        "print(\"\\n✅ All proteins generated and saved to 'proteins.csv'.\")\n",
        "\n",
        "# ───────────────────────────────────────────────────────\n",
        "# 💾 Optional: Save to FASTA\n",
        "# ───────────────────────────────────────────────────────\n",
        "\n",
        "with open(\"proteins.fasta\", \"w\") as fasta_file:\n",
        "    for rec in records:\n",
        "        fasta_file.write(f\">{rec['Protein ID']}\\n{rec['Sequence']}\\n\")\n",
        "\n",
        "print(\"📄 FASTA file also saved as 'proteins.fasta'\")\n"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 0
        },
        "id": "7DZDWcwBLCm1",
        "outputId": "04e45595-18f1-4c36-cf67-0f5c80cda66c"
      },
      "execution_count": 6,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "\n",
            "🚧 Generating Protein 1/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 2/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 3/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 4/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 5/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 6/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 7/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 8/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 9/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 10/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 11/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 12/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 13/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 14/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 15/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 16/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 17/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 18/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 19/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 20/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 21/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 22/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 23/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 24/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 25/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 26/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 27/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 28/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 29/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 30/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 31/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 32/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 33/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 34/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 35/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 36/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 37/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 38/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 39/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 40/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 41/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 42/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 43/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 44/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 45/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 46/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 47/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 48/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 49/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 50/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 51/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 52/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 53/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 54/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 55/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 56/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 57/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 58/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 59/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 60/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 61/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 62/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 63/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 64/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 65/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 66/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 67/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 68/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 69/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 70/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 71/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 72/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 73/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 74/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 75/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 76/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 77/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 78/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 79/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 80/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 81/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 82/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 83/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 84/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 85/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 86/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 87/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 88/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 89/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 90/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 91/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 92/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 93/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 94/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 95/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 96/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 97/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 98/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 99/100...\n",
            "\n",
            "\n",
            "🚧 Generating Protein 100/100...\n",
            "\n",
            "\n",
            "✅ All proteins generated and saved to 'proteins.csv'.\n",
            "📄 FASTA file also saved as 'proteins.fasta'\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "# ╔════════════════════════════════════╗\n",
        "# ║   🧠 Multi-Agent Protein Builder   ║\n",
        "# ╚════════════════════════════════════╝\n",
        "\n",
        "from openai import OpenAI\n",
        "from Bio.SeqUtils.ProtParam import ProteinAnalysis\n",
        "import math\n",
        "\n",
        "# ─────────────────────────────────────────────────────────\n",
        "# 🔑 OpenAI Client Setup (v1+ SDK)\n",
        "# ─────────────────────────────────────────────────────────\n",
        "\n",
        "client = OpenAI(api_key=\"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\")  # Replace with your actual key\n",
        "\n",
        "# ─────────────────────────────────────────────────────────\n",
        "# ⚙️ Configuration\n",
        "# ─────────────────────────────────────────────────────────\n",
        "\n",
        "protein_type = \"Enzyme\"       # e.g., \"Structural\", \"Hormone\", \"Enzyme\"\n",
        "total_length = 100            # Total amino acid length\n",
        "num_agents = 4                # Number of sub-agents\n",
        "segment_length = math.ceil(total_length / num_agents)\n",
        "\n",
        "VALID_AMINO_ACIDS = set(\"ACDEFGHIKLMNPQRSTVWY\")\n",
        "\n",
        "# ─────────────────────────────────────────────────────────\n",
        "# 🧠 Agent: Protein Segment Generator\n",
        "# ─────────────────────────────────────────────────────────\n",
        "\n",
        "def generate_segment(agent_id: int, protein_type: str, segment_length: int) -> str:\n",
        "    prompt = f\"\"\"\n",
        "You are Agent {agent_id}, a protein designer. Generate a protein segment of {segment_length} amino acids.\n",
        "It should be part of a larger {protein_type} protein. Use only standard amino acid 1-letter codes (ACDEFGHIKLMNPQRSTVWY).\n",
        "Ensure your sequence could realistically fold and interact with other segments.\n",
        "\n",
        "Only return the amino acid sequence, no extra commentary.\n",
        "\"\"\"\n",
        "\n",
        "    response = client.chat.completions.create(\n",
        "        model=\"gpt-4\",\n",
        "        messages=[{\"role\": \"user\", \"content\": prompt}]\n",
        "    )\n",
        "    return response.choices[0].message.content.strip().upper()\n",
        "\n",
        "# ─────────────────────────────────────────────────────────\n",
        "# 🧪 Final Agent: Protein Polisher\n",
        "# ─────────────────────────────────────────────────────────\n",
        "\n",
        "def polish_protein(segments: list, protein_type: str) -> str:\n",
        "    prompt = f\"\"\"\n",
        "You are a protein engineer. A team of agents created a raw protein of type '{protein_type}' composed of the following segments:\n",
        "\n",
        "{segments}\n",
        "\n",
        "Please polish and optimize this full protein sequence for:\n",
        "- Functionality as a {protein_type}\n",
        "- Folding compatibility\n",
        "- Avoiding problematic motifs (like long repeats or instability)\n",
        "\n",
        "Return ONLY the final 1-letter amino acid sequence.\n",
        "\"\"\"\n",
        "\n",
        "    response = client.chat.completions.create(\n",
        "        model=\"gpt-4\",\n",
        "        messages=[{\"role\": \"user\", \"content\": prompt}]\n",
        "    )\n",
        "\n",
        "    final_sequence = response.choices[0].message.content\n",
        "    final_sequence = final_sequence.strip().upper()\n",
        "\n",
        "    # Remove any quotes, whitespace, or non-amino-acid characters\n",
        "    import re\n",
        "    final_sequence = re.sub(r\"[^ACDEFGHIKLMNPQRSTVWY]\", \"\", final_sequence)\n",
        "\n",
        "    return final_sequence\n",
        "\n",
        "# ─────────────────────────────────────────────────────────\n",
        "# 🧬 Biopython: Validate and Analyze Protein Sequence\n",
        "# ─────────────────────────────────────────────────────────\n",
        "\n",
        "def validate_and_analyze_sequence(sequence: str, name=\"Protein\"):\n",
        "    sequence = sequence.replace(\"\\n\", \"\").strip().upper()\n",
        "    invalids = set(sequence) - VALID_AMINO_ACIDS\n",
        "\n",
        "    if invalids:\n",
        "        raise ValueError(f\"❌ {name} contains invalid amino acids: {invalids}\")\n",
        "\n",
        "    print(f\"\\n✅ {name} is valid. Length: {len(sequence)} amino acids\")\n",
        "\n",
        "    analysis = ProteinAnalysis(sequence)\n",
        "    print(f\"• Molecular Weight: {analysis.molecular_weight():.2f} Da\")\n",
        "    print(f\"• Aromaticity: {analysis.aromaticity():.3f}\")\n",
        "    print(f\"• Instability Index: {analysis.instability_index():.2f}\")\n",
        "    print(f\"• Isoelectric Point (pI): {analysis.isoelectric_point():.2f}\")\n",
        "    print(f\"• Hydrophobicity (GRAVY): {analysis.gravy():.3f}\")\n",
        "\n",
        "# ─────────────────────────────────────────────────────────\n",
        "# 🚀 Orchestration: Generate → Validate → Polish\n",
        "# ─────────────────────────────────────────────────────────\n",
        "\n",
        "print(f\"\\n🚧 Generating protein using {num_agents} agents...\\n\")\n",
        "\n",
        "segments = []\n",
        "for agent_id in range(1, num_agents + 1):\n",
        "    seg = generate_segment(agent_id, protein_type, segment_length)\n",
        "    print(f\"🔹 Agent {agent_id} Segment ({len(seg)} aa): {seg}\")\n",
        "    validate_and_analyze_sequence(seg, name=f\"Agent {agent_id} Segment\")\n",
        "    segments.append(seg)\n",
        "\n",
        "# Combine segments\n",
        "print(\"\\n🧬 Raw concatenated sequence:\")\n",
        "raw_sequence = \"\".join(segments)\n",
        "print(raw_sequence)\n",
        "\n",
        "# Polish sequence\n",
        "print(\"\\n🧪 Polishing final protein...\")\n",
        "final_protein = polish_protein(segments, protein_type)\n",
        "\n",
        "# Final validation\n",
        "print(\"\\n✅ Final Polished Protein:\")\n",
        "print(final_protein)\n",
        "validate_and_analyze_sequence(final_protein, name=\"Final Polished Protein\")\n"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 0
        },
        "id": "1BZZQ4obJJB4",
        "outputId": "7b2052df-18e1-45de-97e6-750156950a74"
      },
      "execution_count": 4,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "\n",
            "🚧 Generating protein using 4 agents...\n",
            "\n",
            "🔹 Agent 1 Segment (25 aa): VRGHPQSTLVKLYFGPTWYIQKCEA\n",
            "\n",
            "✅ Agent 1 Segment is valid. Length: 25 amino acids\n",
            "• Molecular Weight: 2922.36 Da\n",
            "• Aromaticity: 0.160\n",
            "• Instability Index: 19.77\n",
            "• Isoelectric Point (pI): 9.11\n",
            "• Hydrophobicity (GRAVY): -0.324\n",
            "🔹 Agent 2 Segment (25 aa): QHVRGINFKSLYIGWVTRMNPQRTE\n",
            "\n",
            "✅ Agent 2 Segment is valid. Length: 25 amino acids\n",
            "• Molecular Weight: 3031.45 Da\n",
            "• Aromaticity: 0.120\n",
            "• Instability Index: 3.18\n",
            "• Isoelectric Point (pI): 10.90\n",
            "• Hydrophobicity (GRAVY): -0.760\n",
            "🔹 Agent 3 Segment (25 aa): RQGHYGRSVHMGYIVADKPSTVVLF\n",
            "\n",
            "✅ Agent 3 Segment is valid. Length: 25 amino acids\n",
            "• Molecular Weight: 2818.22 Da\n",
            "• Aromaticity: 0.120\n",
            "• Instability Index: 40.16\n",
            "• Isoelectric Point (pI): 9.70\n",
            "• Hydrophobicity (GRAVY): -0.096\n",
            "🔹 Agent 4 Segment (26 aa): MHTDKYMGKLWQVFANSEKYQIMRGD\n",
            "\n",
            "✅ Agent 4 Segment is valid. Length: 26 amino acids\n",
            "• Molecular Weight: 3177.63 Da\n",
            "• Aromaticity: 0.154\n",
            "• Instability Index: 43.30\n",
            "• Isoelectric Point (pI): 8.16\n",
            "• Hydrophobicity (GRAVY): -0.900\n",
            "\n",
            "🧬 Raw concatenated sequence:\n",
            "VRGHPQSTLVKLYFGPTWYIQKCEAQHVRGINFKSLYIGWVTRMNPQRTERQGHYGRSVHMGYIVADKPSTVVLFMHTDKYMGKLWQVFANSEKYQIMRGD\n",
            "\n",
            "🧪 Polishing final protein...\n",
            "\n",
            "✅ Final Polished Protein:\n",
            "VRGHPQSTLVKLYFGPTWYIQKCEAQHVRGINFKSLYIGWVTRMNPQRTERQGHYGRSVHMGYIVADKPSTVVMHTDKYMGKLWQVFANSEKYQIMRGD\n",
            "\n",
            "✅ Final Polished Protein is valid. Length: 99 amino acids\n",
            "• Molecular Weight: 11635.28 Da\n",
            "• Aromaticity: 0.131\n",
            "• Instability Index: 27.41\n",
            "• Isoelectric Point (pI): 9.88\n",
            "• Hydrophobicity (GRAVY): -0.601\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 1,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 722
        },
        "id": "bDSId0HWIe6L",
        "outputId": "151213ce-ef4b-4d19-84c2-d5d7fd61ccbc"
      },
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Generating protein with 4 agents...\n",
            "\n"
          ]
        },
        {
          "output_type": "error",
          "ename": "APIRemovedInV1",
          "evalue": "\n\nYou tried to access openai.ChatCompletion, but this is no longer supported in openai>=1.0.0 - see the README at https://github.com/openai/openai-python for the API.\n\nYou can run `openai migrate` to automatically upgrade your codebase to use the 1.0.0 interface. \n\nAlternatively, you can pin your installation to the old version, e.g. `pip install openai==0.28`\n\nA detailed migration guide is available here: https://github.com/openai/openai-python/discussions/742\n",
          "traceback": [
            "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
            "\u001b[0;31mAPIRemovedInV1\u001b[0m                            Traceback (most recent call last)",
            "\u001b[0;32m/tmp/ipython-input-189780686.py\u001b[0m in \u001b[0;36m<cell line: 0>\u001b[0;34m()\u001b[0m\n\u001b[1;32m     70\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     71\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0magent_id\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mrange\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mnum_agents\u001b[0m \u001b[0;34m+\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 72\u001b[0;31m     \u001b[0mseg\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mgenerate_segment\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0magent_id\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mprotein_type\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0msegment_length\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     73\u001b[0m     \u001b[0mprint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34mf\"🔹 Agent {agent_id} Segment ({len(seg)} aa): {seg}\"\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     74\u001b[0m     \u001b[0msegments\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mappend\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mseg\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m/tmp/ipython-input-189780686.py\u001b[0m in \u001b[0;36mgenerate_segment\u001b[0;34m(agent_id, protein_type, segment_length)\u001b[0m\n\u001b[1;32m     30\u001b[0m \u001b[0mOnly\u001b[0m \u001b[0;32mreturn\u001b[0m \u001b[0mthe\u001b[0m \u001b[0mamino\u001b[0m \u001b[0macid\u001b[0m \u001b[0msequence\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mno\u001b[0m \u001b[0mextra\u001b[0m \u001b[0mcommentary\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     31\u001b[0m \"\"\"\n\u001b[0;32m---> 32\u001b[0;31m     response = openai.ChatCompletion.create(\n\u001b[0m\u001b[1;32m     33\u001b[0m         \u001b[0mmodel\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m\"gpt-4\"\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     34\u001b[0m         \u001b[0mmessages\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m{\u001b[0m\u001b[0;34m\"role\"\u001b[0m\u001b[0;34m:\u001b[0m \u001b[0;34m\"user\"\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m\"content\"\u001b[0m\u001b[0;34m:\u001b[0m \u001b[0mprompt\u001b[0m\u001b[0;34m}\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;32m/usr/local/lib/python3.12/dist-packages/openai/lib/_old_api.py\u001b[0m in \u001b[0;36m__call__\u001b[0;34m(self, *_args, **_kwargs)\u001b[0m\n\u001b[1;32m     37\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     38\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0m__call__\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m*\u001b[0m\u001b[0m_args\u001b[0m\u001b[0;34m:\u001b[0m \u001b[0mAny\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0m_kwargs\u001b[0m\u001b[0;34m:\u001b[0m \u001b[0mAny\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m->\u001b[0m \u001b[0mAny\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 39\u001b[0;31m         \u001b[0;32mraise\u001b[0m \u001b[0mAPIRemovedInV1\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0msymbol\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_symbol\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     40\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     41\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;31mAPIRemovedInV1\u001b[0m: \n\nYou tried to access openai.ChatCompletion, but this is no longer supported in openai>=1.0.0 - see the README at https://github.com/openai/openai-python for the API.\n\nYou can run `openai migrate` to automatically upgrade your codebase to use the 1.0.0 interface. \n\nAlternatively, you can pin your installation to the old version, e.g. `pip install openai==0.28`\n\nA detailed migration guide is available here: https://github.com/openai/openai-python/discussions/742\n"
          ]
        }
      ],
      "source": [
        "# ╔════════════════════════════════════╗\n",
        "# ║   🧠 Multi-Agent Protein Builder   ║\n",
        "# ╚════════════════════════════════════╝\n",
        "\n",
        "import openai\n",
        "import math\n",
        "from typing import List\n",
        "from openai import OpenAI\n",
        "\n",
        "client = OpenAI(api_key=\"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\")\n",
        "\n",
        "# Example call:\n",
        "response = client.chat.completions.create(\n",
        "    model=\"gpt-4\",\n",
        "    messages=[{\"role\": \"user\", \"content\": prompt}]\n",
        ")\n",
        "output = response.choices[0].message.content.strip()\n",
        "\n",
        "\n",
        "# 🔑 API key\n",
        "openai.api_key =\n",
        "\n",
        "# ════════════════════════════════════════════════\n",
        "# 🔧 CONFIGURATION: Set protein parameters here\n",
        "# ════════════════════════════════════════════════\n",
        "\n",
        "protein_type = \"Enzyme\"      # e.g., \"Structural\", \"Hormone\", \"Enzyme\"\n",
        "total_length = 100           # Total amino acid length\n",
        "num_agents = 4               # Number of agent segments\n",
        "\n",
        "# ════════════════════════════════════════════════\n",
        "# 🧠 AGENT 1-N: Sequence Generators\n",
        "# ════════════════════════════════════════════════\n",
        "\n",
        "def generate_segment(agent_id: int, protein_type: str, segment_length: int) -> str:\n",
        "    prompt = f\"\"\"\n",
        "You are Agent {agent_id}, a protein designer. Generate a protein segment of {segment_length} amino acids.\n",
        "It should be part of a larger {protein_type} protein. Use only standard amino acid 1-letter codes (ACDEFGHIKLMNPQRSTVWY).\n",
        "Ensure your sequence could realistically fold and interact with other segments.\n",
        "\n",
        "Only return the amino acid sequence, no extra commentary.\n",
        "\"\"\"\n",
        "    response = openai.ChatCompletion.create(\n",
        "        model=\"gpt-4\",\n",
        "        messages=[{\"role\": \"user\", \"content\": prompt}]\n",
        "    )\n",
        "    return response['choices'][0]['message']['content'].strip()\n",
        "\n",
        "# ════════════════════════════════════════════════\n",
        "# 🧪 FINAL AGENT: Polisher\n",
        "# ════════════════════════════════════════════════\n",
        "\n",
        "def polish_protein(segments: List[str], protein_type: str) -> str:\n",
        "    raw_sequence = \"\".join(segments)\n",
        "    prompt = f\"\"\"\n",
        "You are a protein engineer. A team of agents created a raw protein of type '{protein_type}' composed of the following segments:\n",
        "\n",
        "{segments}\n",
        "\n",
        "Please polish and optimize this full protein sequence for:\n",
        "- Functionality as a {protein_type}\n",
        "- Folding compatibility\n",
        "- Avoiding problematic motifs (like long repeats or instability)\n",
        "\n",
        "Return ONLY the final 1-letter amino acid sequence.\n",
        "\"\"\"\n",
        "    response = openai.ChatCompletion.create(\n",
        "        model=\"gpt-4\",\n",
        "        messages=[{\"role\": \"user\", \"content\": prompt}]\n",
        "    )\n",
        "    return response['choices'][0]['message']['content'].strip()\n",
        "\n",
        "# ════════════════════════════════════════════════\n",
        "# 🔁 MAIN LOGIC: Multi-Agent Orchestration\n",
        "# ════════════════════════════════════════════════\n",
        "\n",
        "segment_length = math.ceil(total_length / num_agents)\n",
        "segments = []\n",
        "\n",
        "print(f\"Generating protein with {num_agents} agents...\\n\")\n",
        "\n",
        "for agent_id in range(1, num_agents + 1):\n",
        "    seg = generate_segment(agent_id, protein_type, segment_length)\n",
        "    print(f\"🔹 Agent {agent_id} Segment ({len(seg)} aa): {seg}\")\n",
        "    segments.append(seg)\n",
        "\n",
        "print(\"\\n🧬 Raw sequence (before polish):\")\n",
        "print(\"\".join(segments))\n",
        "\n",
        "# Final polishing\n",
        "print(\"\\n🧪 Polishing full protein...\")\n",
        "final_protein = polish_protein(segments, protein_type)\n",
        "\n",
        "print(\"\\n✅ Final Protein Sequence:\")\n",
        "print(final_protein)\n",
        "print(f\"\\n🔬 Final Length: {len(final_protein)} amino acids\")\n"
      ]
    }
  ]
}