DiscreteSignal#
- class DiscreteSignal(dt, samples, start_time=0.0, carrier_freq=0.0, phase=0.0, name=None)[source]#
Bases:
Signal
Piecewise constant signal implemented as an array of samples.
The envelope is specified by an array of samples
s = [s_0, ..., s_k]
, sample widthdt
, and a start timet_0
, with the envelope being evaluated as \(f(t) =\)s[floor((t - t0)/dt)]
ift
is in the interval with endpointsstart_time
andstart_time + dt * len(samples)
, and0.0
otherwise. By default aDiscreteSignal
is defined to start at \(t=0\) but a custom start time can be set via thestart_time
kwarg.Initialize a piecewise constant signal.
- Parameters:
dt (
float
) – The duration of each sample.samples (
Union
[Array
,List
]) – The array of samples.start_time (
float
) – The time at which the signal starts.carrier_freq (
Union
[float
,List
,Array
]) – Frequency of the carrier. Subclasses such as SignalSums represent the carriers of each signal in an array.phase (
Union
[float
,List
,Array
]) – The phase of the carrier. Subclasses such as SignalSums represent the phase of each signal in an array.name (
Optional
[str
]) – name of the signal.
Methods
- add_samples(start_sample, samples)[source]#
Appends samples to the pulse starting at start_sample, filling any gap with zeros.
- Parameters:
start_sample (
int
) – Index of the sample at which the new samples should be appended.samples (
List
) – List of samples to append.
- Raises:
QiskitError – If start_sample is less than the current length of samples.
- complex_value(t)#
Vectorized evaluation of the complex value at time t.
- Return type:
Union
[complex
,array
,Array
]
- draw(t0, tf, n, function='signal', axis=None, title=None)#
Plot the signal over an interval.
The
function
arg specifies which function to plot:function == 'signal'
plots the full signal.function == 'envelope'
plots the complex envelope.function == 'complex_value'
plots thecomplex_value
.
- Parameters:
t0 (
float
) – Initial time.tf (
float
) – Final time.n (
int
) – Number of points to sample in interval.function (
Optional
[str
]) – Which function to plot.axis (
Optional
[axis
]) – The axis to use for plotting.title (
Optional
[str
]) – Title of plot.
- envelope(t)#
Vectorized evaluation of the envelope at time t.
- Return type:
Union
[complex
,array
,Array
]
- classmethod from_Signal(signal, dt, n_samples, start_time=0.0, sample_carrier=False)[source]#
Constructs a
DiscreteSignal
object by sampling aSignal
.The optional argument
sample_carrier
controls whether or not to include the carrier in the sampling. I.e.:- If
sample_carrier == False
, aDiscreteSignal
is constructed with: samples
obtained by samplingsignal.envelope
.carrier_freq = signal.carrier_freq
.phase = signal.phase
.
- If
- If
sample_carrier == True
, aDiscreteSignal
is constructed with: samples
obtained by samplingsignal
(as acallable
)carrier_freq = 0
.phase = signal.phase
.
- If
In either case, samples are obtained from the midpoint of each interval.
- Parameters:
signal (
Signal
) – Signal to sample.dt (
float
) – Time increment to use.n_samples (
int
) – Number of steps to resample with.start_time (
Optional
[float
]) – Start time from which to resample.sample_carrier (
Optional
[bool
]) – Whether or not to include the carrier in the sampling.
- Returns:
The discretized
Signal
.- Return type:
Attributes
- carrier_freq#
The carrier frequency of the signal.
- dt#
Returns: dt: the duration of each sample.
- duration#
Returns: duration: The duration of the signal in samples.
- is_constant#
Whether or not the signal is constant.
- name#
Return the name of the signal.
- phase#
The phase of the signal.
- samples#
Returns: samples: the samples of the piecewise constant signal.
- start_time#
Returns: start_time: The time at which the list of samples start.