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.
Installation
-
Install the software for you DAQ device, e.g. for the LabJack T Series from here.
-
Install the
xclockpackage.
# 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
- 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 number of clock pulses (~10 s)
t4.add_clock_channel(
clock_tick_rate_hz=100,
channel_name=available_clock_channels[0],
enable_clock_now=False,
number_of_pulses=1000,
)
t4.add_clock_channel(
clock_tick_rate_hz=60,
channel_name=available_clock_channels[1],
enable_clock_now=False,
number_of_pulses=600,
)
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 ratesstop- 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 continuous clocks at 60Hz and 100Hz for 10 seconds
xclock --clock-tick-rates 60,100 --duration 10 start
# Generate pulsed clocks: 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:
- Configure the clocks but not start them
- Wait for a rising edge on the device's trigger input (e.g. DIO4 for LabJack T4)
- Start clocks immediately when a trigger is detected
- Use
--timeoutto 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
LabJackT4that adheres to (inherits from) the interface defined inClockDaqDevice. Implement all the abstract methods. - For testing, copy
test_labjack.pyinto a new file and adjust theDEVICE_NAMEandDEVICE_CLASSvariables. 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
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file xclock-0.2.0.tar.gz.
File metadata
- Download URL: xclock-0.2.0.tar.gz
- Upload date:
- Size: 17.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.6.16
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
df52f12fc6bff21357391a3d8e2730385ed28fc3f5be080e5c9d8fc255af7f89
|
|
| MD5 |
abf929c294bc0f5dfcdebd8c07b3def9
|
|
| BLAKE2b-256 |
3dfe73dadbc1249e9c9008c2fb1ebede87bd34d9131fd5cd7983b7233d0f856b
|
File details
Details for the file xclock-0.2.0-py3-none-any.whl.
File metadata
- Download URL: xclock-0.2.0-py3-none-any.whl
- Upload date:
- Size: 21.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.6.16
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
797603c9d56bd7059a09d96e635040044caec517284de7c8f7b7125b50e322d1
|
|
| MD5 |
535e75f2e7a813461d237813b220ef1c
|
|
| BLAKE2b-256 |
ae0dedd1e7de79af85c2ec00a85365ea8042844a969f8e5d47ffb456dde1a208
|