Solver Configuration
Contents
4. Solver Configuration#
The Flow360.json file defines the solver settings used during the CFD solution. Most input quantities in the case configuration file (Flow360.json) are dimensionless. The conventions of nondimensional inputs in Flow360 are explained in detail at the nondimensional inputs knowledge base and the non-dimensionalization in Flow360 tutorial.
4.1. geometry
#
OPTIONAL
The geometry
section defines the geometric reference values. These parameters are used in the calculation of nondimensional loads reported (e.g., \(CL\), \(CMy\), etc.). Please refer to nondimensional inputs knowledge base and the non-dimensionalization in Flow360 tutorial for further information on how to define these.
Options |
Default |
Freestream |
---|---|---|
|
1.0 |
[float] The reference area of the geometry |
|
[0.0, 0.0, 0.0] |
[3-array(float)] The x, y, z moment center of the geometry in grid units |
|
[1.0, 1.0, 1.0] |
[3-array(float)] The x, y, z component-wise moment reference lengths |
Example
1"geometry" : {
2 "refArea" : 45.604,
3 "momentCenter" : [0.0, 0.0, 0.0],
4 "momentLength" : [3.81, 3.81, 3.81]
5}
4.2. freestream
#
REQUIRED
The freestream
section defines the flow conditions at the freestream. Please refer to nondimensional inputs knowledge base and the non-dimensionalization in Flow360 tutorial for further information on how to define these.
Options |
Default |
Description |
---|---|---|
|
Either |
[float] The Reynolds number, = \(\frac{\rho_\infty U_{ref} L_{gridUnit}}{\mu_\infty}\). Note that Flow360 differs from traditional calculations with the use of \(L_{gridUnit}\). |
|
Either |
[float] The freestream dynamic viscosity (nondimensional), = \(\frac{\mu_\infty}{\rho_\infty C_\infty L_{gridUnit}}\). |
|
REQUIRED |
[float] The Mach number, the ratio of freestream velocity to the speed of sound |
|
|
[float] The reference Mach number to compute nondimensional quantities, = \(U_{ref}/C_\infty\). |
|
REQUIRED |
[float] The freestream temperature in Kelvin. -1 means globally constant viscosity. |
|
REQUIRED |
[float] The angle of attack in degrees. |
|
REQUIRED |
[float] The side slip angle in degrees. |
|
DEPENDS |
[float] The ratio between the freestream turbulent viscosity and freestream laminar viscosity, used at freestream boundary and to set initial condition. The default depends on the turbulence model and if the transition model is enabled. For |
Example
1"freestream" :
2{
3 "muRef" : 4.29279e-08,
4 "Mach" : 1.46972e-02,
5 "MachRef" : 0.70,
6 "Temperature" : 288.15,
7 "alphaAngle" : -90.0,
8 "betaAngle" : 0.0
9}
4.3. boundaries
#
REQUIRED
The boundaries
section defines the boundary conditions. Each boundary condition is specified by associating the boundary type for each boundary name in the mesh file, as follows:
1"boundary_name" :
2{
3 "type" : "boundary_type"
4}
The “boundary_name” is the name of each individual patch of the grid and is typically of the form “1” for .ugrid files and “vol-1/wall” for .cgns files. Additionally, for .ugrid meshes an optional parameter “name” can be specified within each boundary dictionary to overwrite the numeric “boundary_name” in results. The “name” option takes a string entry.
Numerous boundary conditions require the specification of additional options, which are outlined in the table below. For a number of boundaries such as NoSlipWall
, IsothermalWall
and Freestream
, mathematical expressions can be used to define the inputs. Please refer to the boundary conditions knowledge base for more information.
Type |
Additional Options |
Description |
---|---|---|
|
None |
[string] Slip wall condition. Also used for symmetry boundary. |
|
[string] Sets no-slip wall condition |
|
|
[3-array(float or expression)] Optionally, a tangential velocity can be prescribed on the wall. |
|
|
[string] Isothermal wall boundary condition |
|
|
[float or expression] Wall temperature specified in Kelvin |
|
|
[3-array(float or expression)] Optionally, a tangential velocity can be prescribed on the wall. |
|
|
[string] Freestream condition, set by parameters in freestream. The default values are set based on the alpha and beta angles. |
|
|
[3-array(float or expression)] The default values are set according to the freestream alpha and beta angles. Optionally, an expression for each of the velocity components can be specified. |
|
|
[string] Subsonic outflow, set through static pressure ratio |
|
|
[float] Static pressure ratio, \(\frac{p_{outflow}}{p_{\infty}}\) |
|
|
[string] Subsonic outflow, set through Mach number |
|
|
[float] Mach number, \(\frac{U_{outflow}}{C_{\infty}}\) |
|
|
[string] Subsonic inflow set through total pressure ratio and total temperature ratio for nozzle or tunnel plenum |
|
|
[float] Total pressure ratio, \(\frac{p_{t, inflow}}{p_{s, inflow}}\) |
|
|
[float] Total temperature ratio, \(\frac{T_{t, inflow}}{T_{s, inflow}}\) |
|
|
[integer] Number of ramp steps during solution initialization |
|
|
[3-array(float or expression)] Direction of the incoming flow. Must be a unit vector pointing into the volume. If unspecified, the direction will be normal to the surface. |
|
|
[string] Mass outflow |
|
|
[float] Mass flow rate at outlet (non-dimensional), \(=\frac{\dot{m}_{outflow}}{{\rho C_{\infty}} L_{gridUnit}^2}\) |
|
|
[string] Mass inflow |
|
|
[float] Mass flow rate at inlet (non-dimensional), \(=\frac{\dot{m}_{inflow}}{{\rho C_{\infty}} L_{gridUnit}^2}\) |
|
|
None |
[string] Sliding interface boundaries. Details of each pair (inner/outer patches) must be prescribed separately: slidingInterfaces. |
|
None |
[string] This boundary type uses wall functions to estimate the velocity field close to the solid boundaries |
|
Translational periodic boundary condition |
|
|
[string] Patch name of the matching pair of a |
|
|
[3-array (float)] Vector that maps the patch to its periodic pair. Required when |
|
|
Fluid side of a conjugate heat transfer interface pair |
|
|
[string] Patch name of the matching pair of a |
|
|
Solid side of a conjugate heat transfer interface pair |
|
|
[string] Patch name of the matching pair of a |
|
|
[string] Isothermal wall boundary condition for a solid zone |
|
|
[float or expression], Wall temperature for a solid zone specified in Kelvin |
|
|
None |
[string] Adiabatic wall boundary condition for a solid zone |
Example
1"boundaries": {
2 "boundary_name_A": {
3 "type": "SlipWall"
4 },
5 "boundary_name_B":{
6 "type":"NoSlipWall",
7 "Velocity":["0.0","0.1*x+exp(y)+z^2","cos(0.2*x*pi)+sqrt(z^2+1)"]
8 },
9 "boundary_name_C": {
10 "type": "IsothermalWall",
11 "Temperature": 300
12 },
13 "boundary_name_D": {
14 "type": "Freestream"
15 },
16 "boundary_name_E": {
17 "type": "SubsonicOutflowPressure",
18 "staticPressureRatio": 1.0
19 },
20 "boundary_name_F": {
21 "type": "SubsonicOutflowMach",
22 "MachNumber": 0.2
23 },
24 "boundary_name_G": {
25 "type": "SubsonicInflow",
26 "totalPressureRatio": 1.0,
27 "totalTemperatureRatio": 1.0
28 },
29 "boundary_name_H": {
30 "type": "MassOutflow",
31 "massFlowRate": 0.2
32 },
33 "boundary_name_I": {
34 "type": "MassInflow",
35 "massFlowRate": 0.2
36 },
37 "boundary_name_J": {
38 "type": "SlidingInterface"
39 },
40 "boundary_name_K": {
41 "type": "WallFunction"
42 },
43 "boundary_name_L": {
44 "type": "TranslationallyPeriodic",
45 "pairedPatchName": "boundary_name_M",
46 "translationVector": [1, 0, 0]
47 },
48 "boundary_name_M": {
49 "type": "TranslationallyPeriodic"
50 },
51 "boundary_name_N": {
52 "type": "ConjugateHeatTransferFluidInterface",
53 "pairedPatchName": "boundary_name_O"
54 },
55 "boundary_name_O": {
56 "type": "ConjugateHeatTransferSolidInterface"
57 },
58 "boundary_name_P": {
59 "type": "SolidIsothermalWall",
60 "Temperature": 350
61 },
62 "boundary_name_Q": {
63 "type": "SolidAdiabaticWall"
64 }
65}
4.4. volumeZones
#
OPTIONAL
This section defines the properties of volume zones. All volume zones are assumed to be fluid
unless specified otherwise. Each volume zone is specified with a structure as follows:
1"volume_zone_name" :
2{
3 "zoneType" : "zone_type"
4}
The “volume_zone_name” needs to be consistent with the definitions in the mesh file.
The options thermalConductivity
and volumetricHeatSource
are only valid for solid zones.
Options |
default |
Description |
---|---|---|
|
REQUIRED |
[string] |
|
REQUIRED for a solid zone |
[float] Thermal conductivity of a solid zone |
|
0 |
[float or expression] Volumetric heat source for a solid zone |
Example
1"volumeZones": {
2 "SOLID": {
3 "modelType": "HeatEquation",
4 "thermalConductivity": 0.003,
5 "volumetricHeatSource": "0.01*sin(pi*x)*sin(pi*y)"
6 }
7}
4.6. turbulenceModelSolver
#
OPTIONAL
This section of the configuration file defines the numerical parameters for the turbulence model solver. For more information on setting up these parameters refer to the turbulence model solver knowledge base.
Options |
Default |
Description |
---|---|---|
|
"SpalartAllmaras" |
[string] |
|
1.00E-08 |
[float] Tolerance for the turbulence model residual, below which the solver progresses to the next physical step (unsteady) or completes the simulation (steady) |
|
0.0 |
[float] Tolerance to the relative residual, below which the solver goes to the next physical step. |
|
Configuration for the linear solver. |
|
|
4 |
[int] Frequency at which the jacobian is updated |
|
4 |
[int] Frequency at which to update the turbulence equation |
|
1.0 |
[float] The strength of gradient limiter used in reconstruction of solution variables at the faces (specified in the range [0.0, 2.0]). 0.0 corresponds to setting the gradient equal to zero, and 2.0 means no limiting. |
|
FALSE |
[boolean] Rotation correction for the turbulence model. Only supported for |
|
FALSE |
[boolean] Quadratic constitutive relation for turbulence shear stress tensor instead of Boussinesq Approximation |
|
2 |
[int] Order of accuracy in space |
|
0 |
[int] For physical steps less than the input value, the jacobian matrix is updated every pseudo-step overriding the |
|
FALSE |
[boolean] |
|
"maxEdgeLength" |
[string] Specifies the length used for the computation of LES length scale. The allowed inputs are |
|
{} |
[dict] A dictionary containing the DDES coefficients in the solver: SpalartAllmaras: |
Example
1"turbulenceModelSolver" : {
2 "modelType" : "SpalartAllmaras",
3 "absoluteTolerance" : 1e-8,
4 "relativeTolerance" : 1e-2,
5 "linearSolverConfig": {
6 "maxIterations": 25
7 },
8 "DDES" : true,
9 "orderOfAccuracy" : 2,
10 "updateJacobianFrequency" : 4,
11 "equationEvalFrequency" : 1,
12 "rotationCorrection" : true,
13 "modelConstants" : {
14 "C_DES": 0.85,
15 "C_d": 8.0
16 }
17}
4.7. transitionModelSolver
#
OPTIONAL
This section of the configuration file defines the numerical parameters for the transition model solver. For more information on setting up these parameters refer to the transition model solver knowledge base.
Options |
Default |
Description |
---|---|---|
|
"None" |
[string] |
|
1.00E-07 |
[float] Tolerance for the transition model residual, below which the solver progresses to the next physical step (unsteady) or completes the simulation (steady) |
|
0.0 |
[float] Tolerance to the relative residual, below which the solver goes to the next physical step. |
|
Configuration for the linear solver. |
|
|
4 |
[int] Frequency at which the jacobian is updated |
|
4 |
[int] Frequency at which to update the transition equation |
|
2 |
[int] Order of accuracy in space |
|
8.15 |
[float] Critical Amplification Factor, Range from [1-11]. Only valid when |
|
0.1 |
Turbulence Intensity, Range from [0.03-2.5]. Only valid when |
|
0 |
[int] For physical steps less than the input value, the jacobian matrix is updated every pseudo-step overriding the |
Example
1"transitionModelSolver": {
2 "modelType": "AmplificationFactorTransport",
3 "absoluteTolerance": 1e-10,
4 "linearSolverConfig": {
5 "maxIterations": 25
6 },
7 "orderOfAccuracy": 2,
8 "updateJacobianFrequency": 4,
9 "equationEvalFrequency": 4,
10 "Ncrit": 9
11}
4.8. heatEquationSolver
#
OPTIONAL
This section specifies the numerical parameters of the heat equation solver for CHT applications.
Options |
Additional Options |
Default |
Description |
---|---|---|---|
|
"None" |
[string] |
|
|
10 |
[int] Frequency at which to solve the heat equation in conjugate heat transfer simulations |
|
|
|
50 |
[int] Maximum number of linear solver iterations |
|
1.00E-10 |
[float] The linear solver converges when the final residual of the pseudo steps below this value. Either absolute tolerance or relative tolerance can be used to determine convergence. |
|
|
[float] The linear solver converges when the ratio of the final residual and the initial residual of the pseudo step is below this value. |
||
|
1.00E-9 |
[float] Absolute residual tolerance that determines the convergence of the heat equation in conjugate heat transfer. This value should be the same or higher than the absolute tolerance for the linear solver by a small margin. |
Example
1"heatEquationSolver": {
2 "modelType" : "HeatEquation",
3 "linearSolverConfig": {
4 "maxIterations": 50,
5 "absoluteTolerance": 1e-10
6 },
7 "equationEvalFrequency": 10
8}
4.9. initialCondition
#
OPTIONAL
This section of the configuration file specifies the initial condition for the simulation.
Options |
Default |
Description |
---|---|---|
|
"freestream" |
[string] |
Example
1"initialCondition": {
2 "type": "expression",
3 "constants": {
4 "gamma": "1.4"
5 },
6 "rho": "1.0",
7 "u": "0.0",
8 "v": "0.0",
9 "w": "0.0",
10 "p": "1/gamma"
11}
4.10. timeStepping
#
OPTIONAL
This section of the configuration file defines the numerical parameters for time stepping. Please refer to the time stepping knowledge base for further guidance regarding these parameters.
Options |
Additional Options |
Default |
Description |
---|---|---|---|
|
1 |
[int] Number of physical steps. "maxPhysicalSteps" is a supported alias for this entry. |
|
|
"inf" |
[string or float] Nondimensional time step size in physical step marching, it is calculated as \(\frac{\Delta t_{physical} C_\infty}{L_{gridUnit}}\), where the \(\Delta t_{physical}\) is the physical time (in seconds) step size. “inf” means steady simulation. |
|
|
2000 |
[int] Maximum pseudo steps within one physical step |
|
|
CFL settings within each physical step |
||
|
"ramp" |
When |
|
|
5 |
[int] Initial CFL for solving pseudo time step (applicable to |
|
|
200 |
[int] Final CFL for solving pseudo time step (applicable to |
|
|
40 |
[int] Number of pseudo steps before reaching CFL |
|
|
0.1 |
The minimum allowable value for CFL (applicable to |
|
|
10000 |
The maximum allowable value for CFL (applicable to |
|
|
1 |
The maximum allowable relative change of CFL (%) at each pseudo step (applicable to |
|
|
0.25 |
This factor specifies the level of conservativeness when using |
Note
The timeStepSize
is in solver units (nondimensional), where time-scale is mesh unit divided by freestream speed of sound. So a time of timeStepSize=1
means the time it takes for sound to travel 1 mesh unit at freestream.
Example
1"timeStepping": {
2 "timeStepSize": "inf",
3 "maxPhysicalSteps": 1,
4 "maxPseudoSteps": 10000,
5 "CFL": {
6 "initial": 1,
7 "final": 100,
8 "rampSteps": 2000
9 }
10}
4.11. slidingInterfaces
(list)#
OPTIONAL
This section of the configuration file defines the simulation parameters of a sliding interface. Please refer to the knowledge base on sliding interfaces for further information.
Options |
Default |
Description |
---|---|---|
|
REQUIRED |
[string] Name of the |
|
REQUIRED |
[list(string)] A list of static patch names of an interface |
|
REQUIRED |
[list(string)] A list of dynamic patch names of an interface |
|
DEPENDS |
[math] Expression for rotation angle (in radians) as a function of time. Required if |
|
DEPENDS |
[math] Expression for rotation angle (in degrees) as a function of time. Required if |
|
DEPENDS |
[float] Nondimensional rotating speed, radians/nondim-unit-time, = \(\frac{\Omega*L_{gridUnit}}{C_\infty}\), where the SI unit of \(\Omega\) is rad/s. Required if |
|
DEPENDS |
[float] Nondimensional rotating speed, degrees/nondim-unit-time, = \(\text{omegaRadians}*180/PI\). Required if |
|
REQUIRED |
[3-array(float)] Origin of rotation |
|
REQUIRED |
[3-array(float)] Axis of Rotation |
|
REQUIRED |
[list, string)] A list of dynamic volume zones related to the above {omega, centerOfRotation, axisOfRotation} |
|
DEPENDS |
[string] Name of the volume zone that the rotating reference frame is contained in, used to compute the acceleration in the nested rotating reference frame. Required when using nested rotating interfaces. |
|
FALSE |
[boolean] Whether rotation of this interface is dictated by |
Example
1"slidingInterfaces" : [
2{
3 "stationaryPatches" : ["farField/rotationInterface"],
4 "rotatingPatches" : ["innerRotating/rotationInterface"],
5 "axisOfRotation" : [0,0,-1],
6 "centerOfRotation" : [0,0,0],
7 "omega" : 1.84691e-01,
8 "volumeName" : ["innerRotating"]
9}
4.12. actuatorDisks
(list)#
OPTIONAL
The actuator disk inputs are defined in this section. Please refer to the actuator disk knowledge base for further information.
Options |
Default |
Description |
---|---|---|
|
REQUIRED |
[3-array(float)] center of the actuator disk |
|
REQUIRED |
[3-array(float)] direction of thrust, it is a unit vector |
|
REQUIRED |
[float] thickness of the actuator disk |
|
REQUIRED |
[list(float)] radius of the sampled locations in grid unit |
|
REQUIRED |
[list(float)] force per area in the axial direction, positive means the axial force follows the same direction as |
|
REQUIRED |
[list(float)] force per area in the circumferential direction, positive means the circumferential force follows the same direction as |
Example
1"actuatorDisks":
2[
3 {
4 "center":[0.0, 0.0, 0.0],
5 "axisThrust":[0.0,0.0,1.0],
6 "thickness": 0.01,
7 "forcePerArea":{
8 "radius":[0.01, 0.05, 0.1],
9 "thrust":[0.001, 0.02, 0],
10 "circumferential":[-0.0001, -0.003, 0]
11 }
12 }
13]
4.13. BETDisks
(list)#
OPTIONAL
In this section, the Blade Element Theory (BET) model inputs are defined. For detailed information on the parameters, please refer to the BET knowledge Base. To generate the sectional polars the BET translators can be used which are outlined here with best-practices for the sectional polars inputs available here. A case study of the XV-15 rotor using the steady BET Disk method is available in Case Studies. Because a transient BET Line simulation is simply a time-accurate version of a steady-state BET Disk simulation, most of the parameters below are applicable to both methods.
Options |
Default |
Description |
---|---|---|
|
"rightHand" |
[string] the rule for rotation direction and thrust direction, “rightHand” or “leftHand”. |
|
REQUIRED |
[3-array(float)] center of the Blade Element Theory (BET) disk |
|
REQUIRED |
[3-array(float)] rotational axis of the BET disk, i.e. (+) thrust axis |
|
REQUIRED |
[int] number of blades to model |
|
REQUIRED |
[float] nondimensional radius of the rotor disk, = \(\text{Radius}_\text{dimensional}/L_{gridUnit}\) |
|
REQUIRED |
[float] nondimensional rotating speed, radians/nondim-unit-time, = \(\frac{\Omega*L_{gridUnit}}{C_\infty}\), where the SI unit of \(\Omega\) is rad/s. |
|
REQUIRED |
[float] nondimensional reference chord used to compute sectional blade loadings |
|
REQUIRED |
[float] Number of nodes used to compute the sectional thrust and torque coefficients \(C_t\) and \(C_q\), defined in BET Loading Output |
|
REQUIRED |
[float] nondimensional thickness of the BET disk |
|
0.0 |
[float] nondimensional chord to use if performing an unsteady BET Line simulation. Default of 0.0 is an indication to run a steady BET Disk simulation. |
|
Required if |
[3-array(float)] Orientation of the first blade in the BET model. Must be specified if performing an unsteady BET Line simulation. |
|
REQUIRED |
[list(dict)] A list of dictionary entries specifying the twist in degrees as a function of radial location. Entries in the list must already be sorted by radius. |
|
REQUIRED |
[list(dict)] A list of dictionary entries specifying the blade chord as a function of the radial location. Entries in the list must already be sorted by radius. |
|
REQUIRED |
[list(dict)] A list of dictionaries for every radial location specified in |
|
REQUIRED |
[list(float)] A list of the radial locations in grid units at which \(C_l\) and \(C_d\) are specified in |
|
REQUIRED |
[list(float)] alphas associated with airfoil polars provided in |
|
REQUIRED |
[list(float)] Mach numbers associated with airfoil polars provided in |
|
REQUIRED |
[list(float)] Reynolds numbers associated with the airfoil polars provided in |
|
"inf" |
[float] Nondimensional distance between blade tip and solid bodies to define a tip loss factor. |
Example
1"BETDisks": [
2 {
3 "rotationDirectionRule": "leftHand",
4 "centerOfRotation": [0, 0, 0],
5 "axisOfRotation": [0, 0, 1],
6 "numberOfBlades": 3,
7 "radius": 150,
8 "omega": 0.0046,
9 "chordRef": 14,
10 "thickness": 15,
11 "nLoadingNodes": 20,
12 "MachNumbers": [0],
13 "ReynoldsNumbers": [1000000],
14 "alphas": [
15 -180,
16 0,
17 180
18 ],
19 "sectionalRadiuses": [
20 13.5,
21 120,
22 150
23 ],
24 "twists": [
25 {
26 "radius": 13.5,
27 "twist": 40.29936539609504
28 },
29 {
30 "radius": 76.5,
31 "twist": 16.596477306554306
32 },
33 {
34 "radius": 150,
35 "twist": 3.97516
36 }
37 ],
38 "chords": [
39 {
40 "radius": 13.4999999,
41 "chord": 0
42 },
43 {
44 "radius": 13.5,
45 "chord": 17.69622361
46 },
47 {
48 "radius": 150.0348189415042,
49 "chord": 14.004512929656503
50 }
51 ],
52 "sectionalPolars": [
53 {
54 "liftCoeffs": [
55 [
56 [
57 8.998801703796744e-12,
58 0.019549999999999998,
59 -8.998801703796744e-12
60 ]
61 ]
62 ],
63 "dragCoeffs": [
64 [
65 [
66 0.03000000000109987,
67 0.007595,
68 0.03000000000109987
69 ]
70 ]
71 ]
72 },
73 {
74 "liftCoeffs": [
75 [
76 [
77 8.998801703796744e-12,
78 0.18164999999999998,
79 -8.998801703796744e-12
80 ]
81 ]
82 ],
83 "dragCoeffs": [
84 [
85 [
86 0.03000000000109987,
87 0.0062699999999999995,
88 0.03000000000109987
89 ]
90 ]
91 ]
92 },
93 {
94 "liftCoeffs": [
95 [
96 [
97 -8.998801703796744e-12,
98 0.0589,
99 -8.998801703796744e-12
100 ]
101 ]
102 ],
103 "dragCoeffs": [
104 [
105 [
106 0.03000000000109987,
107 0.004765,
108 0.03000000000109987
109 ]
110 ]
111 ]
112 }
113 ],
114
115 "tipGap": "inf"
116 }
117 ]
4.14. porousMedia
(list)#
OPTIONAL
This section defines the inputs for the porous media model. For further information please refer to the porous media knowledge base.
Options |
Additional Options |
Default |
Description |
---|---|---|---|
|
REQUIRED |
[3-array(float)] Darcy coefficient of the porous media model which determines the scaling of the viscous loss term. The 3 values define the coefficient for each of the 3 axes defined by the reference frame of the volume zone. |
|
|
REQUIRED |
[3-array(float)] Forchheimer coefficient of the porous media model which determines the scaling of the inertial loss term |
|
|
REQUIRED |
[dict] Dictionary defining the properties of the region of the grid where the porous media model is applied |
|
|
REQUIRED |
[string] Type/Shape of volume zone. Possible values: “box” |
|
|
REQUIRED |
[3-array(float)] For “zoneType”: “box”, it is the center point of the box |
|
|
REQUIRED |
[[3-array(float)], [3-array(float)]] For “zoneType”: “box”, it is 2 axes which define the x and y directions of the box. Also, used to define the reference frame of the volume zone. |
|
|
REQUIRED |
[3-array(float)] For “zoneType”: “box”, it is the length of the box in each of the x, y, z directions |
|
|
[0.02*lengths[0], 0.02*lengths[1], 0.02*lengths[2]] |
[3-array(float)] For “zoneType”: “box”, it is the total length of the box in x, y, z directions over which a window function is applied on the edges |
Example
1 "porousMedia": [
2 {
3 "DarcyCoefficient": [1000000, 0, 0],
4 "ForchheimerCoefficient": [1, 0, 0],
5 "volumeZone": {
6 "zoneType": "box",
7 "center": [0, 0, 0],
8 "lengths": [0.2, 0.2, 2],
9 "axes": [[0, 1, 0], [0, 0, 1]]
10 }
11 }
12]
4.15. userDefinedDynamics
#
OPTIONAL
This section defines the user defined dynamics inputs. An example of how to use the userDefinedDynamics is available here.
Options |
Default |
Description |
---|---|---|
|
REQUIRED |
[string] Name of the dynamics defined by the user |
|
REQUIRED |
[list(string)] List of the inputs to define the user defined dynamics. Allowable inputs are: |
|
Empty |
[list(dict)] A list of dictionary entries specifying the constants used in the updateLaws and outputLaws |
|
REQUIRED |
[list(string)] Name of the output variables for the defined dynamics and the relation between the output variables and input/state variables. e.g. |
|
Empty |
[list(string)] The initial value of state variables are specified here. The entries could be either values (in the form of strings, e.g., |
|
Empty |
[list(string)] List of equations for updating state variables. The list entries correspond to the update laws for |
|
Empty |
[list(string)] List of boundary names (if any) related to the input variables |
Example
1"userDefinedDynamics": [
2 {
3 "dynamicsName": "alphaController",
4 "inputVars": [
5 "CL"
6 ],
7 "constants": {
8 "CLTarget": 0.4,
9 "Kp": 0.2,
10 "Ki": 0.002
11 },
12 "outputVars": {
13 "alphaAngle": "if (pseudoStep > 500) state[0]; else alphaAngle;"
14 },
15 "stateVarsInitialValue": [
16 "alphaAngle",
17 "0.0"
18 ],
19 "updateLaw": [
20 "if (pseudoStep > 500) state[0] + Kp * (CLTarget - CL) + Ki * state[1]; else state[0];",
21 "if (pseudoStep > 500) state[1] + (CLTarget - CL); else state[1];"
22 ],
23 "inputBoundaryPatches": [
24 "1"
25 ]
26 }
27]
4.16. Output#
This section presents all the configuration file inputs regarding solution output. This includes, the surface and volume solutions, as well as slices, isosurfaces and point monitors. For volumeZones
specified as solid
, only output related to the heat equation, i.e. temperatureSolid
and residualHeatSolver
are valid. These variables are plotted as zero outside of the solid zones. Universal nondimensional variables supported by all types of output are presented below: [note]
Name |
Description |
---|---|
|
Coefficient of pressure. \(C_p=(\frac{p-p_\infty}{\frac{1}{2}\rho_\infty{U_{ref}}^2})\) |
|
Gradient of primitive solution |
|
k and omega when using the kOmegaSST model |
|
Mach number |
|
Turbulent viscosity |
|
Ratio between turbulent viscosity and freestream dynamic viscosity, \(\mu_t/{\mu_\infty}\) |
|
Spalart-Almaras variable, nuHat |
|
Outputs rho, u, v, w, p (density, 3 velocities and pressure) |
|
Q criterion |
|
5 components of the N-S residual |
|
Residual for the transition model |
|
Residual for the turbulence model |
|
Entropy |
|
Solution for the N-S equation in conservative form |
|
Solution for the transition model |
|
Solution for the turbulence model |
|
Temperature |
|
Vorticity |
|
Wall distance |
|
Sensor showing where the numericalDissipationFactor has been increased |
|
Temperature in the solid zones |
|
Residual for the heat equation solver |
Additional nondimensional variables supported by volumeOutput and sliceOutput:
Name |
Description |
---|---|
|
Outputs BET disk related metrics, including variables such as |
|
Same as above but each BETdisk has its own |
|
Outputs |
Additional nondimensional variables supported by surfaceOutput:
Name |
Description |
---|---|
|
Viscous stress coefficient vector, = \(C_{f_{Vec}}[3]=\frac{\tau_{wall}[3]}{\frac{1}{2}\rho_\infty U_{ref}^2}\) |
|
Magnitude of |
|
Magnitude of |
|
Magnitude of |
|
Heat flux |
|
Wall normal direction (may not be a unit vector). Note: This variable does not support time average. |
|
\(\frac{\tau_{wall}[3]-(p-p_\infty)*normal[3]}{\rho_\infty C_\infty^2}\), where the \(normal[3]\) is the unit normal vector pointing from solid to fluid |
|
Velocity in rotating frame |
|
non-dimensional wall distance, \(y^+\) |
|
(beta feature) : This metric is a local indicator for quality of the wall model. A value less than 1.25 shows good estimation of wall shear stress. Between 1.25 and 10 is a region of less validity, and values greater than 10 are not reliable for wall shear stress estimation. |
4.16.1. volumeOutput
#
OPTIONAL
Options |
Default |
Description |
---|---|---|
|
-1 |
[int] Frequency (in number of physical time steps) at which volume output is saved. -1 is at end of simulation. |
|
0 |
[int] Offset (in number of physical time steps) at which volume output animation is started. 0 is at beginning of simulation. |
|
FALSE |
[boolean] Enables computation of time-averaged quantities |
|
-1 |
[int] Frequency (in number of physical time steps) at which time averaged volume output is saved. -1 is at end of simulation. |
|
0 |
[int] Offset (in number of physical time steps) at which time averaged volume output animation is started. 0 is at beginning of simulation. |
|
0 |
[int] Physical time step to start calculating averaging |
|
[] |
[list(string)] List of output variables. Including universal output variables, and variables specific to volumeOutput. |
|
"paraview" |
[string] |
Example
1"volumeOutput": {
2 "outputFormat": "tecplot",
3 "animationFrequency": -1,
4 "animationFrequencyOffset": 0,
5 "animationFrequencyTimeAverage": -1,
6 "animationFrequencyTimeAverageOffset": 0,
7 "computeTimeAverages": false,
8 "startAverageIntegrationStep": 0,
9 "outputFields": ["primitiveVars", "betMetrics", "qcriterion"]
10}
4.16.2. surfaceOutput
#
OPTIONAL
Options |
Default |
Description |
---|---|---|
|
-1 |
[int] Frequency (in number of physical time steps) at which surface output is saved. -1 is at end of simulation. |
|
0 |
[int] Offset (in number of physical time steps) at which surface output animation is started. 0 is at beginning of simulation. |
|
"paraview" |
[string] |
|
FALSE” |
[boolean] Enable writing all surface outputs into a single file instead of one file per surface. This option currently only supports Tecplot output format. |
|
FALSE |
[boolean] Enables computation of time-averaged quantities |
|
-1 |
[int] Frequency (in number of physical time steps) at which time averaged surface output is saved. -1 is at end of simulation. |
|
0 |
[int] Offset (in number of physical time steps) at which time averaged surface output animation is started. 0 is at beginning of simulation. |
|
0 |
[int] Physical time step to start calculating averaging |
|
[] |
[list(string)] List of output variables. Including universal output variables and variables specific to surfaceOutput. |
|
{} |
[dict] Dictionary of output surfaces. The name of the surface is used as the key. These surface names have to be the patch name in the grid file or the alias name specified in case JSON. See example below. |
Example
1"surfaceOutput": {
2 "animationFrequency": -1,
3 "animationFrequencyOffset": 0,
4 "animationFrequencyTimeAverage": -1,
5 "animationFrequencyTimeAverageOffset": 0,
6 "computeTimeAverages": false,
7 "outputFormat": "paraview",
8 "startAverageIntegrationStep": 0,
9 "writeSingleFile": false,
10 "outputFields": [ "yPlus" ],
11 "surfaces": {
12 "freestream": {
13 "outputFields": [ "Cp", "Mach" ]
14 # Will output "Cp", "Mach", "yPlus"
15 },
16 "symmetry": {
17 "outputFields": [ "T", "heatFlux" ]
18 # Will output "T", "heatFlux", "yPlus"
19 },
20 "wing": {
21 "outputFields": [ "CfVec" ]
22 # Will output "CfVec", "yPlus"
23 }
24 }
25}
4.16.3. sliceOutput
#
OPTIONAL
Options |
Default |
Description |
---|---|---|
|
-1 |
[int] Frequency (in number of physical time steps) at which slice output is saved. -1 is at end of simulation. |
|
0 |
[int] Offset (in number of physical time steps) at which slice output animation is started. 0 is at beginning of simulation. |
|
"paraview" |
[string] |
|
FALSE |
[boolean] Enables computation of time-averaged quantities |
|
-1 |
[int] Frequency (in number of physical time steps) at which time averaged slice output is saved. -1 is at end of simulation. |
|
0 |
[int] Offset (in number of physical time steps) at which time averaged slice output animation is started. 0 is at beginning of simulation. |
|
0 |
[int] Physical time step to start calculating averaging |
|
[] |
[list(string)] List of output variables. Including universal output variables and variables specific to sliceOutput. |
|
{} |
[dict] Dictionary of output slices. The name of the slice is used as the key. See example below. |
|
[] |
[3-array(float)] Normal direction of the slice (within slices dictionary) |
|
[] |
[3-array(float)] Coordinates of a point on the slice (within slices dictionary) |
Example
1"sliceOutput": {
2 "animationFrequency": -1,
3 "animationFrequencyOffset": 0,
4 "coarsenIterations": 0,
5 "outputFormat": "tecplot",
6 "outputFields": [ "Cp" ],
7 "slices": {
8 "x0": {
9 "sliceNormal": [ 1, 0, 0 ],
10 "sliceOrigin": [ 0, 0, 0 ],
11 "outputFields": [ "Mach" ]
12 # Will output "Mach", "Cp"
13 },
14 "y1": {
15 "sliceNormal": [ 0, 1, 0 ],
16 "sliceOrigin": [ 2, 1, 0 ],
17 "outputFields": [ "T" ]
18 # Will output "T", "Cp"
19 }
20 }
21}
4.16.4. isoSurfaceOutput
#
OPTIONAL
Options |
Additional Options |
Default |
Description |
---|---|---|---|
|
"paraview" |
[string] |
|
|
{} |
[dict] Dictionary of iso-surfaces. The key of the dictionary is the name of the iso-surface file to be written. |
|
|
[string] Isosurface field variable to be written. One of |
||
|
[float] The iso-value of |
||
|
[list(string)] List of output variables, see universal output variables |
||
|
-1 |
[int] Frequency (in number of physical time steps) at which volume output is saved. -1 is at end of simulation. |
|
|
0 |
[int] Offset (in number of physical time steps) at which volume output animation is started. 0 is at beginning of simulation. |
Example
1"isoSurfaceOutput": {
2 "outputFormat": "tecplot",
3 "animationFrequency": 10,
4 "isoSurfaces": {
5 "q_1e-3": {
6 "surfaceField": "qcriterion",
7 "surfaceFieldMagnitude": 1e-3,
8 "outputFields": [ "Cp", "Mach" ]
9 }
10 }
11},
4.16.5. monitorOutput
#
OPTIONAL
Options |
Additional Options |
Default |
Description |
---|---|---|---|
|
{} |
[dict] Dictionary of monitor groups. Data probed at the monitor points are printed to file every 10 pseudo step and at the end of each physical time step. The key of the dictionary is the name of the monitor group. |
|
|
[list(3-array(float))] A list of coordinates of the monitor points belonging to this monitor group |
||
|
[list(string)] List of output fields which will be added to all monitors within the monitor group, see universal output variables |
||
Note
Please increase the precision of the input coordinates when probing near the grid boundaries to ensure that the probing location is within the mesh.
Example
1"monitorOutput": {
2 "monitors": {
3 "Group1": {
4 "monitorLocations": [
5 [ 0.12, 0.34, 0.262 ],
6 [ 3.124e-1, 0.01, 0.03 ]
7 ],
8 "outputFields": [ "primitiveVars", "vorticity", "T", "s", "Cp", "mut" ]
9 }
10 }
11}
- note
Since release-23.1.1.0, previous syntax to specify output variables is being deprecated and not all variables are supported. Users are encouraged to use the new syntax as described in this documentation.