Skip to main content

Python library for importing XDF (Extensible Data Format)

Project description

pylsl

publish workflow PyPI version

This is the Python interface to the Lab Streaming Layer (LSL). LSL is an overlay network for real-time exchange of time series between applications, most often used in research environments. LSL has clients for many other languages and platforms that are compatible with each other.

Let us know if you encounter any bugs (ideally using the issue tracker on the GitHub project).

Installation

Prerequisites

On all non-Windows platforms and for some Windows-Python combinations, you must first obtain a liblsl shared library. See the liblsl repo documentation for further details.

Get pylsl from PyPI

  • pip install pylsl

Get pylsl from source

This should only be necessary if you need to modify or debug pylsl.

  • Download the pylsl source: git clone https://github.com/labstreaminglayer/pylsl.git && cd pylsl
  • From the pylsl working directory, run pip install ..
    • Note: You can use pip install -e . to install while keeping the files in-place. This is convenient for developing pylsl.

Usage

See the examples in pylsl/examples. Note that these can be run directly from the commandline with (e.g.) python -m pylsl.examples.{name-of-example}.

You can get a list of the examples with python -c "import pylsl.examples; help(pylsl.examples)"

liblsl loading

pylsl will search for liblsl first at the filepath specified by an environment variable named PYLSL_LIB, then in the package directory (default location for Windows), then finally in normal system library folders.

If the shared object is not installed onto a standard search path (or it is but can't be found for some other bug), then we recommend that you copy it to the pylsl installed module path's lib subfolder. i.e. {path/to/env/}site-packages/pylsl/lib.

  • The site-packages/pylsl path will only exist after you install pylsl in your Python environment.
  • You may have to create the lib subfolder.
  • Use python -m site to find the "site-packages" path.
  • Use cp -L on platforms that use symlinks.

Alternatively, you can use an environment variable. Set the PYLSL_LIB environment variable to the location of the library or set LD_LIBRARY_PATH to the folder containing the library. For example,

  1. PYLSL_LIB=/usr/local/lib/liblsl.so python -m pylsl.examples.{name-of-example}, or
  2. LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/usr/local/lib python -m pylsl.examples.{name-of-example}

For maintainers

Continuous Integration

pylsl uses continuous integration and distribution. GitHub Actions will upload a new release to pypi whenever a Release is created in GitHub. Before creating the GitHub release, be sure to bump the version number in pylsl/version.py and consider updating the liblsl dependency in .github/workflows/publish-to-pypi.yml.

Linux Binaries Deprecated

We recently stopped building binary wheels for Linux. In practice, the manylinux dependencies were often incompatible with real systems.

Manual Distribution

  1. Manual way:
    1. rm -Rf build dist *.egg-info
    2. python setup.py sdist bdist_wheel
    3. Additional steps on Linux:
      • auditwheel repair dist/*.whl -w dist
      • rm dist/*-linux_x86_64.whl
    4. twine upload dist/*
  2. For conda
    1. build liblsl: conda build ../liblsl/
    2. conda build .

Known Issues with Multithreading on Linux

  • At least for some versions of pylsl, it has been reported that running on Linux one cannot call pylsl functions from a thread that is not the main thread. This has been reported to cause access violations, and can occur during pulling from an inlet, and also from accessing an inlets info structure in a thread.
  • Recent tests with multithreading (especially when safeguarding library calls with locks) using Python 3.7.6. with pylsl 1.14 on Linux Mint 20 suggest that this issue is solved, or at least depends on your machine. See https://github.com/labstreaminglayer/pylsl/issues/29

Acknowledgments

Pylsl was primarily written by Christian Kothe while at Swartz Center for Computational Neuroscience, UCSD. The LSL project was funded by the Army Research Laboratory under Cooperative Agreement Number W911NF-10-2-0022 as well as through NINDS grant 3R01NS047293-06S1. pylsl is maintained primarily by Chadwick Boulay. Thanks for contributions, bug reports, and suggestions go to Bastian Venthur, David Medine, Clemens Brunner, and Matthew Grivich.

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

pylsl-1.17.6.tar.gz (39.9 kB view details)

Uploaded Source

Built Distributions

pylsl-1.17.6-py2.py3-none-win_amd64.whl (364.2 kB view details)

Uploaded Python 2 Python 3 Windows x86-64

pylsl-1.17.6-py2.py3-none-win32.whl (293.8 kB view details)

Uploaded Python 2 Python 3 Windows x86

pylsl-1.17.6-py2.py3-none-any.whl (41.8 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file pylsl-1.17.6.tar.gz.

File metadata

  • Download URL: pylsl-1.17.6.tar.gz
  • Upload date:
  • Size: 39.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.5.8

File hashes

Hashes for pylsl-1.17.6.tar.gz
Algorithm Hash digest
SHA256 8f3cea0c54a27785a43a27e9524f1dee885fe149f4703eed060168923b1695a3
MD5 6af10b78e88f4af15a11e1dccd121b14
BLAKE2b-256 3ffd2cb39e07d09f3aa40bc39d880adcc8bfa08fc9b8de993340e6a7555899f8

See more details on using hashes here.

File details

Details for the file pylsl-1.17.6-py2.py3-none-win_amd64.whl.

File metadata

File hashes

Hashes for pylsl-1.17.6-py2.py3-none-win_amd64.whl
Algorithm Hash digest
SHA256 a5ead3e28ccdd7a08a6523adc797d6f737a1e446f684a8bd4818d784b50d89ba
MD5 744472c06c782a006cec97f030f39738
BLAKE2b-256 92a9b24df99c2dcb128a404dff05a592aa457763d45274c793395919b9b120a6

See more details on using hashes here.

File details

Details for the file pylsl-1.17.6-py2.py3-none-win32.whl.

File metadata

  • Download URL: pylsl-1.17.6-py2.py3-none-win32.whl
  • Upload date:
  • Size: 293.8 kB
  • Tags: Python 2, Python 3, Windows x86
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.5.8

File hashes

Hashes for pylsl-1.17.6-py2.py3-none-win32.whl
Algorithm Hash digest
SHA256 d9a68e86a073b59582b697c2baf1757b067da155e5fb017e30cefb7aa6d22f6d
MD5 45cddebd1ee7248acca87e60487fcf9d
BLAKE2b-256 5a8d0c8818c1a8aecc2a09d9f5df92b0bd321bd73f780c4928ccf0d5952951ad

See more details on using hashes here.

File details

Details for the file pylsl-1.17.6-py2.py3-none-any.whl.

File metadata

  • Download URL: pylsl-1.17.6-py2.py3-none-any.whl
  • Upload date:
  • Size: 41.8 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.5.8

File hashes

Hashes for pylsl-1.17.6-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 78d935d3d944cd572464f6200fcdf3958866b2e3180dea3da83e43a19517acf5
MD5 dbe94d72717aa632ca5a6c653d943938
BLAKE2b-256 9afa38f3ec8ac9073e53c65d850d8d6f51cbb87dbfcb59db5215fe7c7584e6e5

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page