转载链接:http://xiaopingqiu.github.io/2016/04/02/Boundary-conditions-in-OpenFOAM2/

本篇在上一篇的基础上来解读 OpenFOAM 中的基础边界条件。基础边界条件一般包括三类,一是Dirichlet 边界,二是 Neumann 边界,三是混合 Dirichlet 和 Neumann 的边界。

1.
fixedValue

这个是 OpenFOAM 中的 Dirichlet 边界条件。

  • 构造函数

template<class
Type>

fixedValueFvPatchField<Type>::fixedValueFvPatchField

(

const
fvPatch& p,

const
DimensionedField<Type,
volMesh>& iF,

const
dictionary& dict

)

:

fvPatchField<Type>(p,
iF, dict, true)

{}

熟悉 OpenFOAM 的人都知道, fixedValue 这个边界条件需要用 value 关键字来指定边界的值。value 这个关键字是通过 DimensionedField 类来处理的。 DimensionedField 这个类将读取 value 关键字对应的场的值用来初始化边界上的值。

  • Coefficients

template<class
Type>

tmp<Field<Type>
>
fixedValueFvPatchField<Type>::valueInternalCoeffs

(

const
tmp<scalarField>&

)
const

{

return
tmp<Field<Type>
>

(

new
Field<Type>(this->size(),
pTraits<Type>::zero)

);

}

template<class
Type>

tmp<Field<Type>
>
fixedValueFvPatchField<Type>::valueBoundaryCoeffs

(

const
tmp<scalarField>&

)
const

{

return
*this;

}

这里 "*this" 表示类本身,即当前边界上的值。这个值在上面的构造函数中进行了初始化,所以,可以理解为
valueBoundaryCoeffs
函数返回的正是关键字 "value" 所对应的值。

template<class
Type>

tmp<Field<Type>
>
fixedValueFvPatchField<Type>::gradientInternalCoeffs()
const

{

return
-pTraits<Type>::one*this->patch().deltaCoeffs();

}

template<class
Type>

tmp<Field<Type>
>
fixedValueFvPatchField<Type>::gradientBoundaryCoeffs()
const

{

return
this->patch().deltaCoeffs()*(*this);

}

中的边界条件(二)【转载】">

其中 delta为面心与面所属网格中心的距离的倒数。

从上述系数,可以知道,fixedValue 边界条件对边界的值和梯度值的计算为如下:

中的边界条件(二)【转载】">

这与预期是一致的。

2.
zeroGradient

这个是 OpenFOAM 中的一种特殊的 Neumann 边界条件,即边界的梯度为零。

  • evaluate
    函数

template<class
Type>

void
zeroGradientFvPatchField<Type>::evaluate(const
Pstream::commsTypes)

{

if
(!this->updated())

{

this->updateCoeffs();

}

fvPatchField<Type>::operator==(this->patchInternalField());

fvPatchField<Type>::evaluate();

}

注意,这里的 operator== 与 operator= 的作用是一样的,都是赋值运算,而不是比较。

  • coefficients

template<class
Type>

tmp<Field<Type>
>
zeroGradientFvPatchField<Type>::valueInternalCoeffs

(

const
tmp<scalarField>&

)
const

{

return
tmp<Field<Type>
>

(

new
Field<Type>(this->size(),
pTraits<Type>::one)

);

}

template<class
Type>

tmp<Field<Type>
>
zeroGradientFvPatchField<Type>::valueBoundaryCoeffs

(

const
tmp<scalarField>&

)
const

{

return
tmp<Field<Type>
>

(

new
Field<Type>(this->size(),
pTraits<Type>::zero)

);

}

template<class
Type>

tmp<Field<Type>
>
zeroGradientFvPatchField<Type>::gradientInternalCoeffs()
const

{

return
tmp<Field<Type>
>

(

new
Field<Type>(this->size(),
pTraits<Type>::zero)

);

}

template<class
Type>

tmp<Field<Type>
>
zeroGradientFvPatchField<Type>::gradientBoundaryCoeffs()
const

{

return
tmp<Field<Type>
>

(

new
Field<Type>(this->size(),
pTraits<Type>::zero)

);

}

中的边界条件(二)【转载】">

从上述系数,可以知道,fixedValue 边界条件对边界的值和梯度值的计算为如下:

中的边界条件(二)【转载】">

这与预期是一致的。

3. fixedGradient

这个是
OpenFOAM 中的 Neumann 边界条件,可以指定边界上的梯度值。

  • 构造函数

template<class
Type>

fixedGradientFvPatchField<Type>::fixedGradientFvPatchField

(

const
fvPatch& p,

const
DimensionedField<Type,
volMesh>& iF,

const
dictionary& dict

)

:

fvPatchField<Type>(p,
iF, dict),

gradient_("gradient", dict,
p.size())

{

evaluate();

}

需要读取关键字 "gradient" 对应的值来初始化变量 gradient_。

  • evaluate
    函数

template<class
Type>

void
fixedGradientFvPatchField<Type>::evaluate(const
Pstream::commsTypes)

{

if
(!this->updated())

{

this->updateCoeffs();

}

Field<Type>::operator=

(

this->patchInternalField()
+ gradient_/this->patch().deltaCoeffs()

);

fvPatchField<Type>::evaluate();

}

中的边界条件(二)【转载】">

其中 delta 为面心与面所属网格中心的距离的倒数。

  • coefficients

template<class
Type>

tmp<Field<Type>
>
fixedGradientFvPatchField<Type>::valueInternalCoeffs

(

const
tmp<scalarField>&

)
const

{

return
tmp<Field<Type>
>(new
Field<Type>(this->size(),
pTraits<Type>::one));

}

template<class
Type>

tmp<Field<Type>
>
fixedGradientFvPatchField<Type>::valueBoundaryCoeffs

(

const
tmp<scalarField>&

)
const

{

return
gradient()/this->patch().deltaCoeffs();

}

template<class
Type>

tmp<Field<Type>
>
fixedGradientFvPatchField<Type>::

gradientInternalCoeffs()
const

{

return
tmp<Field<Type>
>

(

new
Field<Type>(this->size(),
pTraits<Type>::zero)

);

}

template<class
Type>

tmp<Field<Type>
>
fixedGradientFvPatchField<Type>::

中的边界条件(二)【转载】">

4.
mixed

这是 OpenFOAM 中的混合边界条件。

  • 构造函数

template<class
Type>

mixedFvPatchField<Type>::mixedFvPatchField

(

const
fvPatch& p,

const
DimensionedField<Type,
volMesh>& iF,

const
dictionary& dict

)

:

fvPatchField<Type>(p,
iF, dict),

refValue_("refValue", dict,
p.size()),

refGrad_("refGradient",
dict, p.size()),

valueFraction_("valueFraction",
dict, p.size())

{

evaluate();

}

需要读取三个参数。

  • Evaluate

template<class
Type>

void
mixedFvPatchField<Type>::evaluate(const
Pstream::commsTypes)

{

if
(!this->updated())

{

this->updateCoeffs();

}

Field<Type>::operator=

(

valueFraction_*refValue_

+

(1.0 -
valueFraction_)*

(

this->patchInternalField()

+
refGrad_/this->patch().deltaCoeffs()

)

);

fvPatchField<Type>::evaluate();

}

中的边界条件(二)【转载】">

  • Coefficients

template<class
Type>

tmp<Field<Type>
>
mixedFvPatchField<Type>::valueInternalCoeffs

(

const
tmp<scalarField>&

)
const

{

return
Type(pTraits<Type>::one)*(1.0 -
valueFraction_);

}

template<class
Type>

tmp<Field<Type>
>
mixedFvPatchField<Type>::valueBoundaryCoeffs

(

const
tmp<scalarField>&

)
const

{

return

valueFraction_*refValue_

+ (1.0 -
valueFraction_)*refGrad_/this->patch().deltaCoeffs();

}

template<class
Type>

tmp<Field<Type>
>
mixedFvPatchField<Type>::gradientInternalCoeffs()
const

{

return
-Type(pTraits<Type>::one)*valueFraction_*this->patch().deltaCoeffs();

}

template<class
Type>

tmp<Field<Type>
>
mixedFvPatchField<Type>::gradientBoundaryCoeffs()
const

{

return

valueFraction_*this->patch().deltaCoeffs()*refValue_

+ (1.0 -
valueFraction_)*refGrad_;

}

中的边界条件(二)【转载】">

附注:本篇中所有的下标
pp 都表示当前边界(present boundary patch),下标 CC 表示当前边界所属的网格的中心。

OpenFOAM 中的边界条件(二)【转载】的更多相关文章

  1. OpenFOAM 中的边界条件(一)【转载】

    链接:http://xiaopingqiu.github.io/2016/04/02/Boundary-conditions-in-OpenFOAM1/ 本系列解读 OpenFOAM 中边界条件的实现 ...

  2. 如何在OpenFOAM中增加边界条件【翻译】

    注:如有翻译不妥,还请见谅 翻译自:http://openfoamwiki.net/index.php/HowTo_Adding_a_new_boundary_condition 首先请看:http: ...

  3. OpenFOAM 中边界条件的设定【转载】

    转载自:http://blog.sina.com.cn/s/blog_a0b4201d0102v7jt.html 用习惯了FLUENT的操作界面,再使用OpenFOAM就会觉得非常繁琐.遇到的第一个问 ...

  4. <转载>c++中new一个二维数组

    原文连接 在c++中定义一个二维数组时有多种方式,下面是几种定义方式的说明:其中dataType 表示数据类型,如int  byte  long... 1.dataType (*num)[n] = n ...

  5. C语言中如何将二维数组作为函数的参数传递

    今天写程序的时候要用到二维数组作参数传给一个函数,我发现将二维数组作参数进行传递还不是想象得那么简单里,但是最后我也解决了遇到的问题,所以这篇文章主要介绍如何处理二维数组当作参数传递的情况,希望大家不 ...

  6. C++中的异常处理(二)

    C++中的异常处理(二) 标签: c++C++异常处理 2012-11-24 20:56 1713人阅读 评论(2) 收藏 举报  分类: C++编程语言(24)  版权声明:本文为博主原创文章,未经 ...

  7. C#中的线程二(Cotrol.BeginInvoke和Control.Invoke)

    C#中的线程二(Cotrol.BeginInvoke和Control.Invoke) 原文地址:http://www.cnblogs.com/whssunboy/archive/2007/06/07/ ...

  8. IT公司100题-35- 求一个矩阵中最大的二维矩阵(元素和最大)

    问题描述: 求一个矩阵中最大的二维矩阵(元素和最大).如: 1 2 3 4 5 6 7 8 9 10 1 2 3 4 5 中最大的是: 4 5 9 10   分析: 2*2子数组的最大和.遍历求和,时 ...

  9. c#中的linq二

    c#中的linq二   using System; using System.Collections.Generic; using System.Linq; using System.Text; us ...

随机推荐

  1. 《阿里巴巴 Java 开发规约》自动化检测插件安装及体验

    2017 开春之际,有助于提高行业编码规范化水平的<阿里巴巴 Java 开发手册>首次面世.汇聚阿里集团近万名技术精英的经验知识,这套高含金量的手册一经公开,便引起业界普遍关注和学习. 历 ...

  2. JS权威指南读书笔记(二)

    第四章 表达式和运算符 1 new调用构造函数的过程     a 创建一个新的空对象     b 设置空对象的_proto_指向构造函数原型prototype     c 将这个新对象当做this的值 ...

  3. jQuery的显示和隐藏

    在 jQuery 中可以使用 hide() 和 show() 方法来隐藏和显示 HTML 元素,以及使用 toggle() 方法能够切换 hide() 和 show() 方法. 隐藏例子: <! ...

  4. goroutine并发控制与通信

    转发:https://mp.weixin.qq.com/s/ZlyQHfmoY1lzOoRgFSCOBw 开发go程序的时候,时常需要使用goroutine并发处理任务,有时候这些goroutine是 ...

  5. LInux设置tomcat端口为80

    <Connector port="8080" protocol="HTTP/1.1" connectionTimeout="20000" ...

  6. 虚拟机安装master,克隆slave0、slave1(多台机相连,网络匹配)

    1.在虚拟机中创建一个名叫master的主机 2.创建成功后,打开编辑选项——虚拟网络网络编辑器,填网关 3.打开终端,进入root权限,编写命令 设置虚拟机DNS 4.给master网络配置好后,克 ...

  7. 配置多网卡多IP的方式

    [root@web01 conf.d]# cat ip.conf server {     listen 10.0.0.7:80;     server_name _;       location ...

  8. 部署Nginx网站服务实现访问状态统计以及访问控制功能

    原文:https://blog.51cto.com/11134648/2130987 Nginx专为性能优化而开发,最知名的优点是它的稳定性和低系统资源消耗,以及对HTTP并发连接的高处理能力,单个物 ...

  9. P1280 尼克的任务[区间覆盖dp]

    题目描述 尼克每天上班之前都连接上英特网,接收他的上司发来的邮件,这些邮件包含了尼克主管的部门当天要完成的全部任务,每个任务由一个开始时刻与一个持续时间构成. 尼克的一个工作日为N分钟,从第一分钟开始 ...

  10. m_strcpy

    自己实现strcpy函数 #include <stdio.h> #include <assert.h> //如果它的条件返回错误,则终止程序执行 char *m_strcpy( ...