- InitialCondition
Initial and Boundary Conditions
Nested input block for fields in MultiField that is applied only at the beginning of the simulation to describe initial conditions. In typical use, an InitialCondition is set throughout a volume (although this convention is not a requirement and, as with a BoundaryCondition, an InitialCondition may be set at select surfaces).
- BoundaryCondition:
Nested input block for fields in MultiField that is applied at every time step to describe boundary conditions. In typical use, boundary conditions are set at select surfaces (although this convention is not a requirement and, as with an InitialCondition, a boundary condition may be set throughout a volume).
Periodic boundary conditions are defined in the DomainDecomp input block.
InitialCondition and BoundaryCondition Parameters
- kind (string)
Type of boundary condition. Possible kind values include:
constant
copy
varadd
varset
outGoingWave (for electromagnetic fields only)
- lowerBounds (integer vector)
Lower bounds of the volume where initial or boundary condition is applied.
- upperBounds (integer vector)
Upper bounds of the volume where initial or boundary condition is applied.
- amplitudes (float vector)
Values of the amplitude for each of the indices.
- phases (float vector)
Values of the phase for each of the indices.
- components (integer vector)
Components to be set by the condition.
- STFunc (block)
The space-time function to be used, which is a kind-dependent parameter. The STFunc block must be named componentn where n is the component the function is setting.
STFunc
applies only to the following initial or boundary conditions:varadd
varset
outGoing
- sourceLowerBounds (integer vector)
Lower bounds of the region from which to copy; copy boundary condition only.
- sourceUpperBounds (integer vector)
Upper bounds of the region from which to copy; copy boundary condition only.
- maxApplyTime (real)
Time until which this boundary condition is applied; this applies to only BoundaryCondition.
BoundaryCondition outGoing Kind
Specifying kind = outGoing
in the BoundaryCondition block
sets an open boundary which allows electromagnetic waves with specific
characteristics to leave the domain, instead of reflecting, as they
would from a conductor.
You can also use the open BoundaryCondition to launch a wave. You might want to do this, for example, in the case when you have launched a wave from the left, as a result of which some wave is reflected. You can use an outGoing BoundaryCondition to launch the wave while allowing the reflected wave back through. See the Example of Using kind = open to Handle Wave Reflection.
outGoing Kind Parameters
- phaseVelocity (float)
Sets the phase velocity of the wave the user would like to leave the boundary. Giving phaseVelocity a value of the speed of light allows plane waves in vacuum to leave a boundary. For modes in a waveguide or other structure, the phase velocity may differ from the speed of light. A perfectly matched layer is required for allowing modes with differing phase velocities all to leave a boundary.
Example BoundaryCondition Block for launching an electromagnetic wave
# Wave launcher for E_y at left
<BoundaryCondition lower0Launcher>
kind = varset
lowerBounds = [0 -1 -1]
upperBounds = [1 21 21] # upperBounds = [1 NY1 NZ1]
minDim = 1
components = [1]
<STFunc component1>
k = [5026548.24574 0. 0.] # k = [KAY 0. 0.]
vg = 299790000.0 # vg = LIGHTSPEED
omega = 1.50690889859e+15
amplitudes = [2.56837310961e+12]
phases = [0.] # sine
kind = planeWavePulse
widths = [4e-06 2e-05 2e-05] # widths = [WXPUMP WYPUMP WZPUMP]
origin = [-4e-06 0.0 0.0] # origin = [XSTARTPUMP 0.0 0.0]
</STFunc>
</BoundaryCondition>
Examples of BoundaryCondition Blocks for conductor electromagnetic boundary conditions
# Set E_y to zero on x-lower boundary
<BoundaryCondition xLowerConductor>
kind = constant
# Value same at all cells
lowerBounds = [0 -1 -1]
# Lower cell limits for BC application
upperBounds = [1 21 21]
# Upper cell limits for BC application
# There should be one amplitude for each index
indices = [1]
# E_y set by this
amplitudes = [0.]
</BoundaryCondition>
# Set E_y and E_z to zero on x-upper boundary
<BoundaryCondition xUpperConductor>
kind = constant
lowerBounds = [40 -1 -1]
upperBounds = [41 21 21]
indices = [1 2]
amplitudes = [0. 0.]
</BoundaryCondition>
Example of Using kind = outGoingWave
boundary condition
<BoundaryCondition rightOpen>
kind = outGoingWave
phaseVelocity = $V_OVER_C*LIGHTSPEED$
normalDir = 0
velOverC = V_OVER_C
lowerBounds = [NX -1 -1] # Lower cell limits for application of BC
upperBounds = [NX1 NY1 NZ1] # Upper cell limits for BC application
components = [1 2] # field components boundary is applied to
<STFunc function>
kind = constantFunc
amplitude = 0.
</STFunc>
</BoundaryCondition>
Example of Using kind = open
to Handle Wave Reflection
<BoundaryCondition leftOpenWaveLauncher>
kind = outGoingWave
phaseVelocity = $V_OVER_C*LIGHTSPEED$
normalDir = 0
lowerBounds = [0 -1 -1]
upperBounds = [1 NY1 NZ1]
components = [2]
<STFunc function>
kind = planeWavePulse
amplitude = EWAVE
phase = 1.57
k = [KAY 0 0 ]
omega = OMEGA
vg = LIGHTSPEED
widths = [5.e-6 1.e-5 1.e-5]
origin = [-5.e-6 0.e-5 0.e-5]
</STFunc>
</BoundaryCondition>