{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Extract reference conncectivity matrices of the mouse visual system from various papers"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "from itertools import permutations\n",
    "import pandas as pd\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import pickle"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "there are  30 combinations of areas where we are interested in the strength of the connections\n"
     ]
    }
   ],
   "source": [
    "areas_list = ['V1', 'RL', 'LM', 'AL', 'PM', 'AM']\n",
    "areas_map = {'VISp':'V1', 'VISl':'LM', 'VISrl':'RL', 'VISal':'AL', 'VISpm':'PM', 'VISam':'AM', 'LGd':'LGN', 'LP':'LP'}\n",
    "inverse_areas_map = {v: k for k, v in areas_map.items()}\n",
    "areas_index = [0, 1, 2, 3, 4, 5]\n",
    "\n",
    "index_combinations = list(permutations(areas_index, 2))\n",
    "print('there are ',len(index_combinations), 'combinations of areas where we are interested in the strength of the connections')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "# quick plotting function used to visualize the connectivity matrices\n",
    "def plot_connect_matrix(connect_matrix, title):\n",
    "    plt.imshow(connect_matrix, cmap='viridis', interpolation='nearest')\n",
    "    plt.colorbar()\n",
    "    plt.xticks(areas_index, areas_list)\n",
    "    plt.yticks(areas_index, areas_list)\n",
    "    plt.title(title)\n",
    "    plt.ylabel('Target area')\n",
    "    plt.xlabel('Source area')\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Source 1: *The Mouse Cortical Connectome, Characterized by an Ultra-Dense Cortical Graph, Maintains Specificity by Distinct Connectivity Profiles*\n",
    "https://doi.org/10.1016/j.neuron.2017.12.037\n",
    "\n",
    "- Corresponding File: `source_1.xlsx`, taken from the supplementary information section of the online article.\n",
    "- Connectivity Metric and method: "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "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>Case</th>\n",
       "      <th>Mouse</th>\n",
       "      <th>Strain</th>\n",
       "      <th>Sex</th>\n",
       "      <th>Age (weeks)</th>\n",
       "      <th>Weight (grams)</th>\n",
       "      <th>Source area</th>\n",
       "      <th>Target area</th>\n",
       "      <th>Neurons</th>\n",
       "      <th>Total neurons</th>\n",
       "      <th>FLNe</th>\n",
       "    </tr>\n",
       "  </thead>\n",
       "  <tbody>\n",
       "    <tr>\n",
       "      <th>0</th>\n",
       "      <td>1</td>\n",
       "      <td>13286</td>\n",
       "      <td>PVtdT</td>\n",
       "      <td>NaN</td>\n",
       "      <td>9</td>\n",
       "      <td>22.0</td>\n",
       "      <td>A</td>\n",
       "      <td>ACAd</td>\n",
       "      <td>1781</td>\n",
       "      <td>187372</td>\n",
       "      <td>0.009505</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1</th>\n",
       "      <td>1</td>\n",
       "      <td>13286</td>\n",
       "      <td>PVtdT</td>\n",
       "      <td>NaN</td>\n",
       "      <td>9</td>\n",
       "      <td>22.0</td>\n",
       "      <td>ACAv</td>\n",
       "      <td>ACAd</td>\n",
       "      <td>31458</td>\n",
       "      <td>187372</td>\n",
       "      <td>0.167900</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>2</th>\n",
       "      <td>1</td>\n",
       "      <td>13286</td>\n",
       "      <td>PVtdT</td>\n",
       "      <td>NaN</td>\n",
       "      <td>9</td>\n",
       "      <td>22.0</td>\n",
       "      <td>AId</td>\n",
       "      <td>ACAd</td>\n",
       "      <td>2027</td>\n",
       "      <td>187372</td>\n",
       "      <td>0.010820</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>3</th>\n",
       "      <td>1</td>\n",
       "      <td>13286</td>\n",
       "      <td>PVtdT</td>\n",
       "      <td>NaN</td>\n",
       "      <td>9</td>\n",
       "      <td>22.0</td>\n",
       "      <td>AIp</td>\n",
       "      <td>ACAd</td>\n",
       "      <td>126</td>\n",
       "      <td>187372</td>\n",
       "      <td>0.000673</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>4</th>\n",
       "      <td>1</td>\n",
       "      <td>13286</td>\n",
       "      <td>PVtdT</td>\n",
       "      <td>NaN</td>\n",
       "      <td>9</td>\n",
       "      <td>22.0</td>\n",
       "      <td>AIv</td>\n",
       "      <td>ACAd</td>\n",
       "      <td>263</td>\n",
       "      <td>187372</td>\n",
       "      <td>0.001404</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>...</th>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "      <td>...</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1237</th>\n",
       "      <td>27</td>\n",
       "      <td>14006</td>\n",
       "      <td>PVtdT</td>\n",
       "      <td>NaN</td>\n",
       "      <td>12</td>\n",
       "      <td>NaN</td>\n",
       "      <td>SSp-un</td>\n",
       "      <td>VISC</td>\n",
       "      <td>4830</td>\n",
       "      <td>268646</td>\n",
       "      <td>0.017980</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1238</th>\n",
       "      <td>27</td>\n",
       "      <td>14006</td>\n",
       "      <td>PVtdT</td>\n",
       "      <td>NaN</td>\n",
       "      <td>12</td>\n",
       "      <td>NaN</td>\n",
       "      <td>SSs</td>\n",
       "      <td>VISC</td>\n",
       "      <td>70087</td>\n",
       "      <td>268646</td>\n",
       "      <td>0.260900</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1239</th>\n",
       "      <td>27</td>\n",
       "      <td>14006</td>\n",
       "      <td>PVtdT</td>\n",
       "      <td>NaN</td>\n",
       "      <td>12</td>\n",
       "      <td>NaN</td>\n",
       "      <td>TEa</td>\n",
       "      <td>VISC</td>\n",
       "      <td>17414</td>\n",
       "      <td>268646</td>\n",
       "      <td>0.064820</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1240</th>\n",
       "      <td>27</td>\n",
       "      <td>14006</td>\n",
       "      <td>PVtdT</td>\n",
       "      <td>NaN</td>\n",
       "      <td>12</td>\n",
       "      <td>NaN</td>\n",
       "      <td>TEp</td>\n",
       "      <td>VISC</td>\n",
       "      <td>186</td>\n",
       "      <td>268646</td>\n",
       "      <td>0.000692</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "      <th>1241</th>\n",
       "      <td>27</td>\n",
       "      <td>14006</td>\n",
       "      <td>PVtdT</td>\n",
       "      <td>NaN</td>\n",
       "      <td>12</td>\n",
       "      <td>NaN</td>\n",
       "      <td>V1</td>\n",
       "      <td>VISC</td>\n",
       "      <td>31</td>\n",
       "      <td>268646</td>\n",
       "      <td>0.000115</td>\n",
       "    </tr>\n",
       "  </tbody>\n",
       "</table>\n",
       "<p>1242 rows × 11 columns</p>\n",
       "</div>"
      ],
      "text/plain": [
       "      Case  Mouse Strain  Sex  Age (weeks)  Weight (grams) Source area  \\\n",
       "0        1  13286  PVtdT  NaN            9            22.0           A   \n",
       "1        1  13286  PVtdT  NaN            9            22.0        ACAv   \n",
       "2        1  13286  PVtdT  NaN            9            22.0         AId   \n",
       "3        1  13286  PVtdT  NaN            9            22.0         AIp   \n",
       "4        1  13286  PVtdT  NaN            9            22.0         AIv   \n",
       "...    ...    ...    ...  ...          ...             ...         ...   \n",
       "1237    27  14006  PVtdT  NaN           12             NaN      SSp-un   \n",
       "1238    27  14006  PVtdT  NaN           12             NaN         SSs   \n",
       "1239    27  14006  PVtdT  NaN           12             NaN         TEa   \n",
       "1240    27  14006  PVtdT  NaN           12             NaN         TEp   \n",
       "1241    27  14006  PVtdT  NaN           12             NaN          V1   \n",
       "\n",
       "     Target area  Neurons  Total neurons      FLNe  \n",
       "0           ACAd     1781         187372  0.009505  \n",
       "1           ACAd    31458         187372  0.167900  \n",
       "2           ACAd     2027         187372  0.010820  \n",
       "3           ACAd      126         187372  0.000673  \n",
       "4           ACAd      263         187372  0.001404  \n",
       "...          ...      ...            ...       ...  \n",
       "1237        VISC     4830         268646  0.017980  \n",
       "1238        VISC    70087         268646  0.260900  \n",
       "1239        VISC    17414         268646  0.064820  \n",
       "1240        VISC      186         268646  0.000692  \n",
       "1241        VISC       31         268646  0.000115  \n",
       "\n",
       "[1242 rows x 11 columns]"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "tab1 = pd.read_excel('source_1.xlsx')\n",
    "tab1"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Processing Method:\n",
    "search by source area and target area. If multiple entries are found, average the values."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[0.   0.01 0.27 0.04 0.11 0.01]\n",
      " [0.2  0.   0.05 0.07 0.01 0.01]\n",
      " [0.48 0.02 0.   0.04 0.03 0.02]\n",
      " [0.21 0.09 0.09 0.   0.01 0.02]\n",
      " [0.35 0.   0.05 0.01 0.   0.1 ]\n",
      " [0.11 0.02 0.02 0.01 0.09 0.  ]]\n"
     ]
    },
    {
     "data": {
      "image/png": "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RPTU4VMLpQ0ZMkTydohERERUfRmcDFTmfAEiIqIqhz0D+jhWT0REcmKtOQPWYHAyoNFoKjMOIiIispIKPcKYiIjoqcdhAiIiInmT0zCB0Q8qIiIioqcLewaIiIikcJiAiIhI5mSUDHCYgIiISObYM0BERCRB8f+bqXVUB0wGiIiIpMhomIDJABERkQQuLSQiIiLZYM8AERGRFA4TEBERUXX5MDcVhwmIiIhkjj0DREREEuQ0gZDJABERkRQZzRngMAEREZHMsWeAiIhIAocJiIiI5I7DBERERCQX7BkgIiKSwGECGWj84nnYOdhbOwyLuj35hrVDsDibwPrWDsEqNCqVtUOwClFUZO0QLO5e56bWDsGiSkruAXst1JiMhglkmwwQERE9loySAc4ZICIikjn2DBAREUngnAEiIiK54zABERERyQV7BoiIiCQohIBCmPbV3tTzLYXJABERkRQOExAREZFcsGeAiIhIAlcTEBERyR2HCYiIiEgu2DNAREQkgcMEREREciejYQImA0RERBLk1DPAOQNEREQyx54BIiIiKRwmICIiourSzW8qDhMQERHJHHsGiIiIpAjxYDO1jmqAyQAREZEEriYgIiIi2WDPABERkRSuJiAiIpI3hebBZmod1QGHCYiIiGSOPQNERERSZDRMYPWegaioKCgUCigUCtjb2yMwMBBTpkxBSUkJMjIyoFAo4Obmhnv37umcd/ToUe15RERE5la2msDUrTqwejIAAD169MDvv/+Oc+fOYcyYMZg8eTJmzZql3e/k5ITNmzfrnJOUlIRnn33W0qESEZFclN1nwNStGqgSyYBKpULdunXh6+uLUaNGITQ0FFu3btXuj4yMRHJysvbnu3fvYu3atYiMjLRGuERERE+VKpEMPKpGjRooLi7W/jx8+HAcOHAA2dnZAICNGzfCz88PrVu3fmJdRUVFyM/P19mIiIiehMMEViKEwNdff41du3aha9eu2vI6deqgZ8+eSE1NBQAkJycjJibGoDqnT58OFxcX7ebj41MZoRMR0dNGmGmrBqpEMrB9+3Y4OjpCrVajZ8+eCAsLw+TJk3WOiYmJQWpqKi5evIjDhw9j6NChBtWdkJCAvLw87ZaTk1MJV0BERFR9VYmlhS+99BKWLFkCe3t7eHl5wdZWP6yePXviH//4B2JjY9G3b1/Url3boLpVKhVUKpW5QyYioqecnJ5NUCWSAQcHBwQGBj72GFtbW0RERGDmzJn46quvLBQZERHJloyeWlglhgkMNXXqVFy/fh3du3e3dihERERPjSrRM2Aoe3t7uLu7WzsMIiKSAQ4TWFDZCgEpL774IsRjulgGDBjw2P1EREQVxtsRExERkVxYvWeAiIioKuIwARERkdxpxIPN1DqqASYDREREUjhngIiIiKxh0aJF8PPzg1qtRrt27XDkyJFyjz116hQGDhwIPz8/KBQKzJs3r0JtMhkgIiKSoIAZHlRkZJtpaWmIj4/HpEmT8MMPP6BFixbo3r07rl27Jnn8nTt34O/vj48//hh169at8LUyGSAiIpJSdgdCUzcjzJkzByNHjkR0dDSCgoKwdOlS1KxZE8nJyZLHP//885g1axaGDBli0q33mQwQERFVAcXFxTh+/DhCQ0O1ZUqlEqGhoTh8+HClts0JhERERBLMubQwPz9fp1zqIXo3btxAaWkpPD09dco9PT1x5swZ0wJ5AvYMEBERSRFm2gD4+PjAxcVFu02fPt2il/Ik7BkgIiKqZDk5OXB2dtb+LDW+7+7uDhsbG1y9elWn/OrVqyZNDjQEewaIiIgkKIQwywYAzs7OOptUMmBvb4/g4GCkp6dryzQaDdLT09GhQ4dKvVb2DBAREUnR/P9mah1GiI+PR2RkJNq0aYO2bdti3rx5KCwsRHR0NAAgIiIC3t7e2mGG4uJi/PLLL9p///bbb8jMzISjoyMCAwMNbpfJABERURURFhaG69evY+LEicjNzUXLli2xc+dO7aTC7OxsKJV/depfuXIFrVq10v78ySef4JNPPkFISAgyMjIMbpfJABERkYSHu/lNqcNYcXFxiIuLk9z36Ae8n58fhIkxAkwGiIiIpMno2QRMBoiIiKRU4A6CknVUA1xNQEREJHPsGSAiIpJgzjsQVnVMBoiIiKRwmICIiIjkgj0DREREEhSaB5updVQHTAaIiIikcJiAiIiI5EK2PQN/zPaFrZ3a2mFYVE3nYmuHYHnX/rB2BGRBmpBWTz7oKWP39XFrh2BRCnHfco3xpkNERETyZq3bEVsDhwmIiIhkjj0DREREUmQ0gZDJABERkRQBwNSlgdUjF2AyQEREJIVzBoiIiEg22DNAREQkRcAMcwbMEkmlYzJAREQkRUYTCDlMQEREJHPsGSAiIpKiAaAwQx3VAJMBIiIiCVxNQERERLLBngEiIiIpMppAyGSAiIhIioySAQ4TEBERyRx7BoiIiKTIqGeAyQAREZEULi0kIiKSNy4tJCIiItlgzwAREZEUzhkgIiKSOY0AFCZ+mGuqRzLAYQIiIiKZY88AERGRFA4TEBERyZ0ZkgFUj2SAwwREREQyx54BIiIiKTIaJqgSPQOHDx+GjY0NevfurVOelZUFhUIBGxsb/Pbbbzr7fv/9d9ja2kKhUCArK8uC0RIRkSxohHm2aqBKJANJSUl46623sH//fly5ckVvv7e3N1auXKlTtmLFCnh7e1sqRCIioqeW1ZOBgoICpKWlYdSoUejduzdSU1P1jomMjERKSopOWUpKCiIjIy0UJRERyY7QmGerBqyeDKxbtw6NGjVCw4YNMWzYMCQnJ0M8MsbSr18/3Lx5EwcPHgQAHDx4EDdv3kTfvn2fWH9RURHy8/N1NiIioicqmzNg6lYNWD0ZSEpKwrBhwwAAPXr0QF5eHvbt26dzjJ2dnTZRAIDk5GQMGzYMdnZ2T6x/+vTpcHFx0W4+Pj7mvwgiInr6cM6AZZw9exZHjhxBeHg4AMDW1hZhYWFISkrSOzYmJgbr169Hbm4u1q9fj5iYGIPaSEhIQF5ennbLyckx6zUQERFVd1ZdWpiUlISSkhJ4eXlpy4QQUKlUWLhwoc6xzZo1Q6NGjRAeHo7GjRujadOmyMzMfGIbKpUKKpXK3KETEdHTjksLK19JSQlWrlyJ2bNnIzMzU7v99NNP8PLywhdffKF3TkxMDDIyMgzuFSAiIqowATPMGbD2RRjGaj0D27dvx82bNxEbGwsXFxedfQMHDkRSUhJ69OihUz5y5EgMGjQIrq6uFoyUiIjo6Wa1noGkpCSEhobqJQLAg2Tg2LFjejP/bW1t4e7uDltb3jiRiIgqmYxWE1jtU3Xbtm3l7mvbtq12eeGjywwf1rJly8fuJyIiqjCNBoCJ9wnQ8D4DREREVA2wv52IiEiKjFYTMBkgIiKSIqNkgMMEREREMseeASIiIikaAZNvFFBNbkfMZICIiEiCEBoIE586aOr5lsJkgIiISIoww4OGOGeAiIiIqgP2DBAREUkRZpgzUE16BpgMEBERSdFoAIWJY/7VZM4AhwmIiIhkjj0DREREUjhMQEREJG9Co4EwcZiguiwt5DABERGRzLFngIiISAqHCYiIiGROIwCFPJIBDhMQERHJHHsGiIiIpAgBwNT7DFSPngEmA0RERBKERkCYOEwgqkkywGECIiIiKUJjns1IixYtgp+fH9RqNdq1a4cjR4489vj169ejUaNGUKvVaNasGb788kuj22QyQEREVEWkpaUhPj4ekyZNwg8//IAWLVqge/fuuHbtmuTxhw4dQnh4OGJjY/Hjjz9iwIABGDBgAE6ePGlUu0wGiIiIJAiNMMtmjDlz5mDkyJGIjo5GUFAQli5dipo1ayI5OVny+E8//RQ9evTA2LFj0bhxY0ydOhWtW7fGwoULjWqXyQAREZEUCw8TFBcX4/jx4wgNDdWWKZVKhIaG4vDhw5LnHD58WOd4AOjevXu5x5dHdhMIyyZzlJTcs3Ikllciiq0dAlmIRty3dghWUSrDv2ulzN7rEjy4XktMzCvBfZPvOVQWb35+vk65SqWCSqXSKbtx4wZKS0vh6empU+7p6YkzZ85I1p+bmyt5fG5urlFxyi4ZuH37NgDg6DfTrRwJEZndQWsHQJZy+/ZtuLi4VErd9vb2qFu3Lg7mGj8RT4qjoyN8fHx0yiZNmoTJkyebpX5zkF0y4OXlhZycHDg5OUGhUFi07fz8fPj4+CAnJwfOzs4Wbdta5HjNgDyvW47XDPC6LX3dQgjcvn0bXl5eldaGWq3GpUuXUFxsnt5UIYTe582jvQIA4O7uDhsbG1y9elWn/OrVq6hbt65k3XXr1jXq+PLILhlQKpWoV6+eVWNwdnaW1X8agDyvGZDndcvxmgFetyVVVo/Aw9RqNdRqdaW38zB7e3sEBwcjPT0dAwYMAABoNBqkp6cjLi5O8pwOHTogPT0do0eP1pbt2bMHHTp0MKpt2SUDREREVVV8fDwiIyPRpk0btG3bFvPmzUNhYSGio6MBABEREfD29sb06Q+Gut955x2EhIRg9uzZ6N27N9auXYtjx47hs88+M6pdJgNERERVRFhYGK5fv46JEyciNzcXLVu2xM6dO7WTBLOzs6FU/rUQsGPHjlizZg0mTJiADz74AA0aNMCWLVvQtGlTo9plMmBBKpUKkyZNkhwrelrJ8ZoBeV63HK8Z4HXL7botIS4urtxhgYyMDL2yQYMGYdCgQSa1qRDV5cbJREREVCl40yEiIiKZYzJAREQkc0wGiIiIZI7JABERkcwxGTCTvn37okePHpL7Dhw4AIVCgZ9//hlvv/02goODoVKp0LJlS8sGWYmioqKgUCigUChgZ2eH+vXr47333sO9e3/dK16hUGDLli3WC9KMoqKitDcFeZSfnx8UCgXWrl2rt69JkyZQKBRITU2t3AAt4PDhw7CxsUHv3r11yrOysqBQKJCZmWmdwMzs4d9te3t7BAYGYsqUKSgpKUFGRgYUCgXc3Nx0ftcB4OjRo9rzqqsnvcc2Njb47bffdPb9/vvvsLW1hUKhQFZWlgWjJVMwGTCT2NhY7NmzB7/++qvevpSUFLRp0wbNmzcHAMTExCAsLMzSIVa6Hj164Pfff8fFixcxd+5cLFu2DJMmTbJ2WFbh4+ODlJQUnbLvvvsOubm5cHBwsFJU5pWUlIS33noL+/fvx5UrV6wdTqUq+90+d+4cxowZg8mTJ2PWrFna/U5OTti8ebPOOUlJSXj22WctHapZPek99vb2xsqVK3XKVqxYAW9vb0uFSGbCZMBM+vTpAw8PD71vfAUFBVi/fj1iY2MBAPPnz8ebb74Jf39/K0RZuVQqFerWrQsfHx8MGDAAoaGh2LNnj7XDsoqhQ4di3759yMnJ0ZYlJydj6NChsLWt/rf3KCgoQFpaGkaNGoXevXs/FT0dj1P2u+3r64tRo0YhNDQUW7du1e6PjIzUed783bt3sXbtWkRGRlojXLMw5D2OjIzUS3pTUlKq9XXLFZMBM7G1tUVERARSU1N1Hq25fv16lJaWIjw83IrRWd7Jkydx6NAh2NvbWzsUq/D09ET37t2xYsUKAMCdO3eQlpaGmJgYK0dmHuvWrUOjRo3QsGFDDBs2DMnJyRZ5pGxVUaNGDZ2H2AwfPhwHDhxAdnY2AGDjxo3w8/ND69atrRWiyQx5j/v164ebN2/i4MEHj4s8ePAgbt68ib59+1ojZDIBkwEziomJwYULF7Bv3z5tWUpKCgYOHGiRB2tY2/bt2+Ho6Ai1Wo1mzZrh2rVrGDt2rLXDspqYmBhtcrhhwwYEBAQ8NfNEkpKSMGzYMAAPutDz8vJ0fu+fVkIIfP3119i1axe6du2qLa9Tpw569uyp/facnJxc7RM/Q95jOzs7baIAPLjuYcOGwc7OzuLxkmmYDJhRo0aN0LFjR+0fxvnz53HgwAHtEMHT7qWXXkJmZia+//57REZGIjo6GgMHDrR2WFbTu3dvFBQUYP/+/U/Fh0OZs2fP4siRI9reLltbW4SFhSEpKcnKkVWehxPdnj17IiwsTO9Z9GXJ38WLF3H48GEMHTrUOsGagTHvcUxMDNavX4/c3FysX7/+qfk9lxsmA2YWGxuLjRs34vbt20hJSUFAQABCQkKsHZZFODg4IDAwEC1atEBycjK+//77p/oD4klsbW0xfPhwTJo0Cd9//321/nB4WFJSEkpKSuDl5QVbW1vY2tpiyZIl2LhxI/Ly8qwdXqUoS3TPnTuHu3fvYsWKFXoTQXv27Im7d+8iNjYWffv2Re3ata0UremMeY+bNWuGRo0aITw8HI0bNzb6ATlUNTAZMLPBgwdDqVRizZo1WLlyJWJiYqr10qKKUiqV+OCDDzBhwgTcvXvX2uFYTUxMDPbt24f+/fvDzc3N2uGYrKSkBCtXrsTs2bORmZmp3X766Sd4eXnhiy++sHaIlaIs0X322WfLnQBaNm8oIyOjWn87rsh7HBMTU+2vW+6q/7TmKsbR0RFhYWFISEhAfn4+oqKidPafP38eBQUFyM3Nxd27d7VrsYOCgp66yXaDBg3C2LFjsWjRIrz77rsAgEuXLumtP2/QoEG1XG6Xl5endy2Pfhts3Lgxbty4gZo1a1owssqzfft23Lx5E7GxsXrzYAYOHIikpCTt/TbOnj2rd36TJk2e6vHkqVOnYuzYsdW6V8CY97jMyJEjMWjQILi6ulowUjInJgOVIDY2FklJSejVqxe8vLx09o0YMUJnEk6rVq0APPiQ9PPzs2SYlc7W1hZxcXGYOXMmRo0aBQCIj4/XO+7AgQN44YUXLB2eyTIyMrTvXxmp+SHV+YPhUUlJSQgNDZWcEDtw4EDMnDkT+fn5AIAhQ4boHZOTk4N69epVepzWYm9vD3d3d2uHYRJj3uMytra21f665Y6PMCYiIpI5zhkgIiKSOSYDREREMsdkgIiISOaYDBAREckckwEiIiKZYzJAREQkc0wGiIiIZI7JABERkcwxGSAy0vXr1zFq1Cg8++yzUKlUqFu3Lrp3745vv/3W2qEREVUIb0dMZKSBAweiuLgYK1asgL+/P65evYr09HT88ccfldpucXFxlXl+xf3795/qZwwQyQ17BoiMcOvWLRw4cAAzZszASy+9BF9fX7Rt2xYJCQno16+f9rjs7Gz0798fjo6OcHZ2xuDBg3H16lXt/qioKAwYMECn7tGjR+PFF1/U/vziiy8iLi4Oo0ePhru7O7p37w4AOHXqFPr06QNnZ2c4OTmhc+fOuHDhgva8zz//HI0bN4ZarUajRo2wePHix17Tzp078cILL8DV1RW1a9dGnz59dOrLysqCQqFAWloaQkJCoFarsXr1aoPaev/99/Hcc8+hZs2a8Pf3x4cffoj79+8b9mITkcWwZ4DICI6OjnB0dMSWLVvQvn17qFQqvWM0Go02Edi3bx9KSkrw5ptvIiwsDBkZGUa1t2LFCowaNUo7BPHbb7+hS5cuePHFF/HNN9/A2dkZ3377LUpKSgAAq1evxsSJE7Fw4UK0atUKP/74I0aOHAkHBwdERkZKtlFYWIj4+Hg0b94cBQUFmDhxIl599VVkZmZCqfzr+8K4ceMwe/ZstGrVSpsQPKktJycnpKamwsvLCydOnMDIkSPh5OSE9957z6jXgYgqmSAio2zYsEG4ubkJtVotOnbsKBISEsRPP/2k3b97925hY2MjsrOztWWnTp0SAMSRI0eEEEJERkaK/v3769T7zjvviJCQEO3PISEholWrVjrHJCQkiPr164vi4mLJ2AICAsSaNWt0yqZOnSo6dOhg8PVdv35dABAnTpwQQghx6dIlAUDMmzfP5LZmzZolgoODDY6FiCyDwwRERho4cCCuXLmCrVu3okePHsjIyEDr1q2RmpoKADh9+jR8fHzg4+OjPScoKAiurq44ffq0UW0FBwfr/JyZmYnOnTtLjtcXFhbiwoULiI2N1fZgODo64qOPPtLp9n/UuXPnEB4eDn9/fzg7O2sfpZ2dna1zXJs2bYxuKy0tDZ06dULdunXh6OiICRMm6NVLRNbHYQKiClCr1Xj55Zfx8ssv48MPP8SIESMwadIkREVFGXS+UqmEeOTp4VJj6Q4ODjo/16hRo9w6CwoKAADLly9Hu3btdPbZ2NiUe17fvn3h6+uL5cuXw8vLCxqNBk2bNkVxcXG5sRjS1uHDhzF06FAkJiaie/fucHFxwdq1azF79uxyYyEi62AyQGQGQUFB2LJlCwCgcePGyMnJQU5OjrZ34JdffsGtW7cQFBQEAPDw8MDJkyd16sjMzHziDP3mzZtjxYoVkrP5PT094eXlhYsXL2Lo0KEGxf3HH3/g7NmzWL58OTp37gwAOHjw4BPPM6StQ4cOwdfXF+PHj9eWXb582aC4iMiymAwQGeGPP/7AoEGDEBMTg+bNm8PJyQnHjh3DzJkz0b9/fwBAaGgomjVrhqFDh2LevHkoKSnBG2+8gZCQEG1Xe9euXTFr1iysXLkSHTp0wH/+8x+cPHkSrVq1emz7cXFxWLBgAYYMGYKEhAS4uLjgu+++Q9u2bdGwYUMkJibi7bffhouLC3r06IGioiIcO3YMN2/eRHx8vF59bm5uqF27Nj777DM888wzyM7Oxrhx4wx6LZ7UVoMGDZCdnY21a9fi+eefx44dO7B582YjX3EisghrT1ogqk7u3bsnxo0bJ1q3bi1cXFxEzZo1RcOGDcWECRPEnTt3tMddvnxZ9OvXTzg4OAgnJycxaNAgkZubq1PXxIkThaenp3BxcRH/+te/RFxcnN4EwnfeeUcvhp9++km88sorombNmsLJyUl07txZXLhwQbt/9erVomXLlsLe3l64ubmJLl26iE2bNpV7TXv27BGNGzcWKpVKNG/eXGRkZAgAYvPmzUKIvyYQ/vjjj3rnPqmtsWPHitq1awtHR0cRFhYm5s6dK1xcXB7/IhORxSmEeGTgkoiIiGSFqwmIiIhkjskAERGRzDEZICIikjkmA0RERDLHZICIiEjmmAwQERHJHJMBIiIimWMyQEREJHNMBoiIiGSOyQAREZHMMRkgIiKSOSYDREREMvd/8tYGOnSOmX8AAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# setup the connectivity matrix for source 1\n",
    "CM1 = np.zeros((len(areas_list), len(areas_list)))\n",
    "\n",
    "# read in and store the mean connection strength for each pair of areas\n",
    "for var_from_idx, var_to_idx in index_combinations:\n",
    "    var_from = areas_list[var_from_idx]\n",
    "    var_to = areas_list[var_to_idx]\n",
    "\n",
    "    mean_conn = tab1[(tab1['Source area'] == var_from) & (tab1['Target area'] == var_to)]['FLNe'].mean()\n",
    "    \n",
    "    CM1[var_to_idx, var_from_idx] = mean_conn\n",
    "\n",
    "CM1 = np.round(CM1, 2)\n",
    "\n",
    "print(CM1)\n",
    "plot_connect_matrix(CM1, 'Connectivity matrix based on FLNe scores for source 1')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Export Matrices"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "with open('reference_structural_conn_matrix.pkl', 'wb') as f:\n",
    "    pickle.dump(CM1, f)"
   ]
  }
 ],
 "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
}
