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.

# In Python, get fMRI time series DATA in shape (SAMPLES, TIME, 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' - (default for non-CPU) run all models,
  • 'lite' (default for CPU) – 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 below for full model 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.3.tar.gz (69.4 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.3-py3-none-any.whl (60.7 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: ml4fmri-1.0.3.tar.gz
  • Upload date:
  • Size: 69.4 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.3.tar.gz
Algorithm Hash digest
SHA256 960151d61fe8f40eb0b1cfb92dfa7cf8bd8f19b71581285bf90324b0f7d7dda2
MD5 5d4e657d7df1870189d65a250ce95f77
BLAKE2b-256 13249b736d62fbd34439eda95d56e768f0baa28bd83938680135cdb8b1c38136

See more details on using hashes here.

File details

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

File metadata

  • Download URL: ml4fmri-1.0.3-py3-none-any.whl
  • Upload date:
  • Size: 60.7 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.3-py3-none-any.whl
Algorithm Hash digest
SHA256 15e8132e89a4e639c22df380d9032e2c965fb69b8053e62eee8f185958ffc8e9
MD5 dbe22187e5fa2974def302f5648da6d3
BLAKE2b-256 a5c1b0335b288ec1480de5c826321b6ea14922956f5d283282ee56c6a4b6176b

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