OpenFOAM的fvc::reconstruct(phi)

32 篇文章 30 订阅

用体速度场U生成面速度通量场phi时,用的是fvc::flux(U)的函数,实质上就是fvc::interpolate(U)&mesh.Sf()。反过来,如果phi想要还原回U,则需要用到fvc::reconstruct(phi)了。查看源代码学习处理过程,找到OpenFOAM-x/src/finiteVolume/finiteVolume/fvc/fvcReconstruct.C:

template<class Type>
tmp
<
    GeometricField
    <
        typename outerProduct<vector,Type>::type, fvPatchField, volMesh
    >
>
reconstruct
(
    const GeometricField<Type, fvsPatchField, surfaceMesh>& ssf
)
{
    typedef typename outerProduct<vector, Type>::type GradType;

    const fvMesh& mesh = ssf.mesh();

    surfaceVectorField SfHat(mesh.Sf()/mesh.magSf());

    tmp<GeometricField<GradType, fvPatchField, volMesh>> treconField
    (
        new GeometricField<GradType, fvPatchField, volMesh>
        (
            IOobject
            (
                "volIntegrate("+ssf.name()+')',
                ssf.instance(),
                mesh,
                IOobject::NO_READ,
                IOobject::NO_WRITE
            ),
            inv(surfaceSum(SfHat*mesh.Sf()))&surfaceSum(SfHat*ssf),
            extrapolatedCalculatedFvPatchField<GradType>::typeName
        )
    );

    treconField.ref().correctBoundaryConditions();

    return treconField;
}

输出的treconField就是重构过后的结果。ssf是输入的通量。在初始化treconField时,其计算公式为:

inv(surfaceSum(SfHat*mesh.Sf()))&surfaceSum(SfHat*ssf)

SfHat是每一个面的单位法向矢量,mesh.Sf()经常见到,是面积矢量,方向也是法向的。两者相乘其实就是其面的面积:

\overrightarrow{n}\cdot \overrightarrow{S} = \frac{\overrightarrow S}{\left | \overrightarrow{S} \right |}\cdot \overrightarrow{S}=\frac{\left | \overrightarrow{S} \right |^2}{\left | \overrightarrow{S} \right |}=\left | \overrightarrow{S} \right |

至于为什么不直接用magSf就不清楚了。surfaceSum(SfHat*mesh.Sf())就是这个体元所有面的面积之和。右边surfaceSum(SfHat*ssf)则是体元所有面上的流量之和。inv取逆。因此,体元的值U是包围其体的所有面上的流量之和除以所有面的面积总和求得的。

参考资料:

https://www.openfoam.com/documentation/guides

在OpenFOAM中获取网格详细信息_姜蜉蝣的博客-CSDN博客

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Kino Chan

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值