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:
- parse a mixed-model style formula at the API edge,
- fit a random-intercept mixed model at each channel × timepoint,
- subtract the fitted random effects to obtain marginal EEG,
- run fast mass-univariate OLS on the marginalized data,
- 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.0.tar.gz
(19.1 kB
view details)
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
lmeeeg-0.2.0-py3-none-any.whl
(28.0 kB
view details)
File details
Details for the file lmeeeg-0.2.0.tar.gz.
File metadata
- Download URL: lmeeeg-0.2.0.tar.gz
- Upload date:
- Size: 19.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.14.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ada535cf0025f5df90d5a7ac760ff5a9fc6f01ee8a4ae329b52d528dba2e0376
|
|
| MD5 |
da88b76c74960c2f7376870799a0d4c5
|
|
| BLAKE2b-256 |
076eaf41f46a7d92fdece20369ce0ce4cec4959ad4584bafc802b60a1205dc8e
|
File details
Details for the file lmeeeg-0.2.0-py3-none-any.whl.
File metadata
- Download URL: lmeeeg-0.2.0-py3-none-any.whl
- Upload date:
- Size: 28.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.14.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
90eec349e37f94b43c26897c708ea7fa1732b5f3cfa1a7ebde05f548c79474aa
|
|
| MD5 |
21df7bbee5a568b7edeb6e3d58019634
|
|
| BLAKE2b-256 |
b5a3be2206adebe6177417d4e13f21c463f4693680c3de9459d6fb01d73a901a
|