diff --git a/_data/docs_v7.yml b/_data/docs_v7.yml index bcf13fe6..3b083ba2 100644 --- a/_data/docs_v7.yml +++ b/_data/docs_v7.yml @@ -40,6 +40,7 @@ - Physical-Definition - Markers-and-BC - Convective-Schemes + - Gradients-Limiters - Custom-Output - Linear-Solvers-and-Preconditioners - Multizone diff --git a/_docs_v7/Configuration-File.md b/_docs_v7/Configuration-File.md index 7ea2aa7b..25b1f222 100644 --- a/_docs_v7/Configuration-File.md +++ b/_docs_v7/Configuration-File.md @@ -7,7 +7,7 @@ The configuration file is a text file that contains a user's options for a parti The SU2 configuration file name typically carries a name of the form *filename.cfg*. The file extension .cfg is optional (this is our own convention), and the prefix can be any valid string with no spaces; e.g. config.cfg, su2-config.cfg, and flow_config.cfg are all suitable file names. -**Note: An example configuration file, called config_template.cfg, can be found in the root SU2/ directory or [here](https://github.com/su2code/SU2/blob/master/config_template.cfg). The developers keep this file up to date with the latest options, and it serves as the first reference for the available options in SU2** +**Note: An example configuration file, called config_template.cfg, can be found in the root SU2/ directory or [here](https://github.com/su2code/SU2/blob/master/config_template.cfg). It is a very important document because it supplements the documentation in this website. The developers keep this file up to date with the latest options, and it serves as the first reference for the available options in SU2.** The configuration file consists of only three elements: - **Options**. An option in the file has the following syntax: option_name = value, where option_name is the name of the option and value is the desired option value. The value element may be a scalar data type, a list of data types, or a more complicated structure. The "=" sign must come immediately after the option_name element and is not optional. Lists of data types may be formatted for appearance using commas, ()-braces, {}-braces, and []-braces, though this is not required. Semicolons are semantically relevant for several option types and may not be used as convenience delimiters. SU2 will exit with an error if there are options in the config file which do not exist or if there are options with improper formatting. Some example option formats are given below. diff --git a/_docs_v7/Convective-Schemes.md b/_docs_v7/Convective-Schemes.md index 0195cbe8..9a1c3a62 100755 --- a/_docs_v7/Convective-Schemes.md +++ b/_docs_v7/Convective-Schemes.md @@ -24,7 +24,7 @@ The options listed here do not apply to the high order DG solver. Convective schemes are used in the FVM discretization of convective fluxes through the faces of the dual-grid control volumes. They are selected via option `CONV_NUM_METHOD_FLOW` and fall under the two broad categories of central and upwind. Central schemes tend to be more robust whereas second order upwind schemes can be more accurate (i.e. less dissipative). -To achieve second order upwind schemes need to be used with MUSCL reconstruction (`MUSCL_FLOW = YES`), see the "gradients and limiters" page for the MUSCL-related options. +To achieve second order upwind schemes need to be used with MUSCL reconstruction (`MUSCL_FLOW = YES`), see the [Gradients and Limiters](/docs_v7/Gradients-Limiters) page for the MUSCL-related options. **Note:** MUSCL options have no effect on central schemes or on coarse multigrid levels in general. @@ -32,7 +32,7 @@ To achieve second order upwind schemes need to be used with MUSCL reconstruction | Solver | Version | | --- | --- | -| `EULER`, `NAVIER_STOKES`, `RANS` | 7.0.0 | +| `EULER`, `NAVIER_STOKES`, `RANS` | 7.2.0 | ### Central Schemes ### @@ -89,7 +89,7 @@ Some of the schemes above have tunning parameters or accept extra options, the f | Solver | Version | | --- | --- | -| `INC_EULER`, `INC_NAVIER_STOKES`, `INC_RANS` | 7.0.0 | +| `INC_EULER`, `INC_NAVIER_STOKES`, `INC_RANS` | 7.2.0 | ### Central Schemes ### @@ -103,7 +103,7 @@ Some of the schemes above have tunning parameters or accept extra options, the f | Solver | Version | | --- | --- | -| `RANS`, `INC_RANS` | 7.0.0 | +| `RANS`, `INC_RANS` | 7.2.0 | Only one method is currently available: `SCALAR_UPWIND` which must be selected via option `CONV_NUM_METHOD_TURB`. This method does not have any special parameters. diff --git a/_docs_v7/Custom-Output.md b/_docs_v7/Custom-Output.md index 9610e91e..f01e8dfe 100644 --- a/_docs_v7/Custom-Output.md +++ b/_docs_v7/Custom-Output.md @@ -44,12 +44,15 @@ SU2 can output the solution in several file formats. You can specify what files | `RESTART` | Native SU2 binary restart format | | `RESTART_ASCII` | ASCII CSV restart format | | `CSV` | ASCII CSV restart format (identical to `RESTART_ASCII`) | -| `PARAVIEW` | Binary Paraview .vtk format | +| `PARAVIEW` | Binary Paraview XML .vtu format | +| `PARAVIEW_LEGACY` | Binary Paraview .vtk format | +| `PARAVIEW_MULTIBLOCK` | Paraview XML Multiblock .vtm format | | `PARAVIEW_ASCII` | ASCII Paraview .vtk format | | `TECPLOT` | Binary Tecplot .szplt format | | `TECPLOT_ASCII` | ASCII Tecplot .dat format | | `SURFACE_CSV` | Surface values in CSV format (includes all markers set with `MARKER_PLOTTING`) | -| `SURFACE_PARAVIEW` | Surface values in binary Paraview .vtk format (includes all markers set with `MARKER_PLOTTING`)| +| `SURFACE_PARAVIEW` | Surface values in binary Paraview .vtu format (includes all markers set with `MARKER_PLOTTING`)| +| `SURFACE_PARAVIEW_LEGACY` | Surface values in binary Paraview .vtk format (includes all markers set with `MARKER_PLOTTING`)| | `SURFACE_PARAVIEW_ASCII` | Surface values in ASCII Paraview .vtk format (includes all markers set with `MARKER_PLOTTING`)| | `SURFACE_TECPLOT` | Surface values in binary Tecplot .szplt format (includes all markers set with `MARKER_PLOTTING`)| | `SURFACE_TECPLOT_ASCII` | Surface values in ASCII Tecplot .dat format (includes all markers set with `MARKER_PLOTTING`)| @@ -75,17 +78,20 @@ For the compressible Navier-Stokes solver (i.e. `SOLVER=NAVIER_STOKES`), a **non | `MOMENTUM-X` | Momentum x-component | `SOLUTION` | | `MOMENTUM-Y` | Momentum y-component | `SOLUTION` | | `MOMENTUM-Z` | Momentum z-component | `SOLUTION` | -| `ENERGY` | Energy | `SOLUTION` | +| `ENERGY` | Density times the specific total energy | `SOLUTION` | +| `RMS_` | Root-mean square residual of the solution | `RMS_RES` | | `PRESSURE` | Pressure| `PRIMITIVE` | | `TEMPERATURE` | Temperature | `PRIMITIVE` | | `MACH` | Mach Number | `PRIMITIVE` | | `PRESSURE_COEFF` | Pressure Coefficient | `PRIMITIVE` | | `LAMINAR_VISCOSITY` | Laminar viscosity | `PRIMITIVE` | -| `SKIN_FRICTION-X` | Skin friction coefficient x-component | `PRIMITIVE` | -| `SKIN_FRICTION-Y` | Skin friction coefficient y-component | `PRIMITIVE` | -| `SKIN_FRICTION-Z` | Skin friction coefficient z-component | `PRIMITIVE` | +| `SKIN_FRICTION-X` | Skin friction coefficient x-component in local coordinates | `PRIMITIVE` | +| `SKIN_FRICTION-Y` | Skin friction coefficient y-component in local coordinates | `PRIMITIVE` | +| `SKIN_FRICTION-Z` | Skin friction coefficient z-component in local coordinates | `PRIMITIVE` | | `HEAT_FLUX` | Heat flux | `PRIMITIVE` | | `Y_PLUS` | Y-Plus | `PRIMITIVE` | +| `VORTICITY` | Vorticity | `VORTEX_IDENTIFICATION` | +| `Q_Criterion` | Q-Criterion | `VORTEX_IDENTIFICATION` | ## Customizing the Screen and History Output ## diff --git a/_docs_v7/Gradients-Limiters.md b/_docs_v7/Gradients-Limiters.md new file mode 100644 index 00000000..374a33cc --- /dev/null +++ b/_docs_v7/Gradients-Limiters.md @@ -0,0 +1,36 @@ +--- +title: Gradients and Limiters +permalink: /docs_v7/Gradients-Limiters/ +--- + +This page lists the gradient computation methods and the limiter functions in SU2 as well as their associated options, it is not meant as a detailed theory guide but some application guidance is given nonetheless. The options listed here do not apply to the high order DG solver. + +--- + + +--- + +## Gradient Computation ## +The numerical method for the computation of the spatial gradients used for viscous fluxes and source terms is specified by the `NUM_METHOD_GRAD` field. The list of available options is given below. +`GREEN_GAUSS`: Classic gradient reconstruction based on the Green-Gauss theorem. +`WEIGHTED_LEAST_SQUARES`: Compute the gradient of a field using inverse-distance-weighted approximation. +The default option is set to `WEIGHTED_LEAST_SQUARES`. + +The spatial gradients method used only for upwind reconstruction is specified by the `NUM_METHOD_GRAD_RECON` field. An additional method is available; `LEAST_SQUARES`: Compute the gradient of a field using unweighted Least- Squares approximation. If the `NUM_METHOD_GRAD_RECON` field is left empty or set to `NONE` it defaults to `NUM_METHOD_GRAD`. + +Thin Shear Layer gradient reconstruction is always used for the construction of the Jacobian. + +## Limiters ## +SU2 implements limiter functions to prevent the generation of oscillations when using upwind spatial discretisations. These are specified by the config field `SLOPE_LIMITER_FLOW`. The available options are: +- `NONE` - No limiter +- `VENKATAKRISHNAN` - Slope limiter using Venkatakrisnan method. +- `VENKATAKRISHNAN_WANG` - Slope limiter using Venkatakrisnan method, with the small non-vanishing bias to prevent divisions by zero based on the min-to-max range of the solution. +- `BARTH_JESPERSEN` - Slope limiter using Barth-Jespersen method. +- `VAN_ALBADA_EDGE` - Slope limiter using Van Albada method. +- `SHARP_EDGES` - Slope limiter based on the distance to the nearest sharp edge. +- `WALL_DISTANCE` - Slope limiter based on wall distance. +With the default option set to `VENKATAKRISHNAN`. + +The `VENKAT_LIMITER_COEFF` field is used to compute the small non-vanishing bias to prevent divisions by zero, $\epsilon$. Depending on the limiter to be used this field has different interpretations. For the `VENKATAKRISHNAN` limiter it represents the constant $K$ in $\epsilon^2=\left(K\Delta x\right)^3$. We refer to [Venkatakrishnan](https://doi.org/10.1006/jcph.1995.1084) for further details. For the `VENKATAKRISHNAN_WANG` limiter it represents the constant $\epsilon^{\prime}$ in $\epsilon = \epsilon^{\prime}(q^{\text{\max}}-q^{\text{\min}})$. We refer to [Wang](https://doi.org/10.2514/6.1996-2091) for further details. For both limiters larger values of `VENKAT_LIMITER_COEFF` decrease the extent of limiting, while values approaching zero cause lower-order approximation to the solution. The dafault value is 0.05. + +The option `LIMITER_ITER` specifies the number of iterations afterFreeze the value of the limiter after a number of iterations. DEFAULT value $999999$. diff --git a/_docs_v7/Markers-and-BC.md b/_docs_v7/Markers-and-BC.md index fae2a0b8..91974b95 100755 --- a/_docs_v7/Markers-and-BC.md +++ b/_docs_v7/Markers-and-BC.md @@ -35,7 +35,7 @@ The term *Marker* refers to a named entity in your mesh file. Boundary condition | Solver | Version | | --- | --- | -| `EULER`, `NAVIER_STOKES`, `RANS`, `INC_EULER`, `INC_NAVIER_STOKES`, `INC_RANS`, `FEM_EULER`, `FEM_NAVIER_STOKES` | 7.0.0 | +| `EULER`, `NAVIER_STOKES`, `RANS`, `INC_EULER`, `INC_NAVIER_STOKES`, `INC_RANS`, `FEM_EULER`, `FEM_NAVIER_STOKES` | 7.2.0 | An Euler wall for inviscid flow is defined with the `MARKER_EULER` option. It can also be used as a slip wall in viscous flow. Only the marker name has to be given for this option. @@ -51,7 +51,7 @@ MARKER_EULER = (Euler_Wall1, Euler_Wall2, ...) | Solver | Version | | --- | --- | -| `EULER`, `NAVIER_STOKES`, `RANS`, `INC_EULER`, `INC_NAVIER_STOKES`, `INC_RANS`, `FEM_EULER`, `FEM_NAVIER_STOKES` | 7.0.0 | +| `EULER`, `NAVIER_STOKES`, `RANS`, `INC_EULER`, `INC_NAVIER_STOKES`, `INC_RANS`, `FEM_EULER`, `FEM_NAVIER_STOKES` | 7.2.0 | A symmetry wall is defined with using the `MARKER_SYM` option. Only the marker name has to be given for this option. @@ -61,14 +61,16 @@ For all Finite Volume (FVM) solvers, i.e. not the `FEM_*` solvers, its implement MARKER_SYM = (Symmetry_Wall1, Symmetry_Wall2, ...) ``` +The negative Spalart-Allmaras model implements the same boundary conditions as for the standard/standalone version. + ## Constant Heatflux (no-slip) Wall ## | Solver | Version | | --- | --- | -| `NAVIER_STOKES`, `RANS`, `INC_NAVIER_STOKES`, `INC_RANS`, `FEM_NAVIER_STOKES`, `HEAT_EQUATION_FVM` | 7.0.0 | +| `NAVIER_STOKES`, `RANS`, `INC_NAVIER_STOKES`, `INC_RANS`, `FEM_NAVIER_STOKES`, `HEAT_EQUATION_FVM` | 7.2.0 | -A wall with a prescribed constant heatflux is defined with the `MARKER_HEATFLUX` option. The option format is the marker name followed by the value of the heatflux (in Watts per square meter `[W/m^2],[J/(s*m^2)]`), e.g. +A viscous wall with a prescribed constant heatflux is defined with the `MARKER_HEATFLUX` option. The option format is the marker name followed by the value of the heatflux (in Watts per square meter `[W/m^2],[J/(s*m^2)]`), e.g. ``` MARKER_HEATFLUX = (Wall1, 1e05, Wall2, 0.0) ``` @@ -79,7 +81,7 @@ MARKER_HEATFLUX = (Wall1, 1e05, Wall2, 0.0) | Solver | Version | | --- | --- | -| `NAVIER_STOKES`, `RANS`, `INC_NAVIER_STOKES`, `INC_RANS` | 7.0.0 | +| `NAVIER_STOKES`, `RANS`, `INC_NAVIER_STOKES`, `INC_RANS` | 7.2.0 | A wall with a prescribed locally variable heatflux via a heat transfer coefficient and and a Temperature at infinity (or reservoir Temperature) is defined with the `MARKER_HEATTRANSFER` option. The heatflux `q` computes to `q = h(T_inf - T_wall)`, where `T_wall` is the local wall temperature and therefore no user input. The option format is the marker name followed by the value of the heat-transfer coefficient (in Watts per square meter and Kelvin `[W/(m^2*K)],[J/(s*m^2*K)]`) and the value of the Temperature at infinity (in Kelvin `[K]`), e.g. @@ -93,7 +95,7 @@ MARKER_HEATTRANSFER = (Wall1, 10.0, 350.0, Wall2, 5.0, 330.0, ...) | Solver | Version | | --- | --- | -| `NAVIER_STOKES`, `RANS`, `INC_NAVIER_STOKES`, `INC_RANS`, `FEM_NAVIER_STOKES`, `HEAT_EQUATION_FVM` | 7.0.0 | +| `NAVIER_STOKES`, `RANS`, `INC_NAVIER_STOKES`, `INC_RANS`, `FEM_NAVIER_STOKES`, `HEAT_EQUATION_FVM` | 7.2.0 | A wall with a constant temperature is defined with the `MARKER_ISOTHERMAL` option. The option format is the marker name followed by the value of the temperature (in Kelvin `[K]`), e.g. ``` @@ -104,9 +106,9 @@ MARKER_ISOTHERMAL = (Wall1, 300.0, Wall2, 250.0) | Solver | Version | | --- | --- | -| `EULER`, `NAVIER_STOKES`, `RANS`, `INC_EULER`, `INC_NAVIER_STOKES`, `INC_RANS`, `FEM_EULER`, `FEM_NAVIER_STOKES` | 7.0.0 | +| `EULER`, `NAVIER_STOKES`, `RANS`, `INC_EULER`, `INC_NAVIER_STOKES`, `INC_RANS`, `FEM_EULER`, `FEM_NAVIER_STOKES` | 7.2.0 | -A marker can be defined as a Farfield boundary by addings its name to the `MARKER_FAR` option. No other values are necesseary for that option. The actual values which will be prescribed depend on the solver and other user input settings. More details can be found in the [Physical Definition](/docs_v7/Physical-Definition/) section. +A marker can be defined as a Farfield boundary by addings its name to the `MARKER_FAR` option. No other values are necesseary for that option. The actual values which will be prescribed depend on the solver and other user input settings. The implementation is based on the Riemann invariants of the Euler system calculated from the user input config file. More details can be found in the [Physical Definition](/docs_v7/Physical-Definition/) section. ``` MARKER_FAR= (farfield) @@ -119,7 +121,7 @@ Inlet boundary conditions are set using the option `MARKER_INLET`. | Solver | Version | | --- | --- | -| `EULER`, `NAVIER_STOKES`, `RANS`, `FEM_EULER`, `FEM_NAVIER_STOKES` | 7.0.0 | +| `EULER`, `NAVIER_STOKES`, `RANS`, `FEM_EULER`, `FEM_NAVIER_STOKES` | 7.2.0 | To describe the **Total Conditions** at the inlet, set the option `INLET_TYPE= TOTAL_CONDITIONS` (which is the default). The format for `MARKER_INLET` then is the marker name, followed by the Total Temperature (in Kelvin `[K]`), the total Pressure (in Pascal `[Pa]`) and the flow direction unity vector (in meter per second `[m/s]`). For example: ``` @@ -131,7 +133,7 @@ MARKER_INLET = (inlet1, 300, 1e6, 1.0, 0.0, 0.0, inlet2, 400, 1e6, 0.0, 1.0, 0.0 | Solver | Version | | --- | --- | -| `EULER`, `NAVIER_STOKES`, `RANS`, `FEM_EULER`, `FEM_NAVIER_STOKES` | 7.0.0 | +| `EULER`, `NAVIER_STOKES`, `RANS`, `FEM_EULER`, `FEM_NAVIER_STOKES` | 7.2.0 | To describe the **Mass Flow** at the inlet, set the option `INLET_TYPE= MASS_FLOW`. The format for `MARKER_INLET` then is the marker name, followed by the Density (in `[kg/m^3`]), the Velocity magnitude (in meter per second `[m/s]`) and the flow direction unity vector (in meter per second `[m/s]`). For example: ``` @@ -144,7 +146,7 @@ MARKER_INLET = (inlet1, 1.13 , 20, 1.0, 0.0, 0.0, inlet2, 1.15, 10, 0.0, 1.0, 0. | Solver | Version | | --- | --- | -| `INC_EULER`, `INC_NAVIER_STOKES`, `INC_RANS` | 7.0.0 | +| `INC_EULER`, `INC_NAVIER_STOKES`, `INC_RANS` | 7.2.0 | To describe the **Velocity** at the inlet, set the option `INC_INLET_TYPE= VELOCITY_INLET`. The format for `MARKER_INLET` then is the marker name, followed by the Temperature (in Kelvin `[K`]), the Velocity magnitude (in meter per second `[m/s]`) and the flow direction unity vector (in meter per second `[m/s]`). @@ -157,7 +159,7 @@ MARKER_INLET = (inlet1, 300 , 20, 1.0, 0.0, 0.0, inlet2, 200, 10, 0.0, 1.0, 0.0) | Solver | Version | | --- | --- | -| `INC_EULER`, `INC_NAVIER_STOKES`, `INC_RANS` | 7.0.0 | +| `INC_EULER`, `INC_NAVIER_STOKES`, `INC_RANS` | 7.2.0 | To describe the **Total Pressure** at the inlet, set the option `INC_INLET_TYPE= PRESSURE_INLET`. The format for `MARKER_INLET` then is the marker name, followed by the Temperature (in Kelvin `[K]`), the Total Pressure (in Pascal `[Pa]`) and the flow direction unity vector (in meter per second `[m/s]`). @@ -172,13 +174,13 @@ MARKER_INLET = (inlet1, 300 , 1e6, 1.0, 0.0, 0.0, inlet2, 200, 1e6, 0.0, 1.0, 0. ## Outlet Boundary Condition ## -Outlet boundary conditions are set using the `MARKER_OUTLET` option. +Outlet boundary conditions are set using the `MARKER_OUTLET` option. These are prescribed by computing the Riemann invariants. ### Pressure Outlet (Compressible) ### | Solver | Version | | --- | --- | -| `EULER`, `NAVIER_STOKES`, `RANS`, `FEM_EULER`, `FEM_NAVIER_STOKES` | 7.0.0 | +| `EULER`, `NAVIER_STOKES`, `RANS`, `FEM_EULER`, `FEM_NAVIER_STOKES` | 7.2.0 | To describe the static thermodynamic pressure at an outlet, the format for `MARKER_OUTLET` is the marker name, followed by the value of the static pressure (in Pascal `[Pa]`). @@ -190,7 +192,7 @@ MARKER_OUTLET = (outlet, 1e5) | Solver | Version | | --- | --- | -| `INC_EULER`, `INC_NAVIER_STOKES`, `INC_RANS`| 7.0.0 | +| `INC_EULER`, `INC_NAVIER_STOKES`, `INC_RANS`| 7.2.0 | To describe the pressure at an outlet, set the option `INC_OUTLET_TYPE= PRESSURE_OUTLET`. The format for `MARKER_OUTLET` is the marker name, followed by the value of the gauge pressure (in Pascal `[Pa]`). @@ -205,7 +207,7 @@ MARKER_OUTLET = (outlet, 1e1) | Solver | Version | | --- | --- | -| `INC_EULER`, `INC_NAVIER_STOKES`, `INC_RANS`| 7.0.0 | +| `INC_EULER`, `INC_NAVIER_STOKES`, `INC_RANS`| 7.2.0 | To describe the mass flow at an outlet, set the option `INC_OUTLET_TYPE= MASS_FLOW_OUTLET`. The format for `MARKER_OUTLET` is the marker name, followed by the value of the target mass flow (in kilogramm per second `[kg/s]`). @@ -220,7 +222,13 @@ MARKER_OUTLET = (outlet, 1e1) | Solver | Version | | --- | --- | -| `NAVIER_STOKES`, `RANS`, `INC_NAVIER_STOKES`, `INC_RANS`, `FEM_NAVIER_STOKES` | 7.0.0 | +| `NAVIER_STOKES`, `RANS`, `INC_NAVIER_STOKES`, `INC_RANS`, `FEM_NAVIER_STOKES` | 7.2.0 | + +For two given periodic surfaces `periodic marker` and `donor marker` SU2 defines periodicity by +``` +MARKER_PERIODIC= ( periodic marker, donor marker, rotation_center_x, rotation_center_y, rotation_center_z, rotation_angle_x-axis, rotation_angle_y-axis, rotation_angle_z-axis, translation_x, translation_y, translation_z, ... ) +``` +The same number of points on both surfaces is assumed. Their orientation is specified by the additional set of arguments. For rotational periodicity the parameter `rotation_center_` specifies the coordinates of the center of rotation for the specified axis and `rotation_angle_` defines the rotation angle [in radians] between `periodic marker` and `donor marker` about the specified axis. For translational periodicty the parameter `translation_` specifies the translation between `periodic marker` and `donor marker` in each space direction. ## Structural Boundary Conditions ## @@ -228,7 +236,7 @@ MARKER_OUTLET = (outlet, 1e1) | Solver | Version | | --- | --- | -| `ELASTICITY` | 7.0.0 | +| `ELASTICITY` | 7.2.0 | The format for this boundary condition consists of a list of all clamped surfaces (markers). Structural displacements are set to 0 for the nodes on those surfaces. @@ -242,7 +250,7 @@ MARKER_CLAMPED = (surface_1,...,surface_N) | Solver | Version | | --- | --- | -| `ELASTICITY` | 7.0.0 | +| `ELASTICITY` | 7.2.0 | The displacements of the nodes on `surface` are enforced, the displacement vector is specified by magnitude and direction (the x/y/z components), internally the solver makes the direction unitary, the multiplier (should usually be set to 1) can be used to increase/decrease the magnitude for example after scaling an existing mesh. ``` @@ -255,7 +263,7 @@ MARKER_DISPLACEMENT = (surface, multiplier, magnitude `[m]`, x component, y comp | Solver | Version | | --- | --- | -| `ELASTICITY` | 7.0.0 | +| `ELASTICITY` | 7.2.0 | A force-like boundary condition but specified in terms of pressure (units of Pa) which is integrated to obtain nodal forces. The syntax is identical to `MARKER_DISPLACEMENT`. ``` @@ -268,7 +276,7 @@ MARKER_LOAD = (surface, multiplier, magnitude `[Pa]`, x component, y component, | Solver | Version | | --- | --- | -| `ELASTICITY` | 7.0.0 | +| `ELASTICITY` | 7.2.0 | Normal pressure boundary condition (positive means into the surface). This is a following force both magnitude and direction depend of the deformation of the structure. ``` diff --git a/_docs_v7/Mesh-File.md b/_docs_v7/Mesh-File.md index d9b2d2e7..50e58e67 100644 --- a/_docs_v7/Mesh-File.md +++ b/_docs_v7/Mesh-File.md @@ -147,3 +147,10 @@ It is important to note that SU2 will not use any specific boundary conditions t ## Third-Party Mesh Software We are continuously working to integrate SU2 with industry-standard tools. The latest releases of the Pointwise meshing software can both export and import meshes in the native ASCII SU2 format. In addition, a number of other packages support direct output to the SU2 format, such as GMSH and CENTAUR. CGNS files created by a number of other meshing packages have been successfully tested and used, such as those from ICEM CFD, for instance. + +## Geometry Nomneclature Inside SU2 + +The following image illustrates the primary and dual grid components nomenclature used inside the SU2 code. + +![SU2 geometry definition](../../docs_files/SU2_geometry_nomenclature.png) +*Primary and dual grid nomenclature. Primary grid in black and dual grid in red.* diff --git a/_docs_v7/Physical-Definition.md b/_docs_v7/Physical-Definition.md index c5b36555..040c5e13 100644 --- a/_docs_v7/Physical-Definition.md +++ b/_docs_v7/Physical-Definition.md @@ -25,7 +25,7 @@ SU2 offers different ways of setting and computing this definition. This documen | Solver | Version | | --- | --- | -| `EULER`, `NAVIER_STOKES`, `RANS`, `INC_EULER`, `INC_NAVIER_STOKES`, `INC_RANS`, `FEM_EULER`, `FEM_NAVIER_STOKES` | 7.0.0 | +| `EULER`, `NAVIER_STOKES`, `RANS`, `INC_EULER`, `INC_NAVIER_STOKES`, `INC_RANS`, `FEM_EULER`, `FEM_NAVIER_STOKES` | 7.2.0 | The following table depicts the reference values used by most of the solvers in SU2. The highlighted variables vary depending on the actual solver and the user input. @@ -49,7 +49,7 @@ The following table depicts the reference values used by most of the solvers in | Solver | Version | | --- | --- | -| `EULER`, `NAVIER_STOKES`, `RANS`,`FEM_EULER`, `FEM_NAVIER_STOKES` | 7.0.0 | +| `EULER`, `NAVIER_STOKES`, `RANS`,`FEM_EULER`, `FEM_NAVIER_STOKES` | 7.2.0 | The physical definition for the compressible solvers in SU2 based around the definition of the free-stream. The free-stream values are not only used as boundary conditions for the `MARKER_FAR` option, but also for initialization and non-dimensionalization. That means even if you don't have any farfield BCs in your problem, it might be important to prescribe physically meaningful values for the options. @@ -81,7 +81,7 @@ For all schemes, as reference values for the density and temperature the free-st | Solver | Version | | --- | --- | -| `INC_EULER`, `INC_NAVIER_STOKES`, `INC_RANS` | 7.0.0 | +| `INC_EULER`, `INC_NAVIER_STOKES`, `INC_RANS` | 7.2.0 | The physical definition of the incompressible solvers is accomplished by setting an appropriate flow condition for initialization and non-dimensionalization. SU2 solves the [incompressible Navier-Stokes equations](/docs_v7/Theory/#incompressible-navier-stokes) in a general form allowing for variable density due to heat transfer through the low-Mach approximation (or incompressible ideal gas formulation). diff --git a/_docs_v7/Software-Components.md b/_docs_v7/Software-Components.md index 820aacff..7dd13f7b 100644 --- a/_docs_v7/Software-Components.md +++ b/_docs_v7/Software-Components.md @@ -19,11 +19,11 @@ The key C++ and Python tools in the SU2 software suite are briefly described bel ## C++ Software Modules -- **SU2_CFD (Computational Fluid Dynamics Code)**: Solves direct, adjoint, and linearized problems for the Euler, Navier-Stokes, and Reynolds-Averaged Navier-Stokes (RANS) equation sets, among many others. SU2_CFD can be run serially or in parallel using MPI. It uses a Finite Volume Method (FVM), and an edge-based structure. A Discontinuous-Galerkin Finite Element Method solver is currently being completed and will be available to the public in an upcoming release. Explicit and implicit time integration methods are available with centered or upwinding spatial integration schemes. The software also has several advanced features to improve robustness and convergence, including residual smoothing, preconditioners, and agglomeration multigrid. +- **SU2_CFD (Computational Fluid Dynamics Code)**: Solves direct, adjoint (conitnuous?), and linearized problems for the Euler, Navier-Stokes, and Reynolds-Averaged Navier-Stokes (RANS) equation sets, among many others. SU2_CFD can be run serially or in parallel using MPI. It uses a Finite Volume Method (FVM), and an edge-based structure. A Discontinuous-Galerkin Finite Element Method solver is currently being completed and will be available to the public in an upcoming release. Explicit and implicit time integration methods are available with centered or upwinding spatial integration schemes. The software also has several advanced features to improve robustness and convergence, including residual smoothing, preconditioners, and agglomeration multigrid. - **SU2_DOT (Gradient Projection Code)**: Computes the partial derivative of a functional with respect to variations in the aerodynamic surface. SU2_DOT uses the surface sensitivity, the flow solution, and the definition of the geometrical variable to evaluate the derivative of a particular functional (e.g. drag, lift, etc.). This is essentially a large dot product operation between the adjoint sensitivities and geometric sensitivities for the particular design variable parameterization. - **SU2_DEF (Mesh Deformation Code)**: Computes the geometrical deformation of an aerodynamic surface and the surrounding volumetric grid. Once the type of deformation is defined, SU2_DEF performs the grid deformation by solving the linear elasticity equations on the volume grid. Three-dimensional geometry parameterization is defined using Free Form Deformation, while two-dimensional problems can be defined by both Free From Deformation or bump functions, such as Hicks-Henne. -- **SU2_MSH (Mesh Adaptation Code)**: Performs grid adaptation using various techniques based on an analysis of a converged flow solution, adjoint solution, and linearized problem to strategically refine the mesh about key flow features. This module also contains a preprocessor that creates the appropriate structures for periodic boundary conditions. -- **SU2_SOL (Solution Export Code)**: Generates the volumetric and surface solution files from SU2 restart files. + +- **SU2_SOL (Solution Export Code)**: Generates the volumetric and surface solution files from SU2 restart files from SU2 restart files (although SU2_CFD will output as many formats as requested in the config file). HOW TO USE IT?? - **SU2_GEO (Geometry Definition Code)**: Geometry preprocessing and definition code. In particular, this module performs the calculation of geometric constraints for shape optimization. While they are not C++ modules, two other similar directories included in the source distribution should be mentioned. First, the **SU2_IDE** (Integrated Development Environment) directory contains files associated with various IDEs to aid developers (Eclipse, VisualStudio, Wing, Xcode). Second, the **SU2_PY** directory contains all of the files making up the Python framework, and some of these will be highlighted in a section below. @@ -32,7 +32,8 @@ While they are not C++ modules, two other similar directories included in the so SU2 includes integrated support for Algorithmic Differentiation (AD) based on Operator Overloading to compute arbitrary derivatives. One application of this feature is the discrete adjoint solver that is implemented in SU2. In contrast to the continuous adjoint method, special versions of the modules SU2_CFD and SU2_DOT are required to use this solver. -- **SU2_CFD_AD**: Solves the discrete adjoint equations using a consistent linearization of the flow solver with the help of AD. Although it has additionally the same features as SU2_CFD, using it for other solvers will result in a slight slow-down due to the AD overhead. +- **SU2_CFD_AD**: Solves the discrete adjoint equations using a consistent linearization of the flow solver with the help of AD. It has the same features as SU2_CFD, but using it for direct problems will result in a slow-down due to the AD overhead. +- **SU2_CFD_DIRECTDIFF**: Computes the gradients of an objective function by forward mode of AD. It has the same features as SU2_CFD, but using it for direct problems will result in a slow-down due to the AD overhead. - **SU2_DOT_AD**: The discrete adjoint formulation does not include the influence of the mesh deformation, therefore this module will compute the required partial derivative of the functional with respect to variations in the computational mesh. Instead of SU2_DOT, SU2_DOT_AD uses the volume sensitivities to evaluate the derivative. Finally, the resulting sensitivities on the aerodynamic surface are projected on to the particular design parameterization. ## Python Scripts diff --git a/_docs_v7/Solver-Setup.md b/_docs_v7/Solver-Setup.md index baf046a3..11ec0091 100644 --- a/_docs_v7/Solver-Setup.md +++ b/_docs_v7/Solver-Setup.md @@ -5,6 +5,13 @@ permalink: /docs_v7/Solver-Setup/ This is a basic introduction on how to set up a simulation using SU2. We distinguish between single-zone computations and multi-zone computations. The following considers a single zone only. For an explanation on multi-zone problems, continue with [Basics of Multi-Zone Computations](/docs_v7/Multizone). +Three different types of mathematical problems can be solved in SU2. The type of problem to be solved is specified on the config file by the `MATH_PROBLEM` field. The options are: +`DIRECT`: Also referred to as primal, this is the default when SU2_CFD or SU2_DEF are used. +`DISCRETE_ADJOINT`: A discrete adjoint methodology based on Automatic Differentiation, available for most solvers. +`CONTINUOUS_ADJOINT`: A hand-derived continuous adjoint methodology available only for compressible flows. + +See the [Software Components](/docs_v7/Software-Components/) documentation to determine which software module is required for each problem. + --- - [Defining the Problem](#defining-the-problem) @@ -22,9 +29,11 @@ This is a basic introduction on how to set up a simulation using SU2. We disting | Solver | Version | | --- | --- | -| `ALL`| 7.0.0 | +| `ALL`| 7.2.0 | + +## Direct ## -SU2 is capable of dealing with different kinds of physical problems. The kind of problem is defined by choosing a solver using the `SOLVER` option. A list of possible values and a description can be found in the following table: +SU2 is capable of dealing with different kinds of physical problems. The kind of problem is defined by choosing a solver using the `SOLVER` option. The list of possible values and a description can be found in the following table: | Option Value | Problem | Type | |---|---|---| @@ -40,13 +49,105 @@ SU2 is capable of dealing with different kinds of physical problems. The kind of |`FEM_NAVIER_STOKES`| **Navier-Stokes' equation** | Discontinuous Galerkin FEM | |`MULTIPHYSICS` | Multi-zone problem with different solvers in each zone | - | -Every solver has its specific options and we refer to the tutorial cases for more information. However, the basic controls detailed in the remainder of this page are the same for all problems. +### Turbulence modeling ### + +The turbulence model to be used for RANS and INC_RANS is specified in the config file by the `KIND_TURB_MODEL` option. The current options are `SA` for the Spalart-Allmaras and `SST` for the Mentor Shear Stress Transport. + +Different corrections or variations are implemented for each turbulence model which can be simultaneously used. These are specified in the `TURB_MODEL_CORRECTIONS` option. The default is `NONE` standing for the standalone version. + +``` +% ------------------------- Turbulence modeling -------------------------------% +% +% Turbulence model +KIND_TURB_MODEL= SA +% +% Turbulence model corrections (NONE, SA-EDW, SA-NOFT2, SA-COMP, SA-NEG, SA-QCR2000, SST-SUST) +TURB_MODEL_CORRECTIONS= SA-EDW, SA-NEG +``` + +#### Spalart-Allamaras #### +The single transported Spalart-Allmaras variable $\tilde{\nu}$ is initialized with the value at the farfield or inlet boundary. As suggested in the literature, the value there is computed as $\tilde{\nu}/\nu = \mathrm{turb2lam}$. In SU2 the free-stream Spalart-Allmaras variable to kinematic laminar viscosity ratio, $\mathrm{turb2lam}$, is controlled by the `FREESTREAM_NU_FACTOR` option. The default value is $\tilde{\nu}/\nu = 3.0$ avoiding laminar solutions. + +In the following the implemented model versions in SU2 are listed: +`SA-EDW` refers to the so-called Edwards modification. +`SA-NOFT2` refers to the modification where the $f_{t2}$ term is set to zero, i.e., $c_{t3} = 0$. +`SA-COMP` refers to the Mixing Layer Compressibility modification. +`SA-NEG` refers to the negative Spalart-Allmaras modification. +`SA-QCR2000` refers to the Quadratic Constitutive Relation modification, 2000 version. + +An extension of SU2 includes and hybrid turbulence model: the Spalart-Allmaras original model with Detached-Eddy Simulation (DES) modification. Refer to Eduardo Moina's thesis? Four different techniques are currently implemented: + +`SA_DES` Detached-Eddy Simulation +`SA_DDES` Delayed Detached-Eddy Simulation +`SA_ZDES` Zonal Detached-Eddy Simulation +`SA_EDDES` Enhanced Detached-Eddy Simulation + +In the config file the hybrid RANS/LES model is specified by the `HYBRID_RANSLES` field. The DES constant can be parametrized by the field `DES_CONST`, with 0.65 as default. + +#### Menter’s k-omega SST Model #### +As initial conditions, the values of are initialized at all grid point with the farfield values. The farfield conditions for $k$ and $omega$ are +The freestream turbulence kinetic energy value is set by the `FREESTREAM_TURBULENCEINTENSITY` field. The default value 0.05 which corresponds to a 5%. + +The freestream dissipation is set by the `FREESTREAM_TURB2LAMVISCRATIO` field. The same definition as for `FREESTREAM_TURBULENCEINTENSITY` applies. + +##### Limitations of k and omega ##### +To increase robustness and prevent negative values, a hard-coded upper and lower limit are set for each turbulent variable: +``` +// turbulence kinetic energy +lowerlimit = 1.0e-10; +upperlimit = 1.0e10; + +// +lowerlimit = 1.0e-4; +upperlimit = 1.0e15; +``` +Further, by the model definition in the farfield region there is no production of $k$ nor $\omega$ while destruction still takes place. Consequently the turbulence quantities typically decay on their way from the farfield boundary to the airfoil. In order to prevent the non-physical decay in SU2 there are implemented to two approaches: +- Sustaining terms: it consists on the introduction of additional source terms in the turbulence model equations compensating the destruction terms in the farfield flow. This approach is activated by using the modified version of the SST moodel, `SST-sust`. +- Floor values: this approach is equivalent to setting the lowerlimit to the farfield values in the upstream region of an airfoil. The floor values are implemented in the form of fixed values. This correction can be activated with the following parameters in the config file: +`TURB_FIXED_VALUES= YES` +`TURB_FIXED_VALUES_DOMAIN= -1.0` +To determine those grid points where the correction should be applied, we compare the dot product of the normalized freestream velocity vector and the grid point coordinates. For those points which dot product result is lower than the specified `TURB_FIXED_VALUES_DOMAIN` value, the turbulence quantities are just set to the farfield values there. Note that although the Spalart-Allmaras turbulence model does not suffer from a decaying turbulence variable, the floor values limitation can also be employed. + +### Foward mode of AD ### +The forward mode of AD capability allows to compute the forward derivatives (see [Advanced AD Techniques](/docs_v7/Advanced-AD-Techniques)) of an specified function with respect to a registered variable/s. If multiple design variables are registered as input, the output will consist on the accumulation. The function to be differentiated can be any of the variables specified as `COEFFICIENT` in the `SetHistoryOutputFields` functions of the flow output classes. To get the derivative, one just needs to write D_< string group name > in the `HISTORY_OUTPUT` field from the config file. Addioiniallty, the field `DIRECT_DIFF` specifies the variable to be registered as an input. In SU2 it is possible to register almost any variable. Currently SU2 has implemented the following variables: + +`D_MACH` Freestream Mach number +`D_AOA` angle of attack +`D_PRESSURE` freestream pressure +`D_TEMPERATURE` freestream temperature +`D_DENSITY` freestream density +`D_TURB2LAM` freestream ratio of turbulent to laminar viscosity +`D_SIDESLIP` sideslip angle +`D_VISCOSITY` freestream laminar viscosity +`D_REYNOLDS` freestream Reynolds number +`D_DESIGN` design?? +`D_YOUNG` Young's modulus +`D_POISSON` Poisson's ratio +`D_RHO` solid density (inertial) +`D_RHO_DL` density for dead loads +`D_EFIELD` electric field + +The execution of this capability is done by the module `SU2_CFD_DIRECTDIFF`. See the [Software Components](/docs_v7/Software-Components/) for further details. + +## Adjoint Formulations ## + +### Discrete adjoint ### + +SU2 can compute the sensitivities of an objective function with respect to the control points defining the shape of the design surface. To get the list of objective functions available in SU2 we address to https://github.com/su2code/SU2/blob/master/Common/include/option_structure.hpp ENUM_OBJECTIVE and Objective_Map to see the proper nomenclature for the config file. DON'T KNOW HOW TO ADDRESS PROPERLY? -## Restarting the simulation ## +The objective function value can be scaled by a weighting factor. This value can be specified in the `OBJECTIVE_WEIGHT` field on the config file. + +### Continuous adjoint ### + +Same as the discrete adjoint but using the continuous adjoint approach :) + +Every solver has its specific options and we refer to the tutorial cases for more information. However, the basic controls detailed in the remainder of this page are the same for all solvers and mathematical problems. + +# Restarting the simulation # | Solver | Version | | --- | --- | -| `ALL`| 7.0.0 | +| `ALL`| 7.2.0 | A simulation can be restarted from a previous computation by setting `RESTART_SOL=YES`. If it is a time-dependent problem, additionally `RESTART_ITER` must be set to the time iteration index you want to restart from: @@ -86,7 +187,7 @@ The option `MATH_PROBLEM` defines whether the direct problem (`DIRECT`, default) | Solver | Version | | --- | --- | -| `ALL`| 7.0.0 | +| `ALL`| 7.2.0 | A simulation is controlled by setting the number of iterations the solver should run (or by setting a convergence critera). The picture below depicts the two types of iterations we consider. @@ -95,11 +196,21 @@ A simulation is controlled by setting the number of iterations the solver should SU2 makes use of an outer time loop to march through the physical time, and of an inner loop which is usually a pseudo-time iteration or a (quasi-)Newton scheme. The actual method used depends again on the specific type of solver. +## Courant-Friedrichs-Lewy number ## + +The Courant-Friedrichs-Lewy number is specified by the `CFL_NUMBER` parameter. It is possible to adapt locally its magnitude on each pseudo-iteration according to the solver residual convergence. To enable this capability, the `CFL_ADAPT` must be set to `YES`. + +The option `CFL_ADAPT_PARAM` controls the adaptative CFL number, which parameters are: factor-down, factor-up, CFL min value, CFL max value and acceptable linear solver convergence. + +If an adaptative CFL number is used, the initial CFL number for the finest grid is set to . The local CFL number increases by until if the solution rate of change is not limited, and acceptable linear convergence is achieved. It is reduced by if rate is limited, there is not enough linear convergence, or the nonlinear residuals are stagnant and oscillatory. It is reset back to when linear solvers diverge, or if nonlinear residuals increase too much. + +No idea about the acceptable parameter? + ## Time-dependent Simulation ## | Solver | Version | | --- | --- | -| `ALL`| 7.0.0 | +| `ALL`| 7.2.0 | To enable a time-dependent simulation set the option `TIME_DOMAIN` to `YES` (default is `NO`). There are different methods available for certain solvers which can be set using the `TIME_MARCHING` option. For example for any of the FVM-type solvers a first or second-order dual-time stepping (`DUAL_TIME_STEPPING-1ST_ORDER`/`DUAL_TIME_STEPPING-2ND_ORDER`) method or a conventional time-stepping method (`TIME_STEPPING`) can be used. @@ -128,7 +239,7 @@ The solver will stop either when it reaches the maximum time (`MAX_TIME`) or the | Solver | Version | | --- | --- | -| `ALL`| 7.0.0 | +| `ALL`| 7.2.0 | A steady-state simulation is defined by using `TIME_DOMAIN=NO`, which is the default value if the option is not present. In this case the number of iterations is controlled by the option `ITER`. @@ -138,7 +249,7 @@ A steady-state simulation is defined by using `TIME_DOMAIN=NO`, which is the def | Solver | Version | | --- | --- | -| `ALL`| 7.0.0 | +| `ALL`| 7.2.0 | Despite setting the maximum number of iterations, it is possible to use a convergence criterion so that the solver will stop when it reaches a certain value of a residual or if variations of a coefficient are below a certain threshold. To enable a convergence criterion use the option `CONV_FIELD` to set an output field that should be monitored. The list of possible fields depends on the solver. Take a look at [Custom Output](/docs_v7/Custom-Output/) to learn more about output fields. Depending on the type of field (residual or coefficient) there are two types of methods: diff --git a/_docs_v7/Streamwise-Periodicity.md b/_docs_v7/Streamwise-Periodicity.md index e239e87b..b63ab837 100644 --- a/_docs_v7/Streamwise-Periodicity.md +++ b/_docs_v7/Streamwise-Periodicity.md @@ -5,7 +5,7 @@ permalink: /docs_v7/Streamwise-Periodicity/ | Solver | Version | | --- | --- | -| `INC_NAVIER_STOKES`, `INC_RANS` | 7.0.0 | +| `INC_NAVIER_STOKES`, `INC_RANS` | 7.2.0 | This page contains an overview of the theory behind streamwise periodic flow and builds upon [Incompressible Navier-Stokes](/docs_v7/Theory/#incompressible-navier-stokes). A tutorial for [Streamwise Periodic Flow](/tutorials/Inc_Streamwise_Periodic/) is available. diff --git a/_docs_v7/Theory.md b/_docs_v7/Theory.md index 3b1ebfd6..8f327a5d 100644 --- a/_docs_v7/Theory.md +++ b/_docs_v7/Theory.md @@ -21,7 +21,7 @@ This page contains a very brief summary of the different governing equation sets | Solver | Version | | --- | --- | -| `NAVIER_STOKES`, `RANS`, `FEM_NAVIER_STOKES` | 7.0.0 | +| `NAVIER_STOKES`, `RANS`, `FEM_NAVIER_STOKES` | 7.2.0 | SU2 solves the compressible Navier-Stokes equations expressed in differential form as @@ -66,7 +66,7 @@ Within the `NAVIER_STOKES` and `RANS` solvers, we discretize the equations in sp | Solver | Version | | --- | --- | -| `EULER`, `FEM_EULER` | 7.0.0 | +| `EULER`, `FEM_EULER` | 7.2.0 | SU2 solves the compressible Euler equations, which can be obtained as a simplification of the compressible Navier-Stokes equations in the absence of viscosity and thermal conductivity. They can be expressed in differential form as @@ -90,7 +90,7 @@ Within the `EULER` solvers, we discretize the equations in space using a finite | Solver | Version | | --- | --- | -| `INC_NAVIER_STOKES`, `INC_RANS` | 7.0.0 | +| `INC_NAVIER_STOKES`, `INC_RANS` | 7.2.0 | SU2 solves the incompressible Navier-Stokes equations in a general form allowing for variable density due to heat transfer through the low-Mach approximation (or incompressible ideal gas formulation). The equations can be expressed in differential form as @@ -137,7 +137,7 @@ Within the `INC_NAVIER_STOKES` and `INC_RANS` solvers, we discretize the equatio | Solver | Version | | --- | --- | -| `INC_EULER` | 7.0.0 | +| `INC_EULER` | 7.2.0 | SU2 solves the incompressible Euler equations as a simplification of the low-Mach formulation above in the absence of viscosity and thermal conductivity (no energy equation is required). The equations can be expressed in differential form as @@ -173,7 +173,7 @@ Within the turbulence solvers, we discretize the equations in space using a fini | Solver | Version | | --- | --- | -| `ELASTICITY` | 7.0.0 | +| `ELASTICITY` | 7.2.0 | For structural analysis of solids in SU2, we solve the elasticity equations in a form allowing for geometric non-linearities expressed as @@ -189,7 +189,7 @@ In the `ELASTICITY` solver, we discretize the equations in space with a nodal fi | Solver | Version | | --- | --- | -| `HEAT_EQUATION_FVM` | 7.0.0 | +| `HEAT_EQUATION_FVM` | 7.2.0 | The governing equation for heat conduction through a solid material can be expressed in differential form as the following: diff --git a/docs_files/SU2_geometry_nomenclature.png b/docs_files/SU2_geometry_nomenclature.png new file mode 100644 index 00000000..5b3373bd Binary files /dev/null and b/docs_files/SU2_geometry_nomenclature.png differ