Crates.io | nifti_processing |
lib.rs | nifti_processing |
version | 0.1.1 |
source | src |
created_at | 2023-04-02 11:42:42.097347 |
updated_at | 2024-03-11 08:58:47.143179 |
description | nibabel like 3d resampling functions for Nifti-rs |
homepage | |
repository | https://github.com/liob/NIFTI-Processing-rs |
max_upload_size | |
id | 828022 |
size | 72,884 |
This library is designed as an extension of the NIFTI-rs library, adding 3D resampling support. This library is closely modeled after the NiBabel processing module, hence the name.
The resample_to_output
and resample_from_to
functions with nearest neighbor and trilinear resampling are implemented.
Minimal error checking; Will be extended.
Minimal unit tests; Will be extended.
Please also consult the issue tracker.
The nalgebra_affine
and ndarray_volumes
features of NIFTI-rs are required.
Load a Nifti image file with NIFTI-rs and resample the volume to a grid spacing of 1 mm:
use nifti::{NiftiObject, ReaderOptions, NiftiVolume};
use use nifti_processing::{resample_to_output, sampler};
let obj = ReaderOptions::new().read_file("myvolume.nii.gz")?;
let header = obj.header();
let affine = header.get_affine();
let volume = obj.volume();
let im = volume.into_ndarray::<f32>()?;
let nn = sampler::NearestNeighbor::default();
let (resampled_im, resampled_affine) = resample_to_output(&im, &affine, &[1.0,1.0,1.0], nn)
See also the examples directory.
Licensed under either of
at your option.
Unless you explicitly state otherwise, any Contribution intentionally submitted for inclusion in work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.