.. image:: https://github.com/SciKit-Surgery/scikit-surgerynditracker/raw/master/sksndi_logo.png :height: 128px :target: https://github.com/SciKit-Surgery/scikit-surgerynditracker :alt: Logo
|
.. image:: https://github.com/SciKit-Surgery/scikit-surgerynditracker/workflows/.github/workflows/ci.yml/badge.svg :target: https://github.com/SciKit-Surgery/scikit-surgerynditracker/actions/ :alt: GitHub CI test status
.. image:: https://coveralls.io/repos/github/SciKit-Surgery/scikit-surgerynditracker/badge.svg?branch=master&service=github :target: https://coveralls.io/github/SciKit-Surgery/scikit-surgerynditracker?branch=master :alt: Test coverage
.. image:: https://readthedocs.org/projects/scikit-surgerynditracker/badge/?version=latest :target: http://scikit-surgerynditracker.readthedocs.io/en/latest/?badge=latest :alt: Documentation Status
.. image:: https://img.shields.io/badge/Cite-SciKit--Surgery-informational :target: https://doi.org/10.1007/s11548-020-02180-5 :alt: The SciKit-Surgery paper
.. image:: https://img.shields.io/twitter/follow/scikit_surgery?style=social :target: https://twitter.com/scikit_surgery?ref_src=twsrc%5Etfw :alt: Follow scikit_surgery on twitter
scikit-surgerynditracker is a python interface for Northern Digital (NDI) trackers. It should work with Polaris Vicra, Spectra, and Vega optical trackers and Aurora electromagnetic trackers. Tracking data is output as NumPy arrays.
Author: Stephen Thompson
scikit-surgerynditracker is part of the SciKit-Surgery
software project, developed at the Wellcome EPSRC Centre for Interventional and Surgical Sciences
, part of University College London (UCL)
_.
::
pip install scikit-surgerynditracker
Configuration is done using Python libraries at instantiation. Invalid configuration should raise exceptions. Tracking data is returned in a set of lists, containing the port handles, timestamps, framenumbers, the tracking data and a tracking quality metric. By default tracking data is returned as a 4x4 NumPy array, though can be returned as a quaternion by changing the configuration.
::
from sksurgerynditracker.nditracker import NDITracker
SETTINGS = {
"tracker type": "polaris",
"romfiles" : ["../data/8700339.rom"]
}
TRACKER = NDITracker(SETTINGS)
TRACKER.start_tracking()
port_handles, timestamps, framenumbers, tracking, quality = TRACKER.get_frame()
for t in tracking:
print (t)
TRACKER.stop_tracking()
TRACKER.close()
See demo.py for a full example
Cloning ^^^^^^^
You can clone the repository using the following command:
::
git clone https://github.com/SciKit-Surgery/scikit-surgerynditracker
Running the tests ^^^^^^^^^^^^^^^^^
You can run the unit tests by installing and running tox:
::
pip install tox
tox
Contributing ^^^^^^^^^^^^
Please see the contributing guidelines
_.
Useful links ^^^^^^^^^^^^
Source code repository
_Documentation
_Copyright 2018 University College London.
scikit-surgerynditracker is released under the BSD-3 license. Please see the license file
_ for details.
Supported by Wellcome
and EPSRC
.
.. Wellcome EPSRC Centre for Interventional and Surgical Sciences
: http://www.ucl.ac.uk/weiss
.. source code repository
: https://github.com/SciKit-Surgery/scikit-surgerynditracker
.. Documentation
: https://scikit-surgerynditracker.readthedocs.io
.. SciKit-Surgery
: https://www.github.com/SciKit-Surgery
.. University College London (UCL)
: http://www.ucl.ac.uk/
.. Wellcome
: https://wellcome.ac.uk/
.. EPSRC
: https://www.epsrc.ac.uk/
.. contributing guidelines
: https://github.com/SciKit-Surgery/scikit-surgerynditracker/blob/master/CONTRIBUTING.rst
.. _license file
: https://github.com/SciKit-Surgery/scikit-surgerynditracker/blob/master/LICENSE