.. _connectome_extraction: ============================================================================ Connectome extraction: inverse covariance for direct connections ============================================================================ .. topic:: **Page summary** Given a set of time-series (eg as extracted in the previous section) A *functional connectome* is a set of connections representing brain interactions between regions. Here we show the use of sparse-inverse covariance to extract functional connectomes focussing only on direct interactions between regions. .. contents:: **Contents** :local: :depth: 1 .. topic:: **References** * `Smith et al, Network modelling methods for FMRI, NeuroImage 2011 `_ * `Varoquaux and Craddock, Learning and comparing functional connectomes across subjects, NeuroImage 2013 `_ Sparse inverse covariance for functional connectomes ===================================================== Resting-state functional connectivity can be obtained by estimating a covariance (or correlation) matrix for signals from different brain regions. The same information can be represented as a weighted graph, vertices being brain regions, weights on edges being covariances (gaussian graphical model). However, coefficients in a covariance matrix reflects direct as well as indirect connections. Covariance matrices form very dense brain connectomes, and it is rather difficult to extract from them only the direct connections between two regions. As shown in `[Smith 2011] `_, `[Varoquaux 2010] `_, it is more interesting to use the inverse covariance matrix, ie the *precision matrix*. It gives **only direct connections between regions**, as it contains *partial covariances*, which are covariances between two regions conditioned on all the others. To recover well the interaction structure, a **sparse inverse covariance estimator** is necessary. The GraphLasso, implemented in scikit-learn's estimator :class:`sklearn.covariance.GraphLassoCV` is a good, simple solution. To use it, you need to create an estimator object:: >>> from sklearn.covariance import GraphLassoCV >>> estimator = GraphLasso() And then you can fit it on the activation time series, for instance extracted in :ref:`the previous section `:: >>> estimator.fit(time_series) # doctest: +SKIP The covariance matrix and inverse-covariance matrix (precision matrix) can be found respectively in the `covariance_` and `precision_` attribute of the estimator:: >>> estimator.covariance_ # doctest: +SKIP >>> estimator.precision_ # doctest: +SKIP .. |covariance| image:: ../auto_examples/connectivity/images/plot_inverse_covariance_connectome_001.png :target: ../auto_examples/connectivity/plot_inverse_covariance_connectome.html :scale: 40 .. |precision| image:: ../auto_examples/connectivity/images/plot_inverse_covariance_connectome_003.png :target: ../auto_examples/connectivity/plot_inverse_covariance_connectome.html :scale: 40 .. |covariance_graph| image:: ../auto_examples/connectivity/images/plot_inverse_covariance_connectome_002.png :target: ../auto_examples/connectivity/plot_inverse_covariance_connectome.html :scale: 55 .. |precision_graph| image:: ../auto_examples/connectivity/images/plot_inverse_covariance_connectome_004.png :target: ../auto_examples/connectivity/plot_inverse_covariance_connectome.html :scale: 55 .. centered:: |covariance| |precision| .. centered:: |covariance_graph| |precision_graph| .. topic:: **Parameter selection** The parameter controlling the sparsity is set by `cross-validation `_ scheme. If you want to specify it manually, use the estimator :class:`sklearn.covariance.GraphLasso`. .. topic:: **Full example** See the following example for a full file running the analysis: :ref:`example_connectivity_plot_inverse_covariance_connectome.py` .. topic:: **Exercise: computing sparse inverse covariance** :class: green Compute and visualize a connectome on the first subject of the ADHD dataset downloaded with :func:`nilearn.datasets.fetch_adhd` **Hints:** The example above has the solution .. topic:: **Reference** * The `graph lasso [Friedman et al, Biostatistics 2007] `_ is useful to estimate one inverse covariance, ie to work on single-subject data or concatenate multi-subject data. Sparse inverse covariance on multiple subjects ================================================ To work at the level of a group of subject, it can be interesting to estimate multiple connectomes for each, with a similar structure but differing connection values across subjects. For this, nilearn provides the :class:`nilearn.group_sparse_covariance.GroupSparseCovarianceCV` estimator. Its usage is similar to the GraphLassoCV object, but it takes a list of time series:: >>> estimator.fit([time_series_1, time_series_2, ...]) # doctest: +SKIP And it provides one estimated covariance and inverse-covariance (precision) matrix per time-series: for the first one:: >>> estimator.covariances_[0] # doctest: +SKIP >>> estimator.precisions_[0] # doctest: +SKIP | .. currentmodule:: nilearn.group_sparse_covariance One specific case where this may be interesting is for group analysis across multiple subjects. Indeed, one challenge when doing statistics on the coefficients of a connectivity matrix is that the number of coefficients to compare grows quickly with the number of regions, and as a result correcting for multiple comparisions takes a heavy toll on statistical power. In such a situation, you can use the :class:`GroupSparseCovariance` and set an `alpha` value a bit higher than the alpha value selected by cross-validation in the :class:`GroupSparseCovarianceCV`. Such a choice will enforce a stronger sparsity on the precision matrices for each subject. As the sparsity is common to each subject, you can then do the group analysis only on the non zero coefficients. .. topic:: **Full example** See the following example for a full file running the analysis: :ref:`example_connectivity_plot_multi_subject_connectome.py` .. topic:: **Exercise: computing the correlation matrix of rest fmri** :class: green Try using the information above to compute a connectome on the first 5 subjects of the ADHD dataset downloaded with :func:`nilearn.datasets.fetch_adhd` **Hint:** The example above has the solution .. .. |covariance| image:: ../auto_examples/connectivity/images/plot_adhd_covariance_002.png :target: ../auto_examples/connectivity/plot_adhd_covariance.html :scale: 55 .. |precision| image:: ../auto_examples/connectivity/images/plot_adhd_covariance_001.png :target: ../auto_examples/connectivity/plot_adhd_covariance.html :scale: 55 .. centered:: |covariance| |precision| .. topic:: **Reference** * The `group-sparse covariance [Varoquaux et al, NIPS 2010] `_ | Comparing the different approaches on simulated data ==================================================== We simulate several sets of signals, one set representing one subject, with different precision matrices, but sharing a common sparsity pattern: 10 brain regions, for 20 subjects. A single-subject estimation can be performed using the :class:`sklearn.covariance.GraphLassoCV` estimator from scikit-learn. It is also possible to fit a graph lasso on data from every subject all together. Finally, we use the :class:`nilearn.group_sparse_covariance.GroupSparseCovarianceCV`. The results are the following: .. image:: ../auto_examples/connectivity/images/plot_simulated_connectome_001.png :target: ../auto_examples/connectivity/plot_simulated_connectome.html :scale: 60 The group-sparse estimation outputs matrices with the same sparsity pattern, but different values for the non-zero coefficients. This is not the case for the graph lasso output, which all have similar but different structures. Note that the graph lasso applied to all subjects at once gives a sparsity pattern close to that obtained with the group-sparse one, but cannot provide per-subject information. .. note:: The complete source code for this example can be found here: :ref:`example_connectivity_plot_simulated_connectome.py` ____ A lot of technical details on the algorithm used for group-sparse estimation and its implementation can be found in :doc:`../developers/group_sparse_covariance`.