Metadata-Version: 2.1
Name: mne-rsa
Version: 0.5
Summary: Code for performing Representational Similarity Analysis on MNE-Python data structures.
Home-page: https://github.com/wmvanvliet/mne-rsa
Download-URL: https://github.com/wmvanvliet/mne-rsa/archive/master.zip
Maintainer: Marijn van Vliet
Maintainer-email: w.m.vanvliet@gmail.com
License: BSD-3
Platform: any
Classifier: Intended Audience :: Science/Research
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved
Classifier: Programming Language :: Python
Classifier: Topic :: Software Development
Classifier: Topic :: Scientific/Engineering
Classifier: Operating System :: Microsoft :: Windows
Classifier: Operating System :: POSIX
Classifier: Operating System :: Unix
Classifier: Operating System :: MacOS
License-File: LICENSE
Requires-Dist: numpy
Requires-Dist: scipy
Requires-Dist: matplotlib
Requires-Dist: mne

Representational Similarity Analysis
------------------------------------

|unit_tests|_ |build_docs|_

.. |unit_tests| image:: https://github.com/wmvanvliet/mne-rsa/workflows/unit%20tests/badge.svg
.. _unit_tests: https://github.com/wmvanvliet/mne-rsa/actions?query=workflow%3A%22unit+tests%22

.. |build_docs| image:: https://github.com/wmvanvliet/mne-rsa/workflows/build-docs/badge.svg
.. _build_docs: https://github.com/wmvanvliet/mne-rsa/actions?query=workflow%3Abuild-docs

This is a Python package for performing representational similarity
analysis (RSA) using
`MNE-Python <https://martinos.org/mne/stable/index.html>`__ data
structures. The RSA is computed using a “searchlight” approach.

Read more on RSA in the paper that introduced the technique:

Nikolaus Kriegeskorte, Marieke Mur and Peter Bandettini (2008).
Representational similarity analysis - connecting the branches of
systems neuroscience. Frontiers in Systems Neuroscience, 2(4).
https://doi.org/10.3389/neuro.06.004.2008

.. image:: https://raw.githubusercontent.com/wmvanvliet/mne-rsa/master/doc/rsa.png
   :width: 400


Installation
------------

Here is how to install the package as a user:

``pip install mne-rsa``

Use cases
---------

This is what the package can do for you:

-  Compute DSMs on arbitrary data
-  Compute DSMs in a searchlight across:

   -  vertices/voxels and samples (source level)
   -  sensors and samples (sensor level)
   -  vertices/voxels only (source level)
   -  sensors only (sensor level)
   -  samples only (source and sensor level)

-  Use cross-validated distance metrics when computing DSMs
-  And of course: compute RSA between DSMs

Supported metrics for comparing DSMs:

-  Spearman correlation (the default)
-  Pearson correlation
-  Kendall’s Tau-A
-  Linear regression (when comparing multiple DSMs at once)
-  Partial correlation (when comparing multiple DSMs at once)

Juicy bits of the API
---------------------

.. code:: python

   def compute_dsm(model, pca=False, metric='correlation', **kwargs)

   def rsa_stcs(stcs, model_dsm, src, y=None,
                spatial_radius=0.04, temporal_radius=0.1,
                stc_dsm_metric='correlation', stc_dsm_params=None,
                rsa_metric='spearman',
                n_jobs=1, verbose=False)

   def rsa_evokeds(evokeds, model_dsm, y=None, noise_cov=None,
                   spatial_radius=0.04, temporal_radius=0.1,
                   evoked_dsm_metric='correlation', evoked_dsm_params=None,
                   rsa_metric='spearman',
                   n_jobs=1, verbose=False)

   def rsa_epochs(epochs, model_dsm, y=None, noise_cov=None,
                  spatial_radius=0.04, temporal_radius=0.1,
                  epochs_dsm_metric='correlation', epochs_dsm_params=None,
                  rsa_metric='spearman',
                  n_jobs=1, verbose=False)

   def rsa_nifti(image, model_dsm, src, y=None,
                 spatial_radius=0.01, 
                 image_dsm_metric='correlation', image_dsm_params=None,
                 rsa_metric='spearman',
                 n_jobs=1, verbose=False)

Example usage
-------------

Basic example on the EEG “kiloword” data:

.. code:: python

   import mne
   import rsa
   data_path = mne.datasets.kiloword.data_path(verbose=True)
   epochs = mne.read_epochs(data_path + '/kword_metadata-epo.fif')
   # Compute the model DSM using all word properties
   dsm_model = rsa.compute_dsm(epochs.metadata.iloc[:, 1:].values)
   evoked_rsa = rsa.rsa_epochs(epochs, dsm_model,
                               spatial_radius=0.04, temporal_radius=0.01,
                               verbose=True)

Documentation
-------------

For quick guides on how to do specific things, see the
`examples <https://users.aalto.fi/~vanvlm1/mne-rsa/auto_examples/index.html>`__.

Finally, there is the `API
reference <https://users.aalto.fi/~vanvlm1/mne-rsa/api.html>`__
documentation.

Integration with other packages
-------------------------------

I mainly wrote this package to perform RSA analysis on MEG data. Hence,
integration functions with `MNE-Python <https://mne.tools>`__ are
provided. There is also some integration with `nipy <https://nipy.org>`__ for
fMRI.

Performance
-----------

This package aims to be fast and memory efficient. An important design
feature is that under the hood, everything operates on generators. The
searchlight routines produce a generator of DSMs which are consumed by a
generator of RSA values. Parallel processing is also supported, so you
can use all of your CPU cores.

Development
-----------

Here is how to set up the package as a developer:

::

   git clone git@github.com:wmvanvliet/mne-rsa.git
   cd mne-rsa
   python setup.py develop --user

.. |CircleCI| image:: https://circleci.com/gh/wmvanvliet/mne-rsa.svg?style=shield
   :target: https://circleci.com/gh/wmvanvliet/mne-rsa


