Schmid, Franca
Conti, Giulia
Jenny, Patrick
Weber, Bruno
DOCUMENTATION - Time-averaged simulations results for bi-phasic blood flow simulations in realistic microvascular networks for various single- and multi-capillary occlusion scenarios.
Correspondence: fschmid@ethz.ch (Franca Schmid, ORCID: 0000-0002-0689-9366)
1. Related references:
The data set is published in context with the manuscript:
[1] The severity of microstrokes depends on local vascular topology and baseline perfusion.
F Schmid, G Conti, P Jenny and B Weber. eLife. 2021. Doi: 10.7554/eLife.60208
The bi-phasic blood flow simulations have been performed in realistic microvascular networks (MVNs) from the mouse somatosensory cortex first published in:
[2] The cortical angiome: an interconnected vascular network with noncolumnar patterns of blood flow. P Blinder, PS Tsai, JP Kaufhold, PM Knutsen, H Suhl and D Kleinfeld. Nature Neuroscience. 2013. Doi: 10.1038/nn.3426
The bi-phasic blood flow model for realistic MVNs has first been published in:
[3] Depth-dependent flow and pressure characteristics in cortical microvascular networks. F Schmid, PS Tsai, D Kleinfeld, P Jenny and B Weber. PLoS Computational Biology. 2017. Doi: 10.1371/journal.pcbi.1005392
For further information on how to perform bi-phasic blood flow simulation, please contact the corresponding authors of [1] or [3].
2. Requirements (software):
All simulations and analyses have been performed in Python 2.7. To execute the analysis script the following python libraries need to be installed: cPickle, python-igraph, pandas, seaborn, scipy. The individual analyses script can then be executed by in Python (e.g. “python plot_Figure3.py”).
3. Content:
All folders are stored as compressed archives (*.tar.bz2). On unix-based system the folders can be unpacked by: "tar –jxf ARCHIVE_NAME"
3a. Time-averaged simulation results (python dictionaries stored as python 2.7 pickle files):
SimulationResults_Baseline.tar.bz2:
Folders: MVN1, MVN2
Content: verticesDict_baseline.pkl, edgesDict_baseline.pkl, pathsDict_allPaths_from_DA_to_AV_mainBranch.pkl (generated from prepare_Figure4.py), data_spatial_distribution_AVfactor.pkl (generated from plot_Figure4.py)
SimulationResults_SingleCapillaryOcclusions.tar.bz2:
Folders: 1-in-1-out, 1-in-2-out, 2-in-1-out, 2-in-2-out, 2-in-2-out_high, 2-in-2-out_AL1, 2-in-2-out_AL2, 2-in-2-out_AL3, 2-in-2-out_AL4, 2-in-2-out_AL5, 2-in-2-out_closeToDA, 2-in-2-out_farFromDA
Content: verticesDict_baseline.pkl, edgesDict_baseline.pkl, pathsDict_allPaths_from_DA_to_AV_mainBranch_vertexBased.pkl (only folders: 1-in-1-out, 1-in-2-out, 2-in-1-out, 2-in-2-out)
SimulationResults_MultiCapillaryOcclusions.tar.bz2:
Folders: vesselsOccluded_1, vesselsOccluded_3, vesselsOccluded_5, vesselsOccluded_7, vesselsOccluded_9
Content: verticesDict_baseline.pkl, edgesDict_baseline.pkl, pathsDict_allPaths_from_DA_to_AV_mainBranch_vertexBased.pkl
3b. Analysis scripts (python 2.7 scripts in folder Analyses_Scripts):
For details on the figure content see [1]. The verticesDict* and the edgesDict* are converted into graph structure (python-igraph) for all analyses. The functionality of python-igraph is used heavily throughout the various analyses.
helperFunctions.py: various functions used by the other analysis scripts
plot_Figure1_and_Figure1-supplement_1_a-d.py:
Input: SimulationResults_Baseline/MVN1/edgesDict_baseline.pkl, SimulationResults_Baseline/MVN1/verticesDict_baseline.pkl, SimulationResults_SingleCapillaryOcclusion/2-in-2-out/edgesDict.pkl, SimulationResults_SingleCapillaryOcclusion/2-in-2-out/verticesDict.pkl, SimulationResults_SingleCapillaryOcclusion/2-in-1-out/edgesDict.pkl, SimulationResults_SingleCapillaryOcclusion/2-in-1-out/verticesDict.pkl, SimulationResults_SingleCapillaryOcclusion/1-in-2-out/edgesDict.pkl, SimulationResults_SingleCapillaryOcclusion/1-in-2-out/verticesDict.pkl, SimulationResults_SingleCapillaryOcclusion/1-in-1-out/edgesDict.pkl, SimulationResults_SingleCapillaryOcclusion/1-in-1-out/verticesDict.pkl
Output: Figures/Figure_1/*, Supplementary_Figures/Figure_1-supplement_1_a-d/*
plot_Figure2_and_Figure2_supplement_1_a-d.py:
Input: SimulationResults_Baseline/MVN1/edgesDict_baseline.pkl, SimulationResults_Baseline/MVN1/verticesDict_baseline.pkl, SimulationResults_SingleCapillaryOcclusion/2-in-2-out/edgesDict.pkl, SimulationResults_SingleCapillaryOcclusion/2-in-2-out/verticesDict.pkl, SimulationResults_SingleCapillaryOcclusion/2-in-1-out/edgesDict.pkl, SimulationResults_SingleCapillaryOcclusion/2-in-1-out/verticesDict.pkl, SimulationResults_SingleCapillaryOcclusion/1-in-2-out/edgesDict.pkl, SimulationResults_SingleCapillaryOcclusion/1-in-2-out/verticesDict.pkl, SimulationResults_SingleCapillaryOcclusion/1-in-1-out/edgesDict.pkl, SimulationResults_SingleCapillaryOcclusion/1-in-1-out/verticesDict.pkl
Output: Figures/Figure_2/*, Supplementary_Figures/Figure_2-supplement_1_a-d/*
plot_Figure3.py:
Input: SimulationResults_Baseline/MVN1/edgesDict_baseline.pkl, SimulationResults_Baseline/MVN1/verticesDict_baseline.pkl, SimulationResults_MultiCapillaryOcclusion/*/edgesDict.pkl, SimulationResults_MultiCapillaryOcclusion/*/verticesDict.pkl
Output: Figures/Figure_3/*
prepare_Figure4.py (long execution time!):
Input: SimulationResults_Baseline/MVN*/edgesDict_baseline.pkl, SimulationResults_Baseline/MVN*/verticesDict_baseline.pkl,
Output: SimulationResults_Baseline/MVN*/pathsDict_allPaths_from_DA_to_AV_mainBranch.pkl
plot_Figure4.py (long execution time!):
Input: SimulationResults_Baseline/MVN*/*
Output: SimulationResults_Baseline/MVN*/edgesDict_baseline.pkl (attribute Lfactor_median added), SimulationResults_Baseline/MVN*/data_spatial_distribution_AVfactor.pkl, Figures/Figure_4/*
plot_Figure5.py:
Input: SimulationResults_Baseline/MVN*/*
Output: Figures/Figure_5/*
plot_Figure6.py:
Input: SimulationResults_Baseline/MVN1/*, SimulationResults_SingleCapillaryOcclusion/2-in-2- out/pathsDict_allPaths_from_DA_to_AV_mainBranch_vertexBased.pkl, SimulationResults_SingleCapillaryOcclusion/2-in-1- out/pathsDict_allPaths_from_DA_to_AV_mainBranch_vertexBased.pkl, SimulationResults_SingleCapillaryOcclusion/1-in-2- out/pathsDict_allPaths_from_DA_to_AV_mainBranch_vertexBased.pkl, SimulationResults_SingleCapillaryOcclusion/1-in-1- out/pathsDict_allPaths_from_DA_to_AV_mainBranch_vertexBased.pkl Output: Figures/Figure_6/*
4. Attributes stored in python dictionaries:
4a. Baseline:
verticesDict: contains all relevant information and data stored at vertices.
edgesDict: contains all relevant information and data stored at edges.
pathsDict_allPaths_from_DA_to_AV_mainBranch: contains all flow path from DA main brain to AV main branch. For details see [1].
data_spatial_distribution_AVfactor: contains information on the spatial distribution of venule-sided capillaries (AV-factor > 0.5). For details see [1].
4b. Occlusion scenarios (both single- and multi-capillary occlusions):
verticesDict:
edgesDict:
pathsDict_allPaths_from_DA_to_AV_mainBranch_vertexBased: contains all flow path from DA main brain to AV main branch (unique vertex sequences). For details see helperFunctions.py --> function convert_pathsDict_to_unique_vertexSequence.