Skip to main content

Python interface for Wooting analog keyboards

Project description

TachyWooting

License: BSD-3-Clause Python versions Tests

Python bindings and acquisition utilities for Wooting analog keyboards.

For deeper implementation details, see documentation.md. Read the Docs/Sphinx sources live in docs/ and use NumPy-style docstrings. Console scripts are documented in docs/scripts.md.

Project Documentation

  • README.md: project overview and quick start

  • documentation.md: technical details and architecture notes

  • development.md: maintainer workflow and SDK update process

  • PLUGIN_MANAGEMENT.md: plugin installation and troubleshooting

  • raw_sdk.md: direct lib/ffi SDK reference for advanced use

  • Analog Key Acquisition: Read key positions (0.0–1.0) with microsecond-level timing

  • Threshold-Based Triggering: Automatically capture key press trajectories around actuation threshold

  • HDF5 Logging: Hierarchical per-trial logging with automatic shard merging

  • Multi-Key Support: Efficiently read multiple keys simultaneously using full-buffer API

  • Cross-Platform: Linux, macOS, and Windows support

  • Automatic Setup: Self-contained installation with system configuration

  • CLI Tools: Command-line utilities for plugin management and testing

  • Read analog key pressure as floats in the 0.0 to 1.0 range.

  • Convert analog pressure to integer values in the 0 to 255 range.

  • Acquire one or more keys around a threshold crossing.

  • Log trials to hierarchical HDF5 files.

  • Build against the bundled Wooting Analog SDK headers and native libraries.

  • Inspect HDF5 logs with a small visualization CLI.

Requirements

  • Python 3.10 or newer.
  • A supported Wooting analog keyboard.
  • A local compiler toolchain for the CFFI interface build.
  • Platform-specific permissions for USB/native library access.

Quick Start

pip install .

What setup is needed

pip install does not run system setup — pip installs from wheels, which have no reliable post-install hook. Setup is split into two parts:

  1. CFFI compilation happens automatically the first time you create a WOOTING_ACQUISITION (or run wooting-demo). It needs only a C compiler — no admin rights.

  2. SDK plugins + input permissions require a one-time privileged step:

    wooting-build-interface   # installs SDK plugins + permissions (needs sudo/admin)
    

If the keyboard is not detected, the error message tells you exactly to run this command — you do not have to remember it. To undo it later: wooting-delete-interface.

Development Installation

python -m pip install -e ".[dev]"
wooting-build-interface

Quick Start

from tachywooting import WOOTING_ACQUISITION

acq = WOOTING_ACQUISITION(threshold=0.8)
acq.initialize_keyboard(verbose=True)

try:
    acq.setup_logging(name="tracking", path="logs", int_analog=2)
    trial = acq.acquire_analog_values(target_keys=["A"])
finally:
    acq.uninitialize_keyboard()

CLI Demo

wooting-demo --key A --threshold 50

Visual feedback (TachyPy)

On-screen pressure feedback — the interactive fixation cross and wait_light_press_visual() — lives in TachyPy, not in this hardware package. Install it with pip install 'tachypy[wooting]', then:

from tachypy import WOOTING_ACQUISITION  # keyboard + visual feedback

HDF5 Logging

setup_logging() writes one temporary shard per trial and merges shards when uninitialize_keyboard() is called.

Final files use this layout:

/trials/0001/keys/0004/values

Each values dataset stores columns in this order:

position, time_from_onset, time_abs

Visualize Logs

python -m tachywooting.visualize logs/tracking.hdf5 --list
python -m tachywooting.visualize logs/tracking.hdf5 --trial 1 --key 4

Public API

  • WOOTING_ACQUISITION: acquisition, threshold detection, readiness checks, and logging.
  • convert_char_to_keycode: convert between key labels and HID keycodes.
  • load_trial: load a single trial from an HDF5 log file.
  • load_session: load all trials from an HDF5 log file.
  • trial_to_dataframe: convert a trial dict to a pandas DataFrame.
  • build_interface: rebuild the CFFI interface.
  • delete_interface: remove generated CFFI artifacts.
  • lib and ffi: raw CFFI handles for advanced SDK access.

Troubleshooting

If importing works but acquisition fails with a missing native interface error, run:

wooting-build-interface

If no devices are detected, confirm the keyboard is connected, Wootility recognizes it, and platform permissions have been applied.

Hardware Requirements

This package was developed and tested with the Wooting UwU keypad (wooting.io/uwu), and its use is strongly recommended for optimal results.

Wooting UwU keypad

The UwU is a 3-key Hall effect keypad using Lekker L45 V2 linear switches — contactless magnetic sensors with a smooth linear force curve (30–45 cN, no tactile bump). Keys can be configured to actuate at any depth from 0.1mm to 4.0mm.

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

tachywooting-0.2.1.tar.gz (6.5 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

tachywooting-0.2.1-cp313-cp313-macosx_11_0_universal2.whl (6.5 MB view details)

Uploaded CPython 3.13macOS 11.0+ universal2 (ARM64, x86-64)

File details

Details for the file tachywooting-0.2.1.tar.gz.

File metadata

  • Download URL: tachywooting-0.2.1.tar.gz
  • Upload date:
  • Size: 6.5 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.1

File hashes

Hashes for tachywooting-0.2.1.tar.gz
Algorithm Hash digest
SHA256 5fec16608c2c601fc4b888d05e25c5d7130847100756178f468f3c193f1bff1d
MD5 f589260eec38160f1ed0da9f8d4d430f
BLAKE2b-256 b9995dfc435d07c85de5db643911a3efa72a55cb8243c10a78a0f6b7d822f626

See more details on using hashes here.

File details

Details for the file tachywooting-0.2.1-cp313-cp313-macosx_11_0_universal2.whl.

File metadata

File hashes

Hashes for tachywooting-0.2.1-cp313-cp313-macosx_11_0_universal2.whl
Algorithm Hash digest
SHA256 c3a1df9aa773014cd61e85d9cceb7f0ef32c6f6356183e65d18201055b23fbb5
MD5 2543d75297d0a8d94c374c942a001591
BLAKE2b-256 b94d2ed551bba7e27104f7c604dd7ba88c04af4e50e60f5678ecc7b3d2937726

See more details on using hashes here.

Supported by

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