This is a tutorial to show you how to setup the heated square cavity tutorial with Salome-CFD and Code Saturne.
Here’s the video:
This tutorial is using Code_Saturne 7.0.4. Some differences might appear if you are using an older or more recent version.
The PDF for this tutorial is available here:
https://www.code-saturne.org/cms/web/sites/default/files/07_HeatedSquareCavityFlow.pdf
The code and model is available here: https://github.com/CyprienRusu/Feaforall/tree/master/Code%20Saturne%20Tutorials/heated_cavity
Main Steps of this Simulation
Create the Model and the Mesh
- 1 m x 1 m x 0.01 m
- element size = 0.0125
- number of elements = 80
- Create groups
data:image/s3,"s3://crabby-images/74b82/74b82430bf59dc6a3679579b7c3933e4915f01d4" alt=""
In Code_Saturne GUI
- Define the Mesh
- Mesh -> Boundary Zones
data:image/s3,"s3://crabby-images/2e71e/2e71e34aee017af12a4e5ce20f892c499578842a" alt=""
- Incompressible
- Laminar
data:image/s3,"s3://crabby-images/f533a/f533a4f0f004baadc1e766b4a329716db63e8976" alt=""
Body Forces > Gravity -9.81 m/s2 for gy
data:image/s3,"s3://crabby-images/f67c3/f67c364ae831e0d6cfb95b6c6502dd68e8fc16e0" alt=""
Volume Conditions -> Activate Initialisation
data:image/s3,"s3://crabby-images/c6d26/c6d26e870ccbb2a80e7cb5f41df13944af7f2e30" alt=""
Density> User Law
Reference = 1.2039 kg/m3
Viscosity
Reference = 1.83e-5 Pa.s
Specific Heat
Cp 1004.84 J/kg/K
Thermal Conductivity
Reference Value Lambda = 0.0259 W/m/K
data:image/s3,"s3://crabby-images/7e5c7/7e5c75304d10e7fb70e8ebe41a54e597a74da322" alt=""
Boundary conditions
- Symmetry Plane -> Symmetry
- Others-> Walls
data:image/s3,"s3://crabby-images/c0112/c011238bb82d8cdaa71380efdfd59e57096bd880" alt=""
- Symmetry planes —> nothing to setup
- Adiabatic Walls —> Prescribed Flux = 0
- Hot Wall —> Prescribed Value = 303.15
- Cold Wall —> Prescribed Value = 293.15
Time Settings
- Time varying (Adaptive)
- Velocity-Pressure Algorithm SIMPLEC
- Number of Time steps = 450
data:image/s3,"s3://crabby-images/64831/648315c5b121723eddf32daf8f91eb43caac0ac1" alt=""
User Routines:
Place the following file in the SRC folder (Link)
Here’s the code for the cs_user_physical_properties user routine (C Language):
void cs_user_physical_properties(cs_domain_t *domain) { CS_NO_WARN_IF_UNUSED(domain); /* Check fields exists */ if (CS_F_(rho) == NULL) bft_error(__FILE__, __LINE__, 0,_("error rho not variable\n")); const cs_lnum_t n_cells = cs_glob_mesh->n_cells; cs_real_t *cpro_rho = CS_F_(rho)->val; const cs_real_t *cvar_temp = CS_F_(t)->val; const cs_real_t *grav = cs_glob_physical_constants->gravity; const cs_real_t ro0 = cs_glob_fluid_properties->ro0; const cs_real_t cp0 = cs_glob_fluid_properties->cp0; const cs_real_t lambda0 = cs_glob_fluid_properties->lambda0; const cs_real_t viscl0 = cs_glob_fluid_properties->viscl0; /* Value of the imposed Rayleigh number */ const cs_real_t Ra = 1.e6; /* The givens of the problem */ const cs_real_t L = 1.0, T_hot = 303.15, T_cold = 293.15; const cs_real_t g = sqrt(cs_math_sq(grav[0]) + cs_math_sq(grav[1]) + cs_math_sq(grav[2])); const cs_real_t beta = lambda0 * viscl0 * Ra / (cs_math_sq(ro0) * cp0 * g * pow(L,3) * (T_hot - T_cold)); /* Compute density in all cells */ cs_real_t min_rho = 1.e15, max_rho = 0.; for (cs_lnum_t cell_id = 0; cell_id < n_cells; cell_id++) { const cs_real_t temp_cell = cvar_temp[cell_id]; cpro_rho[cell_id] = ro0 * (1. - beta * (temp_cell - T_cold)); min_rho = fmin(cpro_rho[cell_id], min_rho); max_rho = fmax(cpro_rho[cell_id], max_rho); } if (cs_glob_rank_id >= 0) { cs_parall_min(1, CS_REAL_TYPE, &min_rho); cs_parall_max(1, CS_REAL_TYPE, &max_rho); } bft_printf("min_rho %f max_rho %f\n", min_rho, max_rho); }
You should now be able to launch the calculation and get results
Results:
data:image/s3,"s3://crabby-images/46cc0/46cc0da5972bde907b49183cb073a97cd69a379e" alt=""
data:image/s3,"s3://crabby-images/27e9e/27e9e869f313adb72a651536f6a53324ed9f6219" alt=""
Check the PDF of the tutorial for more details!
https://www.code-saturne.org/cms/web/sites/default/files/07_HeatedSquareCavityFlow.pdf
The code and model is available here: https://github.com/CyprienRusu/Feaforall/tree/master/Code%20Saturne%20Tutorials/heated_cavity
Hope it helps! Let me know if you have questions!
data:image/s3,"s3://crabby-images/3c175/3c1758a7cd2d322dbda72f79ec1807c41c2fae6d" alt=""
Cyprien “Finally got that Simulation working after so long…” Rusu
Leave a Reply