supergrad.time_evolution.pulseshape.PulseGaussian

supergrad.time_evolution.pulseshape.PulseGaussian#

class supergrad.time_evolution.pulseshape.PulseGaussian(length=False, amp=None, delay=0, modulate_wave=False, name: str = 'pulse_gaussian', **kwargs)[source]#

Creates normalized Gaussian pulse, center at center of time range. The duration of the pulse is determined by 2*cutoff*sigma. If length < 2*cutoff*sigma, the waveform will be truncated. If length > 2*cutoff*sigma, zeros will be appended to the waveform.

Note head/tail are directly truncated

Parameters:
  • length – the length of pulse

  • amp – the amplitude of pulse

  • modulate_wave (bool) – True for generate modulated sine wave

  • name – module name

sigma#

the sigma of Gaussian function

cutoff#

the cutoff of Gaussian function

Returns:

an array of amplitudes

__init__(length=False, amp=None, delay=0, modulate_wave=False, name: str = 'pulse_gaussian', **kwargs)[source]#

Initializes the current module with the given name.

Subclasses should call this constructor before creating other modules or variables such that those modules are named correctly.

Parameters:

name – An optional string name for the class. Must be a valid Python identifier. If name is not provided then the class name for the current instance is converted to lower_snake_case and used instead.

Methods

__init__([length, amp, delay, ...])

Initializes the current module with the given name.

create_envelope_pulse(t[, args])

Create envelope pulse shape for various gate operations.

create_pulse(t[, args])

Create desired pulse shape for various gate operations.

params_dict()

Returns parameters keyed by name for this module and submodules.

state_dict()

Returns state keyed by name for this module and submodules.

Attributes

pulse_endtime

The time of last pulse frame