Skip to content

Releases: JuliaHealth/KomaMRI.jl

KomaMRIFiles-v0.9.11

16 Apr 20:15
32ffc8a

Choose a tag to compare

What's Changed

New Contributors

Full Changelog: KomaMRIFiles-v0.9.10...KomaMRIFiles-v0.9.11

KomaMRIBase-v0.9.9

16 Apr 20:13
32ffc8a

Choose a tag to compare

Changes:

  • Fixed some abstract field definitions on Grad and RF structs
  • Removed type stability issues in is_*_on functions

KomaMRIFiles-v0.9.10

01 Apr 23:47
20a8c77

Choose a tag to compare

What's Changed

  • Fix error handling when unsupported (and required) extensions are read by @pvillacorta in #729

Full Changelog: KomaMRIFiles-v0.9.9...KomaMRIFiles-v0.9.10

KomaMRIPlots-v0.9.6

28 Jan 00:24
43a3ab1

Choose a tag to compare

What's Changed

  • plot_seq: RF center is displayed including use, amplitude, and phase information.
  • plot_kspace: Now considers RF use and center to compute k-space coordinates.

Full Changelog: v0.9.1...KomaMRIPlots-v0.9.6

KomaMRIFiles-v0.9.9

28 Jan 00:18
43a3ab1

Choose a tag to compare

What's Changed

  • Pulseq 1.5.1 reader support
  • More tests for Pulseq versions 1.2, 1.3, 1.4 and 1.5.
  • Read Pulseq 1.5.1 by @Stockless in #614

Full Changelog: v0.9.2...KomaMRIFiles-v0.9.9

KomaMRIBase-v0.9.8

28 Aug 20:05
43a3ab1

Choose a tag to compare

What's Changed

  • Inclusion of RF center, first, last and use.
  • RF use is now considered in k-space calculations.
  • Extensions should be more flexible now
  • Read Pulseq 1.5.1 by @Stockless in #614

New Contributors

Full Changelog: v0.9.2...KomaMRIBase-v0.9.8

v0.9.1

06 Mar 21:15
065130a

Choose a tag to compare

KomaMRI v0.9.1

Diff since v0.9.0

Motion-Related Features and Bug fixes
These updates primarily affect KomaMRIBase. Key changes include:

  • Bug fixes related to phantom definition, motion lists, and flow experiments (PR #499, #511, #516, #520, #536).
  • Improved motion definition, allowing for easier specification of single motion instances and flexible time spans (PR #517, #531).
  • Introduction of the TimeCurve structure, enabling arbitrary temporal motion patterns that were previously challenging to replicate (PR #531).
  • Added tests for motion-related functions to improve code coverage (PR #523).

Other Minor Changes

  • Updated and expanded documentation for contributors to Koma, providing clearer guidelines and resources (PR #509, #510, #514, #518, #543).
  • KomaMRIPlots: Standardized colormaps using QMRIColors.jl for T1 and T2 maps (PR #528).
  • KomaMRICore: Removed "hack" of using cos + i sin as oneAPI.jl didn't defined cis(x) . Now we use sincos for GPU kernel code (PR #496).

Merged pull requests:

Closed issues:

  • Add Contributing Guidelines (#209)
  • Include steps for contributing using VSCode (#233)
  • An error of 'DivideError: integer division' occurs in the internal functions of simulate when using a sequence with spiral acquisition (#409)
  • Test setting fields from a Phantom @view (#412)
  • Future: use sincos once available in oneAPI.jl (#463)
  • Use color-map recommendations for MR relaxometry maps by Quantitative MR Study Group (#473)
  • Easily define Phantom motion field composed by only one Motion instance (#481)
  • Troubles defining Float32 or empty phantoms with KomaMRI 0.9 (#498)
  • Don't run CPU benchmarks on GPU workers (#501)
  • Test Motion constructors (#512)
  • Test motion-related functions (#522)
  • Resize collaborators (#525)

v0.9.0

01 Oct 18:09
ca742f6

Choose a tag to compare

KomaMRI v0.9.0

Diff since v0.8.2

This new breaking release of Koma v0.9 has multiple new features. Thanks to @rkierulf, our GSoC student, for the GPU enhancements and @pvillacorta for the new motion definitions that enable flow and shareable phantoms.

(1) Device-agnostic kernel-based simulations (more info here)
We can now use various GPU backends with the help of KernelAbstractions.jl. This means that GPU-related packages like CUDA are not installed by default. Installation and loading of the desired GPU package is needed (for example ] add CUDA, using CUDA).

(2) New simulation method, faster and better
Now Bloch has specialized implementations for CPU and GPU and the previous implementation is in BlochSimple. This new simulation method is 4-5 times faster and uses around 80 times less memory. We have seen a 100-200x improvement in some sequences, especially if they have a lot of soft RF pulses.

(3) Distributed simulations (more info here)
We also tested distributed simulations with multiple GPUs and nodes :)

(4) GPU benchmarks (here)
We have a fancy new benchmarking page to ensure that there are no performance regressions.

(5)Phantom's including flexible motions and flow (more experimental)
You can now plot phantoms with motion and define them using mix-and-match motion definitions! More complex phantoms are possible including simple motions or arbitrary motions. Many more examples of using them are coming soon! 😄 including a realistic CFD-simulated aorta! All of this is done using our new reproducible phantom definition (HDF5-based), which enables the sharing of these phantoms with complex motion.

Hope these changes make your simulations faster! 😄 As always, if you have any problems, feel free to talk to me (@cncastillo ) in Slack or post an issue or discussion on GitHub.

Merged pull requests:

Closed issues:

  • CUDA memory problems? (#125)
  • Using BuildKite for GPU related CI? (#147)
  • Use the same functions to sample RFs in the simulation than for plotting sequence (#167)
  • Separate CI for more comprehensive results (#276)
  • Add simulate function for debugging purposes (#288)
  • Create Pluto example for fat_sat_low_field (#291)
  • Reporting of phantom spatial sampling in obj.info structure. (#322)
  • GSOC Proposal Issue Tracking: Part 1 (#349)
  • GSOC Proposal Issue Tracking: Part 2 (#350)
  • Extend GPU support to include Apple (Metal.jl), AMD (AMDGPU.jl), and Intel (OneAPI.jl) (#351)
  • Profile Bloch Simulation Method (#352)
  • Create new Kernel-based Simulation Method (#353)
  • Use @LocalMem inside future kernel-based simulation functions to speed up memory access (#354)
  • Add example of Multi-GPU simulation (#355)
  • Add example and / or support for multi-node simulation (#356)
  • Simplify ArbitraryMotion struct (#371)
  • Re-use weights in interpolation for ArbitraryMotion (#372)
  • Define Nspins for SimpleMotion (#376)
  • Applying @time to simulate reveals discrepancies on resources and timing reports (#392)
  • plot_signal docstring (correction) (#401)
  • [KomaUI Plotting] obj_ui[] does not draw on first time updated. Need to press :rho or other option. (#407)
  • New motion approach to combine SimpleMotion and ArbitraryMotion into the same phantom (#410)
  • Future: use @testsetup to reduce time to run tests on GPU (#414)
  • Problems initializing KomaUI (#432)
  • Brain phantom values inconsistencies (#464)
  • spin_reset has eltype T and should be an AbstractMatrix{Bool} (#479)

v0.8.2

22 Apr 20:56
9befece

Choose a tag to compare

KomaMRI v0.8.2

Diff since v0.8.1

Merged pull requests:

Closed issues:

  • Modify Literate Examples Generation (#251)
  • plot_seq not plotting Gx if Gy is not on and vice-versa (#374)
  • KomaMRI errors when using Julia nightly (#375)
  • Simulation crashes when trying to simulate soft-RF (get_rf_center) (#378)

v0.8.1

12 Apr 17:10
bd2c310

Choose a tag to compare

KomaMRI v0.8.1

Diff since v0.8.0

Merged pull requests:

Closed issues:

  • Incorrect interpretation of time shaped RFs (#200)
  • Empty sequence adds an undesired block (#203)
  • Unnecessary samples are considered when concatenating sequences (#205)
  • Resolve Circular Dependencies in Tests Environments (#237)
  • Google Summer of Code (GSoC) (#243)
  • Refactor functions for computing moments (#268)
  • Compatible, tested or recommended julia versions for CPU and GPU? (#295)
  • Default simulate fails after clean install of KomaMRI version 0.7.5 (#298)
  • MRIReco.jl v0.8.0 incorrect initialization with multiple threads (#299)
  • Update codecov to consider new subpackages (#302)
  • Reduce spins for pelvis Phantom (#306)
  • Interpretation of '.seq' files is not matching with sequence designed on PyPulseq (#320)
  • Warning: sort(d::Dict; args...) is deprecated, use sort!(OrderedDict(d); args...) instead. (#326)
  • Can't define colormap ranges when plotting phantom object (#328)
  • [BUG] CodeCov Not Working (#335)
  • Refactor get_Mk to compute 't' and 'tadc' more efficiently (#345)
  • Performance improvements for plot_seq (function and UI) (#365)