-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathtgv_qsm_cuda.jl
37 lines (29 loc) · 1.66 KB
/
tgv_qsm_cuda.jl
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
#!/usr/bin/env -S julia --color=yes --startup-file=no --threads=auto
## Usage
# Call with: `<path-to-file>/tgv_qsm_cuda.jl ARGS`
# On windows use: `julia --threads=auto <path-to-file>/tgv_qsm_cuda.jl ARGS`
# Example call:
# `./tgv_qsm_cuda.jl phase.nii.gz mask.nii.gz --TE 0.025 --output output.nii.gz
import Pkg
## Uncomment to use a local julia package directory instead of the global one
# package_dir = joinpath(@__DIR__, ".tgv_cmd_packages")
# mkpath(package_dir)
# Pkg.activate(package_dir)
try
using CUDA, QuantitativeSusceptibilityMappingTGV, MriResearchTools, Comonicon
catch
Pkg.add(["CUDA", "QuantitativeSusceptibilityMappingTGV", "MriResearchTools", "Comonicon"])
using CUDA, QuantitativeSusceptibilityMappingTGV, MriResearchTools, Comonicon
end
version = Comonicon.get_version(QuantitativeSusceptibilityMappingTGV)
Comonicon.get_version(::Module) = version
@main function tgv_qsm(fn_phase, fn_mask; TE::Float64, output::String="output.nii.gz", fieldstrength::Float64=3.0, regularization::Float64=2.0, erosions::Int=3, B0_dir::Array{Int}=[0,0,1], dedimensionalize::Bool=false, no_laplacian_correction::Bool=false, step_size::Float64=3.0, type::DataType=Float32, nblocks::Int=32)
println("Starting calculation...")
phase = readphase(fn_phase)
mask = niread(fn_mask) .!= 0
res = header(phase).pixdim[2:4]
println("Resolution from NIfTI header [mm]: $(round.(Float64.(res); digits=2))")
chi = qsm_tgv(phase, mask, res; TE, B0_dir, fieldstrength, regularization, erosions, dedimensionalize, correct_laplacian=!no_laplacian_correction, gpu=CUDA, step_size, type, nblocks)
println("Writing output")
savenii(chi, output; header=header(phase))
end