1. Introduction
In this tutorial, we will be demonstrating how to model a porous medium. We have simulated the flow through the catalytic converter using the Darcy-Forchheimer porosity model. The inlet velocity has been described by a formula that depends on the coordinates. Second-order velocity discretization (Linear Upwind) has been used to increase the accuracy of the simulation.
2. Download SimFlow
SimFlow is a general purpose CFD Software
To follow this tutorial, you will need SimFlow free version, you may download it via the following link:
Download SimFlow
3. Create Case
Open SimFlow and create a new case named catalytic converter
- Click New
- Provide name catalytic converter
- Click Create to open a new case
data:image/s3,"s3://crabby-images/b0d9c/b0d9cfcc854fc799761d6ba7bc7dd006e1209a14" alt="simflow-launcher"
4. Import Geometry
Firstly we need to Download GeometryCatalytic-converter
- Click Import Geometry
- Select geometry file catalytic-converter.stl
- Click Open to import geometry
data:image/s3,"s3://crabby-images/a395b/a395b2ede987e08ae597294b22ba46f4a5ced858" alt="Catalytic converter 02 Import Geometry"
5. Imported Geometry Units
Since the imported geometry is in STL format, which does not store unit information, we need to confirm the unit in which the model was created. In the selection of unit, we can use the Geometry size label, which displays overall size of the model in each direction. In our case, the model was created in millimeters.
- Select mm unit
- Press OK button
data:image/s3,"s3://crabby-images/54e32/54e323f470f4bede0bf36189944004c280a01639" alt="Catalytic converter 02 unit"
6. Geometry - Catalytic Converter
After importing geometry, it will appear in the 3D window.
- Click Fit View to zoom in on the geometry
data:image/s3,"s3://crabby-images/38342/38342d4f72ab1d9503ae5983205d310924302990" alt="Catalytic converter 03 Geometry check"
7. Split Geometry - Catalytic Converter (I)
The imported geometry is made up of a single surface. We need to split it into multiple faces for further processing.
- Expand the Options list for catalytic_converter
- Select Split
data:image/s3,"s3://crabby-images/e0681/e068109d4bf98c0021487429ef14056e5fa0685e" alt="Catalytic converter 06 Geometry split"
8. Split Geometry - Catalytic Converter (II)
In order to split original geometry into separate objects, we will disable Create Single Geometry options:
- Uncheck Create Single Geometry
- Click Split
data:image/s3,"s3://crabby-images/2cb55/2cb5527df02dd654da9262b0a444b8189f6f078c" alt="Catalytic converter 07 Geometry split2"
9. Rename Geometries
To make the resulting mesh boundaries more readable we will rename each geometry face:
- Select catalytic_converter_patch00 from the list. The selected face will be highlighted in the 3D graphic window
- Double click on the name and change it to match the picture below
catalytic_converter_patch00 \(\rightarrow\) inlet - Repeat these steps for the remaining geometry components
catalytic_converter_patch01 \(\rightarrow\) outlet
catalytic_converter_patch02 \(\rightarrow\) wall
data:image/s3,"s3://crabby-images/f4300/f4300f14d9fd88bc71e07e2bae4ab1cf5c5022e4" alt="Catalytic converter 08 Geometry name"
10. Create Geometry - Cell Zone
In this tutorial, we would like to model a porous zone inside the catalytic converter. To do so we need to define the region where the porous resistance will be applied. For this purpose we will create new box geometry:
- Click on Create Box
- Set the origin and box dimensions accordingly
Origin \({\sf [m]}\)-0.085-0.06-0.09
Dimensions \({\sf [m]}\)0.1750.120.18
data:image/s3,"s3://crabby-images/9a66c/9a66ce053937a12cd5f4dd6143999374b6e9a7b1" alt="Catalytic converter 09 Geometry Cell Zone"
11. Meshing Properties - Catalyctic Converter
In order to create the mesh, we need to specify geometries options used during the meshing process.
- Go to Hex Meshing panel
- Enable Mesh Geometry on the inlet outlet wall
- Enable Create Boundary Layer Mesh on wall geometry
- Click on the wall in the listto expand options
- Set No. Of Layers to 4
data:image/s3,"s3://crabby-images/ff685/ff685891fbda6e54f1ad1c1b2b34154dc109a45a" alt="Catalytic converter 10 Meshing parameters 2"
12. Base Mesh - Domain
Now we will define the base mesh. The box geometry determines the background mesh domain. The model is symmetrical on the XZ plane, so we do not need to mesh the whole geometry. Using the box dimensions we will choose only half of the domain.
- Go to Base tab
- Click on Autosize
- Change Max [m] Y to 0
- Define the number of divisions
Division1551750
data:image/s3,"s3://crabby-images/1d05c/1d05cb26bf0d35a5e9de583c41bf96b78ecf22cb" alt="Catalytic converter 11 Mesh Base"
13. Material Point
Material Point tells the meshing algorithm on which side of the geometry the mesh is to be retained. Since we are considering flow inside the catalytic converter we need to place the material point inside the geometry.
- Go to Point tab
- Specify location inside the catalytic converter geometry
Material Point0-0.020
You can specify the point location from the 3D view. Hold the CTRL key and drag the arrows to the destination.
data:image/s3,"s3://crabby-images/30702/30702846f7eb302d4ee0ca1545d2ba4a68eb5950" alt="Catalytic converter 12 Material Point"
14. Start Meshing
Everything is now set up for meshing
- Go to Mesh tab
- Start the meshing process with Mesh button
data:image/s3,"s3://crabby-images/521d2/521d2f8e50080043d4fab17c530e1eb3e70a4100" alt="Catalytic converter 13 Meshing"
15. Mesh
After the meshing process is finished the mesh will appear in the graphics window.
data:image/s3,"s3://crabby-images/adf00/adf0039a5b1c9c7c20022c0f310bc930a068455a" alt="Catalytic converter 14 Mesh"
16. Create Cell Zone (I)
Now we will define the cell zone using box_1 geometry.
- Expand the Options list next to default region
- Select Add Cell Zones
data:image/s3,"s3://crabby-images/43ace/43acedd0d5d89f25d6b8e64bb7988a5e71157797" alt="Catalytic converter 15 Cell Zone"
17. Create Cell Zone (II)
- Check the box_1
- Click on Create Cell Zones
data:image/s3,"s3://crabby-images/c220a/c220a46808c1460ded81ae9889636df997d3eaee" alt="Catalytic converter 16 Cell Zone2"
18. Display Cell Zone
The cell zone appears inside the catalytic converter. It is colored on light blue.
data:image/s3,"s3://crabby-images/6ab88/6ab8852aaa30a47dcfbcabd7e4e6d0acdb97c901" alt="Catalytic converter 17 Mesh"
19. Boundaries
- Change boundary name from boundaries \(\rightarrow\) symmetry
- Define boundary types accordingly
inlet Patch
outlet Patch
symmetry Symmetry
wall Wall
data:image/s3,"s3://crabby-images/a9ef4/a9ef46f6a1670876c1f36c9bafeb776acfaedd76" alt="Catalytic converter 18 Boundaries"
20. Select Solver - SIMPLE
We want to analyze internal, incompressible turbulent flow. For this purpose, we will use the SIMPLE (simpleFoam) solver.
- Go to SETUP panel
- Enable Steady State filter
- Filter the solvers by Incompressible flow
- Pick SIMPLE (simpleFoam) solver
- Select solver
data:image/s3,"s3://crabby-images/983c4/983c46086bab82d90591049b8ef135b90d98a8c5" alt="Catalytic converter 19 Solver v2"
21. Turbulence
For turbulence modeling, we will use the standard \(k-\varepsilon\) model.
- Go to Turbulence panel
- Select RANS for Turbulence Modeling
data:image/s3,"s3://crabby-images/1b023/1b0239341e84462bff304db4a4cc3811e251b9e4" alt="Catalytic converter 20 Turbulence"
22. Transport Properties
We will change the kinematic viscosity to the value of the exhaust gas.
- Go to Transport Properties panel
- Set the kinematic viscosity
\(\nu\) \({\sf [\frac{m^2}{s}]}\)1.272e-04
data:image/s3,"s3://crabby-images/7a886/7a8867b93f601420684f0a4d29f35d54bb37e95a" alt="Catalytic converter 21 Transport properties"
23. Cell Zones - Porosity
In order to include porosity to our simulation we have to define porosity for the box_1 cell zone.
- Go to Cell Cones panel
- Select the box_1 zone
- Check Porous Zone
- Use default Darcy-Forchheimer model and set its parameters accordingly
d \({\sf [\frac{1}{m^2}]}\)3e-073e-103e-10
f \({\sf [\frac{1}{m}]}\)202000020000
data:image/s3,"s3://crabby-images/90101/90101e94a2190df0164274c9473e641bcdf1fef9" alt="Catalytic converter 22 Cell Zone Porosity"
24. Parameters - R, U
SimFlow allows users to create named parameters that can be used instead of numbers. This allows to easily change a single property without the need to edit all inputs where a given property is used. In this tutorial, we will define two global parameters that we will use during further setup.
- Go to Parameters panel
- Definethe new parameter
Name R Formula 0.025 - Click Create Parameter
- Repeat these steps for the second parameter
Name U Formula 20
The newly created parameters will be shown in the parameters list.
data:image/s3,"s3://crabby-images/e1d18/e1d18e73ee951ec4333ebcdb85436128531b439f" alt="Catalytic converter 23 Parameters"
25. Boundary Conditions - Inlet (Flow)
We will set inlet velocity as a parabolic profile. The profile we will define by the formula using U and R parameters. Velocity magnitude near the wall will be equal to zero and the highest value of U will be in the center of the pipe.
- Go to Boundary Conditions panel
- Select the inlet boundary
- Set the Velocity Inlet character
- Change the velocity type and value accordingly
U Type Fixed Value
U Value \({\sf [\frac{m}{s}]}\)U*( (R-sqrt(y^2 +z^2 ))/R)^(1/7)00
data:image/s3,"s3://crabby-images/df468/df4688f9d4669a988c1f6047d546fab888625d24" alt="Catalytic converter 24 BC Inlet"
26. Save Case
To visualize and check velocity distribution we will open ParaView. Firstly we will save the case.
- Go to RUN panel
- Press Save Case button
data:image/s3,"s3://crabby-images/f22da/f22da267e3ca343132361102305e1c3f3a181404" alt="Catalytic converter 25 Save step"
27. Check Velocity Profile - ParaView (I)
Run the ParaView from the Postprocessing panel.
- Go to POSTPROCESSING panel
- Click on Run ParaView
data:image/s3,"s3://crabby-images/17147/171478d0ad800f92e6b91f267a7768a13d857691" alt="Catalytic converter 26 Velocity check ParaView"
28. Check Velocity Profile - ParaView (II)
We will display a velocity magnitude map on the inlet.
- Make sure that catalytic_converter is selected
- Press Apply
- Uncheck Skip Zero Time
- Press Refresh
- Press Apply
- Select velocity U from the list
data:image/s3,"s3://crabby-images/7a341/7a341b5f0bbe965d524af2bcc82f4e95cf0d9bf6" alt="Catalytic converter 27 Velocity check ParaView2 v2"
29. Boundary Conditions - Inlet (Turbulence)
Back in SimFlow, we will also update the turbulent mixing length for the ε-equation at the inlet.
- Go to Boundary Conditions panel
- Select inlet boundary
- Switch to Turbulence tab
- Set the value of Mixing Length to 7% of inlet diameter
\(\varepsilon\) Mixing Length \({\sf [m]}\)0.07*2*R
data:image/s3,"s3://crabby-images/4ccef/4ccef74cd3b016c76c9b5dbe4c46f83c3dc7d51b" alt="Catalytic converter 28 Inlet Turbulence"
30. Initial Conditions - Potential
In order to give a better initial guess for velocity and pressure fields, we will use the "Potential" initialization feature. This utility solves pseudo potential flow prior to actual calculations.
- Go to Initial Conditions panel
- Switch to Potential tab
- Check the Initialize Potential Flow
- Set No. of correctors to 10
data:image/s3,"s3://crabby-images/34f08/34f080a229975218b962458ab3c22fbaa82067be" alt="Catalytic converter 29 Initial Conditions"
31. Monitors - Boundary
We would like to monitor how results change during computation. We will enable plotting the average pressure at the inlet during the calculation:
- Go to Monitors panel
- Switch to Boundary tab
- Expand Fields list next to inlet boundary
- Check the pressure p
data:image/s3,"s3://crabby-images/eaf03/eaf03b79fedfa073f9f9fca85e6b586921fd5513" alt="Catalytic converter 30 Monitors Boundary"
32. Monitors - Sampling
We will also display intermediate results on a section plane.
- Go to Sampling tab
- Add new Slice
- Set the normal vector
Normal \({\sf [-]}\)010 - Expand Fields menu
- Choose the pressure p and the velocity U to be sampled on the section plane
data:image/s3,"s3://crabby-images/1a0bd/1a0bd247948bf66bbd69b1f57bef18de57bd24c4" alt="Catalytic converter 31 Monitors Slice"
33. Run - Time Control
- Go to RUN panel
- Set the maximal Numbers of Iterations to 300
data:image/s3,"s3://crabby-images/4c5be/4c5befd9f592999387775019f8c31dc1531c7a44" alt="Catalytic converter 32 Time Controls"
34. Run - Output
In this tutorial, we run a steady-state simulation. We are only interested in the latest time step. However, it is advised to keep the previous time step result as a backup on the disk. We will make a backup every 50 iterations.
- Switch to Output tab
- Set the Interval [-] to 50
data:image/s3,"s3://crabby-images/1514a/1514a9e6f84fe0cf75d8e3e84897b8199db28412" alt="Catalytic converter 33 RUN"
35. Run - CPU
To speed up the calculation process, take advantage of parallel computing and increase the number of CPUs based on your PC’s capability. The free version allows you to use only one processor (serial mode). To get the full version, you can use the contact form to Request 30-day Trial
Estimated computation time for serial mode: 8 minutes
- Switch to CPU tab
- Click Run Simulation button
data:image/s3,"s3://crabby-images/44ad5/44ad5387396b164019c7a833691a80624b2cfbdd" alt="run cpu serial"
36. Control Inlet Pressure
Go to the p on inlet tab to observe convergence process.
- Switch to p on inlet tab
data:image/s3,"s3://crabby-images/b1c78/b1c786543ca96ba57d924a83c40e0cd5d4332656" alt="Catalytic converter 34 P on inlet"
37. Discretization
After preliminary calculation, we will continue with a more accurate algorithm. Change velocity discretization to the Linear Upwind scheme to minimize numerical diffusion affecting results of the simulation.
- Go to Discretization panel
- Switch to Convection tab
- Click on Upwind to extend the list
- Select Linear Upwind
data:image/s3,"s3://crabby-images/e7b50/e7b5015fef05d4455700174c1f731ad8f49dc4ca" alt="Catalytic converter 35 Discretization"
38. Run - Continue Simulation
- Go to RUN panel
- Set the maximal Numbers of Iterations to 2000
- Click Continue Simulation button
data:image/s3,"s3://crabby-images/011cf/011cfed1b8d1866e61d85bd593f4eb3e65d2e77a" alt="Catalytic converter 36 RUN2"
39. Control Inlet Pressure - New Scheme
Go back to the p on inlet tab and observe convergence process.
- Switch to p on inlet tab
- Control the convergence of the pressure on the inlet
data:image/s3,"s3://crabby-images/59751/597511d10bf2ed72a27c8b15eeabbb9d917960e6" alt="Catalytic converter 37 P on inlet"
40. Slice - View Velocity Field
Slices tab appears next to the Residuals tab. Under this tab, we can preview results on the defined section plane.
- Change tab to Slices
- Select the velocity U
- Click Adjust range to data
- Click Fit View
- Set the XZ orientation View XZ
data:image/s3,"s3://crabby-images/cf5b4/cf5b42635011c86fd1d6ad7f63d1274e7281508b" alt="Catalytic converter 38 Slice Velocity"
41. Slice - Final Results
At the end, we will look at the pressure distribution. The Darcy porous model assumes resistance and hence pressure gradient to be proportional to the velocity in the porous zone. We can observe the effect of increased resistance from the porous zone. The pressure builds up in front of the porous zone and then linearly decreases along the flow direction due to resistance.
data:image/s3,"s3://crabby-images/bf0ac/bf0ac6cc48f22dd8c24c363243c95c90077eb1c6" alt="Catalytic converter 39 Results"
42. Advanced Postprocessing with ParaView
This concludes the tutorial, covering all the aspects we intended to showcase. To create a finely tuned presentation of the results, you may take advantage of the seamless integration with ParaView. You can easily open simulation results in ParaView with a single click from SimFlow.
In ParaView, you can perform typical and advanced postprocessing tasks such as displaying streamlines, contour plots, vector fields, line or time plots, and calculating volume or surface integrals.
To familiarize yourself with the ParaView capabilities, it’s worth checking out our video tutorial, Paraview CFD Tutorial - Advanced Postprocessing in ParaView, in which we demonstrate some of the most commonly used post-processing techniques.