Installation directory
Let’s start from the installation dirctory, you can use the Linux command “tree” to examine the source code directory organization.
tree -d -L 1 $WM_PROJECT_DIR
This show you the folders in the $WM_PROJECT_DIR
(installation dirctory). You can also find other files in this directory, but most importantly one is Allwmake which compiles all of OpenFOAM by calling other Allwmake scripts. All the directories are introduced as follow:
openFOAM file structure
- applications: The directory contains the source files of all the executables which is created using the C++ libraries. Here is a short description of the directories under applications .
- solvers Contains source code for the distributed solvers.
- tests Contains source code that test and show example of the usage of some OpenFOAM libraries.
- Utilities Contains source code to perform pre- and post-processing tasks involving data manipulations and algebraic manipulations.
note: there is also an Allwmake script, which will compile all the contents of solvers and utilities.
tutorials: Contains tutorials that demonstrate thr usage of all solvers and most of the utilities.
src: The src directory contains several subdirectories which include the the source code for all the libraries. The important folders are:
- finiteVolume This library provides all the classes needed for the finiteVolume discretization, such as the fvMesh class, finiteVolume discretization operators (divergence, laplacian, gradient, and fvc/fvm), and boundary conditions (
fields/fvPatchFields
). IncfdTools/general/include/
you also find the very important file fvCFD.H, which is included in most applications. - OpenFOAM This core library includes the definitions of the containers used for the operations, the field definitions, the declaration of the mesh and of all the mesh features such as zones and sets.
- turbulenceModels Contains many libraries for turbulence models.
- finiteVolume This library provides all the classes needed for the finiteVolume discretization, such as the fvMesh class, finiteVolume discretization operators (divergence, laplacian, gradient, and fvc/fvm), and boundary conditions (
bin: The bin directory contains shell scripts, such as paraFoam,foamNew, foamLog…
doc: The doc directory contains the documentation of OpenFOAM, such as Programmers Guide, User Guide, and Doxygen generated documentation in html format etc.
doc: The doc directory contains the documentation of OpenFOAM, such as Programmers Guide, User Guide, and Doxygen generated documentation in html format etc.
etc: Theetcdirectory contains environment set-up files, global controlDict, and default thermoData.
platforms: Contains the binaries of the applications (bin) and dynamic libraries.
wmake: Compiler settings are included in this directory incluiding optimisation flags. It also contains wmake, a special make command which understand the OpenFOAM file structure.
Case directory (Working diretory)
The basic directory structure for a OpenFOAM case, that contains the minimum set of files required to run an application, is shown in following figure and described as follows:
- constant Contains a full description of the case mesh in a subdirectory polyMesh and files specifying physical properties for the application concerned, e.g. transportProperties.
- system For setting parameters associated with the solution procedure itself. It contains at least the following 3 files: controlDict where run control parameters are set including start/end time, time step and parameters for data output; fvSchemes where discretisation schemes used in the solution may be selected at run-time; and, fvSolution where the equation solvers, tolerances and other algorithm controls are set for the run.
- time (or 0) Containing individual files of data for particular fields, e.g. velocity and pressure. The data can be: either, initial values and boundary conditions that the user must specify to define the problem; or, results written to file by OpenFOAM. The name of each time directory is based on the simulated time at which the data is written. It is sufficient to say now that since we usually start our simulations at time t = 0, the initial conditions are usually stored in a directory named 0 or 0.000000e+00, depending on the name format specified. For example, in the cavity tutorial, the velocity field U and pressure field p are initialised from files 0/U and 0/p respectively.
Run tutorials in OpenFOAM
For OpenFOAM users, tutorials are essential because in most cases you will start your own project by:
- Selecting a solver which implements all necessary physics
- Checking the tutorials available for the solver
- Copying, renaming and modifying the most similar tutorial
- Testing and running your own simulation
However, the tutorial collection contains a variety of different case setups. In the following, three different ways to run these tutorials are introduced.
- Simple blockMesh/mySolverFoam tutorials
- Tutorials with Allrun/Allclean scripts
- Tutorials which require system operations
Thses 3 ways are briefly descrided as follow, see this article for further detail.
Simple blockMesh/mySolverFoam tutorials For a common case such as lid-driven cavity flow (you can find it in
$FOAM_RUN/tutorials/incompressible/icoFoam/cavity/
), the directory contains system, constant, and 0. If no further execution scripts are provided, you will always have to runblockMesh
, for the mesh creation, and afterwards your solver of choice,icoFoam
in our case . A possible scenario is an additional setFieldsDict to set initial field values. The corresponding utility to run afterblockMesh
would besetFields
.blockMesh = >> setFields (if need)= >> icoFoam(choose your solver)
Tutorials with Allrun/Allclean scripts For some complicated cases, automating processes comes naturally within a Linux environment via Shell scripts. Basically, all necessary commands are written into a file which is then executed. In the tutorial collection these scripts are usually called Allrun.
Tutorials which require system operations “System operations” basically means that an application (e.g. a solver) compiles and (hopefully) runs user-supplied C++ source code at runtime. Examples are the #codeStream directive or the codedFixedValue boundary condition.
- Reference: