{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c7c08eb8",
   "metadata": {},
   "outputs": [],
   "source": [
    "import h5py\n",
    "import hdf5plugin\n",
    "from scipy.signal import decimate\n",
    "import numpy as np\n",
    "import plotly.graph_objects as go\n",
    "from plotly.subplots import make_subplots\n",
    "import plotly.express as px\n",
    "hdf5plugin.register()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "190b65d0",
   "metadata": {},
   "outputs": [],
   "source": [
    "def plot_patient(sample):\n",
    "    fig = make_subplots(\n",
    "        rows=1, cols=1,\n",
    "    )\n",
    "\n",
    "    sample_ieeg = sample[\"/data/ieeg\"][:]\n",
    "    sample_ieeg = sample_ieeg[:20] # 20 channels out of 88\n",
    "    sample_ieeg = decimate(sample_ieeg, 10) # Downsample to make plotting faster\n",
    "    # sample_seizures = sample[\"/data/seizures/\"][:] # No seizures in this sample\n",
    "    ch_range = (sample_ieeg.max(axis=-1)-sample_ieeg.min(axis=-1)).max()\n",
    "    time_min = np.arange(sample_ieeg.shape[-1]) / (512/10) / 60\n",
    "\n",
    "    for ch in range(sample_ieeg.shape[0]):\n",
    "        fig.add_trace(go.Scatter(x=time_min, y=sample_ieeg[ch]*2+ch*ch_range, showlegend=False, line_color=\"black\"))\n",
    "\n",
    "    fig.update_layout(\n",
    "        height=1080, \n",
    "        width=1920,\n",
    "    )\n",
    "\n",
    "    yticks = [(ch * ch_range) for ch in range(sample_ieeg.shape[0])]\n",
    "    yticklabels = [f\"Ch {ch+1}\" for ch in range(sample_ieeg.shape[0])]\n",
    "\n",
    "    fig.update_yaxes(title_text=\"Channel\", tickvals=yticks, ticktext=yticklabels, row=1, col=1)\n",
    "    fig.update_xaxes(title_text=\"Time (minutes)\", row=1, col=1)\n",
    "\n",
    "    fig.update_layout(font_size=24, font_color=\"black\", font_weight=\"bold\", margin_b=10, margin_l=10, margin_r=10, margin_t=10)\n",
    "    fig.update_xaxes(linecolor='black', ticks=\"inside\")\n",
    "    fig.update_yaxes(linecolor='black', ticks=\"inside\")\n",
    "\n",
    "    fig.update_layout(plot_bgcolor='rgba(255,255,255,100)')\n",
    "\n",
    "    return fig"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "2e1ace7b",
   "metadata": {},
   "outputs": [],
   "source": [
    "patient_sample = h5py.File(\"ID01_sample.h5\")\n",
    "fig = plot_patient(patient_sample)\n",
    "fig.show()"
   ]
  }
 ],
 "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.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
