Skip to content
  • 最新
  • 版块
  • 东岳流体
  • 随机看[请狂点我]
皮肤
  • Light
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • 默认(不使用皮肤)
  • 不使用皮肤
折叠
CFD中文网

CFD中文网

  1. CFD中文网
  2. OpenFOAM
  3. [simpleFoam]、雷诺应力及湍流模型原理

[simpleFoam]、雷诺应力及湍流模型原理

已定时 已固定 已锁定 已移动 OpenFOAM
12 帖子 5 发布者 8.7k 浏览
  • 从旧到新
  • 从新到旧
  • 最多赞同
回复
  • 在新帖中回复
登录后回复
此主题已被删除。只有拥有主题管理权限的用户可以查看。
  • evensunE 离线
    evensunE 离线
    evensun
    写于 最后由 编辑
    #1

    各位老师好,我是一个刚接触湍流模型的萌新,关于simpleFoam和k-epsilon湍流模型有以下问题想请教:
    ①k-epsilon模型是通过k和epsilon两方程解出涡粘系数nut,进而求解雷诺应力使方程封闭对吗,雷诺应力是包含在turbulence->divDevReff(U)这项当中的吗;
    ②在simpleFoam中,UEqn中有turbulence->divDevReff(U)这一项,为什么我在src/TurbulenceModels文件夹下搜索“divDevReff”关键词却没有找到其表达式,只有divDevRhoReff的表达式呢;
    ③以下是我找到的nuEff的表达式,其有nu和nut组成,这是否是湍流模型在求解器计算UEqn时发挥作用的体现呢(不然SIMPLEC算法直接就解出U和p了)

    //- Return the effective viscosity
            virtual tmp<volScalarField> nuEff() const
            {
                return volScalarField::New
                (
                    IOobject::groupName("nuEff", this->alphaRhoPhi_.group()),
                    this->nut() + this->nu()
                );
            }
    

    ④如果在求解器中设置了很多速度,比如U、Ut、Uf等,那么湍流模型在计算的时候,是选择其中的U来计算雷诺应力吗,选择的依据是什么呢;
    我的湍流模型基础较薄弱,希望老师多多指教,感激不尽

    1 条回复 最后回复
  • evensunE 离线
    evensunE 离线
    evensun
    写于 最后由 编辑
    #2

    谢谢各位老师,我找到了相关资料:
    对于线性涡粘模型,divDevReff(U) = divDevRhoReff(U)
    这样问题②就明白啦

    1 条回复 最后回复
  • evensunE 离线
    evensunE 离线
    evensun
    写于 最后由 编辑
    #3

    不好意思各位老师,以上问题我已经全部明白了,以后我会多读代码加深理解的

    羽之下羽 C 2 条回复 最后回复
  • 羽之下羽 离线
    羽之下羽 离线
    羽之下
    在 中回复了 evensun 最后由 编辑
    #4

    @evensun :xinxin2:

    高速旋转机械/旋风分离器/气固分离

    1 条回复 最后回复
  • C 离线
    C 离线
    cccrrryyy 超神
    在 中回复了 evensun 最后由 编辑
    #5

    @evensun 建议搞明白自己的问题后稍微辛苦下把自己的回答也写下来,这样以后别人看到了会有所帮助:146:

    I don't want to survive, I want to thrive.

    evensunE 1 条回复 最后回复
  • evensunE 离线
    evensunE 离线
    evensun
    写于 最后由 编辑
    #6

    雷诺应力确实有一部分包含在turbulence->divDevReff(U)这一项中,在OpenFoam中这一项称为有效雷诺应力,表达式如下
    \begin{equation}
    \mathbf R_\mathrm{eff} = \nu_\mathrm{eff} \left[ \nabla \overline{\mathbf u} + (\nabla \overline{\mathbf u})^\mathsf{T} - \frac{2}{3} (\nabla \cdot \overline{\mathbf u}) \mathbf I \right]
    \end{equation}其中的$\nu_\mathrm{eff}=\nu + \nu_t$,$\nu_t$即为通过k-epsilon模型计算出的涡粘性系数。turbulence->divDevReff(U)在动量方程中,由此湍流模型在求解速度时发挥作用。
    另外关于turbulence->divDevReff(U)这一项的调用,虽然此项在不可压求解器中,但如果采用线性涡粘的湍流模型,调用的是linearViscousStress 中的 divDevRhoReff(U)(可压缩也用这个),具体代码为:

    template<class BasicTurbulenceModel>
    Foam::tmp<Foam::fvVectorMatrix>
    Foam::linearViscousStress<BasicTurbulenceModel>::divDevRhoReff
    (
        volVectorField& U
    ) const
    {
        return
        (
          - fvc::div((this->alpha_*this->rho_*this->nuEff())*dev2(T(fvc::grad(U))))
          - fvm::laplacian(this->alpha_*this->rho_*this->nuEff(), U)
        );
    }
    

    计算时根据括号中的量选择带入计算的是哪个速度。(其中负号是因为定义在系数矩阵等式的右边)
    以上内容整理自OpenFOAM 中的不可压和可压 RANS 方程,网页内容非常详细,要是我早点看到能省不少麻烦:xinlei:

    A 1 条回复 最后回复
  • evensunE 离线
    evensunE 离线
    evensun
    在 中回复了 cccrrryyy 最后由 编辑
    #7

    @cccrrryyy 谢谢老师提醒,我把我理解的内容整理在楼下了:xiezuoye:

    李东岳李 1 条回复 最后回复
  • C 离线
    C 离线
    cccrrryyy 超神
    写于 最后由 编辑
    #8

    感谢,辛苦啦!

    I don't want to survive, I want to thrive.

    1 条回复 最后回复
  • 李东岳李 在线
    李东岳李 在线
    李东岳 管理员
    在 中回复了 evensun 最后由 编辑
    #9

    @evensun 感谢分享。

    你用的是哪个雷诺应力模型?LRR?SSG?

    http://dyfluid.com/index.html
    需要帮助debug算例的看这个 https://cfd-china.com/topic/8018

    evensunE 1 条回复 最后回复
  • evensunE 离线
    evensunE 离线
    evensun
    在 中回复了 李东岳 最后由 编辑
    #10

    @李东岳 我用的是RAS下的k-epsilon。其实目前的工作是在openfoam中植入新的湍流模型,但想通过学习k-epsilon的求解过程来打开思路。

    1 条回复 最后回复
  • A 离线
    A 离线
    AppleKiller
    在 中回复了 evensun 最后由 编辑
    #11

    @evensun 大佬您好,这段代码中的this->alpha_表示什么呢?因为我感觉
    this->rho_*this->nuEff())*dev2(T(fvc::grad(U))
    已经足够表示
    $$\mu^{eff}(\nabla\pmb{U} + \nabla\pmb{U^\top} - \frac{2}{3}\nabla\cdot\pmb{U}\mathcal{I})$$

    A 1 条回复 最后回复
  • A 离线
    A 离线
    AppleKiller
    在 中回复了 AppleKiller 最后由 AppleKiller 编辑
    #12

    问题解决,this->alpha_的定义在

    template
    <
        class Alpha,
        class Rho,
        class BasicTurbulenceModel,
        class TransportModel
    >
    class TurbulenceModel
    :
        public BasicTurbulenceModel
    {
    
    public:
    
        typedef Alpha alphaField;
        typedef Rho rhoField;
        typedef TransportModel transportModel;
    
    
    protected:
    
        // Protected data
    
            const alphaField& alpha_;
            const transportModel& transport_;
         ..........
    }
    

    这里的alpha_应该表示相分数。

    1 条回复 最后回复

  • 登录

  • 登录或注册以进行搜索。
  • 第一个帖子
    最后一个帖子
0
  • 最新
  • 版块
  • 东岳流体
  • 随机看[请狂点我]