{
 "cells": [
  {
   "cell_type": "code",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-01T11:27:45.594008Z",
     "start_time": "2025-07-01T11:27:36.838267Z"
    }
   },
   "source": [
    "import json\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import os\n",
    "import pandas as pd\n",
    "from pathlib import Path\n",
    "import re\n",
    "import torch\n",
    "from sklearn.metrics import roc_auc_score\n",
    "import math"
   ],
   "outputs": [],
   "execution_count": 1
  },
  {
   "cell_type": "code",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-01T11:27:45.689568Z",
     "start_time": "2025-07-01T11:27:45.599253Z"
    }
   },
   "source": [
    "#load dict with annotation of binding sites -> uniprot_id: {'site_1' : ['res1', 'res2', ..], ..}\n",
    "cpath = Path(os.getcwd())\n",
    "data_path =  cpath.parent / \"data\" / \"protobind_diff/attention\"\n",
    "file_bs = data_path / 'binding_sites_BioLip2.json'\n",
    "with open(file_bs, \"r\") as f:\n",
    "    binding_site_dict = json.load(f)"
   ],
   "outputs": [],
   "execution_count": 2
  },
  {
   "cell_type": "code",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-01T11:27:45.730694Z",
     "start_time": "2025-07-01T11:27:45.693528Z"
    }
   },
   "source": [
    "sequences = np.array(list(binding_site_dict.keys()))\n",
    "\n",
    "# Collect all binding site residue indices for each sequence into a dictionary\n",
    "\n",
    "bs_indexes = {}\n",
    "for seq in sequences:\n",
    "    indexes = [\n",
    "        int(re.search(r'\\d+', res).group())\n",
    "        for res_list in binding_site_dict[seq].values()\n",
    "        for res in res_list\n",
    "    ]\n",
    "    bs_indexes[seq] = indexes\n"
   ],
   "outputs": [],
   "execution_count": 3
  },
  {
   "cell_type": "code",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-01T11:27:45.993291Z",
     "start_time": "2025-07-01T11:27:45.752278Z"
    }
   },
   "source": [
    "# ---- load & restore numpy dict with attention maps  -----------------------------------\n",
    "loaded = torch.load(data_path / 'preds_active_uid_filtered.pt', map_location='cpu', weights_only=False)\n",
    "attention_maps = {k: v.numpy() for k, v in loaded.items()}"
   ],
   "outputs": [],
   "execution_count": 4
  },
  {
   "cell_type": "code",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-01T11:27:46.001652Z",
     "start_time": "2025-07-01T11:27:45.997318Z"
    }
   },
   "source": [
    "# Compute metrics based on windowed attention scores.\n",
    "# Each window takes the max attention score and checks if any true binding site falls within it.\n",
    "# This treats nearby predictions (\"near misses\") as correct, making the evaluation more tolerant and realistic.\n",
    "\n",
    "def window_prediction_metrics(att, binding_site_indices, window_size=10, stride=10):\n",
    "    active = set(i - 1 for i in binding_site_indices)\n",
    "    L = len(att)\n",
    "\n",
    "    # collect all windows\n",
    "    windows = []\n",
    "    start = 0\n",
    "    while start < L:\n",
    "        end = min(start + window_size, L)     \n",
    "        score = att[start:end].max()      \n",
    "        label = any(i in active for i in range(start, end)) \n",
    "        windows.append({'score': score, 'label': label})\n",
    "        start += stride\n",
    "\n",
    "\n",
    "    df_ = pd.DataFrame(windows)\n",
    "    len_ = (df_['label'] == 1).sum()\n",
    "    if len_ == 0:\n",
    "        print(\"stop\")\n",
    "    result = {}\n",
    "    \n",
    "    result['roc_auc'] = roc_auc_score(df_['label'].to_list(), df_['score'].to_list())\n",
    "    return result\n"
   ],
   "outputs": [],
   "execution_count": 5
  },
  {
   "cell_type": "code",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-01T11:28:05.950624Z",
     "start_time": "2025-07-01T11:27:46.045214Z"
    }
   },
   "source": [
    "window_size = 3\n",
    "n_heads = 8\n",
    "\n",
    "# Initialize per-head metrics dicts\n",
    "metrics_by_head = [{} for _ in range(n_heads)]\n",
    "\n",
    "for uid, attn_heads in attention_maps.items():\n",
    "    for head_idx in range(n_heads):\n",
    "        metrics_by_head[head_idx][uid] = window_prediction_metrics(\n",
    "            attn_heads[head_idx], bs_indexes[uid], window_size, window_size\n",
    "        )\n"
   ],
   "outputs": [],
   "execution_count": 6
  },
  {
   "cell_type": "code",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-01T11:28:06.921057Z",
     "start_time": "2025-07-01T11:28:06.652799Z"
    }
   },
   "source": [
    "heads      = [f'{i}' for i in range(1, 9)]\n",
    "dfs        = [pd.DataFrame(d).T for d in metrics_by_head]\n",
    "mean_auc   = [df['roc_auc'].mean() for df in dfs]\n",
    "sem_auc    = [df['roc_auc'].std(ddof=1) / math.sqrt(len(df))\n",
    "              for df in dfs]                   \n",
    "\n",
    "best_idx   = int(np.argmax(mean_auc))\n",
    "fig, ax = plt.subplots(figsize=(6, 4))\n",
    "\n",
    "bars = ax.bar(\n",
    "    heads,\n",
    "    mean_auc,\n",
    "    yerr=sem_auc,\n",
    "    capsize=0,       \n",
    "    alpha=0.7,\n",
    ")\n",
    "bars[best_idx].set_hatch('//') \n",
    "\n",
    "ax.set_ylabel('Mean ROC-AUC')\n",
    "ax.set_xlabel('Attention Heads')\n",
    "ax.set_ylim(0.45, 0.75)\n",
    "for spine in ('top', 'right'):\n",
    "    ax.spines[spine].set_visible(False)\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.savefig(\"attention_windows.png\")\n",
    "plt.show()\n",
    "\n"
   ],
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<Figure size 600x400 with 1 Axes>"
      ],
      "image/png": "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"
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "execution_count": 7
  },
  {
   "cell_type": "code",
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-01T11:28:06.970238Z",
     "start_time": "2025-07-01T11:28:06.968493Z"
    }
   },
   "source": [],
   "outputs": [],
   "execution_count": null
  },
  {
   "metadata": {
    "ExecuteTime": {
     "end_time": "2025-07-01T11:28:07.014784Z",
     "start_time": "2025-07-01T11:28:07.012649Z"
    }
   },
   "cell_type": "code",
   "source": "",
   "outputs": [],
   "execution_count": null
  },
  {
   "metadata": {},
   "cell_type": "code",
   "outputs": [],
   "execution_count": null,
   "source": ""
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.11.4"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
