将函数指针封装成FunctionBase对象。 更多...
#include <analytic_function.h>
Public 类型 | |
typedef Output(* | OutputFunction )(const Point &p, const Real time) |
标量返回值函数指针类型。 更多... | |
typedef void(* | OutputVectorFunction )(DenseVector< Output > &output, const Point &p, const Real time) |
矢量返回值函数指针类型。 更多... | |
Public 成员函数 | |
AnalyticFunction (OutputFunction fptr) | |
构造函数。接受标量返回值函数的函数指针。 更多... | |
AnalyticFunction (OutputVectorFunction fptr) | |
构造函数。接受矢量值函数的函数指针。 更多... | |
AnalyticFunction (AnalyticFunction &&)=default | |
该类的5个特殊函数可以为该类默认。 更多... | |
AnalyticFunction (const AnalyticFunction &)=default | |
AnalyticFunction & | operator= (const AnalyticFunction &)=default |
AnalyticFunction & | operator= (AnalyticFunction &&)=default |
virtual | ~AnalyticFunction ()=default |
virtual void | init () override |
初始化函数。检查是否已准备好使用。 更多... | |
virtual void | clear () override |
清理函数。将函数指针重置为nullptr,并标记未准备好使用。 更多... | |
virtual std::unique_ptr < FunctionBase< Output > > | clone () const override |
克隆函数。创建并返回一个与当前实例相同类型的新实例。 更多... | |
virtual Output | operator() (const Point &p, const Real time=0.) override |
重载操作符,用于计算标量值。 更多... | |
virtual void | operator() (const Point &p, const Real time, DenseVector< Output > &output) override |
重载操作符,用于计算矢量值。 更多... | |
void | operator() (const Point &p, DenseVector< Output > &output) |
Evaluation function for time-independent vector-valued functions. 更多... | |
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 |
Public 属性 | |
OutputFunction | _number_fptr |
指向用户提供的函数的指针,该函数在有解析表达式时计算边界值。 更多... | |
OutputVectorFunction | _vector_fptr |
指向用户提供的矢量值函数的指针。 更多... | |
Protected 属性 | |
const FunctionBase * | _master |
指向我们的主函数对象的const指针,初始化为 nullptr。 可能存在需要多个函数的情况,但为了节省内存,一个主函数对象可以处理一些集中的数据。 更多... | |
bool | _initialized |
当 init() 被调用以确保一切都准备好后,可以调用 operator() (...) 时为 true。 更多... | |
bool | _is_time_dependent |
成员变量用于缓存函数是否真正依赖于时间。 更多... | |
将函数指针封装成FunctionBase对象。
该类提供了函数样式的对象,其中用户可以提供返回标量或矢量值的函数指针。 所有重载的虚拟函数在function_base.h中有文档说明。 这个类的目的是允许用户提供函数指针,以便创建一个类,该类的实例可以被用作函数。 它可以处理返回标量或矢量的情况。
在文件 analytic_function.h 第 48 行定义.
typedef Output(* libMesh::AnalyticFunction< Output >::OutputFunction)(const Point &p, const Real time) |
标量返回值函数指针类型。
在文件 analytic_function.h 第 53 行定义.
typedef void(* libMesh::AnalyticFunction< Output >::OutputVectorFunction)(DenseVector< Output > &output, const Point &p, const Real time) |
矢量返回值函数指针类型。
在文件 analytic_function.h 第 62 行定义.
libMesh::AnalyticFunction< Output >::AnalyticFunction | ( | OutputFunction | fptr | ) |
构造函数。接受标量返回值函数的函数指针。
fptr | 标量返回值函数的函数指针。 |
在文件 analytic_function.h 第 158 行定义.
参考 libMesh::FunctionBase< Output >::_initialized.
|
inline |
构造函数。接受矢量值函数的函数指针。
fptr | 矢量返回值函数的函数指针。 |
在文件 analytic_function.h 第 173 行定义.
参考 libMesh::FunctionBase< Output >::_initialized.
|
default |
该类的5个特殊函数可以为该类默认。
|
default |
|
virtualdefault |
|
inlineoverridevirtual |
清理函数。将函数指针重置为nullptr,并标记未准备好使用。
重载 libMesh::FunctionBase< Output > .
在文件 analytic_function.h 第 200 行定义.
|
inlineoverridevirtual |
克隆函数。创建并返回一个与当前实例相同类型的新实例。
实现了 libMesh::FunctionBase< Output >.
在文件 analytic_function.h 第 215 行定义.
|
inlinevirtualinherited |
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.h 第 240 行定义.
|
overridevirtual |
初始化函数。检查是否已准备好使用。
重载 libMesh::FunctionBase< Output > .
在文件 analytic_function.h 第 186 行定义.
|
inlineinherited |
p
和时间 time
处的向量的分量 i。
子类可以选择重写这个函数以提高效率,因为默认实现基于向量评估,通常是不必要的低效率。
i | 分量的索引。 |
p | 坐标点。 |
time | 时间。 |
i+1
的DenseVector的operator(),如果operator() 在该限制之外进行访问,将导致意外行为。 在文件 function_base.h 第 216 行定义.
|
inlineinherited |
true
,否则返回 false。
这个函数用于查询函数对象是否依赖于时间。有些函数对象的时间依赖性是从外部确定的,因此可以使用这个函数设置。
在文件 function_base.h 第 232 行定义.
参考自 libMesh::CompositeFunction< Output >::attach_subfunction().
|
inlineoverridevirtual |
重载操作符,用于计算标量值。
p | 计算点的坐标。 |
time | 时间值,默认为0。 |
实现了 libMesh::FunctionBase< Output >.
在文件 analytic_function.h 第 132 行定义.
|
inlineinherited |
Evaluation function for time-independent vector-valued functions.
Sets output values in the passed-in output
DenseVector.
在文件 function_base.h 第 252 行定义.
|
inlineoverridevirtual |
重载操作符,用于计算矢量值。
p | 计算点的坐标。 |
time | 时间值。 |
output | 计算得到的矢量值。 |
实现了 libMesh::FunctionBase< Output >.
在文件 analytic_function.h 第 146 行定义.
|
default |
|
default |
|
inlineinherited |
设置函数是否依赖时间的函数。 这仅应该由无法本地确定时间依赖性的子类使用。 在这种情况下,应在构造之后立即使用这个函数。
在文件 function_base.h 第 224 行定义.
|
protectedinherited |
当 init()
被调用以确保一切都准备好后,可以调用 operator()
(...) 时为 true。
这个成员变量用于跟踪函数对象是否已经完成初始化,如果已经准备好进行评估,则为 true。
在文件 function_base.h 第 191 行定义.
参考自 libMesh::AnalyticFunction< Output >::AnalyticFunction(), libMesh::ConstFunction< Output >::ConstFunction(), libMesh::ParsedFunction< Output, OutputGradient >::ParsedFunction() , 以及 libMesh::WrappedFunction< Output >::WrappedFunction().
|
protectedinherited |
成员变量用于缓存函数是否真正依赖于时间。
在文件 function_base.h 第 197 行定义.
参考自 libMesh::CompositeFunction< Output >::attach_subfunction() , 以及 libMesh::ConstFunction< Output >::ConstFunction().
|
protectedinherited |
指向我们的主函数对象的const指针,初始化为 nullptr。
可能存在需要多个函数的情况,但为了节省内存,一个主函数对象可以处理一些集中的数据。
这个成员变量用于指向主函数对象的指针,有时候多个函数对象需要共享一些数据,可以通过主函数对象来管理。
在文件 function_base.h 第 184 行定义.
OutputFunction libMesh::AnalyticFunction< Output >::_number_fptr |
指向用户提供的函数的指针,该函数在有解析表达式时计算边界值。
在文件 analytic_function.h 第 83 行定义.
OutputVectorFunction libMesh::AnalyticFunction< Output >::_vector_fptr |
指向用户提供的矢量值函数的指针。
在文件 analytic_function.h 第 88 行定义.