Skip to main content

Tools for synchronizing eXperimental Clocks

Project description

XClock - Synchronizing eXperimental Clocks

XClock is a Python package designed to help synchronize data acquisition clocks in experimental setups, particularly for neuroscience and behavioral experiments. It provides tools to generate precise clock signals using various data acquisition (DAQ) devices, such as the LabJack T4.

XClock allows you to

  • output multiple clock frequencies simultaneously, all synchronized to the same internal clock source to ensure precise timing alignment.
  • record the timestamps of the clock pulses relative to the internal DAQ device clock

The given output pulses can be used to trigger and synchronize industrial cameras used for behavioral monitoring or two-photon imaging.

Note: This Python project is not the clock for the original X Window System.

Python Tests

Documentation

Full documentation is available at Read the Docs.

Installation

  1. Install the software for you DAQ device, e.g. for the LabJack T Series from here.

  2. Install the xclock package.

# via pip
pip install git+http://github.com/brain-bremen/XClock.git

# via uv (recommended)
uv add git+https://github.com/brain-bremen/XClock.git
  1. Verify installation by running the CLI tool:
xclock --help

Use xclock library in your Python scripts

To use your DAQ device as a clock

from xclock.devices import LabJackT4
import pathlib
import numpy as np

t4 = LabJackT4()
available_clock_channels = t4.get_available_output_clock_channels()

# add two clocks with a defined duration (~10 s)
# pulses are auto-calculated: 100 Hz * 10s = 1000 pulses, 60 Hz * 10s = 600 pulses
t4.add_clock_channel(
    clock_tick_rate_hz=100,
    channel_name=available_clock_channels[0],
    enable_clock_now=False,
    duration_s=10.0,
)

t4.add_clock_channel(
    clock_tick_rate_hz=60,
    channel_name=available_clock_channels[1],
    enable_clock_now=False,
    duration_s=10.0,
)

output_filename = pathlib.Path.home() / "Documents" / "XClock" / "foo.csv"
t4.start_clocks_and_record_edge_timestamps(
    wait_for_pulsed_clocks_to_finish=True,
    filename=output_filename
)

# load and inspect data
loaded_data = np.loadtxt(output_filename, dtype=np.int64, delimiter=",")

See more examples in the examples directory.

Use xclock CLI tool for controlling clocks

The xclock CLI tool provides a convenient command-line interface to control clock generation without writing Python scripts. It supports all the core functionality through simple commands.

Installation

After installing the XClock package, the xclock command becomes available in your terminal:

# Install the package first (see Installation section above)
uv add git+https://github.com/brain-bremen/XClock.git
xclock --help

# or directly run it using uvx / uv tool
uvx git+https://github.com/brain-bremen/XClock.git

Basic Usage

The CLI uses a simple structure: global options followed by a command.

xclock [OPTIONS] COMMAND

Available Commands

  • start - Start clocks with specified rates
  • stop - Stop all running clocks

Common Options

  • --clock-tick-rates RATES - Comma-separated clock frequencies in Hz (required for start)
  • --device DEVICE - DAQ device to use (default: labjackt4)
  • --verbose, -v - Enable detailed logging
  • --when {now,on_trigger} - When to start clocks (default: now)
  • --duration SECONDS - Run clocks for specified duration (0 = continuous)
  • --number-of-pulses PULSES - Generate specific number of pulses per clock
  • --record-timestamps - Save edge timestamps to CSV file
  • --timeout SECONDS - Timeout when waiting for trigger

Examples

# Start two clocks at 60Hz and 100Hz for 10 seconds (pulses auto-calculated)
xclock --clock-tick-rates 60,100 --duration 10 start

# Generate pulsed clocks with explicit pulse counts: 200 pulses at 60Hz, 150 pulses at 100Hz
xclock --clock-tick-rates 60,100 --number-of-pulses 200,150 start

# Wait for external trigger before starting clocks
xclock --clock-tick-rates 60,100 --when on_trigger start

# Record edge timestamps while generating clocks
xclock --clock-tick-rates 60,100 --record-timestamps --number-of-pulses 100,150 start

# Stop any running clocks
xclock stop

# Start with verbose logging for debugging
xclock --clock-tick-rates 60,100 --verbose --duration 5 start

Trigger Mode

When using --when on_trigger, the CLI will:

  1. Configure the clocks but not start them
  2. Wait for a rising edge on the device's trigger input (e.g. DIO4 for LabJack T4)
  3. Start clocks immediately when a trigger is detected
  4. Use --timeout to set maximum wait time (0 = no timeout)

Timestamp Recording

When using --record-timestamps, the CLI will:

  • Monitor clock outputs and record all edge transitions
  • Save timestamps to ~/Documents/XClock/xclock_timestamps_<date>.csv
  • Format: timestamp_ns, edge_type (<0: falling edge, >0: rising edge, number is clock channel index)

Device Support

Currently only the LabJack T4 is supported to be used as a clock device. The recommended and supported wiring is as follows:

Adding a different, unsupported device as a clock

Adding a new device is straightforward and entails the following steps.

  • Write a class similar to LabJackT4 that adheres to (inherits from) the interface defined in ClockDaqDevice. Implement all the abstract methods.
  • For testing, copy test_labjack.py into a new file and adjust the DEVICE_NAME and DEVICE_CLASS variables. If your device class adheres to the interface, all tests should run and complete sucessfully.

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

xclock-0.3.0.tar.gz (23.4 kB view details)

Uploaded Source

Built Distribution

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

xclock-0.3.0-py3-none-any.whl (28.7 kB view details)

Uploaded Python 3

File details

Details for the file xclock-0.3.0.tar.gz.

File metadata

  • Download URL: xclock-0.3.0.tar.gz
  • Upload date:
  • Size: 23.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.7

File hashes

Hashes for xclock-0.3.0.tar.gz
Algorithm Hash digest
SHA256 a5e09815a75fe4757cf5496088274487a869281e9fbe58618509a2f92e81dd03
MD5 290300954adaab4063783f35fa61e4dc
BLAKE2b-256 d84170e43b898af46002222d42079cae17575f29cd31c2527b43e1a7d1aca278

See more details on using hashes here.

File details

Details for the file xclock-0.3.0-py3-none-any.whl.

File metadata

  • Download URL: xclock-0.3.0-py3-none-any.whl
  • Upload date:
  • Size: 28.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.7

File hashes

Hashes for xclock-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 16de7456011b8e23da78b8c9f8c2bcbc5535111e5cbc64291b3952b88166941b
MD5 2a5cd36c562e74d37d8d9bca466a59a3
BLAKE2b-256 feae6122dd87a0899a97ddb7a03c1d8266dd516dbda77a356ea4bda82dd746ab

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