Source code for goalie.utility
"""
Utility functions and classes for mesh adaptation.
"""
import os
import firedrake
import numpy as np
__all__ = ["AttrDict", "create_directory", "effectivity_index"]
[docs]
class AttrDict(dict):
"""
Dictionary that provides both ``self[key]`` and ``self.key`` access to members.
**Disclaimer**: Copied from `stackoverflow
<http://stackoverflow.com/questions/4984647/accessing-dict-keys-like-an-attribute-in-python>`__.
"""
def __init__(self, *args, **kwargs):
super().__init__(*args, **kwargs)
self.__dict__ = self
[docs]
def effectivity_index(error_indicator, Je):
r"""
Compute the overestimation factor of some error estimator for the QoI error.
Note that this is only typically used for simple steady-state problems with
analytical solutions.
:arg error_indicator: a :math:`\mathbb P0` error indicator which localises
contributions to an error estimator to individual elements
:type error_indicator: :class:`firedrake.function.Function`
:arg Je: the error in the quantity of interest
:type Je: :class:`float`
:returns: the effectivity index
:rtype: :class:`float`
"""
if not isinstance(error_indicator, firedrake.Function):
raise ValueError("Error indicator must return a Function.")
el = error_indicator.ufl_element()
if not (el.family() == "Discontinuous Lagrange" and el.degree() == 0):
raise ValueError("Error indicator must be P0.")
eta = error_indicator.vector().gather().sum()
return np.abs(eta / Je)
[docs]
def create_directory(path, comm=firedrake.COMM_WORLD):
"""
Create a directory on disk.
**Disclaimer**: Code copied from `Thetis <https://thetisproject.org>`__.
:arg path: path to the directory
:type path: :class:`str`
:kwarg comm: MPI communicator
:type comm: :class:`mpi4py.MPI.Intracomm`
:returns: the path in absolute form
:rtype path: :class:`str`
"""
if comm.rank == 0:
if not os.path.exists(path):
os.makedirs(path)
comm.barrier()
return path