CFD Online Logo CFD Online URL
www.cfd-online.com
[Sponsors]
Home > Forums > Software User Forums > OpenFOAM > OpenFOAM Post-Processing

How postProcess R works?

Register Blogs Community New Posts Updated Threads Search

Reply
 
LinkBack Thread Tools Search this Thread Display Modes
Old   April 19, 2021, 07:25
Default How postProcess R works?
  #1
New Member
 
Jan
Join Date: Oct 2020
Posts: 11
Rep Power: 6
Kosdalak is on a distinguished road
Hello,

I'm using some RAS models for the same case. After simulating a few 1000 iterations I want to compare the results of these models.

One of the things I want to compare is the Tensor R. With the command "postProcess -func R" it's possible to calculate the Reynolds Stress for the saved time steps. That works no worries so far.

But my question now is, HOW calculates OF this tensor exactly?

Does it just use the nut from each model and calculates it with the following equation or are there other "special" ways?

-\overline{uv} = \nu_t (\frac{\partial U}{\partial y} + \frac{\partial V}{\partial x})



I want to compare four RAS models. The kEpsilon, komegaSST, v2f and the LienCubic. With "special" I mean for example that the LienCubic handles the \overline{uv} diffrent than the other models.

I appriciate all kinds of help or hints!

Thanks in advance and Greetings
Jan
Kosdalak is offline   Reply With Quote

Old   April 21, 2021, 05:54
Default
  #2
Senior Member
 
Andrea
Join Date: Feb 2012
Location: Leeds, UK
Posts: 179
Rep Power: 16
Andrea1984 is on a distinguished road
Hi Jan,

The postProcess framework in OpenFOAM makes use of functionObjects. The "R" option will give you the field returned by the "R" method of the turbulence model that is in use in your case. In fact, I am guessing that the simple command

Code:
postProcess -func R
won't work, because R needs a turbulence model to be evaluated. Hence you have to execute (assuming that your solver is simpleFoam):

Code:
simpleFoam -postProcess -func R
This will instantiate the turbulenceModel object that you need. The field that will be created by
Code:
-postProcess -func R
is the volSymmTensorField returned by the R() method of that turbulenceModel object that is instantiated when you execute your solver.

You can see this in the implementation of the turbulenceFields functionObject in /src/functionObjects/field/turbulenceFields. So the way in which R is calculated in OpenFOAM depends on the turbulence model that you are using in your case.

For linear eddy-viscosity models this is:
Code:
template<class BasicTurbulenceModel>
Foam::tmp<Foam::volSymmTensorField>
Foam::eddyViscosity<BasicTurbulenceModel>::R() const
{
    tmp<volScalarField> tk(k());

    // Get list of patchField type names from k
    wordList patchFieldTypes(tk().boundaryField().types());

    // For k patchField types which do not have an equivalent for symmTensor
    // set to calculated
    forAll(patchFieldTypes, i)
    {
        if
        (
           !fvPatchField<symmTensor>::patchConstructorTablePtr_
                ->found(patchFieldTypes[i])
        )
        {
            patchFieldTypes[i] = calculatedFvPatchField<symmTensor>::typeName;
        }
    }

    return volSymmTensorField::New
    (
        IOobject::groupName("R", this->alphaRhoPhi_.group()),
        ((2.0/3.0)*I)*tk() - (nut_)*dev(twoSymm(fvc::grad(this->U_))),
        patchFieldTypes
    );
}
For non-linear eddy viscosity models, this is:
Code:
template<class BasicTurbulenceModel>
Foam::tmp<Foam::volSymmTensorField>
Foam::nonlinearEddyViscosity<BasicTurbulenceModel>::R() const
{
    tmp<volSymmTensorField> tR
    (
        eddyViscosity<BasicTurbulenceModel>::R()
    );
    tR.ref() += nonlinearStress_;
    return tR;
}
where you can see that there is a contribution due to non-linearity of the model. The nonlinearStress term is evaluated according to the specific non-linear eddy viscosity model that you use. For the Lien cubic kEpsilon this is:

Code:
void LienCubicKE::correctNonlinearStress(const volTensorField& gradU)
{
    volSymmTensorField S(symm(gradU));
    volTensorField W(skew(gradU));

    volScalarField sBar((k_/epsilon_)*sqrt(2.0)*mag(S));
    volScalarField wBar((k_/epsilon_)*sqrt(2.0)*mag(W));

    volScalarField Cmu((2.0/3.0)/(Cmu1_ + sBar + Cmu2_*wBar));
    volScalarField fMu(this->fMu());

    nut_ = Cmu*fMu*sqr(k_)/epsilon_;
    nut_.correctBoundaryConditions();

    nonlinearStress_ =
        fMu*k_
       *(
            // Quadratic terms
            sqr(k_/epsilon_)/(Cbeta_ + pow3(sBar))
           *(
                Cbeta1_*dev(innerSqr(S))
              + Cbeta2_*twoSymm(S&W)
              + Cbeta3_*dev(symm(W&W))
            )

            // Cubic terms
          - pow3(Cmu*k_/epsilon_)
           *(
                (Cgamma1_*magSqr(S) - Cgamma2_*magSqr(W))*S
              + Cgamma4_*twoSymm((innerSqr(S)&W))
            )
        );
}
Hope this clarifies it.
Andrea
Andrea1984 is offline   Reply With Quote

Old   April 21, 2021, 08:09
Default
  #3
New Member
 
Jan
Join Date: Oct 2020
Posts: 11
Rep Power: 6
Kosdalak is on a distinguished road
Hi Andrea,

Thank you very much! That was exactly what I needed to know.
I'm using piso, but it works the same - that I know.



So it is really dependet on which model I use. OF suprises me everytime


For the linear eddy-viscosity models, the code means mathematically the following right?


\overline{(u_i u_j)} = 2/3 \delta_{ij} k - \nu_t ( \frac{\partial U_i}{\partial x_j} + \frac{\partial U_j}{\partial x_i} -2/3 \frac{\partial U_k}{\partial x_k} \delta_{ij} )


I'm still a bit confused about the last term because in the Boussinesq assumption it does not appear. Or where am I failing?

Again, thank you for the detailed answer.

Greetings

Jan
Kosdalak is offline   Reply With Quote

Old   April 22, 2021, 10:41
Default
  #4
Senior Member
 
Andrea
Join Date: Feb 2012
Location: Leeds, UK
Posts: 179
Rep Power: 16
Andrea1984 is on a distinguished road
No worries, glad it helped.

Yes, the equation is the standard expression that you reported for linear eddy-viscosity models for the deviatoric part of the Reynolds Stress tensor.

The term

\frac{2}{3} \frac{\partial U_k}{\partial x_k} \delta_{ij}

is equal to zero for constant-density flows, so you probably should not worry about it.

Andrea
Andrea1984 is offline   Reply With Quote

Old   April 22, 2021, 13:52
Default
  #5
New Member
 
Jan
Join Date: Oct 2020
Posts: 11
Rep Power: 6
Kosdalak is on a distinguished road
Oh yeah, I was not thinking so far.

Thanks again!

Greetings
Jan
Kosdalak is offline   Reply With Quote

Reply


Posting Rules
You may not post new threads
You may not post replies
You may not post attachments
You may not edit your posts

BB code is On
Smilies are On
[IMG] code is On
HTML code is Off
Trackbacks are Off
Pingbacks are On
Refbacks are On


Similar Threads
Thread Thread Starter Forum Replies Last Post
Postprocess utility : I am lost Gearb0x OpenFOAM Post-Processing 4 July 7, 2019 15:27
Viscosity UDF works when interpreted, Doesn't when compiled? bloodflow Fluent UDF and Scheme Programming 4 April 11, 2019 10:06
My UDF works well with Fluent 16 but not with Fluent 19 Ahmed A. Serageldin Fluent UDF and Scheme Programming 3 October 19, 2018 12:38
Why renumbering works for LduMatrix? chengdi OpenFOAM 4 July 31, 2017 19:54
Parallel runs with sonicDyMFoam crashes (works fine with sonicFoam) jnilsson OpenFOAM Running, Solving & CFD 0 March 9, 2012 07:45


All times are GMT -4. The time now is 15:47.