A python library for neuroimaging transformations
Project description
warpkit
A python library for neuroimaging transforms
If you've landed here, you're probably interested in the Multi-Echo DIstortion Correction (MEDIC) algorithm, which this library implements.
You can find the pre-print for MEDIC here: https://www.biorxiv.org/content/10.1101/2023.11.28.568744v1.
See below for usage details.
Installation
Julia
warpkit
requires julia
installed on your system ensure that you have the julia
executable in your path, and
the julia
libraries correctly setup in your ld.so.conf
. See the below instructions for both Linux and macOS.
Linux
If you installed julia via a package manager, library configuration should be done for you (most of the time) already.
However, if you installed Julia manually, you may need to tell ldconfig
where the julia libraries are. For example,
on debian based systems you can do this with:
# /path to julia installation (the lib folder will have libjulia.so)
echo /path/to/julia/lib > /etc/ld.so.conf.d/julia.conf
ldconfig
If you have done this correctly, you should see libjulia.so
in your ldconfig:
ldconfig -p | grep julia
libjulia.so.1 (libc6,x86-64) => /usr/lib/libjulia.so.1
libjulia.so (libc6,x86-64) => /usr/lib/libjulia.so
The above may require root privileges. The alternative to the above is to set the LD_LIBRARY_PATH
environment
variable to the path of the julia libraries.
# /path to julia installation (the lib folder will have libjulia.so)
export LD_LIBRARY_PATH=/path/to/julia/lib:$LD_LIBRARY_PATH
Note however, that you must type the above each time you open a new terminal. To make this permanent, you can add the above line to your shell's profile file.
macOS
If you installed julia through brew
, this should be done for you already.
However, if you get an error saying that libjulia
cannot be found, you may need to add the julia libraries via your
DYLD_LIBRARY_PATH
environment variable. For example, if you installed julia to /Applications/Julia-1.6.app
, you
would add the following to your shell's profile file:
export DYLD_LIBRARY_PATH=/Applications/Julia-1.6.app/Contents/Resources/julia/lib:$DYLD_LIBRARY_PATH
Installing through pip
Assuming you have julia
installed and configured correctly, you can install warpkit
through pip
:
pip install warpkit
If you encounter any errors during the installation process, please report them to the issue tracker with the logs
reported from pip install warpkit -v
.
Installing through conda
Another way to install warpkit
is through a conda
environment. Currently, warpkit
is not uploaded to any
conda
channels, so you will need to build it from source (Looking for help on this
issue).
[!NOTE] For advanced users only A
meta.yaml
file is present in theconda
folder in the root of the repo. If you are familiar withconda-build
you should be able to build this with your existingconda
install.
Fortunately, there is an automated script that will download micromamba
(a conda
variant), create a new
environment, and build/install warpkit
for you automagically. To do this, clone this repo and run the following:
# switch to conda directory in repo
cd conda
# run the install script (use -p or --path to specify an install prefix)
# by default this is set to ~/micromamba
./warpkit-conda-install.sh
# in your shell profile add the following lines
# or just execute them in your current shell
# but it won't be permanent
export MAMBA_ROOT_PREFIX=/whatever/path/you/installed/micromamba/prefix/above
eval "$(/whatever/path/you/installed/micromamba/prefix/above/bin/micromamba shell hook -s posix)"
# if you added the above to your profile
# restart your shell then activate the environment
#
# unless you have already executed the above in your current shell
# then you don't need to restart it and can just activate the environment
micromamba activate base
# you should now be able to import/use warpkit
python -c "import warpkit" # should return no errors
medic --help # should return help
After installing and configuring everything, you must type micromamba activate base
each time you open a new terminal
to get back into the conda
environment to use warpkit
. To make this permanent, you can add the above line to your
shell's profile file.
Installing through docker
If you are familiar with docker
, you can also install warpkit
through a docker
container.
docker run -it --rm ghcr.io/vanandrew/warpkit:latest
Note that the default entrypoint is the medic
CLI script, so you can run medic --help
to get the help message.
Building and installing from source
To build and install from source, clone this repo and run the following in the repo directory. I highly recommend installing it in editable mode (with the strict option, see here):
pip install -e ./[dev] -v --config-settings editable_mode=strict
You will need a C++ compiler with C++17 support, as well as Julia pre-installed on your system. See the Julia section for more details.
The build process uses CMake to build the C++/Python Extension. If you encounter an error during the build process,
please report the full logs of the build process using the -v
flag to the pip
command above.
What is MEDIC?
MEDIC takes your ME-EPI phase data from this:
to this:
for each frame of your data. You can then use these field maps to distortion correct your data.
MEDIC Usage
The warpkit
library is meant for integration into a larger neuroimaging pipeline/software package.
An example of how to call MEDIC from python is provided below:
import nibabel as nib
from warpkit.distortion import medic
from warpkit.utilities import displacement_map_to_warp
# load phase and magnitude images into lists
# each element in list is a different echo
phases = [nib.load(p) for p in phases_paths]
magnitudes = [nib.load(p) for p in magnitude_paths]
TEs = [TE1, TE2, ...] # in milliseconds
effective_echo_spacing = ... # in seconds
phase_encoding_direction = either i, j, k, i-, j-, k-, x , y, z, x-, y-, z-
# call the medic function
field_maps_native, displacement_maps, field_maps = medic(
phases, magnitudes, TEs, effective_echo_spacing, phase_encoding_direction)
# field_maps_native are returned in the distorted space (Hz) (mainly for reference/debugging purposes)
# you shouldn't need to use these probably???
# displacement_maps are returned in the undistorted space (mm) (see below for usage)
# field_maps are returned in the undistorted space (Hz) (same field map output as topup/fugue, but framewise)
# returns are nibabel Nifti1Image objects, so they can be saved to file by:
# displacement_maps to file
displacement_maps.to_filename("/path/to/save.nii.gz")
# these should be converted to displacement fields
# by the displacement_map_to_field function
# and specifying the appropriate type (i.e. itk, ants, afni, fsl)
displacement_field = displacement_map_to_field(displacement_maps, axis="y", format="itk", frame=0)
# where axis specifies the phase encoding direction, format is the desired output format, and frame is the index of
# displacement map to convert to a displacement field
# the displacement field can then be saved to file by the to_filename method
# Each file can be applied with the respective software's displacement field application tool:
# itk: the internal format warpkit uses. See utilities.resample_image
# ants: antsApplyTransforms (note that even though ants also uses itk, warpkit's itk warp format is NOT equivalent)
# afni: 3dNwarpApply
# fsl: applywarp
# if you are using fsl and instead want to use fugue to distortion correction, you can use the field_maps outputs
# (these are the equivalent field maps of that you would get from fugue, but with multiple frames)
You can also use the provided CLI script medic
to run MEDIC from the command line. The script is installed to your
PATH
when you install the package. medic
takes the following arguments:
usage: medic [-h] --magnitude MAGNITUDE [MAGNITUDE ...] --phase PHASE
[PHASE ...] --metadata METADATA [METADATA ...]
[--out_prefix OUT_PREFIX] [-f NOISEFRAMES] [-n N_CPUS]
[--debug] [--wrap_limit]
Multi-Echo DIstortion Correction
options:
-h, --help show this help message and exit
--magnitude MAGNITUDE [MAGNITUDE ...]
Magnitude data
--phase PHASE [PHASE ...]
Phase data
--metadata METADATA [METADATA ...]
JSON sidecar for each echo
--out_prefix OUT_PREFIX
Prefix to output field maps and displacment maps.
-f NOISEFRAMES, --noiseframes NOISEFRAMES
Number of noise frames
-n N_CPUS, --n_cpus N_CPUS
Number of CPUs to use.
--debug Debug mode
--wrap_limit Turns off some heuristics for phase unwrapping
Vahdeta Suljic <suljic@wustl.edu>, Andrew Van <vanandrew@wustl.edu>
12/09/2022
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distributions
File details
Details for the file warpkit-0.1.0.tar.gz
.
File metadata
- Download URL: warpkit-0.1.0.tar.gz
- Upload date:
- Size: 155.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/4.0.2 CPython/3.11.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 60b7fd9d5eb361293ef5c4fe7a33e8a50f71ad3e14c4ffd4da21c56ba4007c8c |
|
MD5 | 1d6e2f47631435b9362b675d8c4da709 |
|
BLAKE2b-256 | 97c30c1dc2b8b0dff973f13f883f96f46fa5457d829c0d1a18b646aae072862b |
File details
Details for the file warpkit-0.1.0-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
.
File metadata
- Download URL: warpkit-0.1.0-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
- Upload date:
- Size: 1.3 MB
- Tags: CPython 3.12, manylinux: glibc 2.17+ x86-64
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/4.0.2 CPython/3.11.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 80ade40347737efeadbe79ecabf87d2a27b2a785483b4408dc626b38b6ae8895 |
|
MD5 | 355826a0e86f16d1d47f8ae6bdb938d1 |
|
BLAKE2b-256 | 8cd35b3577ef87cb757a06e7670bccdcef68124c1897c08e9e4a89f3a3b07a20 |
File details
Details for the file warpkit-0.1.0-cp312-cp312-macosx_10_9_universal2.whl
.
File metadata
- Download URL: warpkit-0.1.0-cp312-cp312-macosx_10_9_universal2.whl
- Upload date:
- Size: 2.2 MB
- Tags: CPython 3.12, macOS 10.9+ universal2 (ARM64, x86-64)
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/4.0.2 CPython/3.11.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | b60a55924c30d2c84a486d922e473427ed736da319f78c2283f10f4b3f1faf87 |
|
MD5 | 8ca9c73f70598346cc88f8a3b212d9f7 |
|
BLAKE2b-256 | 6926771ab1a56ca6af6015ef28387adbe2f4ddd4de200c521e4f92f8c4bd3367 |
File details
Details for the file warpkit-0.1.0-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
.
File metadata
- Download URL: warpkit-0.1.0-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
- Upload date:
- Size: 1.3 MB
- Tags: CPython 3.11, manylinux: glibc 2.17+ x86-64
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/4.0.2 CPython/3.11.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 98dcaf7d6bb378182af0956c78792f60d101cd4ac75e762fb8ca9899e1df9229 |
|
MD5 | fe00f6364b6737d6a35b28562308fab0 |
|
BLAKE2b-256 | 5edb3cd25cb180f02da2c794fa47805c285cd1569618176861529b6ddd6ac829 |
File details
Details for the file warpkit-0.1.0-cp311-cp311-macosx_10_9_universal2.whl
.
File metadata
- Download URL: warpkit-0.1.0-cp311-cp311-macosx_10_9_universal2.whl
- Upload date:
- Size: 2.2 MB
- Tags: CPython 3.11, macOS 10.9+ universal2 (ARM64, x86-64)
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/4.0.2 CPython/3.11.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | a6d86f2bdb6525927eb4d8bdc26f8032c28510d3e410ab73866b709a7d67e294 |
|
MD5 | af237e6d43869e758275af757e95dca8 |
|
BLAKE2b-256 | c6dd77d308e667b7669adf36dca2ccdc5ea555d4f71508c33f27e32f9192fd00 |
File details
Details for the file warpkit-0.1.0-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
.
File metadata
- Download URL: warpkit-0.1.0-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
- Upload date:
- Size: 1.3 MB
- Tags: CPython 3.10, manylinux: glibc 2.17+ x86-64
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/4.0.2 CPython/3.11.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 03e047e9915d0b96d2f8fb45c7cf89b750625bfc96f83e6049f8b76b424ea125 |
|
MD5 | 865a1c9acbbc9980cf95b65920ca5d9d |
|
BLAKE2b-256 | c544ab34f927332fb0ae7c3e637a0b91d6036be5e97d9fdb25c83eba69ab25e0 |
File details
Details for the file warpkit-0.1.0-cp310-cp310-macosx_10_9_universal2.whl
.
File metadata
- Download URL: warpkit-0.1.0-cp310-cp310-macosx_10_9_universal2.whl
- Upload date:
- Size: 2.2 MB
- Tags: CPython 3.10, macOS 10.9+ universal2 (ARM64, x86-64)
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/4.0.2 CPython/3.11.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 31868cbeae5972cad29205ab6d007e67b93a9de75f0adef7a1c0eaa12c90e20a |
|
MD5 | 38e904c501fdc8826a1804870fc91f37 |
|
BLAKE2b-256 | a7b139d74a877c4f99b5d156bd274cc5fc997665e3bc0d3adea350274200a9d9 |
File details
Details for the file warpkit-0.1.0-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
.
File metadata
- Download URL: warpkit-0.1.0-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
- Upload date:
- Size: 1.3 MB
- Tags: CPython 3.9, manylinux: glibc 2.17+ x86-64
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/4.0.2 CPython/3.11.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | c1494c5ab1eeb73b1ab8159879645a086b00fcb128166d7f5cdfb2aff2db88ae |
|
MD5 | 6c4a4ae65f21d3ec658ce7e48615d56c |
|
BLAKE2b-256 | 1c88b604de80c8b3a681f289484dfd5178f2f24043786b11d39cb527339c5014 |
File details
Details for the file warpkit-0.1.0-cp39-cp39-macosx_10_9_universal2.whl
.
File metadata
- Download URL: warpkit-0.1.0-cp39-cp39-macosx_10_9_universal2.whl
- Upload date:
- Size: 2.2 MB
- Tags: CPython 3.9, macOS 10.9+ universal2 (ARM64, x86-64)
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/4.0.2 CPython/3.11.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 507ba9c6687749c16212db509b6b3a9a8297ff7743ec96227d8ad48e38182ba2 |
|
MD5 | a24e5aaafb374f8af746fbf97fe570cd |
|
BLAKE2b-256 | 083e0162b091b6afe6c9a2a01670f78e48785f2485266a24b83201f9dd8c67a6 |
File details
Details for the file warpkit-0.1.0-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
.
File metadata
- Download URL: warpkit-0.1.0-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
- Upload date:
- Size: 1.3 MB
- Tags: CPython 3.8, manylinux: glibc 2.17+ x86-64
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/4.0.2 CPython/3.11.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 4cc04cefad37edda4ca915ec3aeb4520464be910d6443bd05167500d01677011 |
|
MD5 | 682b4b6676a9acf9a0f3747da4e3d54a |
|
BLAKE2b-256 | 6e5f51dfc704db18aa2b4897b41a83637b5e0c52801e15bff119e68a3959a038 |
File details
Details for the file warpkit-0.1.0-cp38-cp38-macosx_10_9_universal2.whl
.
File metadata
- Download URL: warpkit-0.1.0-cp38-cp38-macosx_10_9_universal2.whl
- Upload date:
- Size: 2.2 MB
- Tags: CPython 3.8, macOS 10.9+ universal2 (ARM64, x86-64)
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/4.0.2 CPython/3.11.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 9d122ec18cc1ff551fb44bb1ae7e87af0cefbfcb7c7c7fa434c2818feee90aa0 |
|
MD5 | 9c5981e7eac0f85bdbff8ffe86c1d26b |
|
BLAKE2b-256 | def1e79c06920cbd5bb9e25a0576b14b2319e25afaadb122c5830878a97b9e69 |