Trekker¶
Note
December 19th, 2024
UPDATE: Trekker v1.0.0-rc2 now out! See below for a list of major changes.
Trekker offers state-of-the-art tractography tools to study the structural connectivity of the brain. Trekker aims to improve fiber tracking pipelines by offering features like:
Well-organized, clean, probabilistic streamline tractography using the parallel transport tractography (PTT) algorithm.
A comprehensive set of tractogram filtering options, including support for anatomical constraints using surface meshes.
Compatibility with .vtk format, to enable the use of powerful third-party 3D rendering software, such as Paraview, for easy and high-quality visualizations.
Support for asymmetric FODs, providing greater flexibility in fiber tracking.
Several features designed for high-performance computing (HPC), including multithreading, time-limited tracking, and a user-friendly command line interface.
Since 2017, algorithms and pipelines based on Trekker have earned awards in every international tractography competition, each featuring different themes.
See also
🏆 Awards and Recognitions
Tractography pipelines based on Trekker have earned awards in every international tractography challenge since 2017. Click here to learn more about Trekker’s awards.
Installation¶
Option 1: Stand-alone executables¶
Please find the stand-alone executables under Releases.
Option 2: Building from source¶
Trekker relies on nibrary. To compile Trekker from source, ensure that nibrary is installed first. Then follow these steps to compile Trekker:
Step 1: Download the Source Code
git clone https://github.com/dmritrekker/trekker
Step 2: Modify and run the build script
For Linux: Edit
build_Linux.sh
Usage¶
Simply run trekker
on the terminal. This will display help and the commands, which are listed below:
Command | Description |
---|---|
info | Displays information about input file. |
track | Performs fiber tracking using parallel transport tractography (PTT) algorithm. PTT excels in reconstructing geometrically smooth and topographically organized fiber bundles. |
filter | Trekker employs an intuitive set of pathway rules to filter tractograms. The rules can be specified with surface meshes, as well as with spheres, image masks and partial volume fractions. |
track2img | Maps tractogram features on an image. |
track2surf | Maps tractogram features on a surface. |
img2track | Maps image values on a tractogram. |
select | Selects streamlines from a tractogram. |
resample | Resamples streamlines in a tractogram. |
convert | Converts tractogram file formats (.vtk, .tck, .trk). |
transform | Applies a transform on an input tractogram. |
diff | Finds different streamlines between two tractograms. |
merge | Merges two tractograms, optionally ignoring duplicates. |
addColor | Adds colors to streamlines (.vtk only). |
fieldExport | Exports a selected vtk field from a tractogram (.vtk only). |
fieldImport | Adds a new vtk field with values read from a file (.vtk only). |
fieldRemove | Removes a vtk field from a tractogram (.vtk only). |
dMRI | dMRI commands |
Examples¶
Fiber tracking example:
./trekker track \
FOD.nii.gz \
--seed WHITE_MATTER_SURFACE.gii \
--seed_surf_useSurfNorm \
--seed_count 100000 \
--pathway discard_if_ends_inside WHITE_MATTER.nii.gz \
--pathway discard_if_enters CSF.nii.gz \
--minLength 20 \
--maxLength 300 \
--output OUT_TRACK.vtk
Fiber filtering example:
# You can use the --seed option when filtering too.
./trekker filter \
INP_TRACK.vtk \
--seed WHITE_MATTER_SURFACE.gii \
--pathway require_end_inside LEFT_THAL.nii.gz \
OUT_TRACK.vtk
Release notes for Trekker-v1.0.0-rc2¶
Bug fix 1: Fixed a bug which prevented using negative labels for selecting surface ROIs.
Bug fix 2: Fixed a bug in track2surf that was introduced as a result of the major updates in rc1, which led to the saving of wrong field information for mapped streamlines on surface meshes.
Improvement 1: Added a new command info, which prints basic information about input files.
Improvement 2: Added a new command dMRI recon tran_shi_2015, which fits dMRI data onto a compartment model proposed in [TranShi2015].
Improvement 3: Added option to flip surface normals when defining pathway rules.
Improvement 4: Added option to use only the surface boundary when the provided mesh is closed for defining pathway rules.
Improvement 5: (As a solution to the nibrary issue submitted by Xi Zhu) Added option to use ascii (text) files for defining seed density for fiber tracking with surface-based seeding.
Improvement 6: Random seeds are now sampled using an approach based on cumulative distribution function instead of rejection sampling.
Release notes for Trekker-v1.0.0-rc1¶
Bug fix 1: Fixed a bug in track where streamlines were not stopped as expected when a pathway rule was set. This issue occurred because track allowed stop options unsupported by nibrary. The fix involved providing nibrary with the necessary stopping features during tracking.
Bug fix 2: (Thanks to John Kruper for spotting this one!) Fixed a bug in track related to the computation of data support in parallel transport tracking. Previously, the contribution from the last part of the probe was reused as the first part’s contribution in the next iteration to speed up computation. This fix ensures the data support contribution is computed only once for the first part and reused for other candidate probes. Although this bug has existed since v0.5, it should not significantly affect results with default probe quality (4) and length (0.25 x voxel size). However, it may impact streamlines computed with longer probe lengths and lower quality probes.
Bug fix 3: Fixed a bug affecting both track and filter, where streamlines were not following the require_end_inside rule. The issue occured because this rule was commented out during a part of the development, and it was forgotten to be restored.
Improvement 1: Reorganized the code to harmonize the handling of segment-surface interactions.
Improvement 2: Switched to the double datatype in certain functions to better manage edge cases.
With the beta release (May 21st, 2024), Trekker has gone through significant changes:
- Powered by nibrary, Trekker now features:
Support for surface based tracking and filtering
Advanced pathway rules for filtering streamlines
Subcommands to perform various tractogram operations
Improved command line interface
- While the core fiber tracking algorithm (PTT) works the same, the new version of Trekker is not compatible with the previous versions due to the above changes.
Remark: Your previous code (script) written for earlier versions of Trekker need to be modified to work with the latest version.
- Some existing features in earlier versions of Trekker are currently missing in the latest version:
Windows compatibility
Python and Matlab support
Exporting of a .json formatted tracking report
Enjoy the new Trekker!