ufl.core package¶
Submodules¶
ufl.core.base_form_operator module¶
Base form operator.
This module defines the BaseFormOperator class, which is the base class for objects that can be seen as forms and as operators such as ExternalOperator or Interpolate.
- class ufl.core.base_form_operator.BaseFormOperator(*operands, function_space, derivatives=None, argument_slots=())[source]¶
Bases:
Operator,BaseForm,CountedBase form operator.
- argument_slots(outer_form=False)[source]¶
Returns a tuple of expressions containing argument and coefficient based expressions.
We get an argument uhat when we take the Gateaux derivative in the direction uhat: d/du N(u; v*) = dNdu(u; uhat, v*) where uhat is a ufl.Argument and v* a ufl.Coargument Applying the action replace the last argument by coefficient: action(dNdu(u; uhat, v*), w) = dNdu(u; w, v*) where du is a ufl.Coefficient.
- ufl_free_indices = ()¶
- ufl_function_space()[source]¶
Return the function space associated to the operator.
I.e. return the dual of the base form operator’s Coargument.
- ufl_index_dimensions = ()¶
- ufl_operands¶
- property ufl_shape¶
Return the UFL shape of the coefficient.produced by the operator.
ufl.core.compute_expr_hash module¶
Non-recursive traversal-based hash computation algorithm.
Fast iteration over nodes in an Expr DAG to compute
memoized hashes for all unique nodes.
ufl.core.expr module¶
This module defines the Expr class, the superclass for all expression tree node types in UFL.
NB: A note about other operators not implemented here:
More operators (special functions) on Expr instances are defined in
exproperators.py, as well as the transpose A.T and spatial derivative
a.dx(i).
This is to avoid circular dependencies between Expr and its subclasses.
- class ufl.core.expr.Expr[source]¶
Bases:
objectBase class for all UFL expression types.
- Instance properties
Every
Exprinstance will have certain properties. The most important ones areufl_operands,ufl_shape,ufl_free_indices, andufl_index_dimensionsproperties. Expressions are immutable and hashable.- Type traits
The
ExprAPI defines a number of type traits that each subclass needs to provide. Most of these are specified indirectly via the arguments to theufl_typeclass decorator, allowing UFL to do some consistency checks and automate most of the traits for most types. Type traits are accessed via a class or instance object of the formobj._ufl_traitname_. See the source code for description of each type trait.- Operators
Some Python special functions are implemented in this class, some are implemented in subclasses, and some are attached to this class in the
ufl_typeclass decorator.- Defining subclasses
To define a new expression class, inherit from either
TerminalorOperator, and apply theufl_typeclass decorator with suitable arguments. See the docstring ofufl_typefor details on its arguments. Looking at existing classes similar to the one you wish to add is a good idea. Looking through the comments in theExprclass andufl_typeto understand all the properties that may need to be specified is also a good idea. Note that many algorithms in UFL and form compilers will need handlers implemented for each new type::.@ufl_type() class MyOperator(Operator): pass
- Type collections
All
Exprsubclasses are collected byufl_typein global variables available viaExpr.- Profiling
Object creation statistics can be collected by doing
Expr.ufl_enable_profiling() # ... run some code initstats, delstats = Expr.ufl_disable_profiling()
Giving a list of creation and deletion counts for each typecode.
- property T¶
Transpose a rank-2 tensor expression.
For more general transpose operations of higher order tensor expressions, use indexing and Tensor.
- dx(*ii)¶
Return the partial derivative with respect to spatial variable number ii.
- evaluate(x, mapping, component, index_values)[source]¶
Evaluate expression at given coordinate with given values for terminals.
- static ufl_disable_profiling()[source]¶
Turn off the object counting mechanism. Return object init and del counts.
ufl.core.external_operator module¶
External operator.
This module defines the ExternalOperator class, which symbolically represents operators that are not
straightforwardly expressible in UFL. Subclasses of ExternalOperator must define
how this operator should be evaluated as well as its derivatives from a given set of operands.
ufl.core.interpolate module¶
This module defines the Interpolate class.
- class ufl.core.interpolate.Interpolate(expr, v)[source]¶
Bases:
BaseFormOperatorSymbolic representation of the interpolation operator.
- ufl_operands¶
ufl.core.multiindex module¶
This module defines the single index types and some internal index utilities.
- class ufl.core.multiindex.FixedIndex(value)[source]¶
Bases:
IndexBaseUFL value: An index with a specific value assigned.
- class ufl.core.multiindex.Index(count=None)[source]¶
-
UFL value: An index with no value assigned.
Used to represent free indices in Einstein indexing notation.
- class ufl.core.multiindex.MultiIndex(indices)[source]¶
Bases:
TerminalRepresents a sequence of indices, either fixed or free.
- property ufl_free_indices¶
Get the UFL free indices.
This should not be used.
- property ufl_index_dimensions¶
Get the UFL index dimensions.
This should not be used.
- property ufl_shape¶
Get the UFL shape.
This should not be used.
ufl.core.operator module¶
Operator.
ufl.core.terminal module¶
This module defines the Terminal class.
Terminal the superclass for all types that are terminal nodes in an expression tree.
- class ufl.core.terminal.FormArgument[source]¶
Bases:
TerminalAn abstract class for a form argument (a thing in a primal finite element space).
- class ufl.core.terminal.Terminal[source]¶
Bases:
ExprBase class for terminal objects.
A terminal node in the UFL expression tree.
- evaluate(x, mapping, component, index_values, derivatives=())[source]¶
Get self from mapping and return the component asked for.
- ufl_free_indices = ()¶
- ufl_index_dimensions = ()¶
- ufl_operands = ()¶
ufl.core.ufl_id module¶
Utilites for types with a globally counted unique id attached to each object.
- ufl.core.ufl_id.attach_ufl_id(cls)[source]¶
Equip class with
.ufl_id()and handle bookkeeping.Usage:
Apply to class:
@attach_ufl_id class MyClass(object):
If
__slots__is defined, include_ufl_idattribute:__slots__ = ("_ufl_id",)
Add keyword argument to constructor:
def __init__(self, *args, ufl_id=None):
Call
self._init_ufl_idwithufl_idand assign to._ufl_idattribute:self._ufl_id = self._init_ufl_id(ufl_id)
Result:
MyClass().ufl_id()returns unique value for each constructed object.
ufl.core.ufl_type module¶
UFL type.
- class ufl.core.ufl_type.UFLType[source]¶
Bases:
typeBase class for all UFL types.
Equip UFL types with some ufl specific properties.
- ufl.core.ufl_type.attach_implementations_of_indexing_interface(cls, inherit_shape_from_operand, inherit_indices_from_operand)[source]¶
Attach implementations of indexing interface.
- ufl.core.ufl_type.attach_operators_from_hash_data(cls)[source]¶
Class decorator to attach
__hash__,__eq__and__ne__implementations.These are implemented in terms of a
._ufl_hash_data()method on the class, which should return a tuple or hashable and comparable data.
- ufl.core.ufl_type.check_abstract_trait_consistency(cls)[source]¶
Check that the first base classes up to
Exprare other UFL types.
- ufl.core.ufl_type.check_has_slots(cls)[source]¶
Check if type has __slots__ unless it is marked as exception with _ufl_noslots_.
- ufl.core.ufl_type.check_implements_required_methods(cls)[source]¶
Check if type implements the required methods.
- ufl.core.ufl_type.check_implements_required_properties(cls)[source]¶
Check if type implements the required properties.
- ufl.core.ufl_type.check_is_terminal_consistency(cls)[source]¶
Check for consistency in
is_terminaltrait among superclasses.
- ufl.core.ufl_type.check_type_traits_consistency(cls)[source]¶
Execute a variety of consistency checks on the ufl type traits.
- ufl.core.ufl_type.determine_num_ops(cls, num_ops, unop, binop, rbinop)[source]¶
Determine number of operands for this type.
- ufl.core.ufl_type.get_base_attr(cls, name)[source]¶
Return first non-
Noneattribute of given name among base classes.
- ufl.core.ufl_type.set_trait(cls, basename, value, inherit=False)[source]¶
Assign a trait to class with namespacing
_ufl_basename_applied.If trait value is
None, optionally inherit it from the closest base class that has it.
- ufl.core.ufl_type.ufl_type(is_abstract=False, is_terminal=None, is_scalar=False, is_index_free=False, is_shaping=False, is_literal=False, is_terminal_modifier=False, is_in_reference_frame=False, is_restriction=False, is_evaluation=False, is_differential=None, use_default_hash=True, num_ops=None, inherit_shape_from_operand=None, inherit_indices_from_operand=None, wraps_type=None, unop=None, binop=None, rbinop=None)[source]¶
This decorator is to be applied to every subclass in the UFL
ExprandBaseFormhierarchy.This decorator contains a number of checks that are intended to enforce uniform behaviour across UFL types.
The rationale behind the checks and the meaning of the optional arguments should be sufficiently documented in the source code below.
Module contents¶
UFL core.