{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import pickle\n",
    "\n",
    "from allensdk.brain_observatory.ecephys.ecephys_project_cache import EcephysProjectCache"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "areas = ('VISp', 'VISl', 'VISrl', 'VISal', 'VISpm', 'VISam') # original name in allen brain observatory\n",
    "areas_map = {'VISp':'V1', 'VISl':'LM', 'VISrl':'RL', 'VISal':'AL', 'VISpm':'PM', 'VISam':'AM'} # shortened name commonly used in other papers"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Load in sessions where the activity of the 6 visual cortex areas of interest were measured"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Example cache directory path, it determines where downloaded data will be stored\n",
    "output_dir = '/home/dan/Desktop/AllenSDKCache'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['brain_observatory_1.1', 'functional_connectivity']\n"
     ]
    }
   ],
   "source": [
    "# this path determines where downloaded data will be stored\n",
    "manifest_path = os.path.join(output_dir, \"manifest.json\")\n",
    "cache = EcephysProjectCache.from_warehouse(manifest=manifest_path)\n",
    "print(cache.get_all_session_types())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>published_at</th>\n",
       "      <th>specimen_id</th>\n",
       "      <th>session_type</th>\n",
       "      <th>age_in_days</th>\n",
       "      <th>sex</th>\n",
       "      <th>full_genotype</th>\n",
       "      <th>unit_count</th>\n",
       "      <th>channel_count</th>\n",
       "      <th>probe_count</th>\n",
       "      <th>ecephys_structure_acronyms</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>id</th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "      <th></th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>715093703</th>\n",
       "      <td>2019-10-03T00:00:00Z</td>\n",
       "      <td>699733581</td>\n",
       "      <td>brain_observatory_1.1</td>\n",
       "      <td>118.0</td>\n",
       "      <td>M</td>\n",
       "      <td>Sst-IRES-Cre/wt;Ai32(RCL-ChR2(H134R)_EYFP)/wt</td>\n",
       "      <td>884</td>\n",
       "      <td>2219</td>\n",
       "      <td>6</td>\n",
       "      <td>[CA1, VISrl, nan, PO, LP, LGd, CA3, DG, VISl, ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>719161530</th>\n",
       "      <td>2019-10-03T00:00:00Z</td>\n",
       "      <td>703279284</td>\n",
       "      <td>brain_observatory_1.1</td>\n",
       "      <td>122.0</td>\n",
       "      <td>M</td>\n",
       "      <td>Sst-IRES-Cre/wt;Ai32(RCL-ChR2(H134R)_EYFP)/wt</td>\n",
       "      <td>755</td>\n",
       "      <td>2214</td>\n",
       "      <td>6</td>\n",
       "      <td>[TH, Eth, APN, POL, LP, DG, CA1, VISpm, nan, N...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>721123822</th>\n",
       "      <td>2019-10-03T00:00:00Z</td>\n",
       "      <td>707296982</td>\n",
       "      <td>brain_observatory_1.1</td>\n",
       "      <td>125.0</td>\n",
       "      <td>M</td>\n",
       "      <td>Pvalb-IRES-Cre/wt;Ai32(RCL-ChR2(H134R)_EYFP)/wt</td>\n",
       "      <td>444</td>\n",
       "      <td>2229</td>\n",
       "      <td>6</td>\n",
       "      <td>[MB, SCig, PPT, NOT, DG, CA1, VISam, nan, LP, ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>732592105</th>\n",
       "      <td>2019-10-03T00:00:00Z</td>\n",
       "      <td>717038288</td>\n",
       "      <td>brain_observatory_1.1</td>\n",
       "      <td>100.0</td>\n",
       "      <td>M</td>\n",
       "      <td>wt/wt</td>\n",
       "      <td>824</td>\n",
       "      <td>1847</td>\n",
       "      <td>5</td>\n",
       "      <td>[grey, VISpm, nan, VISp, VISl, VISal, VISrl]</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>737581020</th>\n",
       "      <td>2019-10-03T00:00:00Z</td>\n",
       "      <td>718643567</td>\n",
       "      <td>brain_observatory_1.1</td>\n",
       "      <td>108.0</td>\n",
       "      <td>M</td>\n",
       "      <td>wt/wt</td>\n",
       "      <td>568</td>\n",
       "      <td>2218</td>\n",
       "      <td>6</td>\n",
       "      <td>[grey, VISmma, nan, VISpm, VISp, VISl, VISrl]</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>739448407</th>\n",
       "      <td>2019-10-03T00:00:00Z</td>\n",
       "      <td>716813543</td>\n",
       "      <td>brain_observatory_1.1</td>\n",
       "      <td>112.0</td>\n",
       "      <td>M</td>\n",
       "      <td>wt/wt</td>\n",
       "      <td>625</td>\n",
       "      <td>2221</td>\n",
       "      <td>6</td>\n",
       "      <td>[grey, VISam, nan, VIS, VISp, VISl, VISrl]</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>742951821</th>\n",
       "      <td>2019-10-03T00:00:00Z</td>\n",
       "      <td>723627604</td>\n",
       "      <td>brain_observatory_1.1</td>\n",
       "      <td>120.0</td>\n",
       "      <td>M</td>\n",
       "      <td>wt/wt</td>\n",
       "      <td>893</td>\n",
       "      <td>2219</td>\n",
       "      <td>6</td>\n",
       "      <td>[VISal, nan, grey, VISl, VISrl, VISp, VISpm, VIS]</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>743475441</th>\n",
       "      <td>2019-10-03T00:00:00Z</td>\n",
       "      <td>722882755</td>\n",
       "      <td>brain_observatory_1.1</td>\n",
       "      <td>121.0</td>\n",
       "      <td>M</td>\n",
       "      <td>wt/wt</td>\n",
       "      <td>553</td>\n",
       "      <td>2225</td>\n",
       "      <td>6</td>\n",
       "      <td>[LP, LGd, HPF, DG, CA3, CA1, VISrl, nan, PP, P...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>744228101</th>\n",
       "      <td>2019-10-03T00:00:00Z</td>\n",
       "      <td>719817805</td>\n",
       "      <td>brain_observatory_1.1</td>\n",
       "      <td>122.0</td>\n",
       "      <td>M</td>\n",
       "      <td>wt/wt</td>\n",
       "      <td>659</td>\n",
       "      <td>2226</td>\n",
       "      <td>6</td>\n",
       "      <td>[Eth, TH, LP, POL, APN, DG, CA1, VIS, nan, CA3...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>746083955</th>\n",
       "      <td>2019-10-03T00:00:00Z</td>\n",
       "      <td>726170935</td>\n",
       "      <td>brain_observatory_1.1</td>\n",
       "      <td>98.0</td>\n",
       "      <td>F</td>\n",
       "      <td>Pvalb-IRES-Cre/wt;Ai32(RCL-ChR2(H134R)_EYFP)/wt</td>\n",
       "      <td>582</td>\n",
       "      <td>2216</td>\n",
       "      <td>6</td>\n",
       "      <td>[VPM, TH, LGd, CA3, CA2, CA1, VISal, nan, grey...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>750332458</th>\n",
       "      <td>2019-10-03T00:00:00Z</td>\n",
       "      <td>726141251</td>\n",
       "      <td>brain_observatory_1.1</td>\n",
       "      <td>91.0</td>\n",
       "      <td>M</td>\n",
       "      <td>wt/wt</td>\n",
       "      <td>902</td>\n",
       "      <td>2216</td>\n",
       "      <td>6</td>\n",
       "      <td>[grey, VISrl, nan, VISal, IntG, IGL, LGd, CA3,...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>750749662</th>\n",
       "      <td>2019-10-03T00:00:00Z</td>\n",
       "      <td>726162197</td>\n",
       "      <td>brain_observatory_1.1</td>\n",
       "      <td>92.0</td>\n",
       "      <td>M</td>\n",
       "      <td>wt/wt</td>\n",
       "      <td>761</td>\n",
       "      <td>2223</td>\n",
       "      <td>6</td>\n",
       "      <td>[LP, DG, CA1, VISp, nan, LGd, CA3, VISrl, VPM,...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>751348571</th>\n",
       "      <td>2019-10-03T00:00:00Z</td>\n",
       "      <td>732548380</td>\n",
       "      <td>brain_observatory_1.1</td>\n",
       "      <td>93.0</td>\n",
       "      <td>F</td>\n",
       "      <td>Vip-IRES-Cre/wt;Ai32(RCL-ChR2(H134R)_EYFP)/wt</td>\n",
       "      <td>859</td>\n",
       "      <td>2217</td>\n",
       "      <td>6</td>\n",
       "      <td>[grey, LGv, CA3, DG, CA1, VISl, nan, APN, POL,...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>754312389</th>\n",
       "      <td>2019-10-03T00:00:00Z</td>\n",
       "      <td>719828690</td>\n",
       "      <td>brain_observatory_1.1</td>\n",
       "      <td>140.0</td>\n",
       "      <td>M</td>\n",
       "      <td>wt/wt</td>\n",
       "      <td>502</td>\n",
       "      <td>2220</td>\n",
       "      <td>6</td>\n",
       "      <td>[APN, POL, LP, DG, CA1, VISam, nan, LGd, HPF, ...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>754829445</th>\n",
       "      <td>2019-10-03T00:00:00Z</td>\n",
       "      <td>726298253</td>\n",
       "      <td>brain_observatory_1.1</td>\n",
       "      <td>141.0</td>\n",
       "      <td>M</td>\n",
       "      <td>wt/wt</td>\n",
       "      <td>832</td>\n",
       "      <td>1851</td>\n",
       "      <td>5</td>\n",
       "      <td>[PoT, LP, LGd, CA3, DG, CA1, VISp, nan, VPM, C...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>755434585</th>\n",
       "      <td>2019-10-03T00:00:00Z</td>\n",
       "      <td>730760270</td>\n",
       "      <td>brain_observatory_1.1</td>\n",
       "      <td>100.0</td>\n",
       "      <td>M</td>\n",
       "      <td>Vip-IRES-Cre/wt;Ai32(RCL-ChR2(H134R)_EYFP)/wt</td>\n",
       "      <td>650</td>\n",
       "      <td>2220</td>\n",
       "      <td>6</td>\n",
       "      <td>[grey, VISrl, nan, MGv, MGd, TH, LGd, CA3, DG,...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>756029989</th>\n",
       "      <td>2019-10-03T00:00:00Z</td>\n",
       "      <td>734865738</td>\n",
       "      <td>brain_observatory_1.1</td>\n",
       "      <td>96.0</td>\n",
       "      <td>M</td>\n",
       "      <td>Sst-IRES-Cre/wt;Ai32(RCL-ChR2(H134R)_EYFP)/wt</td>\n",
       "      <td>684</td>\n",
       "      <td>2214</td>\n",
       "      <td>6</td>\n",
       "      <td>[TH, DG, CA3, CA1, VISl, nan, PO, Eth, LP, VIS...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>757216464</th>\n",
       "      <td>2019-10-03T00:00:00Z</td>\n",
       "      <td>733457989</td>\n",
       "      <td>brain_observatory_1.1</td>\n",
       "      <td>105.0</td>\n",
       "      <td>M</td>\n",
       "      <td>wt/wt</td>\n",
       "      <td>959</td>\n",
       "      <td>2225</td>\n",
       "      <td>6</td>\n",
       "      <td>[LP, DG, CA3, CA1, VISrl, nan, PO, LGd, HPF, V...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>757970808</th>\n",
       "      <td>2019-10-03T00:00:00Z</td>\n",
       "      <td>730756780</td>\n",
       "      <td>brain_observatory_1.1</td>\n",
       "      <td>106.0</td>\n",
       "      <td>M</td>\n",
       "      <td>wt/wt</td>\n",
       "      <td>773</td>\n",
       "      <td>1853</td>\n",
       "      <td>5</td>\n",
       "      <td>[grey, DG, CA3, CA1, VISli, nan, MGd, SGN, LP,...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>758798717</th>\n",
       "      <td>2019-10-03T00:00:00Z</td>\n",
       "      <td>735109609</td>\n",
       "      <td>brain_observatory_1.1</td>\n",
       "      <td>102.0</td>\n",
       "      <td>M</td>\n",
       "      <td>Sst-IRES-Cre/wt;Ai32(RCL-ChR2(H134R)_EYFP)/wt</td>\n",
       "      <td>593</td>\n",
       "      <td>1486</td>\n",
       "      <td>4</td>\n",
       "      <td>[MGv, MGd, TH, DG, CA1, VISal, nan, SGN, LP, S...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>759883607</th>\n",
       "      <td>2019-10-03T00:00:00Z</td>\n",
       "      <td>740268986</td>\n",
       "      <td>brain_observatory_1.1</td>\n",
       "      <td>113.0</td>\n",
       "      <td>M</td>\n",
       "      <td>wt/wt</td>\n",
       "      <td>483</td>\n",
       "      <td>1489</td>\n",
       "      <td>4</td>\n",
       "      <td>[MB, SCig, PPT, NOT, SUB, ProS, CA1, VISam, na...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>760345702</th>\n",
       "      <td>2019-10-03T00:00:00Z</td>\n",
       "      <td>739783171</td>\n",
       "      <td>brain_observatory_1.1</td>\n",
       "      <td>103.0</td>\n",
       "      <td>M</td>\n",
       "      <td>Pvalb-IRES-Cre/wt;Ai32(RCL-ChR2(H134R)_EYFP)/wt</td>\n",
       "      <td>501</td>\n",
       "      <td>1862</td>\n",
       "      <td>5</td>\n",
       "      <td>[MB, TH, PP, PIL, DG, CA3, CA1, VISal, nan, gr...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>760693773</th>\n",
       "      <td>2019-10-03T00:00:00Z</td>\n",
       "      <td>738651054</td>\n",
       "      <td>brain_observatory_1.1</td>\n",
       "      <td>110.0</td>\n",
       "      <td>F</td>\n",
       "      <td>Sst-IRES-Cre/wt;Ai32(RCL-ChR2(H134R)_EYFP)/wt</td>\n",
       "      <td>826</td>\n",
       "      <td>2233</td>\n",
       "      <td>6</td>\n",
       "      <td>[grey, VISrl, nan, VISal, VISp, VISpm, VISam]</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>761418226</th>\n",
       "      <td>2019-10-03T00:00:00Z</td>\n",
       "      <td>742714475</td>\n",
       "      <td>brain_observatory_1.1</td>\n",
       "      <td>119.0</td>\n",
       "      <td>M</td>\n",
       "      <td>wt/wt</td>\n",
       "      <td>712</td>\n",
       "      <td>2230</td>\n",
       "      <td>6</td>\n",
       "      <td>[grey, CA3, CA2, CA1, VISal, nan, LGd, HPF, DG...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>762120172</th>\n",
       "      <td>2019-10-03T00:00:00Z</td>\n",
       "      <td>745276236</td>\n",
       "      <td>brain_observatory_1.1</td>\n",
       "      <td>100.0</td>\n",
       "      <td>M</td>\n",
       "      <td>Vip-IRES-Cre/wt;Ai32(RCL-ChR2(H134R)_EYFP)/wt</td>\n",
       "      <td>717</td>\n",
       "      <td>1860</td>\n",
       "      <td>5</td>\n",
       "      <td>[grey, VISal, nan, VISl, VISp, VIS, VISam]</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>762602078</th>\n",
       "      <td>2019-10-03T00:00:00Z</td>\n",
       "      <td>744915204</td>\n",
       "      <td>brain_observatory_1.1</td>\n",
       "      <td>110.0</td>\n",
       "      <td>M</td>\n",
       "      <td>Sst-IRES-Cre/wt;Ai32(RCL-ChR2(H134R)_EYFP)/wt</td>\n",
       "      <td>531</td>\n",
       "      <td>2233</td>\n",
       "      <td>6</td>\n",
       "      <td>[MB, APN, NOT, DG, CA1, VISam, nan, VISrl, LGv...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>763673393</th>\n",
       "      <td>2019-10-03T00:00:00Z</td>\n",
       "      <td>742602892</td>\n",
       "      <td>brain_observatory_1.1</td>\n",
       "      <td>126.0</td>\n",
       "      <td>M</td>\n",
       "      <td>wt/wt</td>\n",
       "      <td>629</td>\n",
       "      <td>2227</td>\n",
       "      <td>6</td>\n",
       "      <td>[CA3, CA2, CA1, VISl, nan, APN, MB, DG, VISam,...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>773418906</th>\n",
       "      <td>2019-10-03T00:00:00Z</td>\n",
       "      <td>757329624</td>\n",
       "      <td>brain_observatory_1.1</td>\n",
       "      <td>124.0</td>\n",
       "      <td>F</td>\n",
       "      <td>Pvalb-IRES-Cre/wt;Ai32(RCL-ChR2(H134R)_EYFP)/wt</td>\n",
       "      <td>546</td>\n",
       "      <td>2232</td>\n",
       "      <td>6</td>\n",
       "      <td>[PPT, NOT, SUB, ProS, CA1, VISam, nan, APN, DG...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>791319847</th>\n",
       "      <td>2019-10-03T00:00:00Z</td>\n",
       "      <td>769360779</td>\n",
       "      <td>brain_observatory_1.1</td>\n",
       "      <td>116.0</td>\n",
       "      <td>M</td>\n",
       "      <td>Vip-IRES-Cre/wt;Ai32(RCL-ChR2(H134R)_EYFP)/wt</td>\n",
       "      <td>555</td>\n",
       "      <td>2229</td>\n",
       "      <td>6</td>\n",
       "      <td>[APN, DG, CA1, VISam, nan, LP, TH, VISpm, POL,...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>797828357</th>\n",
       "      <td>2019-10-03T00:00:00Z</td>\n",
       "      <td>776061251</td>\n",
       "      <td>brain_observatory_1.1</td>\n",
       "      <td>107.0</td>\n",
       "      <td>M</td>\n",
       "      <td>Pvalb-IRES-Cre/wt;Ai32(RCL-ChR2(H134R)_EYFP)/wt</td>\n",
       "      <td>611</td>\n",
       "      <td>2232</td>\n",
       "      <td>6</td>\n",
       "      <td>[PPT, MB, APN, NOT, HPF, ProS, CA1, VISam, nan...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>798911424</th>\n",
       "      <td>2019-10-03T00:00:00Z</td>\n",
       "      <td>775876828</td>\n",
       "      <td>brain_observatory_1.1</td>\n",
       "      <td>110.0</td>\n",
       "      <td>F</td>\n",
       "      <td>Vip-IRES-Cre/wt;Ai32(RCL-ChR2(H134R)_EYFP)/wt</td>\n",
       "      <td>825</td>\n",
       "      <td>2233</td>\n",
       "      <td>6</td>\n",
       "      <td>[APN, TH, Eth, LP, DG, HPF, CA3, CA1, VISrl, n...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>799864342</th>\n",
       "      <td>2019-10-03T00:00:00Z</td>\n",
       "      <td>772616823</td>\n",
       "      <td>brain_observatory_1.1</td>\n",
       "      <td>129.0</td>\n",
       "      <td>M</td>\n",
       "      <td>wt/wt</td>\n",
       "      <td>604</td>\n",
       "      <td>2233</td>\n",
       "      <td>6</td>\n",
       "      <td>[APN, POL, LP, DG, CA1, VISrl, nan, LGd, CA3, ...</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "                   published_at  specimen_id           session_type  \\\n",
       "id                                                                    \n",
       "715093703  2019-10-03T00:00:00Z    699733581  brain_observatory_1.1   \n",
       "719161530  2019-10-03T00:00:00Z    703279284  brain_observatory_1.1   \n",
       "721123822  2019-10-03T00:00:00Z    707296982  brain_observatory_1.1   \n",
       "732592105  2019-10-03T00:00:00Z    717038288  brain_observatory_1.1   \n",
       "737581020  2019-10-03T00:00:00Z    718643567  brain_observatory_1.1   \n",
       "739448407  2019-10-03T00:00:00Z    716813543  brain_observatory_1.1   \n",
       "742951821  2019-10-03T00:00:00Z    723627604  brain_observatory_1.1   \n",
       "743475441  2019-10-03T00:00:00Z    722882755  brain_observatory_1.1   \n",
       "744228101  2019-10-03T00:00:00Z    719817805  brain_observatory_1.1   \n",
       "746083955  2019-10-03T00:00:00Z    726170935  brain_observatory_1.1   \n",
       "750332458  2019-10-03T00:00:00Z    726141251  brain_observatory_1.1   \n",
       "750749662  2019-10-03T00:00:00Z    726162197  brain_observatory_1.1   \n",
       "751348571  2019-10-03T00:00:00Z    732548380  brain_observatory_1.1   \n",
       "754312389  2019-10-03T00:00:00Z    719828690  brain_observatory_1.1   \n",
       "754829445  2019-10-03T00:00:00Z    726298253  brain_observatory_1.1   \n",
       "755434585  2019-10-03T00:00:00Z    730760270  brain_observatory_1.1   \n",
       "756029989  2019-10-03T00:00:00Z    734865738  brain_observatory_1.1   \n",
       "757216464  2019-10-03T00:00:00Z    733457989  brain_observatory_1.1   \n",
       "757970808  2019-10-03T00:00:00Z    730756780  brain_observatory_1.1   \n",
       "758798717  2019-10-03T00:00:00Z    735109609  brain_observatory_1.1   \n",
       "759883607  2019-10-03T00:00:00Z    740268986  brain_observatory_1.1   \n",
       "760345702  2019-10-03T00:00:00Z    739783171  brain_observatory_1.1   \n",
       "760693773  2019-10-03T00:00:00Z    738651054  brain_observatory_1.1   \n",
       "761418226  2019-10-03T00:00:00Z    742714475  brain_observatory_1.1   \n",
       "762120172  2019-10-03T00:00:00Z    745276236  brain_observatory_1.1   \n",
       "762602078  2019-10-03T00:00:00Z    744915204  brain_observatory_1.1   \n",
       "763673393  2019-10-03T00:00:00Z    742602892  brain_observatory_1.1   \n",
       "773418906  2019-10-03T00:00:00Z    757329624  brain_observatory_1.1   \n",
       "791319847  2019-10-03T00:00:00Z    769360779  brain_observatory_1.1   \n",
       "797828357  2019-10-03T00:00:00Z    776061251  brain_observatory_1.1   \n",
       "798911424  2019-10-03T00:00:00Z    775876828  brain_observatory_1.1   \n",
       "799864342  2019-10-03T00:00:00Z    772616823  brain_observatory_1.1   \n",
       "\n",
       "           age_in_days sex                                    full_genotype  \\\n",
       "id                                                                            \n",
       "715093703        118.0   M    Sst-IRES-Cre/wt;Ai32(RCL-ChR2(H134R)_EYFP)/wt   \n",
       "719161530        122.0   M    Sst-IRES-Cre/wt;Ai32(RCL-ChR2(H134R)_EYFP)/wt   \n",
       "721123822        125.0   M  Pvalb-IRES-Cre/wt;Ai32(RCL-ChR2(H134R)_EYFP)/wt   \n",
       "732592105        100.0   M                                            wt/wt   \n",
       "737581020        108.0   M                                            wt/wt   \n",
       "739448407        112.0   M                                            wt/wt   \n",
       "742951821        120.0   M                                            wt/wt   \n",
       "743475441        121.0   M                                            wt/wt   \n",
       "744228101        122.0   M                                            wt/wt   \n",
       "746083955         98.0   F  Pvalb-IRES-Cre/wt;Ai32(RCL-ChR2(H134R)_EYFP)/wt   \n",
       "750332458         91.0   M                                            wt/wt   \n",
       "750749662         92.0   M                                            wt/wt   \n",
       "751348571         93.0   F    Vip-IRES-Cre/wt;Ai32(RCL-ChR2(H134R)_EYFP)/wt   \n",
       "754312389        140.0   M                                            wt/wt   \n",
       "754829445        141.0   M                                            wt/wt   \n",
       "755434585        100.0   M    Vip-IRES-Cre/wt;Ai32(RCL-ChR2(H134R)_EYFP)/wt   \n",
       "756029989         96.0   M    Sst-IRES-Cre/wt;Ai32(RCL-ChR2(H134R)_EYFP)/wt   \n",
       "757216464        105.0   M                                            wt/wt   \n",
       "757970808        106.0   M                                            wt/wt   \n",
       "758798717        102.0   M    Sst-IRES-Cre/wt;Ai32(RCL-ChR2(H134R)_EYFP)/wt   \n",
       "759883607        113.0   M                                            wt/wt   \n",
       "760345702        103.0   M  Pvalb-IRES-Cre/wt;Ai32(RCL-ChR2(H134R)_EYFP)/wt   \n",
       "760693773        110.0   F    Sst-IRES-Cre/wt;Ai32(RCL-ChR2(H134R)_EYFP)/wt   \n",
       "761418226        119.0   M                                            wt/wt   \n",
       "762120172        100.0   M    Vip-IRES-Cre/wt;Ai32(RCL-ChR2(H134R)_EYFP)/wt   \n",
       "762602078        110.0   M    Sst-IRES-Cre/wt;Ai32(RCL-ChR2(H134R)_EYFP)/wt   \n",
       "763673393        126.0   M                                            wt/wt   \n",
       "773418906        124.0   F  Pvalb-IRES-Cre/wt;Ai32(RCL-ChR2(H134R)_EYFP)/wt   \n",
       "791319847        116.0   M    Vip-IRES-Cre/wt;Ai32(RCL-ChR2(H134R)_EYFP)/wt   \n",
       "797828357        107.0   M  Pvalb-IRES-Cre/wt;Ai32(RCL-ChR2(H134R)_EYFP)/wt   \n",
       "798911424        110.0   F    Vip-IRES-Cre/wt;Ai32(RCL-ChR2(H134R)_EYFP)/wt   \n",
       "799864342        129.0   M                                            wt/wt   \n",
       "\n",
       "           unit_count  channel_count  probe_count  \\\n",
       "id                                                  \n",
       "715093703         884           2219            6   \n",
       "719161530         755           2214            6   \n",
       "721123822         444           2229            6   \n",
       "732592105         824           1847            5   \n",
       "737581020         568           2218            6   \n",
       "739448407         625           2221            6   \n",
       "742951821         893           2219            6   \n",
       "743475441         553           2225            6   \n",
       "744228101         659           2226            6   \n",
       "746083955         582           2216            6   \n",
       "750332458         902           2216            6   \n",
       "750749662         761           2223            6   \n",
       "751348571         859           2217            6   \n",
       "754312389         502           2220            6   \n",
       "754829445         832           1851            5   \n",
       "755434585         650           2220            6   \n",
       "756029989         684           2214            6   \n",
       "757216464         959           2225            6   \n",
       "757970808         773           1853            5   \n",
       "758798717         593           1486            4   \n",
       "759883607         483           1489            4   \n",
       "760345702         501           1862            5   \n",
       "760693773         826           2233            6   \n",
       "761418226         712           2230            6   \n",
       "762120172         717           1860            5   \n",
       "762602078         531           2233            6   \n",
       "763673393         629           2227            6   \n",
       "773418906         546           2232            6   \n",
       "791319847         555           2229            6   \n",
       "797828357         611           2232            6   \n",
       "798911424         825           2233            6   \n",
       "799864342         604           2233            6   \n",
       "\n",
       "                                  ecephys_structure_acronyms  \n",
       "id                                                            \n",
       "715093703  [CA1, VISrl, nan, PO, LP, LGd, CA3, DG, VISl, ...  \n",
       "719161530  [TH, Eth, APN, POL, LP, DG, CA1, VISpm, nan, N...  \n",
       "721123822  [MB, SCig, PPT, NOT, DG, CA1, VISam, nan, LP, ...  \n",
       "732592105       [grey, VISpm, nan, VISp, VISl, VISal, VISrl]  \n",
       "737581020      [grey, VISmma, nan, VISpm, VISp, VISl, VISrl]  \n",
       "739448407         [grey, VISam, nan, VIS, VISp, VISl, VISrl]  \n",
       "742951821  [VISal, nan, grey, VISl, VISrl, VISp, VISpm, VIS]  \n",
       "743475441  [LP, LGd, HPF, DG, CA3, CA1, VISrl, nan, PP, P...  \n",
       "744228101  [Eth, TH, LP, POL, APN, DG, CA1, VIS, nan, CA3...  \n",
       "746083955  [VPM, TH, LGd, CA3, CA2, CA1, VISal, nan, grey...  \n",
       "750332458  [grey, VISrl, nan, VISal, IntG, IGL, LGd, CA3,...  \n",
       "750749662  [LP, DG, CA1, VISp, nan, LGd, CA3, VISrl, VPM,...  \n",
       "751348571  [grey, LGv, CA3, DG, CA1, VISl, nan, APN, POL,...  \n",
       "754312389  [APN, POL, LP, DG, CA1, VISam, nan, LGd, HPF, ...  \n",
       "754829445  [PoT, LP, LGd, CA3, DG, CA1, VISp, nan, VPM, C...  \n",
       "755434585  [grey, VISrl, nan, MGv, MGd, TH, LGd, CA3, DG,...  \n",
       "756029989  [TH, DG, CA3, CA1, VISl, nan, PO, Eth, LP, VIS...  \n",
       "757216464  [LP, DG, CA3, CA1, VISrl, nan, PO, LGd, HPF, V...  \n",
       "757970808  [grey, DG, CA3, CA1, VISli, nan, MGd, SGN, LP,...  \n",
       "758798717  [MGv, MGd, TH, DG, CA1, VISal, nan, SGN, LP, S...  \n",
       "759883607  [MB, SCig, PPT, NOT, SUB, ProS, CA1, VISam, na...  \n",
       "760345702  [MB, TH, PP, PIL, DG, CA3, CA1, VISal, nan, gr...  \n",
       "760693773      [grey, VISrl, nan, VISal, VISp, VISpm, VISam]  \n",
       "761418226  [grey, CA3, CA2, CA1, VISal, nan, LGd, HPF, DG...  \n",
       "762120172         [grey, VISal, nan, VISl, VISp, VIS, VISam]  \n",
       "762602078  [MB, APN, NOT, DG, CA1, VISam, nan, VISrl, LGv...  \n",
       "763673393  [CA3, CA2, CA1, VISl, nan, APN, MB, DG, VISam,...  \n",
       "773418906  [PPT, NOT, SUB, ProS, CA1, VISam, nan, APN, DG...  \n",
       "791319847  [APN, DG, CA1, VISam, nan, LP, TH, VISpm, POL,...  \n",
       "797828357  [PPT, MB, APN, NOT, HPF, ProS, CA1, VISam, nan...  \n",
       "798911424  [APN, TH, Eth, LP, DG, HPF, CA3, CA1, VISrl, n...  \n",
       "799864342  [APN, POL, LP, DG, CA1, VISrl, nan, LGd, CA3, ...  "
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "sessions = cache.get_session_table()\n",
    "brain_observatory_type_sessions = sessions[sessions[\"session_type\"] == \"brain_observatory_1.1\"]\n",
    "brain_observatory_type_sessions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Found the following valid sessions:\n",
      "[719161530, 750332458, 750749662, 754312389, 755434585, 756029989, 791319847, 797828357]\n"
     ]
    }
   ],
   "source": [
    "valid_session_ids = []\n",
    "ephys_structure_acronyms = brain_observatory_type_sessions['ecephys_structure_acronyms']\n",
    "for id, acronyms in ephys_structure_acronyms.items():\n",
    "    if set(areas).issubset(acronyms):\n",
    "        valid_session_ids.append(id)\n",
    "\n",
    "print(\"Found the following valid sessions:\")\n",
    "print(valid_session_ids)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Extract the relevant data from each session\n",
    "This will be 100 seconds of activity from 10 seconds before, and 90 seconds after a stimulus is presented to the mouse. There are multiple distinct stimulus presentation times (typicially 15-20) in each session. For each presentation, we extract the activity of the 6 visual cortex areas of interest. The raw data contains spike timings, we bin these into 100ms bins for each neuron. The output for a given area and a given presentation is a 1000*d matrix, representing the activity of d neurons in 100ms bins for 100 seconds (1000 timsteps)."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/dan/anaconda3/lib/python3.11/site-packages/hdmf/utils.py:668: UserWarning: Ignoring cached namespace 'hdmf-common' version 1.1.3 because version 1.8.0 is already loaded.\n",
      "  return func(args[0], **pargs)\n",
      "/home/dan/anaconda3/lib/python3.11/site-packages/hdmf/utils.py:668: UserWarning: Ignoring cached namespace 'core' version 2.2.2 because version 2.7.0 is already loaded.\n",
      "  return func(args[0], **pargs)\n"
     ]
    }
   ],
   "source": [
    "session_id = valid_session_ids[5] # choose one of the valid sessions\n",
    "session = cache.get_session_data(session_id)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div>\n",
       "<style scoped>\n",
       "    .dataframe tbody tr th:only-of-type {\n",
       "        vertical-align: middle;\n",
       "    }\n",
       "\n",
       "    .dataframe tbody tr th {\n",
       "        vertical-align: top;\n",
       "    }\n",
       "\n",
       "    .dataframe thead th {\n",
       "        text-align: right;\n",
       "    }\n",
       "</style>\n",
       "<table border=\"1\" class=\"dataframe\">\n",
       "  <thead>\n",
       "    <tr style=\"text-align: right;\">\n",
       "      <th></th>\n",
       "      <th>start_time</th>\n",
       "      <th>stop_time</th>\n",
       "      <th>duration</th>\n",
       "      <th>stimulus_name</th>\n",
       "      <th>stimulus_block</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>24.429348</td>\n",
       "      <td>84.496188</td>\n",
       "      <td>60.066840</td>\n",
       "      <td>spontaneous</td>\n",
       "      <td>null</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>84.496188</td>\n",
       "      <td>996.491813</td>\n",
       "      <td>911.995625</td>\n",
       "      <td>gabors</td>\n",
       "      <td>0.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>996.491813</td>\n",
       "      <td>1285.483398</td>\n",
       "      <td>288.991585</td>\n",
       "      <td>spontaneous</td>\n",
       "      <td>null</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>1285.483398</td>\n",
       "      <td>1583.982946</td>\n",
       "      <td>298.499548</td>\n",
       "      <td>flashes</td>\n",
       "      <td>1.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>1583.982946</td>\n",
       "      <td>1585.734418</td>\n",
       "      <td>1.751472</td>\n",
       "      <td>spontaneous</td>\n",
       "      <td>null</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>5</th>\n",
       "      <td>1585.734418</td>\n",
       "      <td>2185.235561</td>\n",
       "      <td>599.501143</td>\n",
       "      <td>drifting_gratings</td>\n",
       "      <td>2.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>6</th>\n",
       "      <td>2185.235561</td>\n",
       "      <td>2216.261498</td>\n",
       "      <td>31.025937</td>\n",
       "      <td>spontaneous</td>\n",
       "      <td>null</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>7</th>\n",
       "      <td>2216.261498</td>\n",
       "      <td>2816.763498</td>\n",
       "      <td>600.502000</td>\n",
       "      <td>natural_movie_three</td>\n",
       "      <td>3.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>8</th>\n",
       "      <td>2816.763498</td>\n",
       "      <td>2846.788598</td>\n",
       "      <td>30.025100</td>\n",
       "      <td>spontaneous</td>\n",
       "      <td>null</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>9</th>\n",
       "      <td>2846.788598</td>\n",
       "      <td>3147.039578</td>\n",
       "      <td>300.250980</td>\n",
       "      <td>natural_movie_one</td>\n",
       "      <td>4.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>10</th>\n",
       "      <td>3147.039578</td>\n",
       "      <td>3177.064688</td>\n",
       "      <td>30.025110</td>\n",
       "      <td>spontaneous</td>\n",
       "      <td>null</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>11</th>\n",
       "      <td>3177.064688</td>\n",
       "      <td>3776.565851</td>\n",
       "      <td>599.501163</td>\n",
       "      <td>drifting_gratings</td>\n",
       "      <td>5.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>12</th>\n",
       "      <td>3776.565851</td>\n",
       "      <td>4077.834348</td>\n",
       "      <td>301.268497</td>\n",
       "      <td>spontaneous</td>\n",
       "      <td>null</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>13</th>\n",
       "      <td>4077.834348</td>\n",
       "      <td>4678.336348</td>\n",
       "      <td>600.502000</td>\n",
       "      <td>natural_movie_three</td>\n",
       "      <td>6.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>14</th>\n",
       "      <td>4678.336348</td>\n",
       "      <td>4708.361438</td>\n",
       "      <td>30.025090</td>\n",
       "      <td>spontaneous</td>\n",
       "      <td>null</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>15</th>\n",
       "      <td>4708.361438</td>\n",
       "      <td>5397.937871</td>\n",
       "      <td>689.576433</td>\n",
       "      <td>drifting_gratings</td>\n",
       "      <td>7.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>16</th>\n",
       "      <td>5397.937871</td>\n",
       "      <td>5398.938718</td>\n",
       "      <td>1.000847</td>\n",
       "      <td>spontaneous</td>\n",
       "      <td>null</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>17</th>\n",
       "      <td>5398.938718</td>\n",
       "      <td>5879.340268</td>\n",
       "      <td>480.401550</td>\n",
       "      <td>static_gratings</td>\n",
       "      <td>8.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>18</th>\n",
       "      <td>5879.340268</td>\n",
       "      <td>5909.365398</td>\n",
       "      <td>30.025130</td>\n",
       "      <td>spontaneous</td>\n",
       "      <td>null</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>19</th>\n",
       "      <td>5909.365398</td>\n",
       "      <td>6389.766968</td>\n",
       "      <td>480.401570</td>\n",
       "      <td>natural_scenes</td>\n",
       "      <td>9.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>20</th>\n",
       "      <td>6389.766968</td>\n",
       "      <td>6690.017948</td>\n",
       "      <td>300.250980</td>\n",
       "      <td>spontaneous</td>\n",
       "      <td>null</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>21</th>\n",
       "      <td>6690.017948</td>\n",
       "      <td>7170.419568</td>\n",
       "      <td>480.401620</td>\n",
       "      <td>natural_scenes</td>\n",
       "      <td>10.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>22</th>\n",
       "      <td>7170.419568</td>\n",
       "      <td>7200.444628</td>\n",
       "      <td>30.025060</td>\n",
       "      <td>spontaneous</td>\n",
       "      <td>null</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>23</th>\n",
       "      <td>7200.444628</td>\n",
       "      <td>7680.846188</td>\n",
       "      <td>480.401560</td>\n",
       "      <td>static_gratings</td>\n",
       "      <td>11.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>24</th>\n",
       "      <td>7680.846188</td>\n",
       "      <td>7710.871348</td>\n",
       "      <td>30.025160</td>\n",
       "      <td>spontaneous</td>\n",
       "      <td>null</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>25</th>\n",
       "      <td>7710.871348</td>\n",
       "      <td>8011.122288</td>\n",
       "      <td>300.250940</td>\n",
       "      <td>natural_movie_one</td>\n",
       "      <td>12.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>26</th>\n",
       "      <td>8011.122288</td>\n",
       "      <td>8041.147408</td>\n",
       "      <td>30.025120</td>\n",
       "      <td>spontaneous</td>\n",
       "      <td>null</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>27</th>\n",
       "      <td>8041.147408</td>\n",
       "      <td>8569.088694</td>\n",
       "      <td>527.941286</td>\n",
       "      <td>natural_scenes</td>\n",
       "      <td>13.0</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>28</th>\n",
       "      <td>8569.088694</td>\n",
       "      <td>8611.624248</td>\n",
       "      <td>42.535554</td>\n",
       "      <td>spontaneous</td>\n",
       "      <td>null</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>29</th>\n",
       "      <td>8611.624248</td>\n",
       "      <td>9152.076028</td>\n",
       "      <td>540.451780</td>\n",
       "      <td>static_gratings</td>\n",
       "      <td>14.0</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "</div>"
      ],
      "text/plain": [
       "     start_time    stop_time    duration        stimulus_name stimulus_block\n",
       "0     24.429348    84.496188   60.066840          spontaneous           null\n",
       "1     84.496188   996.491813  911.995625               gabors            0.0\n",
       "2    996.491813  1285.483398  288.991585          spontaneous           null\n",
       "3   1285.483398  1583.982946  298.499548              flashes            1.0\n",
       "4   1583.982946  1585.734418    1.751472          spontaneous           null\n",
       "5   1585.734418  2185.235561  599.501143    drifting_gratings            2.0\n",
       "6   2185.235561  2216.261498   31.025937          spontaneous           null\n",
       "7   2216.261498  2816.763498  600.502000  natural_movie_three            3.0\n",
       "8   2816.763498  2846.788598   30.025100          spontaneous           null\n",
       "9   2846.788598  3147.039578  300.250980    natural_movie_one            4.0\n",
       "10  3147.039578  3177.064688   30.025110          spontaneous           null\n",
       "11  3177.064688  3776.565851  599.501163    drifting_gratings            5.0\n",
       "12  3776.565851  4077.834348  301.268497          spontaneous           null\n",
       "13  4077.834348  4678.336348  600.502000  natural_movie_three            6.0\n",
       "14  4678.336348  4708.361438   30.025090          spontaneous           null\n",
       "15  4708.361438  5397.937871  689.576433    drifting_gratings            7.0\n",
       "16  5397.937871  5398.938718    1.000847          spontaneous           null\n",
       "17  5398.938718  5879.340268  480.401550      static_gratings            8.0\n",
       "18  5879.340268  5909.365398   30.025130          spontaneous           null\n",
       "19  5909.365398  6389.766968  480.401570       natural_scenes            9.0\n",
       "20  6389.766968  6690.017948  300.250980          spontaneous           null\n",
       "21  6690.017948  7170.419568  480.401620       natural_scenes           10.0\n",
       "22  7170.419568  7200.444628   30.025060          spontaneous           null\n",
       "23  7200.444628  7680.846188  480.401560      static_gratings           11.0\n",
       "24  7680.846188  7710.871348   30.025160          spontaneous           null\n",
       "25  7710.871348  8011.122288  300.250940    natural_movie_one           12.0\n",
       "26  8011.122288  8041.147408   30.025120          spontaneous           null\n",
       "27  8041.147408  8569.088694  527.941286       natural_scenes           13.0\n",
       "28  8569.088694  8611.624248   42.535554          spontaneous           null\n",
       "29  8611.624248  9152.076028  540.451780      static_gratings           14.0"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# find when the stimulus times occur\n",
    "stimulus_epochs = session.get_stimulus_epochs()\n",
    "stimulus_epochs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Found the following 15 stimulus start times:\n",
      "[84.49618798636119, 1285.4833979863608, 1585.7344179863614, 2216.2614979863615, 2846.7885979863613, 3177.0646879863616, 4077.8343479863615, 4708.361437986361, 5398.938717986361, 5909.365397986361, 6690.017947986361, 7200.444627986361, 7710.871347986361, 8041.147407986361, 8611.624247986361]\n"
     ]
    }
   ],
   "source": [
    "# filter out the spontaneous and invalid presentations\n",
    "stim_start_times = stimulus_epochs[(stimulus_epochs['stimulus_name'] != 'spontaneous') & (stimulus_epochs['stimulus_name'] != 'invalid_presentation')][['start_time']]\n",
    "stim_start_times = list(stim_start_times['start_time'])\n",
    "print(\"Found the following\", len(stim_start_times) ,\"stimulus start times:\")\n",
    "print(stim_start_times)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "V1 has 51 units\n",
      "LM has 30 units\n",
      "RL has 24 units\n",
      "AL has 51 units\n",
      "PM has 90 units\n",
      "AM has 72 units\n"
     ]
    }
   ],
   "source": [
    "# check that the areas of interest indeed have neurons recorded\n",
    "for area_idx, area in enumerate(areas):\n",
    "    units = session.units[(session.units.ecephys_structure_acronym == area)].index.values\n",
    "    print(areas_map[area], 'has', len(units), 'units')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 91,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "> Collecting data for Stimulus presented at time: 84.49618798636119\n",
      "V1\n",
      "(1000, 51)\n",
      "LM\n",
      "(1000, 30)\n",
      "RL\n",
      "(1000, 24)\n",
      "AL\n",
      "(1000, 51)\n",
      "PM\n",
      "(1000, 90)\n",
      "AM\n",
      "(1000, 72)\n",
      "> Collecting data for Stimulus presented at time: 1285.4833979863608\n",
      "V1\n",
      "(1000, 51)\n",
      "LM\n",
      "(1000, 30)\n",
      "RL\n",
      "(1000, 24)\n",
      "AL\n",
      "(1000, 51)\n",
      "PM\n",
      "(1000, 90)\n",
      "AM\n",
      "(1000, 72)\n",
      "> Collecting data for Stimulus presented at time: 1585.7344179863614\n",
      "V1\n",
      "(1000, 51)\n",
      "LM\n",
      "(1000, 30)\n",
      "RL\n",
      "(1000, 24)\n",
      "AL\n",
      "(1000, 51)\n",
      "PM\n",
      "(1000, 90)\n",
      "AM\n",
      "(1000, 72)\n",
      "> Collecting data for Stimulus presented at time: 2216.2614979863615\n",
      "V1\n",
      "(1000, 51)\n",
      "LM\n",
      "(1000, 30)\n",
      "RL\n",
      "(1000, 24)\n",
      "AL\n",
      "(1000, 51)\n",
      "PM\n",
      "(1000, 90)\n",
      "AM\n",
      "(1000, 72)\n",
      "> Collecting data for Stimulus presented at time: 2846.7885979863613\n",
      "V1\n",
      "(1000, 51)\n",
      "LM\n",
      "(1000, 30)\n",
      "RL\n",
      "(1000, 24)\n",
      "AL\n",
      "(1000, 51)\n",
      "PM\n",
      "(1000, 90)\n",
      "AM\n",
      "(1000, 72)\n",
      "> Collecting data for Stimulus presented at time: 3177.0646879863616\n",
      "V1\n",
      "(1000, 51)\n",
      "LM\n",
      "(1000, 30)\n",
      "RL\n",
      "(1000, 24)\n",
      "AL\n",
      "(1000, 51)\n",
      "PM\n",
      "(1000, 90)\n",
      "AM\n",
      "(1000, 72)\n",
      "> Collecting data for Stimulus presented at time: 4077.8343479863615\n",
      "V1\n",
      "(1000, 51)\n",
      "LM\n",
      "(1000, 30)\n",
      "RL\n",
      "(1000, 24)\n",
      "AL\n",
      "(1000, 51)\n",
      "PM\n",
      "(1000, 90)\n",
      "AM\n",
      "(1000, 72)\n",
      "> Collecting data for Stimulus presented at time: 4708.361437986361\n",
      "V1\n",
      "(1000, 51)\n",
      "LM\n",
      "(1000, 30)\n",
      "RL\n",
      "(1000, 24)\n",
      "AL\n",
      "(1000, 51)\n",
      "PM\n",
      "(1000, 90)\n",
      "AM\n",
      "(1000, 72)\n",
      "> Collecting data for Stimulus presented at time: 5398.938717986361\n",
      "V1\n",
      "(1000, 51)\n",
      "LM\n",
      "(1000, 30)\n",
      "RL\n",
      "(1000, 24)\n",
      "AL\n",
      "(1000, 51)\n",
      "PM\n",
      "(1000, 90)\n",
      "AM\n",
      "(1000, 72)\n",
      "> Collecting data for Stimulus presented at time: 5909.365397986361\n",
      "V1\n",
      "(1000, 51)\n",
      "LM\n",
      "(1000, 30)\n",
      "RL\n",
      "(1000, 24)\n",
      "AL\n",
      "(1000, 51)\n",
      "PM\n",
      "(1000, 90)\n",
      "AM\n",
      "(1000, 72)\n",
      "> Collecting data for Stimulus presented at time: 6690.017947986361\n",
      "V1\n",
      "(1000, 51)\n",
      "LM\n",
      "(1000, 30)\n",
      "RL\n",
      "(1000, 24)\n",
      "AL\n",
      "(1000, 51)\n",
      "PM\n",
      "(1000, 90)\n",
      "AM\n",
      "(1000, 72)\n",
      "> Collecting data for Stimulus presented at time: 7200.444627986361\n",
      "V1\n",
      "(1000, 51)\n",
      "LM\n",
      "(1000, 30)\n",
      "RL\n",
      "(1000, 24)\n",
      "AL\n",
      "(1000, 51)\n",
      "PM\n",
      "(1000, 90)\n",
      "AM\n",
      "(1000, 72)\n",
      "> Collecting data for Stimulus presented at time: 7710.871347986361\n",
      "V1\n",
      "(1000, 51)\n",
      "LM\n",
      "(1000, 30)\n",
      "RL\n",
      "(1000, 24)\n",
      "AL\n",
      "(1000, 51)\n",
      "PM\n",
      "(1000, 90)\n",
      "AM\n",
      "(1000, 72)\n",
      "> Collecting data for Stimulus presented at time: 8041.147407986361\n",
      "V1\n",
      "(1000, 51)\n",
      "LM\n",
      "(1000, 30)\n",
      "RL\n",
      "(1000, 24)\n",
      "AL\n",
      "(1000, 51)\n",
      "PM\n",
      "(1000, 90)\n",
      "AM\n",
      "(1000, 72)\n",
      "> Collecting data for Stimulus presented at time: 8611.624247986361\n",
      "V1\n",
      "(1000, 51)\n",
      "LM\n",
      "(1000, 30)\n",
      "RL\n",
      "(1000, 24)\n",
      "AL\n",
      "(1000, 51)\n",
      "PM\n",
      "(1000, 90)\n",
      "AM\n",
      "(1000, 72)\n"
     ]
    }
   ],
   "source": [
    "dataset = {areas_map[area]:[] for area in areas} # dataset is keyed by shortened area name\n",
    "\n",
    "for start_time in stim_start_times:\n",
    "    print('> Collecting data for Stimulus presented at time:', start_time)\n",
    "    sample_start_time = start_time - 10 # go back 10 seconds\n",
    "    sample_end_time = start_time + 90 # go forward 90 seconds\n",
    "    \n",
    "    for area_idx, area in enumerate(areas):\n",
    "        print(areas_map[area])\n",
    "        # get the units in the specified area\n",
    "        units = session.units[(session.units.ecephys_structure_acronym == area)].index.values\n",
    "        \n",
    "        firing_rates = []\n",
    "        for idx, unit in enumerate(units):\n",
    "            # get spike times for the specified unit\n",
    "            spike_data = session.spike_times[unit]\n",
    "            # only keep spikes in the specified time window\n",
    "            spike_data = spike_data[sample_start_time <= spike_data]\n",
    "            spike_data = spike_data[spike_data <= sample_end_time]\n",
    "            spike_data = spike_data - sample_start_time\n",
    "            # count the number of spikes ocurring every 100 ms\n",
    "            bins = np.arange(0, 100.1, 0.1)\n",
    "            binned_spike_counts, _ = np.histogram(spike_data, bins=bins)\n",
    "            firing_rates.append(binned_spike_counts)\n",
    "\n",
    "        firing_rates = np.array(firing_rates)\n",
    "        firing_rates = firing_rates.T\n",
    "        print(firing_rates.shape)\n",
    "\n",
    "        dataset[areas_map[area]].append(firing_rates)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 92,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Use pickle.dump() to serialize the dictionary and write it to the file\n",
    "with open(f'session_{session_id}_100ms.pkl', 'wb') as file:\n",
    "    #pickle.dump(dataset, file)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "base",
   "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.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
