Initial Field
InitialField
Represents an object with various parameters for a beam of light.
Initializes an object with various parameters for a beam of light.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
beam_width
|
float
|
The beam width parameter represents the width of the beam. It determines the spread of the beam and is typically measured as the full width at half maximum (FWHM) of the beam intensity distribution. |
required |
focal_point
|
tuple
|
The focal point is the point in space where the beam is focused. It is a coordinate in three-dimensional space (x, y, z) that represents the position of the focal point. |
required |
field_type
|
str
|
The |
'gaussian'
|
amplitude
|
float
|
The amplitude parameter represents the maximum value or intensity of the beam. It determines the overall strength or power of the beam. Defaults to 1. |
1
|
polar_angle
|
float
|
The |
0
|
azimuthal_angle
|
float
|
The azimuthal angle is a measure of the angle between the projection of the vector onto the xy-plane and the positive x-axis. It determines the orientation of the beam in the xy-plane. Defaults to 0. |
0
|
polarization
|
str
|
The "polarization" parameter determines the polarization of the beam. It can have two possible values: "TE" for transverse electric polarization and "TM" for transverse magnetic polarization. Defaults to "TE". |
'TE'
|
Source code in yasfpy/initial_field.py
10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 |
|
field_type = field_type
instance-attribute
amplitude = amplitude
instance-attribute
polar_angle = polar_angle
instance-attribute
azimuthal_angle = azimuthal_angle
instance-attribute
polarization = polarization
instance-attribute
beam_width = beam_width
instance-attribute
focal_point = focal_point
instance-attribute
log = logging.getLogger(self.__class__.__module__)
instance-attribute
__set_pol_idx
Sets the polarization index based on the polarization type.
The polarization index is determined based on the value of the polarization
attribute.
If the polarization
is "unp" or 0, the polarization index is set to 0.
If the polarization
is "te" or 1, the polarization index is set to 1.
If the polarization
is "tm" or 2, the polarization index is set to 2.
If the polarization
is not a valid value, the polarization index is set to 0 and a warning message is logged.
Source code in yasfpy/initial_field.py
51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 |
|
__set_normal_incidence
Sets the normal incidence flag based on the polar angle.
This method checks the value of the polar angle and determines if it is close to zero. If the absolute value of the sine of the polar angle is less than 1e-5, the normal incidence flag is set to True. Otherwise, the normal incidence flag is set to False.
Source code in yasfpy/initial_field.py
83 84 85 86 87 88 89 90 91 |
|
__setup
Performs the initial setup of the field.
This method sets the polarization index and normal incidence for the field.
Source code in yasfpy/initial_field.py
93 94 95 96 97 98 99 100 |
|