diff --git a/src/sycomore/TimeInterval.cpp b/src/sycomore/TimeInterval.cpp index 78f46b0..84721f0 100644 --- a/src/sycomore/TimeInterval.cpp +++ b/src/sycomore/TimeInterval.cpp @@ -36,6 +36,12 @@ ::shortest(Vector3Q const & k, Quantity const & G_max) return sycomore::TimeInterval(min_time, k); } +TimeInterval +::TimeInterval() +{ + // Nothing else. +} + TimeInterval ::TimeInterval( Quantity const & duration, Quantity const & gradient) diff --git a/src/sycomore/TimeInterval.h b/src/sycomore/TimeInterval.h index edfded7..938ffb1 100644 --- a/src/sycomore/TimeInterval.h +++ b/src/sycomore/TimeInterval.h @@ -25,13 +25,16 @@ class TimeInterval * or dephasing (rad/m) and maximum gradient amplitude */ static TimeInterval shortest(Vector3Q const & k, Quantity const & G_max); - + + /// @brief Default-initialize duration and gradient. + TimeInterval(); + /** * @brief Constructor, gradient may be specified as amplitude (in T/m), * area (in T/m*s) or dephasing (in rad/m). */ TimeInterval( - Quantity const & duration=0*units::s, + Quantity const & duration, Quantity const & gradient=0*units::T/units::m); /** @@ -39,7 +42,13 @@ class TimeInterval * area (in T/m*s) or dephasing (in rad/m). */ TimeInterval(Quantity const & duration, Vector3Q const & gradient); - + + TimeInterval(TimeInterval const &) = default; + TimeInterval(TimeInterval &&) = default; + TimeInterval & operator=(TimeInterval const &) = default; + TimeInterval & operator=(TimeInterval &&) = default; + ~TimeInterval() = default; + /// @brief Return the duration. Quantity const & duration() const;