Skip to main content

Minimal Python implementation of lmeEEG for random-intercept mass-univariate M/EEG analysis

Project description

LmeEEG

Minimal Python package implementing the core lmeEEG workflow for epoched M/EEG data with random intercepts:

  1. parse a mixed-model style formula at the API edge,
  2. fit a random-intercept mixed model at each channel × timepoint,
  3. subtract the fitted random effects to obtain marginal EEG,
  4. run fast mass-univariate OLS on the marginalized data,
  5. perform max-stat, cluster, or TFCE correction.

Current scope

  • One grouping factor in the public API
  • Random intercept only
  • Trial-wise epoched data shaped (n_observations, n_channels, n_times)
  • Cluster / TFCE correction via MNE-Python when installed
  • Tiny simulation utilities for recovery / null checks

Not yet included

  • Random slopes
  • Two grouping factors in the public API
  • Real-data validation workflows
  • Parallel / distributed optimization

Basic example

import numpy as np
import pandas as pd

from lmeeeg.api.fit import fit_lmm_mass_univariate
from lmeeeg.api.infer import permute_fixed_effect
from lmeeeg.simulation.generator import simulate_random_intercept_dataset

simulated = simulate_random_intercept_dataset(
    n_subjects=10,
    n_trials_per_subject=12,
    n_channels=4,
    n_times=25,
    effect_channels=[1, 2],
    effect_times=range(8, 14),
    beta=0.8,
    seed=13,
)

fit_result = fit_lmm_mass_univariate(
    eeg=simulated.eeg,
    metadata=simulated.metadata,
    formula="y ~ condition + latency + (1|subject)",
    variable_types={
        "condition": "categorical",
        "latency": "numeric",
        "subject": "group",
    },
)

# A rich progress bar is shown during the per-feature mixed-model fits by default.
# Disable it for quiet runs with:
# from lmeeeg.api.fit import FitConfig
# fit_result = fit_lmm_mass_univariate(..., config=FitConfig(show_progress=False))

inference = permute_fixed_effect(
    fit_result=fit_result,
    effect="condition[T.B]",
    correction="maxstat",
    n_permutations=200,
    seed=13,
)

print(inference.corrected_p_values.shape)

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

lmeeeg-0.2.1.tar.gz (19.8 kB view details)

Uploaded Source

Built Distribution

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

lmeeeg-0.2.1-py3-none-any.whl (28.9 kB view details)

Uploaded Python 3

File details

Details for the file lmeeeg-0.2.1.tar.gz.

File metadata

  • Download URL: lmeeeg-0.2.1.tar.gz
  • Upload date:
  • Size: 19.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.0

File hashes

Hashes for lmeeeg-0.2.1.tar.gz
Algorithm Hash digest
SHA256 918051f08808afc048bde1e891d7cbf5356c42398a4a52a32f944dbd68f7d101
MD5 a8a97f644b2f6c13509bb7baef7e7a5d
BLAKE2b-256 296487b1bdc389651b3313af34da51b4e4582509be10f3a549b412c9f2da3663

See more details on using hashes here.

File details

Details for the file lmeeeg-0.2.1-py3-none-any.whl.

File metadata

  • Download URL: lmeeeg-0.2.1-py3-none-any.whl
  • Upload date:
  • Size: 28.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.0

File hashes

Hashes for lmeeeg-0.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 00f673270e42cdf53aef724c2177cf4364895c61f2c76eb8921e1a696d78a0a8
MD5 e7bb9505f6b39a8d6e36989ab9cb80c2
BLAKE2b-256 e43fd405344959eb69d03d7bd6125070d7ceba3368cf493adefdc11c581d78cf

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