Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Incorrect gradient interpretation when waveforms do not end in zero #321

Merged
merged 62 commits into from
Apr 8, 2024
Merged
Show file tree
Hide file tree
Changes from 3 commits
Commits
Show all changes
62 commits
Select commit Hold shift + click to select a range
cd844bc
Avoid abrupt changes between block gradients
beorostica Mar 11, 2024
c0d5589
Remove delay for RF when no RF is present during pulseq reading
beorostica Mar 11, 2024
ce9e97a
Add condition for no RF or ADC when reading pulseq file
beorostica Mar 12, 2024
a4b1d1e
Temporal read tests: comparison between koma and pulseq
beorostica Mar 13, 2024
929bf5e
Move folder for temporal read tests
beorostica Mar 13, 2024
cf572ca
Temporal updates for reading pulseq files
beorostica Mar 14, 2024
aefa3e0
Fix bug when running new read comparison tests
beorostica Mar 15, 2024
ba56717
Sort tests when comparing pulseq and koma readings
beorostica Mar 15, 2024
17899c1
Merge branch 'master' into zero-concat
beorostica Mar 26, 2024
7ed7c4b
Temporal local changes: add first last pulseq points for grads
beorostica Mar 26, 2024
c95e309
Add logic to consider first and last points for gradients
beorostica Mar 26, 2024
83da9a5
Add temporal time_shape_id property to Grad struct for debuging
beorostica Mar 27, 2024
f2e3b05
Merge branch 'master' into zero-concat
cncastillo Mar 27, 2024
ddc6d93
Remove temporal time_shape_id property from Grad struct
beorostica Mar 27, 2024
d3cc103
Add temporal test for comparing read RF
beorostica Mar 28, 2024
591130c
Merge branch 'master' into zero-concat
cncastillo Mar 28, 2024
84043cf
Add tests for spiral GRE and EPI when reading pulseq
beorostica Apr 1, 2024
5ed4362
Add some changes for first/last points in gradients
beorostica Apr 3, 2024
ed9def0
Merge branch 'zero-concat' of github.com:cncastillo/KomaMRI.jl into z…
beorostica Apr 3, 2024
8d680e4
Update KomaMRIFiles/src/Sequence/Pulseq.jl
beorostica Apr 3, 2024
aefbc9a
Update KomaMRIFiles/src/Sequence/Pulseq.jl
beorostica Apr 3, 2024
5baa0a0
Remove dummy conditional for pulseq read_ADC
beorostica Apr 3, 2024
d96120e
Merge branch 'zero-concat' of github.com:cncastillo/KomaMRI.jl into z…
beorostica Apr 3, 2024
435d447
Update KomaMRIFiles/src/Sequence/Pulseq.jl
beorostica Apr 3, 2024
e8d4d85
Add some tabs to Grad struct
beorostica Apr 3, 2024
1a989f5
Create `fix_first_last_grads!` function
beorostica Apr 3, 2024
5c97fcb
Merge branch 'master' into zero-concat
cncastillo Apr 3, 2024
8dfb9d2
Change RF interpretation from ZOH -> linear-interpolation and read th…
beorostica Apr 4, 2024
b55c84f
Add `if: !cancelled()` to CI
beorostica Apr 4, 2024
e437fca
Use @testitem for pulseq reading comparison
beorostica Apr 4, 2024
c9b6556
Proper RF Δf handling
cncastillo Apr 4, 2024
0a6c3f3
Fixed Δf in get_theo_A
cncastillo Apr 4, 2024
c98fb51
Removed RF phase bug (after ZOH->Lin)
cncastillo Apr 4, 2024
8819526
Plots now consider Δf
cncastillo Apr 4, 2024
44c8e31
Fixes eps causing incorrect block categorization.
cncastillo Apr 4, 2024
516b909
Removed unecessary functions
cncastillo Apr 4, 2024
ed884c9
Removed print in test
cncastillo Apr 4, 2024
8d6f08f
Added missing @suppress in tests
cncastillo Apr 4, 2024
a7fab0f
Temporal changes for testing pulseq first/last
beorostica Apr 5, 2024
1a3b546
More temporal changes for testing pulseq first/las
beorostica Apr 5, 2024
6a099dc
More x2 Temporal changes for testing pulseq first/last
beorostica Apr 5, 2024
c9677ee
KomaMRIBase: Export is_X_on
cncastillo Apr 7, 2024
d0448a7
KomaMRIBase: Changed get_samples and constructors for type-stability
cncastillo Apr 7, 2024
05cfda6
Renames get_tho to time and ampl, improved type stability
cncastillo Apr 7, 2024
c505bb2
More efficient Seq constructor, and fix #203
cncastillo Apr 7, 2024
8c5f7fe
Delay now creates Seq with seq.DUR=T
cncastillo Apr 7, 2024
8fc52a5
RF flip angle now calculated using ampl, time, trapz
cncastillo Apr 7, 2024
47dea75
`trapz` now works with vectors
cncastillo Apr 7, 2024
a3cea4f
KomaBase test changes
cncastillo Apr 7, 2024
940b828
KomaCore test do not use global variables anymore
cncastillo Apr 7, 2024
0c10aaa
KomaFiles Removed utils.jl
cncastillo Apr 7, 2024
6176d03
KomaFiles Pulseq read optimization and type stability #224
cncastillo Apr 7, 2024
2b53c89
KomaFiles Improved Pulseq compat tests
cncastillo Apr 7, 2024
682af57
Fixed #203
cncastillo Apr 7, 2024
1d589b9
KomaPlots Improved performance of plot_seq
cncastillo Apr 7, 2024
26b8d50
KomaMRI: Fixed seq export to mat
cncastillo Apr 7, 2024
d1573c2
KomaMRI/Plots performance improvements plots #364
cncastillo Apr 8, 2024
a0ab60a
Fixed DUR for older Pulseq versions
cncastillo Apr 8, 2024
18ce3ae
Improved show_seq_blocks
cncastillo Apr 8, 2024
4e0c670
KomaBase export time ampl freq
cncastillo Apr 8, 2024
0bba7c5
KomaPlots give option to include RF freq inside phase (integration)
cncastillo Apr 8, 2024
303e78c
Minor changes in Pulseq.jl [skip ci]
cncastillo Apr 8, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
8 changes: 8 additions & 0 deletions KomaMRIBase/src/timing/KeyValuesCalculation.jl
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,14 @@ get_theo_A(g::Grad; off_val=0) = begin
else
aux = [off_val; 0; A; 0]
end
# To remove abrut changes in the plots
if g.rise == 0
aux[2] = aux[3]
end
if g.fall == 0
aux[end] = aux[end-1]
beorostica marked this conversation as resolved.
Show resolved Hide resolved
end
# If no signal, then don't show samples
cncastillo marked this conversation as resolved.
Show resolved Hide resolved
if sum(abs.(g.A)) == 0
aux *= off_val
end
Expand Down
14 changes: 13 additions & 1 deletion KomaMRIFiles/src/Sequence/Pulseq.jl
Original file line number Diff line number Diff line change
Expand Up @@ -497,7 +497,8 @@ function read_Grad(gradLibrary, shapeLibrary, Δt_gr, i)
#Creating timings
if time_shape_id == 0 #no time waveform
gT = Nrf * Δt_gr
G = Grad(gA, gT, Δt_gr/2, Δt_gr/2, delay)
beorostica marked this conversation as resolved.
Show resolved Hide resolved
#G = Grad(gA, gT, Δt_gr/2, Δt_gr/2, delay)
G = Grad(gA, gT, 0, 0, delay)
cncastillo marked this conversation as resolved.
Show resolved Hide resolved
else
gt = decompress_shape(shapeLibrary[time_shape_id]...)
gT = (gt[2:end] .- gt[1:end-1]) * Δt_gr
Expand All @@ -522,6 +523,11 @@ Reads the RF. It is used internally by [`get_block`](@ref).
- `rf`: (`1x1 ::Matrix{RF}`) RF struct
"""
function read_RF(rfLibrary, shapeLibrary, Δt_rf, i)

if isempty(rfLibrary) || i==0
return reshape([RF(0,0)], 1, 1)
end

#Unpacking
#(1)amplitude (2)mag_id (3)phase_id (4)time_shape_id (5)delay (6)freq (7)phase
r = rfLibrary[i]["data"]
Expand Down Expand Up @@ -569,8 +575,14 @@ Reads the ADC. It is used internally by [`get_block`](@ref).
- `adc`: (`1x1 ::Vector{ADC}`) ADC struct
"""
function read_ADC(adcLibrary, i)

if isempty(adcLibrary) || i==0
return [ADC(0, 0)]
end
beorostica marked this conversation as resolved.
Show resolved Hide resolved

#Unpacking
#(1)num (2)dwell (3)delay (4)freq (5)phase
# It is needed a review for this, the dwell definition may cause problems
beorostica marked this conversation as resolved.
Show resolved Hide resolved
if !isempty(adcLibrary) # Is this the best? maybe defining i=0 is better, it works with RFs(?)
a = adcLibrary[i]["data"]
else
beorostica marked this conversation as resolved.
Show resolved Hide resolved
Expand Down
Loading