Skip to content

paulzerr/napview_beta

Repository files navigation

napview: real-time sleep scoring and analysis visualizer

v0.1beta

napview is a powerful and user-friendly software for automatic sleep scoring in the sleep lab. It provides a real-time interface to machine learning tools for sleep data analysis.

napview uses machine learning models to infer sleep parameters from incoming EEG data and visualizes the classifier output, quantifying e.g., the probability of a sleep study participant to be in a particular sleep stage.

napview runs independently of existing lab setups.

napview is the nightshift experimenter's friend.

The GUI

GUI Screenshot

An example of the real-time display

Result Screenshot

Installation

Note: Windows users in restricted environments without admin rights can download a standalone release here.

1. Make sure you have Python 3.8 or later installed on your system.

2. Clone the repository:

Navigate to a directory of your choice, open a terminal or command prompt and download napview:

git clone https://github.com/paulzerr/napview_beta/
cd napview_beta

2. Create a new virtual environment:

python -m venv napview_venv

or

python3 -m venv napview_venv

Note: using a virtual environment is not strictly necessary, but is strongly recommended to ensure compatibility. Installing napview requires approximately 350MB of hard drive space.

3. Activate the virtual environment:

Linux and macOS:

 source napview_venv/bin/activate

Windows:

 napview_venv\Scripts\activate.bat

or, if you're using Powershell:

 napview_venv\Scripts\Activate.ps1

4. Install napview:

Ensure that you are in the directory where you cloned the repository, and install:

pip install .

5. Start napview

From a terminal or command prompt:

napview

6. Alternatively:

Install dependencies manually:

pip install -r requirements.txt

Navigate to the cloned repository and start napview from there:

python3 -m src/napview/napview.py

Dependencies

These packages and their dependencies will automatically be installed via pip. Otherwise install manually.

Scipy==1.14.1
numpy==2.1.2
mne==1.8.0
Flask==3.0.3
peewee==3.17.6
pylsl==1.16.2
usleep_api==0.1.3
setuptools==70.3.0
edfio==0.4.3

How to use napview

1. Open a command window or terminal, type in napview and hit Enter. This will open the GUI in your default browser, usually at http://127.0.0.1:8145. A folder called "napview" will be created in your user directory. Temporary data, logs and output files will be stored there.

2. Select your EEG amplifier as data source. Or you can try out napview with the built-in EEG simulator, which streams a recording from an .edf file. You can also connect to any ongoing LSL EEG stream.

3. Select your preferred sleep scoring model. U-Sleep is strongly recommended, but requires an internet connection and an API key, which can be requested for free at https://sleep.ai.ku.dk/. YASA is an alternative model that doesn't require an API key. It needs about 15 minutes of recording time before it delivers accurate results.

4. Follow further instructions displayed in red in the Status window on the right (if any).

5. When everything is green, click START to begin. A new tab will open containing the data visualizer. This will typically be at http://127.0.0.1:8245. Sleep stage probabilities will be displayed as provided by the classifier, but it will take a few minutes for the sleep scoring output to become reliable. By default a new datapoint is shown every 30 seconds.

Other data can be displayed, such as band power, eye movements, spindle/K density, heart rate, aperiodic slope, etc.

6. When you are done with the situation, click SHUTDOWN to end data streaming and save the recording.


Using napview with OpenBCI GUI

1. If you want to concurrently use the OpenBCI GUI, start the data stream, open the Networking widget and select the LSL protocol.

2. In Stream 1, select TimeSeriesRaw as Data Type.

3. Click "Start LSL stream".

4. In napview, select CustomLSL stream as Data Source and enter the stream name.

Using napview with OpenBCI directly

1. If you want to directly connect to an OpenBCI board, you can simply select your board type and port as Data Source.

Using napview with BrainVision amplifiers

1. Start a recent version of Recorder.

2. Make sure the RDA plugin is activated. You can activate it by going to the Options menu, selecting Data Transfer, and then enabling RDA. This allows external software to access data as it's being recorded.

3. Obtain the IP address of the acquisition computer if you want to use napview on a different computer on the network, or the default 127.0.0.1 if you run napview on the same computer.

4. Start the data stream in Recorder and select Brainvision as Data Source in napview. Enter the IP.

Compatibility

  • napview has been tested with BrainVision passive electrode EEG amplifiers on Kubuntu 24 Linux + Windows 10; Python 3.9 + 3.12, but should run on most systems as it is platform independent. Any system able to run python3 and a web browser should be compatible.

  • Any amplifier with real-time streaming capabilities can be used with napview via an LSL connector script. These are available for most EEG amps, or you can create your own with a few lines of Python code.

  • Napview runs independently of your lab setup.

  • Feel free to contact us for assistance to make napview work in your lab setup.

TODO:

  • auto-reject bad channels
  • allow the user to choose channels for YASA sleep scoring
  • implement spindle, eye movement detection, etc
  • implement alerts for certain events (e.g., arousal)
  • add Docker install option

License

napview is released under the BSD-3 Clause License.

Contact

If you have any questions, suggestions, or feedback, please feel free to reach out:

  • Email: paul.zerr [ at ] donders.ru.nl