Skip to main content

Machine learning models for fMRI classification

Project description

cvbench output example

ml4fmri

A one-line Python toolkit for fMRI classification that allows you to benchmark multiple deep learning models for fMRI analysis on your data with a single function call. While designed for fMRI time series, it can work with any temporal classification task.

Originally based on the codebase behind the NeuroImage paper:
"A simple but tough-to-beat baseline for fMRI time-series classification"

Use example

You can install the package directly from PyPI:

pip install ml4fmri

For a more detailed guide, check out the Colab tutorial:

👉 Open in Google Colab

# In Python, get fMRI time series data in shape (samples, time, n_features)
# and labels in shape (samples) (binary or multiclass)

from ml4fmri import cvbench  # runs CV experiments with implemented models on the given data

# Run cross-validation with all available models. See below for more info on available `models`
report = cvbench(data, labels, models='all', n_folds=5)

# Plot test AUC boxplots for all models
report.plot_scores()

# Save test and training dataframes as .csv, and metadata as .json
report.save()

# Access logs directly as variables
train_df = report.get_train_dataframe()
test_df  = report.get_test_dataframe()
meta     = report.get_meta()

# Inspect training curves
report.plot_training_curves()

Available Models

You can set models input in cvbench to:

  • 'all' - run all models,
  • 'lite' (default) – use only faster models, better for quick tests
  • 'ts' – run only time series models
  • 'fnc' – run only FNC models; FNC data is derived from input time series
  • '<model_name>' – run only the specified model (e.g. 'meanMLP'); see ml4fmri.models README for full list
  • ['<model_name_1>', '<model_name_2>'] – run only the listed models

Time Series Models

  • "meanMLP" (Time Series)
    A simple MLP model for time series classification, surprisingly good for fMRi time series. Paper
    Code and bib item

  • "LSTM" (Time Series)
    Standard LSTM recurrent network for sequence classification.
    Paper
    Code and bib item

  • "meanLSTM" (Time Series)
    A variant of LSTM where outputs are mean-aggregated across time.
    Paper
    Code and bib item

  • "Transformer" (Time Series)
    Vanilla transformer encoder for modeling temporal dependencies in fMRI time series.
    Paper
    Code and bib item

  • "meanTransformer" (Time Series)
    Transformer with temporal mean pooling for classification.
    Paper
    Code and bib item

  • "MILC" (Time Series)
    CNN+LSTM model for fMRI time series.
    Paper
    Code and bib item

  • "BolT" (Time Series) Fused window Transformer for fMRI time series; slow but good, outperformed meanMLP on larger datasets. Paper Code and bib item

  • "DICE" (Time Series) LSTM-based connectivity estimator and classifier, works with time series. Paper Code and bib item

  • "Glacier" (Time Series) Transformer-based connectivity estimator and classifier, works with time series. Paper Code and bib item

  • "FBNetGen" (Time Series + FNC) Connectivity estimator, fuses it with FNC to do classification. Paper Code and bib item

FNC Models

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

ml4fmri-1.0.1.tar.gz (69.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

ml4fmri-1.0.1-py3-none-any.whl (60.6 kB view details)

Uploaded Python 3

File details

Details for the file ml4fmri-1.0.1.tar.gz.

File metadata

  • Download URL: ml4fmri-1.0.1.tar.gz
  • Upload date:
  • Size: 69.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.11

File hashes

Hashes for ml4fmri-1.0.1.tar.gz
Algorithm Hash digest
SHA256 2beefbf443c2e9279bca58bbc524d8e24099b025255ada8b5dd838e0d0f3657e
MD5 6600a54b79b67de363f17ce4d1c0938f
BLAKE2b-256 b7cd2abfb667a5be40bdc5a52cb56a90f9d5160fb4f86aa1a64ae2e1fc1f3689

See more details on using hashes here.

File details

Details for the file ml4fmri-1.0.1-py3-none-any.whl.

File metadata

  • Download URL: ml4fmri-1.0.1-py3-none-any.whl
  • Upload date:
  • Size: 60.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.11

File hashes

Hashes for ml4fmri-1.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 bd4b04c4190a1fa2b29fe684312a3a0bc8ca0b73a18ca9c20e347bfc5fe40f00
MD5 96307769f19923a63d2bf4512cb06f32
BLAKE2b-256 4552ae0b249d1bc8df5b37a18c6abfd10ceaacf227ece0c3af88cbfc948d7e40

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page