Difference between revisions of "OpenFOAM/C3/Introduction-to-SnappyHexMesh/English"
(Created page with 'Tutorial: Introduction to snappyHexMesh in OpenFOAM. Script and Narration: Chaitrali Ghodke. Keywords: Import STL file, background hex mesh, snappyHexMeshDict. {| style="…') |
Nancyvarkey (Talk | contribs) |
||
Line 19: | Line 19: | ||
|- | |- | ||
| style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:none;padding:0.097cm;"| Slide 2 : Learning Objectives | | style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:none;padding:0.097cm;"| Slide 2 : Learning Objectives | ||
− | |||
− | |||
| style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:0.05pt solid #000000;padding:0.097cm;"| In this tutorial, we will learn about | | style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:0.05pt solid #000000;padding:0.097cm;"| In this tutorial, we will learn about | ||
− | * The parameters in '''snappyHexMesh''' to generate '''Mesh''' in '''OpenFOAM'''. | + | * The different parameters in '''snappyHexMesh''' to generate '''Mesh''' in '''OpenFOAM'''. |
− | + | ||
− | + | ||
|- | |- | ||
| style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:none;padding:0.097cm;"| Slide 2: Pre-requisite | | style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:none;padding:0.097cm;"| Slide 2: Pre-requisite | ||
| style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:0.05pt solid #000000;padding:0.097cm;"| As a pre-requisite, the user requires | | style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:0.05pt solid #000000;padding:0.097cm;"| As a pre-requisite, the user requires | ||
− | |||
* Surface data files in '''STL''' format | * Surface data files in '''STL''' format | ||
* A domain with '''hex mesh''' | * A domain with '''hex mesh''' | ||
* '''snappyHexMeshDict''' located in the '''system''' sub-directory of''' case''' | * '''snappyHexMeshDict''' located in the '''system''' sub-directory of''' case''' | ||
− | |||
− | |||
|- | |- | ||
Line 48: | Line 41: | ||
* '''OpenFOAM''' version 2.2.1 | * '''OpenFOAM''' version 2.2.1 | ||
* '''ParaView''' version 3.12.0 | * '''ParaView''' version 3.12.0 | ||
− | |||
− | |||
|- | |- | ||
Line 72: | Line 63: | ||
Type run '''cd OpenFOAM-2.2.2/tutorials/mesh/snappyHexMesh/flange''' | Type run '''cd OpenFOAM-2.2.2/tutorials/mesh/snappyHexMesh/flange''' | ||
− | | style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:0.05pt solid #000000;padding:0.097cm;"| Let us learn, the different parameters in snappyHexMesh to generate mesh in OpenFOAM. | + | | style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:0.05pt solid #000000;padding:0.097cm;"| Let us learn, the different parameters in''' snappyHexMesh''' to generate '''mesh''' in '''OpenFOAM'''. |
To do this, we will open the '''terminal window '''and enter the path for '''flange '''as shown. | To do this, we will open the '''terminal window '''and enter the path for '''flange '''as shown. | ||
Line 86: | Line 77: | ||
|- | |- | ||
| style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:none;padding:0.097cm;"| Type '''ls''' | | style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:none;padding:0.097cm;"| Type '''ls''' | ||
− | |||
− | |||
| style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:0.05pt solid #000000;padding:0.097cm;"| Now type '''ls''' and press '''Enter.''' | | style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:0.05pt solid #000000;padding:0.097cm;"| Now type '''ls''' and press '''Enter.''' | ||
Line 106: | Line 95: | ||
|- | |- | ||
− | | style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:none;padding:0.097cm;"| Type '''gedit snappyHexMeshDict''' | + | | style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:none;padding:0.097cm;"| Type '''gedit space snappyHexMeshDict''' |
+ | |||
+ | (Note that H, M and D here are in capital letters.) | ||
| style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:0.05pt solid #000000;padding:0.097cm;"| To view the contents of the file type - | | style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:0.05pt solid #000000;padding:0.097cm;"| To view the contents of the file type - | ||
− | '''gedit snappyHexMeshDict ''' | + | '''gedit space snappyHexMeshDict ''' |
and press '''Enter.''' | and press '''Enter.''' | ||
− | |||
− | |||
− | |||
|- | |- | ||
Line 149: | Line 137: | ||
|- | |- | ||
| style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:none;padding:0.097cm;"| '''nCellsBetweenLevels''' | | style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:none;padding:0.097cm;"| '''nCellsBetweenLevels''' | ||
− | | style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:0.05pt solid #000000;padding:0.097cm;"| '''nCellsBetweenLevels''' defines number of cells for each refinement level. | + | | style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:0.05pt solid #000000;padding:0.097cm;"| '''nCellsBetweenLevels''' defines number of cells for each '''refinement level'''. |
Line 155: | Line 143: | ||
|- | |- | ||
− | | style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:none;padding:0.097cm;"| Explicit feature edge refinement | + | | style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:none;padding:0.097cm;"| Highlight '''Explicit feature edge refinement''' |
− | | style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:0.05pt solid #000000;padding:0.097cm;"| In the | + | | style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:0.05pt solid #000000;padding:0.097cm;"| In the '''Explicit feature edge refinement''' section, you can set specific '''refinement level''' for geometry’s feature edges. |
Line 166: | Line 154: | ||
− | | style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:0.05pt solid #000000;padding:0.097cm;"| In the ''' | + | | style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:0.05pt solid #000000;padding:0.097cm;"| In the '''Surface-based refinement '''section, you can set the '''refinement levels''' of all surfaces defined in '''geometry''' file. |
|- | |- | ||
| style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:none;padding:0.097cm;"| Mesh selection | | style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:none;padding:0.097cm;"| Mesh selection | ||
− | | style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:0.05pt solid #000000;padding:0.097cm;"| Mesh selection is a very important parameter. | + | | style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:0.05pt solid #000000;padding:0.097cm;"| '''Mesh selection''' is a very important parameter. |
− | If the chosen point is inside the surface described in '''geometry''' file, then '''snappyHexMesh''' will create the internal mesh. | + | If the chosen point is inside the surface described in '''geometry''' file, then '''snappyHexMesh''' will create the internal '''mesh'''. |
− | Otherwise the external part (inside the blockMesh) is meshed. | + | Otherwise the external part (inside the '''blockMesh''') is meshed. |
|- | |- | ||
| style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:none;padding:0.097cm;"| | | style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:none;padding:0.097cm;"| | ||
− | | style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:0.05pt solid #000000;padding:0.097cm;"| The next step involves moving cell vertex points onto the surface geometry. | + | | style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:0.05pt solid #000000;padding:0.097cm;"| The next step involves moving '''cell vertex points''' onto the '''surface geometry'''. |
|- | |- | ||
Line 192: | Line 180: | ||
| style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:0.05pt solid #000000;padding:0.097cm;"| The snapping process is carried out by four parameters: | | style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:0.05pt solid #000000;padding:0.097cm;"| The snapping process is carried out by four parameters: | ||
− | * nSmoothPatch | + | * '''nSmoothPatch''' |
− | * tolerance | + | * '''tolerance''' |
− | * nSolveIter | + | * '''nSolveIter''' |
− | * nRelaxIter | + | * '''nRelaxIter''' |
These parameters control the number of iterations and tolerance between '''mesh''' and '''STL''' surface. | These parameters control the number of iterations and tolerance between '''mesh''' and '''STL''' surface. | ||
Line 201: | Line 189: | ||
|- | |- | ||
| style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:none;padding:0.097cm;"| nSmoothPatch | | style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:none;padding:0.097cm;"| nSmoothPatch | ||
− | | style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:0.05pt solid #000000;padding:0.097cm;"| | + | | style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:0.05pt solid #000000;padding:0.097cm;"| '''nSmoothPatch '''option changes how many times the exterior (the boundary wall) should be iterated. |
− | + | The '''mesh''' will become smoother if the number of iterations are more. | |
− | + | ||
− | + | ||
− | ''' | + | |
− | + | ||
− | + | ||
− | + | ||
|- | |- | ||
| style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:none;padding:0.097cm;"| tolerance | | style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:none;padding:0.097cm;"| tolerance | ||
− | | style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:0.05pt solid #000000;padding:0.097cm;"| | + | | style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:0.05pt solid #000000;padding:0.097cm;"| '''Tolerance''' option changes how long distance the program should look for a point to snap. |
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
Line 226: | Line 203: | ||
|- | |- | ||
| style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:none;padding:0.097cm;"| nSolveIter | | style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:none;padding:0.097cm;"| nSolveIter | ||
− | | style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:0.05pt solid #000000;padding:0.097cm;"| | + | | style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:0.05pt solid #000000;padding:0.097cm;"| '''nSolveIter '''option changes how many times the snapping part of '''snappyHexMesh '''should be run. |
|- | |- | ||
Line 233: | Line 210: | ||
− | | style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:0.05pt solid #000000;padding:0.097cm;"| | + | | style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:0.05pt solid #000000;padding:0.097cm;"| '''nRelaxIter''' option changes how many times the mesh should run a relaxing script, that removes bad '''mesh''' points. |
|- | |- | ||
Line 240: | Line 217: | ||
− | | style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:0.05pt solid #000000;padding:0.097cm;"| The process of mesh layer addition involves shrinking the existing mesh from the boundary and inserting layers of cells. | + | | style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:0.05pt solid #000000;padding:0.097cm;"| The process of '''mesh''' layer addition involves shrinking the existing '''mesh''' from the boundary and inserting layers of cells. |
The group of parameters define the dimensions for layers and surface on which they will be attached. | The group of parameters define the dimensions for layers and surface on which they will be attached. | ||
Line 250: | Line 227: | ||
|- | |- | ||
| style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:none;padding:0.097cm;"| layers | | style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:none;padding:0.097cm;"| layers | ||
− | | style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:0.05pt solid #000000;padding:0.097cm;"| In '''layers''' option, you can define the number of '''layers''' and | + | | style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:0.05pt solid #000000;padding:0.097cm;"| In '''layers''' option, you can define the number of '''layers''' and patch on which attach the '''layers'''. |
− | It must be an STL patch in ''' | + | It must be an STL patch in '''geometry''' menu, and not a user defined region. |
|- | |- | ||
Line 260: | Line 237: | ||
− | | style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:0.05pt solid #000000;padding:0.097cm;"| '''ExpansionRatio''' parameters | + | | style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:0.05pt solid #000000;padding:0.097cm;"| '''ExpansionRatio''' parameters sets the ratio between two subsequent layers. |
|- | |- | ||
Line 304: | Line 281: | ||
− | | style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:0.05pt solid #000000;padding:0.097cm;"| meshQualityControls parameter sets the minimum thresholds to generate mesh in snap and add-layers parts. | + | | style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:0.05pt solid #000000;padding:0.097cm;"| meshQualityControls parameter sets the minimum thresholds to generate mesh in '''snap''' and '''add-layers''' parts. |
Line 310: | Line 287: | ||
− | But sometimes you can deactivate one or more controls to force mesh generation. | + | But sometimes, you can deactivate one or more controls to force '''mesh''' generation. |
|- | |- | ||
| style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:none;padding:0.097cm;"| | | style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:none;padding:0.097cm;"| | ||
− | | style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:0.05pt solid #000000;padding:0.097cm;"| These are the different parameters in '''snappyHexMeshDict'''. | + | | style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:0.05pt solid #000000;padding:0.097cm;"| These are the different parameters in '''snappyHexMeshDict''' file. |
These parameters are important to generate mesh using '''snappyHexMesh''' utility. | These parameters are important to generate mesh using '''snappyHexMesh''' utility. | ||
− | |||
− | |||
− | |||
− | |||
− | |||
|- | |- | ||
Line 336: | Line 308: | ||
| style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:0.05pt solid #000000;padding:0.097cm;"| In this tutorial we learnt : | | style="border-top:none;border-bottom:0.05pt solid #000000;border-left:0.05pt solid #000000;border-right:0.05pt solid #000000;padding:0.097cm;"| In this tutorial we learnt : | ||
− | Different parameteres in '''snappyHexMesh '''to generate mesh in '''OpenFoam'''. | + | Different parameteres in '''snappyHexMesh '''to generate '''mesh''' in '''OpenFoam'''. |
|- | |- |
Revision as of 22:45, 5 July 2014
Tutorial: Introduction to snappyHexMesh in OpenFOAM.
Script and Narration: Chaitrali Ghodke.
Keywords: Import STL file, background hex mesh, snappyHexMeshDict.
|
|
Slide 1 | Hello and welcome to the spoken tutorial on Introduction to snappyHexMesh in OpenFOAM. |
Slide 2 : Learning Objectives | In this tutorial, we will learn about
|
Slide 2: Pre-requisite | As a pre-requisite, the user requires
|
Slide 3:
System Requirement |
To record this tutorial, I am using
|
Slide 4: Methodology for snappyHexMesh
|
There are five steps to create a mesh with the snappyHexMesh utility.
Step 1 : Create a base mesh by using blockMesh utility Step 2 : Refine base mesh Step 3 : Remove unused cells Step 4 : Snap mesh to surface Step 5 : Add layers |
Ctrl+Alt+t simultaneously
Type run cd OpenFOAM-2.2.2/tutorials/mesh/snappyHexMesh/flange |
Let us learn, the different parameters in snappyHexMesh to generate mesh in OpenFOAM.
To do this, we will open the terminal window and enter the path for flange as shown. |
Type run | Type run and press Enter. |
Type cd tutorials/mesh/snappyHexMesh/flange | Type cd tutorials/mesh/snappyHexMesh/flange and press Enter. |
Type ls | Now type ls and press Enter.
|
Type cd system | Type cd space system and press Enter. |
Type ls | Now type ls and press Enter.
|
Type gedit space snappyHexMeshDict
(Note that H, M and D here are in capital letters.) |
To view the contents of the file type -
gedit space snappyHexMeshDict and press Enter. |
This will open up the snappyHexMeshDict file. | |
Let me drag this to the capture area. | |
Slide 5 : | snappyHexMeshDict file contains all the instructions and the entire process revolves around this file. |
Activation rows
|
With the first rows of snappyHexMeshDict, you can activate or skip sections of the process. |
Geometry | In geometry section, all active regions that take part in snappy process can be defined. |
castellatedMeshControls section. | The parameters that govern the process of cell splitting are described in castellatedMeshControls section. |
CastellatedMeshControls | The parameters that are listed below are well explained in snappyHexMeshDict file. |
nCellsBetweenLevels | nCellsBetweenLevels defines number of cells for each refinement level.
|
Highlight Explicit feature edge refinement | In the Explicit feature edge refinement section, you can set specific refinement level for geometry’s feature edges.
|
Surface based refinement
|
In the Surface-based refinement section, you can set the refinement levels of all surfaces defined in geometry file. |
Mesh selection | Mesh selection is a very important parameter.
|
The next step involves moving cell vertex points onto the surface geometry. | |
SnapControls
|
The snapping process is carried out by four parameters:
These parameters control the number of iterations and tolerance between mesh and STL surface. |
nSmoothPatch | nSmoothPatch option changes how many times the exterior (the boundary wall) should be iterated.
|
tolerance | Tolerance option changes how long distance the program should look for a point to snap.
|
nSolveIter | nSolveIter option changes how many times the snapping part of snappyHexMesh should be run. |
nRelaxIter
|
nRelaxIter option changes how many times the mesh should run a relaxing script, that removes bad mesh points. |
addLayerControls
|
The process of mesh layer addition involves shrinking the existing mesh from the boundary and inserting layers of cells.
The group of parameters define the dimensions for layers and surface on which they will be attached. |
relativeSizes | RelativeSizes option (true or false) changes the way to read the parameters. |
layers | In layers option, you can define the number of layers and patch on which attach the layers.
|
expansionRatio
|
ExpansionRatio parameters sets the ratio between two subsequent layers. |
finalLayerThickness
|
FinalLayerThickness parameter sets the thickness of the last layer. |
minThickness | MinThickness parameter sets the minimum allowable thickness of layer. |
Advanced settings
|
Advanced settings is the second group of parameters.
|
featureAngle
|
FeatureAngle is the angle above which the surface will not be extruded. |
==== nRelaxIter ==== | nRelaxIter option changes how many times the mesh will run a relaxing script. |
==== maxFaceThicknessRatio ==== | MaxFaceThicknessRatio option changes the maximum allowable value of aspect ratio. |
meshQualityControls
|
meshQualityControls parameter sets the minimum thresholds to generate mesh in snap and add-layers parts.
|
These are the different parameters in snappyHexMeshDict file.
| |
Let us summarize. | |
Slide 9: Summary
|
In this tutorial we learnt :
Different parameteres in snappyHexMesh to generate mesh in OpenFoam. |
Slide 10: About Spoken tutorials | Watch the video available at this URL:
http://spoken-tutorial.org/What_is_a_Spoken_Tutorial It summarizes the Spoken Tutorial project. If you do not have good bandwidth, you can download and watch it. |
Slide 11:
About Spoken tutorials |
The Spoken Tutorial Project Team
-Conducts workshops using spoken tutorials -Gives certificates to those who pass an online test -For more details, please write to contact@spoken-tutorial.org |
Slide 12:
Acknowledgement
|
Spoken Tutorial is a part of Talk to a Teacher project,
It is supported by the National Mission on Education through ICT, MHRD, Government of India. More information on the same is available at the following URL link http://spoken-tutorial.org/NMEICT-Intro |
About the contributor | This is Chaitrali Ghodke from IIT BOMBAY signing off.
Thanks for joining. |