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.3.4.tar.gz
(22.2 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.3.4-py3-none-any.whl
(32.0 kB
view details)
File details
Details for the file lmeeeg-0.3.4.tar.gz.
File metadata
- Download URL: lmeeeg-0.3.4.tar.gz
- Upload date:
- Size: 22.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.14.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
26dbcdec087ed98f92dde9df0f163eeca42caa713f03a98b4abdba896cf779fb
|
|
| MD5 |
b1a9011c194fe86139363380643a1c51
|
|
| BLAKE2b-256 |
71d6c2b0bfa7995bd04b30fd765e21d19893bde6df7a32f75b1093d294f5daa4
|
File details
Details for the file lmeeeg-0.3.4-py3-none-any.whl.
File metadata
- Download URL: lmeeeg-0.3.4-py3-none-any.whl
- Upload date:
- Size: 32.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 |
f4ac471a0315beacb96fc92799a75874bed7232d94d254f9771f4d41a0138958
|
|
| MD5 |
35bb29ab053519d813a3596ac4cd21e1
|
|
| BLAKE2b-256 |
c905ea2ae608ce4418e761be2e5c4d90c727f36f4f1b27b98691c5f1222b58aa
|