trk-io
implements a TrackVis
(.trk) reader and writer.
- Can read and write
TrackVis
files. Handles affine transformation asnibabel.streamlines
andMI-Brain
would. - Reading and writing is tested as much as in
nibabel.streamlines
. - Can optionally use the
nifti-rs
crate, which can then be used to create a trk header from aNiftiHeader
, like you would do innibabel
Reader
can read all streamlines at once or can be used as a generator.- Scalars and properties are supported when reading and writing trk. You can
find some examples in
trk_color.rs
. - Write all at once or streamline per streamline.
- Follows
nibabel.streamlines
architecture (all 3D points are in a singleVec![Point3D]
). Currently, this is only useful for performance, but it may lead to easier changes when and if we support BLAS. - Handles endianness.
- Some useful tools are coded in
examples/*.rs
. It's a good way to learn how to use this library.
// Read complete streamlines to memory
let tractogram = Reader::new("bundle.trk").unwrap().read_all();
for streamline in &tractogram.streamlines {
println!("Nb points: {}", streamline.len());
for point in streamline {
println!("{}", point);
}
}
// Simple read/write. Using a generator, so it will load only
// one streamline in memory.
let reader = Reader::new("full_brain.trk").unwrap();
let mut writer = Writer::new(
"copy.trk", Some(reader.header.clone()));
for tractogram_item in reader.into_iter() {
// tractogram_item is a TractogramItem, which is a tuple of
// (streamline, scalars, properties).
writer.write(tractogram_item);
}
// The new file will be completed only at the end of the scope. The
// 'n_count' field is written in the destructor because we don't
// know how many streamlines the user will write.
There's still a lot of work to do but it should work perfectly for simple use cases. In particular, future versions should be able to:
- Support TCK reading/writing
- Create some binary tools using this lib, e.g. show_affine, count_tracks, pruning, strip_info, etc.
- Support for
ops.Range
, e.g.streamlines[0..10]
Your help is much appreciated. Consider filing an issue in case something is missing for your use case to work. Pull requests are also welcome.