Source code for ufl.algorithms.traversal

"""This module contains algorithms for traversing expression trees in different ways."""

# Copyright (C) 2008-2016 Martin Sandve Alnæs and Anders Logg
#
# This file is part of UFL (https://www.fenicsproject.org)
#
# SPDX-License-Identifier:    LGPL-3.0-or-later
#
# Modified by Anders Logg, 2008

from ufl.core.expr import Expr
from ufl.integral import Integral
from ufl.action import Action
from ufl.adjoint import Adjoint
from ufl.form import Form, FormSum, BaseForm


# --- Traversal utilities ---

[docs]def iter_expressions(a): """Utility function to handle Form, Integral and any Expr the same way when inspecting expressions. Returns an iterable over Expr instances: - a is an Expr: (a,) - a is an Integral: the integrand expression of a - a is a Form: all integrand expressions of all integrals - a is a FormSum: the components of a - a is an Action: the left and right component of a - a is an Adjoint: the underlying form of a """ if isinstance(a, Form): return (itg.integrand() for itg in a.integrals()) elif isinstance(a, Integral): return (a.integrand(),) elif isinstance(a, (FormSum, Adjoint, Action)): return tuple(e for op in a.ufl_operands for e in iter_expressions(op)) elif isinstance(a, (Expr, BaseForm)): return (a,) raise ValueError(f"Not an UFL type: {type(a)}")