3.2.3.2. lekkersim.BeamSplitter
- class lekkersim.BeamSplitter(ratio: float = 0.5, t: float = None, phase: float = 0.0)
Model of variable ration beam splitter
- __init__(ratio: float = 0.5, t: float = None, phase: float = 0.0) None
Initialize the model
- Parameters:
ratio (float) – Power coupling coefficient. It is also the splitting ratio if t is not provided.
t (float) – Power transmission coefficient. If None (default) it is calculated from the ratio assuming no loss in the component.
phase (float) – phase shift of the transmitted ray (in unit of pi). Default to 0.0
Methods
S2PD([func])Function for returning the Scattering Matrix as a PD Dataframe
__init__([ratio, t, phase])Initialize the model
create_S()Function for returning the scattering matrix of the model
expand_mode(mode_list)This function expands the model by adding additional modes.
get_A(pin1, pin2)Function for returning complex amplitude of the transmission between two ports
get_PH(pin1, pin2)Function for returning the phase of the transmission between two ports
get_T(pin1, pin2)Function for returning the energy transmission between two ports
get_output(input_dic[, power])Returns the outputs from all ports of the model given the inputs amplitudes
get_pin_basenames()Returns a list of the basenames of the pins
get_pin_modes(basename)Parse the pins for locating the pins with the same base name
inspect()Function that print self.
is_empty()Checks if model is empy
pin_mapping(pin_mapping)Function for changing the names of the pins of a model
print_S([func])Function for nice printing of scattering matrix in agreement with pins
prune()Check if the model is empty
put([source_pin, target_pin, param_mapping])Function for putting a model in a Solver object, and eventually specify connections
show_free_pins()Function for printing pins of model
solve(**kargs)Function for returning the solved model
update_params(update_dic)Update the parameters of model, setting defaults when value is not provides
update_pins()