qiskit.pulse.GaussianSquare¶
-
class
GaussianSquare
(duration, amp, sigma, width=None, risefall_sigma_ratio=None, name=None)[source]¶ - A square pulse with a Gaussian shaped risefall on both sides. Either risefall_sigma_ratio
or width parameter has to be specified.
If risefall_sigma_ratio is not None and width is None:
\(risefall = risefall\) _ \(to\) _ \(sigma * sigma\)
\(width = duration - 2 * risefall\)
If width is not None and risefall_sigma_ratio is None:
\[risefall = (duration - width) / 2\]In both cases, the pulse is defined as:
\[ \begin{align}\begin{aligned}0 <= x < risefall\\f(x) = amp * exp( -(1/2) * (x - risefall/2)^2 / sigma^2) )\\risefall <= x < risefall + width\\f(x) = amp\\risefall + width <= x < duration\\f(x) = amp * exp( -(1/2) * (x - (risefall + width)/2)^2 / sigma^2) )\end{aligned}\end{align} \]Initialize the gaussian square pulse.
- Parameters
duration (
Union
[int
,ParameterExpression
]) – Pulse length in terms of the the sampling period dt.amp (
Union
[complex
,ParameterExpression
]) – The amplitude of the Gaussian and of the square pulse.sigma (
Union
[float
,ParameterExpression
]) – A measure of how wide or narrow the Gaussian risefall is; see the class docstring for more details.width (
Union
[float
,ParameterExpression
,None
]) – The duration of the embedded square pulse.risefall_sigma_ratio (
Union
[float
,ParameterExpression
,None
]) – The ratio of each risefall duration to sigma.name (
Optional
[str
]) – Display name for this pulse envelope.
-
__init__
(duration, amp, sigma, width=None, risefall_sigma_ratio=None, name=None)[source]¶ Initialize the gaussian square pulse.
- Parameters
duration (
Union
[int
,ParameterExpression
]) – Pulse length in terms of the the sampling period dt.amp (
Union
[complex
,ParameterExpression
]) – The amplitude of the Gaussian and of the square pulse.sigma (
Union
[float
,ParameterExpression
]) – A measure of how wide or narrow the Gaussian risefall is; see the class docstring for more details.width (
Union
[float
,ParameterExpression
,None
]) – The duration of the embedded square pulse.risefall_sigma_ratio (
Union
[float
,ParameterExpression
,None
]) – The ratio of each risefall duration to sigma.name (
Optional
[str
]) – Display name for this pulse envelope.
Methods
__init__
(duration, amp, sigma[, width, …])Initialize the gaussian square pulse.
assign
(parameter, value)Assign one parameter to a value, which can either be numeric or another parameter expression.
assign_parameters
(value_dict)Return a new ParametricPulse with parameters assigned.
draw
([dt, style, filename, interp_method, …])Plot the interpolated envelope of pulse.
Return a Waveform with samples filled according to the formula that the pulse represents and the parameter values it contains.
Return True iff the instruction is parameterized.
Validate parameters.
Attributes
The Gaussian amplitude.
Unique identifier for this pulse.
limit_amplitude
Return a dictionary containing the pulse’s parameters.
The duration of each risefall in terms of sigma.
The Gaussian standard deviation of the pulse width.
The width of the square portion of the pulse.
-
property
amp
¶ The Gaussian amplitude.
- Return type
Union
[complex
,ParameterExpression
]
-
assign
(parameter, value)¶ Assign one parameter to a value, which can either be numeric or another parameter expression.
- Return type
ParametricPulse
-
assign_parameters
(value_dict)¶ Return a new ParametricPulse with parameters assigned.
- Parameters
value_dict (
Dict
[ParameterExpression
,Union
[ParameterExpression
,float
]]) – A mapping from Parameters to either numeric values or another Parameter expression.- Return type
ParametricPulse
- Returns
New pulse with updated parameters.
-
draw
(dt=None, style=None, filename=None, interp_method=None, scale=None, interactive=None, draw_title=None, backend=None, time_range=None, time_unit='dt', show_waveform_info=True, plotter='mpl2d', axis=None)¶ Plot the interpolated envelope of pulse.
- Parameters
style (
Optional
[Dict
[str
,Any
]]) – Stylesheet options. This can be dictionary or preset stylesheet classes. See :py:class:~`qiskit.visualization.pulse_v2.stylesheets.IQXStandard`, :py:class:~`qiskit.visualization.pulse_v2.stylesheets.IQXSimple`, and :py:class:~`qiskit.visualization.pulse_v2.stylesheets.IQXDebugging` for details of preset stylesheets.backend (Optional[BaseBackend]) – Backend object to play the input pulse program. If provided, the plotter may use to make the visualization hardware aware.
time_range (
Optional
[Tuple
[int
,int
]]) – Set horizontal axis limit. Tuple(tmin, tmax)
.time_unit (
str
) – The unit of specified time range eitherdt
orns
. The unit ofns
is available only whenbackend
object is provided.show_waveform_info (
bool
) – Show waveform annotations, i.e. name, of waveforms. SetTrue
to show additional information about waveforms.plotter (
str
) –Name of plotter API to generate an output image. One of following APIs should be specified:
mpl2d: Matplotlib API for 2D image generation. Matplotlib API to generate 2D image. Charts are placed along y axis with vertical offset. This API takes matplotlib.axes.Axes as `axis` input.
axis and style kwargs may depend on the plotter.
axis (
Optional
[Any
]) – Arbitrary object passed to the plotter. If this object is provided, the plotters use a givenaxis
instead of internally initializing a figure object. This object format depends on the plotter. See plotter argument for details.dt (
Optional
[Any
]) – Deprecated. This argument is used by the legacy pulse drawer.filename (
Optional
[Any
]) – Deprecated. This argument is used by the legacy pulse drawer. To save output image, you can call .savefig method with returned Matplotlib Figure object.interp_method (
Optional
[Any
]) – Deprecated. This argument is used by the legacy pulse drawer.scale (
Optional
[Any
]) – Deprecated. This argument is used by the legacy pulse drawer.interactive (
Optional
[Any
]) – Deprecated. This argument is used by the legacy pulse drawer.draw_title (
Optional
[Any
]) – Deprecated. This argument is used by the legacy pulse drawer.
- Returns
Visualization output data. The returned data type depends on the
plotter
. If matplotlib family is specified, this will be amatplotlib.pyplot.Figure
data.
-
get_waveform
()[source]¶ Return a Waveform with samples filled according to the formula that the pulse represents and the parameter values it contains.
- Return type
Waveform
-
property
id
¶ Unique identifier for this pulse.
- Return type
int
-
is_parameterized
()¶ Return True iff the instruction is parameterized.
- Return type
bool
-
property
parameters
¶ Return a dictionary containing the pulse’s parameters.
- Return type
Dict
[str
,Any
]
-
property
risefall_sigma_ratio
¶ The duration of each risefall in terms of sigma.
- Return type
Union
[float
,ParameterExpression
]
-
property
sigma
¶ The Gaussian standard deviation of the pulse width.
- Return type
Union
[float
,ParameterExpression
]
-
validate_parameters
()[source]¶ Validate parameters.
- Raises
PulseError – If the parameters passed are not valid.
- Return type
None
-
property
width
¶ The width of the square portion of the pulse.
- Return type
Union
[float
,ParameterExpression
]