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.1.tar.gz (24.3 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.1-py3-none-any.whl (29.5 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for xclock-0.3.1.tar.gz
Algorithm Hash digest
SHA256 6f9f9be49fd73056f1075bfd3657719de4d40b4a42fd73c7cb9df67f196e4035
MD5 63b90659b6cbd57097d9fc4ef1d0acf2
BLAKE2b-256 de8531c7a71bab887a391f9cbbb7b1c23a80c5a31f30439fef3cd09b0552a769

See more details on using hashes here.

File details

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

File metadata

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

File hashes

Hashes for xclock-0.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 32b2380b1fcfcdfc4607f8b93989d7ef6dd6fae650e7de80716f632989c0ddb3
MD5 2d4ccbd4ce9e5f39469b18d08faa2112
BLAKE2b-256 9c7d33ebefebb7ef1d72f74701d87ac86f05090d90c5204def67dba75f8266aa

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