Code for EARSM by Hellsten and RSM by Manceau, square duct, 2d turbulent channel
under the link
you can download some codes and tutorials of turbulence models I implemented in OpenFOAM for different versions. They are implemented for incompressible flow (simpleFoam, pisoFoam,...). I validated them at serveral cases (2d channel, square duct, annular pipe flow, rod bundles).
Code: nonlinear algebraic stress model ( EARSM ) by Hellsten and two validationcases: channel flow and square duct. Good agreement of the velocity profile at the 2d channel. The uv Reynolds stress is good (even for a annular pipe flow). (uu, vv, ww) are too low.
Pic: Attachment 23602
Code: Reynolds stress model ( RSM ) by Manceau and the same two validation cases. Good agreement of velocity profiles, Reynolds stresses and secondary flows (see the pics)
RSM: Reynolds stress profiles of a 2d channel
RSM: Square Duct
Post-Processing yplus: To check the y+ values: post-processing tool to calculate them using low Reynolds models.
Good luck ;)
thank you very much for providing your files!
I am interested in your square duct simulation using the Reynolds-stress model you implemented. Unfortunately, the link to the case setup (OF211_RSM_Manceau_quadchannel) doesn't work correctly (it's linked to the EARSM case). I wonder if you could fix it or upload your case folder here, since I have some problems with setting the right boundary conditions / fvSchemes.
Thank you in advance!
I have uploaded it now.
Try following link:
thank you very much for your reply. Could you also upload the 3D case of a square duct (OF211_RSM_Manceau_quadchannel) or do you use the same boundary conditions and fvSchemes as for the 2D channel?
Furthermore, I have some questions concerning the 2D case you've just uploaded.
What kind of boundary condition do you use for epsilon? Do you calculate the values for epsilon a priori and impose them as fixedValue?
Is the initialization of the flow field important?
If I get it right, there is no need for any lowReWallfunctions when using your code?
here is the correct link for the quad-channel.
It is a low Reynolds-number model with a elliptic factor, no damping functions are necessary... epsilon is calculated by a correction-function within the code. Its put to fixed value, but every time step the boundary values are updated.
I made pre-simulations with the Launder-Sharma-model and used the results as starting conditions, because of the model is very sensitive.
Of course, you have to correct the boundary conditions.
You must read the papers of Manceau to understand the code. (an improved version ....)
thank you once again. You helped me a lot!
I've tried your quadchannel case and it works fine if I run it on a single core. Since I'd like to test it also on a bigger case I'll need to run it in parallel. The problem is that the case cannot be decomposed and it returns me the following error:
Would you please write down exact reference to works of Manceau and Hellsten? I am not sure about title of the papers.
Expressing the production term 'G'
Thanks for the code!
Thanks for sharing your code and the results.
Has anybody managed to compile the EARSM code for newer openfoam versions?
I have been struggling with it for some time without any success.
Here are some infos; bit late ;)
the EARSM from Hellsten is the version from his Dissertation:
new two equation turbulence model for aerodynamics applications.
The RSM by Manceau should be the one from the paper:
AN IMPROVED VERSION OF THE ELLIPTIC BLENDING MODEL
APPLICATION TO NON-ROTATING AND ROTATING CHANNEL FLOWS
I'm working with Remi Manceau now, your code is helpful a lot :)
The current version of the code is not robust.
You need to make it stable.
Split the anisotoropy tensor to deviatic and diagonal and use Sp in deviatic part! check the implementation of Spezial-Sarkar-Gatski RSM as well.
This is my REq:
+ fvm::div(phi_, R_)
//+ fvm::SuSp(-fvc::div(phi_), R_)
- fvm::Sp(fvc::div(phi_), R_)
- fvm::laplacian(nu(), R_)
- fvm::laplacian(CMu/sigmak*TEBM*R_,R_) //anisotrope SSG-Modellierung
+ fvm::Sp(anisotrope, R_)
- fvm::Sp(epsilonterm1, R_)
If you have problem with it contact me!
|All times are GMT -4. The time now is 00:41.|