__init__.py 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. import numpy as np
  2. # =========
  3. # BANKER'S ROUNDING FIX
  4. # =========
  5. def round_half_up(n, decimals=0):
  6. """
  7. Avoid banker's rounding inconsistencies; from https://realpython.com/python-rounding/#rounding-half-up
  8. """
  9. multiplier = 10**decimals
  10. return np.floor(np.abs(n) * multiplier + 0.5) / multiplier
  11. # =========
  12. # NP.FLOAT EPSILON
  13. # =========
  14. eps = np.finfo(np.float64).eps
  15. # =========
  16. # PACKAGE-LEVEL IMPORTS
  17. # =========
  18. from seqgen.pypulseq.SAR.SAR_calc import calc_SAR
  19. from seqgen.pypulseq.Sequence.sequence import Sequence
  20. from seqgen.pypulseq.add_gradients import add_gradients
  21. from seqgen.pypulseq.align import align
  22. from seqgen.pypulseq.calc_duration import calc_duration
  23. from seqgen.pypulseq.calc_ramp import calc_ramp
  24. from seqgen.pypulseq.calc_rf_bandwidth import calc_rf_bandwidth
  25. from seqgen.pypulseq.calc_rf_center import calc_rf_center
  26. from seqgen.pypulseq.make_adc import make_adc
  27. from seqgen.pypulseq.make_adiabatic_pulse import make_adiabatic_pulse
  28. from seqgen.pypulseq.make_arbitrary_rf import make_arbitrary_rf
  29. from seqgen.pypulseq.make_block_pulse import make_block_pulse
  30. from seqgen.pypulseq.make_sigpy_pulse import *
  31. from seqgen.pypulseq.make_delay import make_delay
  32. from seqgen.pypulseq.make_digital_output_pulse import make_digital_output_pulse
  33. from seqgen.pypulseq.make_extended_trapezoid import make_extended_trapezoid
  34. from seqgen.pypulseq.make_extended_trapezoid_area import make_extended_trapezoid_area
  35. from seqgen.pypulseq.make_gauss_pulse import make_gauss_pulse
  36. from seqgen.pypulseq.make_label import make_label
  37. from seqgen.pypulseq.make_sinc_pulse import make_sinc_pulse
  38. from seqgen.pypulseq.make_trapezoid import make_trapezoid
  39. from seqgen.pypulseq.sigpy_pulse_opts import SigpyPulseOpts
  40. from seqgen.pypulseq.make_trigger import make_trigger
  41. from seqgen.pypulseq.opts import Opts
  42. from seqgen.pypulseq.points_to_waveform import points_to_waveform
  43. from seqgen.pypulseq.rotate import rotate
  44. from seqgen.pypulseq.scale_grad import scale_grad
  45. from seqgen.pypulseq.split_gradient import split_gradient
  46. from seqgen.pypulseq.split_gradient_at import split_gradient_at
  47. from seqgen.pypulseq.supported_labels_rf_use import get_supported_labels
  48. from seqgen.pypulseq.traj_to_grad import traj_to_grad