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

Check out the 👉 Colab tutorial for a more detailed guide and ways to modify the default behavior.

# 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.4.tar.gz (72.0 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.4-py3-none-any.whl (61.2 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: ml4fmri-1.0.4.tar.gz
  • Upload date:
  • Size: 72.0 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.4.tar.gz
Algorithm Hash digest
SHA256 860c18ff9952fc8672b3d0f98f0c96fc0fff0a9a77556aeff9776190a992e368
MD5 c448ca3bbd863c96c154f4089ebb98a0
BLAKE2b-256 8e41e96d1840763b9994a2bc21da40c065acec263df65409331b0e29c116e282

See more details on using hashes here.

File details

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

File metadata

  • Download URL: ml4fmri-1.0.4-py3-none-any.whl
  • Upload date:
  • Size: 61.2 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.4-py3-none-any.whl
Algorithm Hash digest
SHA256 5d33b497217fa2f6039293cf896724516d2af50f80a7fea2150256ad840cdeb9
MD5 e14b120942b50d4317b81f0dbf808b86
BLAKE2b-256 b71857646ec09dd9de51aaccded180db9bd030b5651a7e372abd8cf6bca9ea47

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