Difference between revisions of "Getting Started with Simmodeler"
|  (→2D and 1D Boundary Layers) | |||
| (67 intermediate revisions by 4 users not shown) | |||
| Line 1: | Line 1: | ||
| + | ==Goal of using SimModeler== | ||
| + | In this section you will learn how to create a mesh and apply boundary and initial conditions to your <code>translated-model.smd</code> model file from the previous step.  You will save both the model and mesh containing the boundary/initial conditions under new file names, which we will later prepare to be passed into '''Chef'''. | ||
| + | |||
| ==Launching the Software == | ==Launching the Software == | ||
| − | + | First, tunnel to viz002 or viz003 using <code>vglconnect -s viz00x</code>. | |
| + | |||
| + | Then, set your environment as shown in the [https://fluid.colorado.edu/tutorials/tutorialVideos/Convert2Sim_Tutorial.mp4 convert step video]. | ||
| + | |||
| + | Finally, run <code>vglrun simmodeler</code> in your terminal to launch simmodeler. Once SimModeler is opened, select File > Open Model. If you ran <code>vglrun simmodeler</code> while in your working directory, the <code>translated-model.smd</code> file should be immediately available to select and open. | ||
| + | |||
| + | ==Accessing the User Manual== | ||
| + | When launching simmodeler, there is a blue question mark at the top right of the GUI. Click it and then click "launch manual" to open the user manual associated with the version of simmodeler you are using. This gives detailed descriptions of the various attributes and how they are defined to generate the desired mesh. | ||
| − | == | + | ==Surface Meshing== | 
| + | |||
| + | ===2D and 1D Boundary Layers=== | ||
| + | |||
| + | To generate a proper surface mesh, it is important that both 2D and 1D boundary layers are implemented. Note that a 2D Boundary layer is defined on a surface and a 1D Boundary layer is defined on a line. The linked [https://fluid.colorado.edu/tutorials/tutorialVideos/MeshingWingInRoom_1D_2D_BLs.mp4 video] shows both 2D and 1D boundary layers being applied to an airfoil and the mesh that results from these applied attributes. | ||
| + | |||
| + | ===Boundary Layer Mesh Height Grows in X=== | ||
| + | |||
| + | An advanced technique for boundary layer meshing utilizes the "Specific Thicknesses" option of the 2D Boundary Layer attribute in SimModeler. This option can prescribe the boundary layer mesh to grow as it develops along the surface, mimicking the behavior of the boundary layer itself. | ||
| + | |||
| + | # Create a 2D Boundary Layer attribute on the edge where you expect the boundary layer to grow. Select the "Specific Thicknesses" type. | ||
| + | # Select and set the face where you want the boundary layer mesh to propagate into (it should be connected to the selected edge). | ||
| + | # Edit "Layer Thicknesses" and select "Import" in the pop-up window. | ||
| + | #* The imported file should have the thicknesses of each layer of the mesh, growing as a function of x. The example below shows the first and last few lines of such a setup. In this case, the first layer of the mesh is 5e-6 m tall at the beginning of the selected edge. In the geometry file of this example, the beginning of the selected edge starts at 0.25 meters. As you traverse in x, the thickness of the mesh is scaled by a factor of 20. This pattern can be easily extrapolated in an excel file to grow the mesh at a desired rate. | ||
| + | |||
| + | (1)  5.00E-06*(1.0+($x-0.25)*20) <br> | ||
| + | (2)  5.88E-06*(1.0+($x-0.25)*20) <br> | ||
| + | (3)  6.92E-06*(1.0+($x-0.25)*20) <br> | ||
| + | ... <br> | ||
| + | (49) 1.00E-04*(1.0+($x-0.25)*20) <br> | ||
| + | (50) 1.00E-04*(1.0+($x-0.25)*20) <br> | ||
| + | |||
| + | ===Mesh Size and Face Extrusions=== | ||
| + | |||
| + | Two more useful attributes when generating proper surface meshes are defining Mesh Sizes and Face Extrusions on your desired surfaces. Face Extrusions are useful when adding refinement over curved surfaces. This process is well covered in this [https://fluid.colorado.edu/tutorials/tutorialVideos/MeshingWingInRoom_MeshSize_FaceExt.mp4 video]. | ||
| + | |||
| + | ==Volume Meshing== | ||
| ===3D Boundary Layers=== | ===3D Boundary Layers=== | ||
| − | One of the most important aspects of  | + | One of the most important aspects of volume mesh development is generating proper 3D boundary layers. This process is well outlined [https://fluid.colorado.edu/tutorials/tutorialVideos/RajDemo.mp4 here] from around 8:30 to 16:00. Note that all mesh attributes are set up under the "Meshing" tab. | 
| + | |||
| + | ===Mesh Refinement Zones=== | ||
| + | Mesh refinement zones are useful for increasing the grid density within certain volumes of your simulation domain. The linked [https://fluid.colorado.edu/tutorials/tutorialVideos/Mesh_refinement_zone_tutorial.mp4 mesh refinement tutorial] will briefly walk you through how these are implemented. | ||
| + | |||
| + | ==Applying Boundary and Initial Conditions== | ||
| + | A nice description of each of the common BCs used in both the Compressible and Incompressible builds of PHASTA is provided [[SimModeler|here]]. The same video as the [https://fluid.colorado.edu/tutorials/tutorialVideos/RajDemo.mp4 volume meshing step] shows how to apply boundary conditions for an incompressible case starting at around 16:20. This linked [https://fluid.colorado.edu/tutorials/tutorialVideos/BC_tutorial.mp4 video] also shows how the BCs are applied for an incompressible case. Note that the case needs to be called ''geom'' as is done and explained in the tutorial video. Once you are done applying the BC's, it is very important that you save out the model <code>.smd</code> file with these applied boundary conditions. | ||
| + | |||
| + | ==Preferred Units to be used in Simmodeler== | ||
| − | === | + | While SimModeler itself is unitless, it is recommended to use consistent units throughout the model setup. The preferred convention is to use SI units, as shown in the table below. | 
| + | |||
| + | {| class="wikitable" | ||
| + | |+ Preferred units when working in SimModeler | ||
| + | ! Physical Quantity || Suggested Unit | ||
| + | |- | ||
| + | | Velocity || meters per second (m/s) | ||
| + | |- | ||
| + | | Pressure || pascals (Pa) | ||
| + | |- | ||
| + | | Length || meters (m) | ||
| + | |- | ||
| + | | Temperature || kelvin (K) | ||
| + | |- | ||
| + | | Length (for meshing operations) || meters (m) | ||
| + | |- | ||
| + | | Heat Flux || watts per square meter (W/m²) | ||
| + | |} | ||
| + | |||
| + | Using SI units ensures that all physical quantities are interpreted correctly in results. | ||
| + | |||
| + | ==Saving Out the Mesh== | ||
| + | Once you are satisfied with your mesh refinement and have applied boundary/initial conditions to your model, you are ready to generate and save out the final mesh. In the meshing tab, you will want to click ''Generate Mesh''. The default settings will suffice for proper mesh generation. If your grid is large, this step can take some time. Once the grid is finished generating, you will want to save out the generated <code>.sms</code> file as you will need it for the next step in the process.  | ||
| − | + | ==Next Steps  -  Preping for Chef== | |
| + | Once the BCs are successfully implemented, you have saved out a model file with these BCs (<code>.smd</code>), and have generated and saved your mesh grid (<code>.sms</code> file), you are ready to prepare the grid for Chef. To get started on this step, head over to [[Prepping the Grid for Chef]]. | ||
Latest revision as of 13:05, 14 May 2025
Contents
Goal of using SimModeler
In this section you will learn how to create a mesh and apply boundary and initial conditions to your translated-model.smd model file from the previous step.  You will save both the model and mesh containing the boundary/initial conditions under new file names, which we will later prepare to be passed into Chef.
Launching the Software
First, tunnel to viz002 or viz003 using vglconnect -s viz00x.
Then, set your environment as shown in the convert step video.
Finally, run vglrun simmodeler in your terminal to launch simmodeler. Once SimModeler is opened, select File > Open Model. If you ran vglrun simmodeler while in your working directory, the translated-model.smd file should be immediately available to select and open.
Accessing the User Manual
When launching simmodeler, there is a blue question mark at the top right of the GUI. Click it and then click "launch manual" to open the user manual associated with the version of simmodeler you are using. This gives detailed descriptions of the various attributes and how they are defined to generate the desired mesh.
Surface Meshing
2D and 1D Boundary Layers
To generate a proper surface mesh, it is important that both 2D and 1D boundary layers are implemented. Note that a 2D Boundary layer is defined on a surface and a 1D Boundary layer is defined on a line. The linked video shows both 2D and 1D boundary layers being applied to an airfoil and the mesh that results from these applied attributes.
Boundary Layer Mesh Height Grows in X
An advanced technique for boundary layer meshing utilizes the "Specific Thicknesses" option of the 2D Boundary Layer attribute in SimModeler. This option can prescribe the boundary layer mesh to grow as it develops along the surface, mimicking the behavior of the boundary layer itself.
- Create a 2D Boundary Layer attribute on the edge where you expect the boundary layer to grow. Select the "Specific Thicknesses" type.
- Select and set the face where you want the boundary layer mesh to propagate into (it should be connected to the selected edge).
-  Edit "Layer Thicknesses" and select "Import" in the pop-up window.
- The imported file should have the thicknesses of each layer of the mesh, growing as a function of x. The example below shows the first and last few lines of such a setup. In this case, the first layer of the mesh is 5e-6 m tall at the beginning of the selected edge. In the geometry file of this example, the beginning of the selected edge starts at 0.25 meters. As you traverse in x, the thickness of the mesh is scaled by a factor of 20. This pattern can be easily extrapolated in an excel file to grow the mesh at a desired rate.
 
(1)  5.00E-06*(1.0+($x-0.25)*20) 
(2)  5.88E-06*(1.0+($x-0.25)*20) 
(3)  6.92E-06*(1.0+($x-0.25)*20) 
... 
(49) 1.00E-04*(1.0+($x-0.25)*20) 
(50) 1.00E-04*(1.0+($x-0.25)*20) 
Mesh Size and Face Extrusions
Two more useful attributes when generating proper surface meshes are defining Mesh Sizes and Face Extrusions on your desired surfaces. Face Extrusions are useful when adding refinement over curved surfaces. This process is well covered in this video.
Volume Meshing
3D Boundary Layers
One of the most important aspects of volume mesh development is generating proper 3D boundary layers. This process is well outlined here from around 8:30 to 16:00. Note that all mesh attributes are set up under the "Meshing" tab.
Mesh Refinement Zones
Mesh refinement zones are useful for increasing the grid density within certain volumes of your simulation domain. The linked mesh refinement tutorial will briefly walk you through how these are implemented.
Applying Boundary and Initial Conditions
A nice description of each of the common BCs used in both the Compressible and Incompressible builds of PHASTA is provided here. The same video as the volume meshing step shows how to apply boundary conditions for an incompressible case starting at around 16:20. This linked video also shows how the BCs are applied for an incompressible case. Note that the case needs to be called geom as is done and explained in the tutorial video. Once you are done applying the BC's, it is very important that you save out the model .smd file with these applied boundary conditions.
Preferred Units to be used in Simmodeler
While SimModeler itself is unitless, it is recommended to use consistent units throughout the model setup. The preferred convention is to use SI units, as shown in the table below.
| Physical Quantity | Suggested Unit | 
|---|---|
| Velocity | meters per second (m/s) | 
| Pressure | pascals (Pa) | 
| Length | meters (m) | 
| Temperature | kelvin (K) | 
| Length (for meshing operations) | meters (m) | 
| Heat Flux | watts per square meter (W/m²) | 
Using SI units ensures that all physical quantities are interpreted correctly in results.
Saving Out the Mesh
Once you are satisfied with your mesh refinement and have applied boundary/initial conditions to your model, you are ready to generate and save out the final mesh. In the meshing tab, you will want to click Generate Mesh. The default settings will suffice for proper mesh generation. If your grid is large, this step can take some time. Once the grid is finished generating, you will want to save out the generated .sms file as you will need it for the next step in the process. 
Next Steps - Preping for Chef
Once the BCs are successfully implemented, you have saved out a model file with these BCs (.smd), and have generated and saved your mesh grid (.sms file), you are ready to prepare the grid for Chef. To get started on this step, head over to Prepping the Grid for Chef.
