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

Deprecate the discrete pulse library #11110

Merged
merged 7 commits into from
Oct 31, 2023
Merged
Show file tree
Hide file tree
Changes from 3 commits
Commits
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

Large diffs are not rendered by default.

88 changes: 44 additions & 44 deletions qiskit/pulse/library/discrete.py
Original file line number Diff line number Diff line change
Expand Up @@ -28,14 +28,14 @@


@deprecate_func(
since="0.25.0",
additional_msg="The discrete pulses library, including constant() is pending deprecation."
since="1.0.0",
TsafrirA marked this conversation as resolved.
Show resolved Hide resolved
additional_msg="The discrete pulses library, including constant() is deprecated."
" Instead, use the SymbolicPulse library to create the waveform with"
" pulse.Constant(...).get_waveform(). "
" Note that complex value support for the `amp` parameter is pending deprecation"
" in the SymbolicPulse library. It is therefore recommended to use two float values"
" Note that complex value support for the `amp` parameter is deprecated"
" in the SymbolicPulse library. Use two float values"
" for (`amp`, `angle`) instead of complex `amp`",
pending=True,
pending=False,
)
def constant(duration: int, amp: complex, name: Optional[str] = None) -> Waveform:
r"""Generates constant-sampled :class:`~qiskit.pulse.library.Waveform`.
Expand All @@ -58,11 +58,11 @@ def constant(duration: int, amp: complex, name: Optional[str] = None) -> Wavefor


@deprecate_func(
since="0.25.0",
additional_msg="The discrete pulses library, including zero() is pending deprecation."
since="1.0.0",
additional_msg="The discrete pulses library, including zero() is deprecated."
" Instead, use the SymbolicPulse library to create the waveform with"
" pulse.Constant(amp=0,...).get_waveform().",
pending=True,
pending=False,
)
def zero(duration: int, name: Optional[str] = None) -> Waveform:
"""Generates zero-sampled :class:`~qiskit.pulse.library.Waveform`.
Expand All @@ -84,13 +84,13 @@ def zero(duration: int, name: Optional[str] = None) -> Waveform:


@deprecate_func(
since="0.25.0",
additional_msg="The discrete pulses library, including square() is pending deprecation."
since="1.0.0",
additional_msg="The discrete pulses library, including square() is deprecated."
" Instead, use the SymbolicPulse library to create the waveform with"
" pulse.Square(...).get_waveform()."
" Note that pulse.Square() does not support complex values for `amp`,"
" and that the phase is defined differently. See documentation.",
pending=True,
pending=False,
)
def square(
duration: int, amp: complex, freq: float = None, phase: float = 0, name: Optional[str] = None
Expand Down Expand Up @@ -125,15 +125,15 @@ def square(


@deprecate_func(
since="0.25.0",
additional_msg="The discrete pulses library, including sawtooth() is pending deprecation."
since="1.0.0",
additional_msg="The discrete pulses library, including sawtooth() is deprecated."
" Instead, use the SymbolicPulse library to create the waveform with"
" pulse.Sawtooth(...).get_waveform()."
" Note that pulse.Sawtooth() does not support complex values for `amp`."
" Instead, use two float values for (`amp`, `angle`)."
" Also note that the phase is defined differently, such that 2*pi phase"
" shifts by a full cycle.",
pending=True,
pending=False,
)
def sawtooth(
duration: int, amp: complex, freq: float = None, phase: float = 0, name: Optional[str] = None
Expand Down Expand Up @@ -182,13 +182,13 @@ def sawtooth(


@deprecate_func(
since="0.25.0",
additional_msg="The discrete pulses library, including triangle() is pending deprecation."
since="1.0.0",
additional_msg="The discrete pulses library, including triangle() is deprecated."
" Instead, use the SymbolicPulse library to create the waveform with"
" pulse.Triangle(...).get_waveform()."
" Note that pulse.Triangle() does not support complex values for `amp`."
" Instead, use two float values for (`amp`, `angle`).",
pending=True,
pending=False,
)
def triangle(
duration: int, amp: complex, freq: float = None, phase: float = 0, name: Optional[str] = None
Expand Down Expand Up @@ -237,13 +237,13 @@ def triangle(


@deprecate_func(
since="0.25.0",
additional_msg="The discrete pulses library, including cos() is pending deprecation."
since="1.0.0",
additional_msg="The discrete pulses library, including cos() is deprecated."
" Instead, use the SymbolicPulse library to create the waveform with"
" pulse.Cos(...).get_waveform()."
" Note that pulse.Cos() does not support complex values for `amp`."
" Instead, use two float values for (`amp`, `angle`).",
pending=True,
pending=False,
)
def cos(
duration: int, amp: complex, freq: float = None, phase: float = 0, name: Optional[str] = None
Expand Down Expand Up @@ -275,13 +275,13 @@ def cos(


@deprecate_func(
since="0.25.0",
additional_msg="The discrete pulses library, including sin() is pending deprecation."
since="1.0.0",
additional_msg="The discrete pulses library, including sin() is deprecated."
" Instead, use the SymbolicPulse library to create the waveform with"
" pulse.Sin(...).get_waveform()."
" Note that pulse.Sin() does not support complex values for `amp`."
" Instead, use two float values for (`amp`, `angle`).",
pending=True,
pending=False,
)
def sin(
duration: int, amp: complex, freq: float = None, phase: float = 0, name: Optional[str] = None
Expand Down Expand Up @@ -313,14 +313,14 @@ def sin(


@deprecate_func(
since="0.25.0",
additional_msg="The discrete pulses library, including gaussian() is pending deprecation."
since="1.0.0",
additional_msg="The discrete pulses library, including gaussian() is deprecated."
" Instead, use the SymbolicPulse library to create the waveform with"
" pulse.Gaussian(...).get_waveform()."
" Note that complex value support for the `amp` parameter is pending deprecation"
" Note that complex value support for the `amp` parameter is deprecated"
" in the SymbolicPulse library. It is therefore recommended to use two float values"
" for (`amp`, `angle`) instead of complex `amp`",
pending=True,
pending=False,
)
def gaussian(
duration: int, amp: complex, sigma: float, name: Optional[str] = None, zero_ends: bool = True
Expand Down Expand Up @@ -367,13 +367,13 @@ def gaussian(


@deprecate_func(
since="0.25.0",
additional_msg="The discrete pulses library, including gaussian_deriv() is pending deprecation."
since="1.0.0",
additional_msg="The discrete pulses library, including gaussian_deriv() is deprecated."
" Instead, use the SymbolicPulse library to create the waveform with"
" pulse.GaussianDeriv(...).get_waveform()."
" Note that pulse.GaussianDeriv() does not support complex values for `amp`."
" Instead, use two float values for (`amp`, `angle`).",
pending=True,
pending=False,
)
def gaussian_deriv(
duration: int, amp: complex, sigma: float, name: Optional[str] = None
Expand Down Expand Up @@ -404,13 +404,13 @@ def gaussian_deriv(


@deprecate_func(
since="0.25.0",
additional_msg="The discrete pulses library, including sech() is pending deprecation."
since="1.0.0",
additional_msg="The discrete pulses library, including sech() is deprecated."
" Instead, use the SymbolicPulse library to create the waveform with"
" pulse.Sech(...).get_waveform()."
" Note that pulse.Sech() does not support complex values for `amp`."
" Instead, use two float values for (`amp`, `angle`).",
pending=True,
pending=False,
)
def sech(
duration: int, amp: complex, sigma: float, name: str = None, zero_ends: bool = True
Expand Down Expand Up @@ -455,13 +455,13 @@ def sech(


@deprecate_func(
since="0.25.0",
additional_msg="The discrete pulses library, including sech_deriv() is pending deprecation."
since="1.0.0",
additional_msg="The discrete pulses library, including sech_deriv() is deprecated."
" Instead, use the SymbolicPulse library to create the waveform with"
" pulse.SechDeriv(...).get_waveform()."
" Note that pulse.SechDeriv() does not support complex values for `amp`."
" Instead, use two float values for (`amp`, `angle`).",
pending=True,
pending=False,
)
def sech_deriv(duration: int, amp: complex, sigma: float, name: str = None) -> Waveform:
r"""Generates unnormalized sech derivative :class:`~qiskit.pulse.library.Waveform`.
Expand Down Expand Up @@ -489,14 +489,14 @@ def sech_deriv(duration: int, amp: complex, sigma: float, name: str = None) -> W


@deprecate_func(
since="0.25.0",
additional_msg="The discrete pulses library, including gaussian_square() is pending deprecation."
since="1.0.0",
additional_msg="The discrete pulses library, including gaussian_square() is deprecated."
" Instead, use the SymbolicPulse library to create the waveform with"
" pulse.GaussianSquare(...).get_waveform()."
" Note that complex value support for the `amp` parameter is pending deprecation"
" Note that complex value support for the `amp` parameter is deprecated"
" in the SymbolicPulse library. It is therefore recommended to use two float values"
" for (`amp`, `angle`) instead of complex `amp`",
pending=True,
pending=False,
)
def gaussian_square(
duration: int,
Expand Down Expand Up @@ -565,14 +565,14 @@ def gaussian_square(


@deprecate_func(
since="0.25.0",
additional_msg="The discrete pulses library, including drag() is pending deprecation."
since="1.0.0",
additional_msg="The discrete pulses library, including drag() is deprecated."
" Instead, use the SymbolicPulse library to create the waveform with"
" pulse.Drag(...).get_waveform()."
" Note that complex value support for the `amp` parameter is pending deprecation"
" Note that complex value support for the `amp` parameter is deprecated"
" in the SymbolicPulse library. It is therefore recommended to use two float values"
" for (`amp`, `angle`) instead of complex `amp`",
pending=True,
pending=False,
)
def drag(
duration: int,
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
---
deprecations:
- |
The discrete pulse library is now deprecated and will be removed in a future release. This includes:

* :func:`~qiskit.pulse.library.constant`
* :func:`~qiskit.pulse.library.zero`
* :func:`~qiskit.pulse.library.square`
* :func:`~qiskit.pulse.library.sawtooth`
* :func:`~qiskit.pulse.library.triangle`
* :func:`~qiskit.pulse.library.cos`
* :func:`~qiskit.pulse.library.sin`
* :func:`~qiskit.pulse.library.gaussian`
* :func:`~qiskit.pulse.library.gaussian_deriv`
* :func:`~qiskit.pulse.library.sech`
* :func:`~qiskit.pulse.library.sech_deriv`
* :func:`~qiskit.pulse.library.gaussian_square`
* :func:`~qiskit.pulse.library.drag`

Instead, use the corresponding :class:`~qiskit.pulse.SymbolicPulse`, with :meth:`~.SymbolicPulse.get_waveform()`.
For example, instead of ``pulse.gaussian(100,0.5,10)`` use ``pulse.Gaussian(100,0.5,10).get_waveform()``.

Note that the phase of both ``Sawtooth`` and ``Square`` is defined such that a phase of :math:``2\\pi``
shifts by a full cycle, contrary to the discrete counterpart. Also note that complex amplitude support is
deprecated in the symbolic pulse library - use ``float`` ``amp`` and ``angle`` instead.
Loading
Loading