libmesh解析
本工作只是尝试解析原libmesh的代码,供学习使用
 全部  命名空间 文件 函数 变量 类型定义 枚举 枚举值 友元 
Public 成员函数 | Protected 成员函数 | Protected 属性 | 所有成员列表
libMesh::FunctionBase< Output > 模板类 参考abstract

FunctionBase是一个函数对象的基类,可以在某一点(可选地包括时间)进行评估。 更多...

#include <dirichlet_boundaries.h>

类 libMesh::FunctionBase< Output > 继承关系图:
[图例]

Public 成员函数

 FunctionBase (FunctionBase &&)=default
 这个类的5个特殊函数可以被默认设置。 更多...
 
 FunctionBase (const FunctionBase &)=default
 
FunctionBaseoperator= (const FunctionBase &)=default
 
FunctionBaseoperator= (FunctionBase &&)=default
 
virtual ~FunctionBase ()=default
 
virtual void init ()
 实际的初始化过程。 更多...
 
virtual void clear ()
 清除函数。 更多...
 
virtual std::unique_ptr
< FunctionBase< Output > > 
clone () const =0
 
virtual Output operator() (const Point &p, const Real time=0.)=0
 
void operator() (const Point &p, DenseVector< Output > &output)
 Evaluation function for time-independent vector-valued functions. 更多...
 
virtual void operator() (const Point &p, const Real time, DenseVector< Output > &output)=0
 用于时间无关的矢量值函数的评估函数。 将输出值设置在传入的 output DenseVector 中。 更多...
 
virtual Output component (unsigned int i, const Point &p, Real time=0.)
 
bool initialized () const
 
void set_is_time_dependent (bool is_time_dependent)
 设置函数是否依赖时间的函数。 这仅应该由无法本地确定时间依赖性的子类使用。 在这种情况下,应在构造之后立即使用这个函数。 更多...
 
bool is_time_dependent () const
 

Protected 成员函数

 FunctionBase (const FunctionBase *master=nullptr)
 构造函数。可选地接受一个master。 更多...
 

Protected 属性

const FunctionBase_master
 指向我们的主函数对象的const指针,初始化为 nullptr。 可能存在需要多个函数的情况,但为了节省内存,一个主函数对象可以处理一些集中的数据。 更多...
 
bool _initialized
 init() 被调用以确保一切都准备好后,可以调用 operator() (...) 时为 true。 更多...
 
bool _is_time_dependent
 成员变量用于缓存函数是否真正依赖于时间。 更多...
 

详细描述

template<typename Output>
class libMesh::FunctionBase< Output >

FunctionBase是一个函数对象的基类,可以在某一点(可选地包括时间)进行评估。

FunctionBase的实例代表时间和空间的函数(数学上的意义), $ f(\mathbf{x},t) = \mbox{\texttt{v}} $, 其中 v 可以是 NumberDenseVector<Number>。这个基类的子类实现了不同类型的数据检索,用于这些函数。 使用派生类的构造函数来创建新的对象。每个派生类的必需输入阻碍了常用的 build() 成员的有效使用。 但之后虚成员允许通过 FunctionBase * 进行方便的、与libMesh通用的用法。

注解
对于矢量值变量的函数对象,假定每个分量是连续索引的; 例如,如果 u_var 是一个索引为3的三维矢量值变量,其后是索引为0、1和2的一些标量值变量, 那么libMesh期望 u_var 的x分量位于索引3,y分量位于索引4,z分量位于索引5。
对于三维空间中的二维元素,libMesh期望有2个分量(即mesh_dimension()数量的分量)。
作者
Daniel Dreyer
日期
2003

描述了FunctionBase类,它是一个函数对象的基类,用于表示在空间和时间上的数学函数。 这个类的实例可以表示标量或向量值函数,可以在指定的点和时间上进行评估。不同子类可以实现不同类型的函数对象。 使用派生类的构造函数来创建具体的函数对象。每个派生类的必需输入阻碍了常用的 build() 成员的有效使用, 但之后的虚成员允许通过 FunctionBase * 进行方便的、与libMesh通用的用法。

在文件 dirichlet_boundaries.h44 行定义.

构造及析构函数说明

template<typename Output >
libMesh::FunctionBase< Output >::FunctionBase ( const FunctionBase< Output > *  master = nullptr)
inlineexplicitprotected

构造函数。可选地接受一个master。

参数
master指向主函数对象的指针(可选)。

在文件 function_base.h206 行定义.

206  :
207  _master (master),
208  _initialized (false),
209  _is_time_dependent (true) // 假设我们是时间相关的,直到用户说不是为止
210 {
211 }
const FunctionBase * _master
指向我们的主函数对象的const指针,初始化为 nullptr。 可能存在需要多个函数的情况,但为了节省内存,一个主函数对象可以处理一些集中的数据。
bool _initialized
当 init() 被调用以确保一切都准备好后,可以调用 operator() (...) 时为 true。
bool _is_time_dependent
成员变量用于缓存函数是否真正依赖于时间。
template<typename Output>
libMesh::FunctionBase< Output >::FunctionBase ( FunctionBase< Output > &&  )
default

这个类的5个特殊函数可以被默认设置。

template<typename Output>
libMesh::FunctionBase< Output >::FunctionBase ( const FunctionBase< Output > &  )
default
template<typename Output>
virtual libMesh::FunctionBase< Output >::~FunctionBase ( )
virtualdefault

成员函数说明

template<typename Output>
virtual void libMesh::FunctionBase< Output >::clear ( )
inlinevirtual

清除函数。

这个函数可以用来清除函数对象的状态,以备重新使用。

libMesh::ParsedFunction< Output, OutputGradient >, libMesh::ParsedFunction< T > , 以及 libMesh::AnalyticFunction< Output > 重载.

在文件 function_base.h95 行定义.

95 {}
template<typename Output>
virtual std::unique_ptr<FunctionBase<Output> > libMesh::FunctionBase< Output >::clone ( ) const
pure virtual
template<typename Output >
Output libMesh::FunctionBase< Output >::component ( unsigned int  i,
const Point &  p,
Real  time = 0. 
)
inlinevirtual
返回
用于时间相关的矢量值函数的评估函数,在坐标 p 和时间 time 处的向量分量 i。
注解
子类不需要重写这个函数,因为默认实现基于完整向量评估,通常是正确的。
推荐子类重写这个函数,因为默认实现基于向量评估,通常是不必要的低效率。
默认实现调用带有大小为 i+1 的DenseVector的operator(),如果operator()在该限制之外进行访问,将导致意外行为。
参数
p坐标点。
time时间。
output输出的向量。

libMesh::CompositeFunction< Output >, libMesh::ParsedFunction< Output, OutputGradient >, libMesh::ParsedFunction< T > , 以及 libMesh::WrappedFunction< Output > 重载.

在文件 function_base.h240 行定义.

243 {
244  DenseVector<Output> outvec(i+1);
245  (*this)(p, time, outvec);
246  return outvec(i);
247 }
template<typename Output>
virtual void libMesh::FunctionBase< Output >::init ( )
inlinevirtual

实际的初始化过程。

这个函数可以用来进行函数对象的初始化工作。

libMesh::ParsedFunction< Output, OutputGradient >, libMesh::ParsedFunction< T > , 以及 libMesh::AnalyticFunction< Output > 重载.

在文件 function_base.h89 行定义.

89 {}
template<typename Output >
bool libMesh::FunctionBase< Output >::initialized ( ) const
inline
返回
在坐标 p 和时间 time 处的向量的分量 i。

子类可以选择重写这个函数以提高效率,因为默认实现基于向量评估,通常是不必要的低效率。

参数
i分量的索引。
p坐标点。
time时间。
注解
默认实现调用带有大小为 i+1 的DenseVector的operator(),如果operator() 在该限制之外进行访问,将导致意外行为。

在文件 function_base.h216 行定义.

217 {
218  return (this->_initialized);
219 }
bool _initialized
当 init() 被调用以确保一切都准备好后,可以调用 operator() (...) 时为 true。
template<typename Output >
bool libMesh::FunctionBase< Output >::is_time_dependent ( ) const
inline
返回
当前对象表示的函数是否实际上是时间相关的,是返回 true ,否则返回 false。

这个函数用于查询函数对象是否依赖于时间。有些函数对象的时间依赖性是从外部确定的,因此可以使用这个函数设置。

在文件 function_base.h232 行定义.

参考自 libMesh::CompositeFunction< Output >::attach_subfunction().

233 {
234  return (this->_is_time_dependent);
235 }
bool _is_time_dependent
成员变量用于缓存函数是否真正依赖于时间。
template<typename Output>
virtual Output libMesh::FunctionBase< Output >::operator() ( const Point &  p,
const Real  time = 0. 
)
pure virtual
template<typename Output>
void libMesh::FunctionBase< Output >::operator() ( const Point &  p,
DenseVector< Output > &  output 
)
inline

Evaluation function for time-independent vector-valued functions.

Sets output values in the passed-in output DenseVector.

在文件 function_base.h252 行定义.

254 {
255  // 调用时间相关的函数,时间设为0。
256  this->operator()(p, 0., output);
257 }
virtual Output operator()(const Point &p, const Real time=0.)=0
template<typename Output>
virtual void libMesh::FunctionBase< Output >::operator() ( const Point &  p,
const Real  time,
DenseVector< Output > &  output 
)
pure virtual
template<typename Output>
FunctionBase& libMesh::FunctionBase< Output >::operator= ( const FunctionBase< Output > &  )
default
template<typename Output>
FunctionBase& libMesh::FunctionBase< Output >::operator= ( FunctionBase< Output > &&  )
default
template<typename Output >
void libMesh::FunctionBase< Output >::set_is_time_dependent ( bool  is_time_dependent)
inline

设置函数是否依赖时间的函数。 这仅应该由无法本地确定时间依赖性的子类使用。 在这种情况下,应在构造之后立即使用这个函数。

在文件 function_base.h224 行定义.

225 {
227 }
bool is_time_dependent() const
bool _is_time_dependent
成员变量用于缓存函数是否真正依赖于时间。

类成员变量说明

template<typename Output>
bool libMesh::FunctionBase< Output >::_initialized
protected

init() 被调用以确保一切都准备好后,可以调用 operator() (...) 时为 true。

这个成员变量用于跟踪函数对象是否已经完成初始化,如果已经准备好进行评估,则为 true。

在文件 function_base.h191 行定义.

参考自 libMesh::AnalyticFunction< Output >::AnalyticFunction(), libMesh::ConstFunction< Output >::ConstFunction(), libMesh::ParsedFunction< Output, OutputGradient >::ParsedFunction() , 以及 libMesh::WrappedFunction< Output >::WrappedFunction().

template<typename Output>
bool libMesh::FunctionBase< Output >::_is_time_dependent
protected

成员变量用于缓存函数是否真正依赖于时间。

在文件 function_base.h197 行定义.

参考自 libMesh::CompositeFunction< Output >::attach_subfunction() , 以及 libMesh::ConstFunction< Output >::ConstFunction().

template<typename Output>
const FunctionBase* libMesh::FunctionBase< Output >::_master
protected

指向我们的主函数对象的const指针,初始化为 nullptr。 可能存在需要多个函数的情况,但为了节省内存,一个主函数对象可以处理一些集中的数据。

这个成员变量用于指向主函数对象的指针,有时候多个函数对象需要共享一些数据,可以通过主函数对象来管理。

在文件 function_base.h184 行定义.


该类的文档由以下文件生成: