A Python package for sleep analysis and hypnogram processing
Project description
hypnofunk 🌙
hypnofunk is a high-performance toolkit for sleep researchers. It calculates 40+ macrostructure parameters, performs first-order Markov-chain transition analysis, and detects sleep cycles—all from simple hypnogram sequences.
Installation
# Core package
pip install hypnofunk
# Full installation — includes Lempel-Ziv complexity, plotting, and EDF support
pip install hypnofunk[full]
Supported Input Formats
Hypnogram data (in-memory)
hypnofunk accepts standard AASM sleep stage labels (W, N1, N2, N3, R) as:
- Python lists, NumPy arrays, or Pandas Series.
File formats (via example workflow)
The included polyman_analysis.py provides a turnkey solution for:
- EDF / EDF+: Reads Polyman-style annotations directly.
- CSV: Processes exported spreadsheets with epoch-by-epoch scoring.
Standard Analysis Parameters
hypnofunk uses industry-standard defaults, all of which are configurable via function arguments:
| Parameter | Default | Logic |
|---|---|---|
epoch_duration |
30s |
The standard temporal resolution for clinical sleep scoring. |
max_wake_epochs |
10 |
Keeps 5 mins of wake after final sleep before trimming terminal wake. |
min_nrem_epochs |
30 |
Defines a NREM cycle as ≥15 mins of continuous NREM starting with N2. |
min_rem_epochs |
10 |
Subsequent REM cycles must be ≥5 mins (1st REM cycle can be any length). |
Sleep Cycle Detection Logic
Our detection algorithms follow standard clinical research criteria to ensure consistency across datasets:
NREM Cycles 🌙
A sequence is identified as a NREM cycle if:
- It starts with N2 sleep.
- It contains at least 15 minutes (30 epochs) of continuous NREM (N1, N2, or N3).
- This prevents short "transitional" light sleep from being miscounted as a full cycle.
REM Cycles ⚡
REM detection handles the unique nature of early-night sleep:
- First REM Cycle: Accepted at any length (standard research practice).
- Subsequent REM Cycles: Must be at least 5 minutes (10 epochs) long.
- This ensures that REM "fragments" commonly found in fragmented sleep don't artificially inflate cycle counts.
Markov-Chain Transition Analysis 🔄
hypnofunk provides a robust framework for quantifying sleep stability and fragmentation using first-order Markov chains:
- Full Transition Matrix: A 5×5 matrix of probabilities for transitions between every sleep stage (W, N1, N2, N3, R).
- Stage Persistence: The probability of remaining in a specific stage (diagonal nodes of the Markov chain).
- Awakening Probabilities: The specific likelihood of transitioning to Wake from each individual sleep stage.
- Sleep Compactness: A global consolidation index calculated as the mean persistence across all sleep stages.
- Fragility Metrics: Proportion of all transitions that result in awakening.
Quick Start
from hypnofunk import hypnoman, analyze_transitions
# 10 epochs Wake, 50 N2, 30 N3, 20 REM, 5 Wake
hypnogram = ["W"]*10 + ["N2"]*50 + ["N3"]*30 + ["R"]*20 + ["W"]*5
# Get 40+ parameters in one line (Macrostructure)
params = hypnoman(hypnogram, epoch_duration=30)
print(f"TST: {params['TST'].values[0]:.1f} min | SE: {params['Sleep_efficiency'].values[0]:.1f}%")
# Analyze stage transitions & Markov chain dynamics
trans = analyze_transitions(hypnogram)
print(f"Sleep Compactness: {trans['Sleep_Compactness'].values[0]:.3f}")
print(f"Prob. N2 Persistence: {trans['Persistence_N2'].values[0]:.3f}")
Core Functionality
Sleep Macrostructure — hypnoman()
Returns a single-row pd.DataFrame containing:
- Time metrics: TRT, TST, SPT, WASO, SOL.
- Efficiency: Sleep Efficiency (SE), Sleep Maintenance Efficiency (SME).
- Stage statistics: Duration, percentage, and onset latency for all stages.
- Streak analysis: Longest, mean, and median "runs" (streaks) for every stage.
- Information Theory: Lempel-Ziv complexity (LZc) — a non-linear measure of sleep stage variety (requires
antropy).
Transition Analysis — analyze_transitions()
Performs the Markov-chain analysis described above, returning:
- Total transitions (fragmentation count).
- Probability of awakening.
- Sleep compactness index.
- Per-stage persistence and awakening probabilities.
- Complete transition matrix (25 probability values).
API Reference
hypnofunk.io
read_edf_hypnogram(): Standardized loader for Polyman EDF and EDF+ files.
hypnofunk.core
hypnoman(): The main entry point for macrostructure metrics.find_nremstretches()&find_rem_stretches(): Cycle detection engines.trim_terminal_wake(): Utility to clean extended wake at the end of recordings.
hypnofunk.transitions
analyze_transitions(): Main entry point for fragmentation and Markov metrics.compute_transition_matrix(): Raw transition probability calculations.compute_sleep_compactness(): Statistical consolidated sleep index.
hypnofunk.visualization
plot_hypnogram_with_cycles(): Clean hypnograms with cycle-overlay bars.plot_transition_matrix(): Heatmap visualization of stage dynamics (Markov matrix).
Citation
@software{hypnofunk2026,
author = {Venugopal, Rahul},
title = {hypnofunk: A Python package for sleep analysis},
year = {2026},
url = {https://github.com/rahulvenugopal/hypnofunk}
}
License
MIT — see LICENSE for details. Developed by Rahul Venugopal.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
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
File details
Details for the file hypnofunk-0.3.0.tar.gz.
File metadata
- Download URL: hypnofunk-0.3.0.tar.gz
- Upload date:
- Size: 21.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
39e7895957edcfd4091fd7f213af9e3f4d512c393bbe622085198b5e94460bf6
|
|
| MD5 |
894901360a24d602f8b0786d1e76ed2c
|
|
| BLAKE2b-256 |
b7ba2acc63a40e782cf56636cc51419c305c275071baf4bdbe4e628c98eb2f1f
|
Provenance
The following attestation bundles were made for hypnofunk-0.3.0.tar.gz:
Publisher:
publish.yml on rahulvenugopal/hypnofunk
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
hypnofunk-0.3.0.tar.gz -
Subject digest:
39e7895957edcfd4091fd7f213af9e3f4d512c393bbe622085198b5e94460bf6 - Sigstore transparency entry: 973413548
- Sigstore integration time:
-
Permalink:
rahulvenugopal/hypnofunk@0d510e53e79fdc0b2ab49f8314ecbfb7e885d59c -
Branch / Tag:
refs/tags/v0.3.0 - Owner: https://github.com/rahulvenugopal
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@0d510e53e79fdc0b2ab49f8314ecbfb7e885d59c -
Trigger Event:
release
-
Statement type:
File details
Details for the file hypnofunk-0.3.0-py3-none-any.whl.
File metadata
- Download URL: hypnofunk-0.3.0-py3-none-any.whl
- Upload date:
- Size: 17.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
6356c466a80de863e121b06e1431e00c0ec8ea691e90c263bcc811359380c674
|
|
| MD5 |
6b3fb80ba59242aca5adde09a9d3516e
|
|
| BLAKE2b-256 |
5d50d3bf3c635f25eed7856db34b4f0a3a407bf50551c45889e80c25634c0105
|
Provenance
The following attestation bundles were made for hypnofunk-0.3.0-py3-none-any.whl:
Publisher:
publish.yml on rahulvenugopal/hypnofunk
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
hypnofunk-0.3.0-py3-none-any.whl -
Subject digest:
6356c466a80de863e121b06e1431e00c0ec8ea691e90c263bcc811359380c674 - Sigstore transparency entry: 973413550
- Sigstore integration time:
-
Permalink:
rahulvenugopal/hypnofunk@0d510e53e79fdc0b2ab49f8314ecbfb7e885d59c -
Branch / Tag:
refs/tags/v0.3.0 - Owner: https://github.com/rahulvenugopal
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@0d510e53e79fdc0b2ab49f8314ecbfb7e885d59c -
Trigger Event:
release
-
Statement type: