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 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.2.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.2-py3-none-any.whl (60.6 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: ml4fmri-1.0.2.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.2.tar.gz
Algorithm Hash digest
SHA256 1101c6836d9b667dc4191facaeba18ddc9f39db5f0ebed2f07e70ed7591b3414
MD5 aceeb9159a572e3529cf4957418883db
BLAKE2b-256 d32a8dd61901f5a691ce16a6a4b3b27cb447f69c22b8dcb9455d83d0273ddab8

See more details on using hashes here.

File details

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

File metadata

  • Download URL: ml4fmri-1.0.2-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.2-py3-none-any.whl
Algorithm Hash digest
SHA256 a0f1655633e268e52d79402a5857c65d171eead8eb4e4f13b2215ab83b0e2adf
MD5 82b35a7346b995e9b341b2ad6cc31aaa
BLAKE2b-256 db60b2a6a460cdd9fc9e365d110c12550898c78b44297ec11fc3776e03b6ca9d

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