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()