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. 一些constrainPressure的疑问

一些constrainPressure的疑问

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

    先贴icofoam中的一段代码

                adjustPhi(phiHbyA, U, p);
    
                // Update the pressure BCs to ensure flux consistency
                constrainPressure(p, U, phiHbyA, rAU);
    

    疑问是constrainPressure是做什么用的?有的求解器前面跟了adjustPhi,像icofoam,adjustPhi是修正压力边界使连续性方程有解,有的求解器像buoyantBoussinesqPimpleFoam没有adjustPhi只有constrainPressure。
    再来看constrainPressure的代码

    forAll(pBf, patchi)
        {
            if (isA<fixedFluxPressureFvPatchScalarField>(pBf[patchi]))
            {
                refCast<fixedFluxPressureFvPatchScalarField>
                (
                    pBf[patchi]
                ).updateCoeffs
                (
                    (
                        phiHbyABf[patchi]
                      - rho.boundaryField()[patchi]
                       *MRF.relative(SfBf[patchi] & UBf[patchi], patchi)
                    )
                   /(magSfBf[patchi]*rhorAUBf[patchi])
                );
            }
        }
    }
    

    所以以上代码的意思是压力的边界条件如果是fixedFluxPressure,那么压力的边界面法向梯度等于

    (边界流量 - 边界流量)/网格面积*密度/Uequ.A() ????????这不成0了

    完全一脸茫然??????这干嘛用的,有啥意义呢?

    1 条回复 最后回复
  • 麦迪文麦 离线
    麦迪文麦 离线
    麦迪文
    写于 最后由 编辑
    #2

    。。。。。。自问自答 ,汗

    phiHbyABf不是边界流量。。。。

    所以以下代码应该是符合动量方程,猜测可能是进入压力PISO循环之前修改下边界条件的系数

                    (
                        phiHbyABf[patchi]
                      - rho.boundaryField()[patchi]
                       *MRF.relative(SfBf[patchi] & UBf[patchi], patchi)
                    )
                   /(magSfBf[patchi]*rhorAUBf[patchi])
    
    1 条回复 最后回复

  • 登录

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