File: ReferenceElementSets.h

package info (click to toggle)
python-escript 5.6-10
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 144,304 kB
  • sloc: python: 592,074; cpp: 136,909; ansic: 18,675; javascript: 9,411; xml: 3,384; sh: 738; makefile: 207
file content (86 lines) | stat: -rw-r--r-- 3,266 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86

/*****************************************************************************
*
* Copyright (c) 2003-2020 by The University of Queensland
* http://www.uq.edu.au
*
* Primary Business: Queensland, Australia
* Licensed under the Apache License, version 2.0
* http://www.apache.org/licenses/LICENSE-2.0
*
* Development until 2012 by Earth Systems Science Computational Center (ESSCC)
* Development 2012-2013 by School of Earth Sciences
* Development from 2014-2017 by Centre for Geoscience Computing (GeoComp)
* Development from 2019 by School of Earth and Environmental Sciences
**
*****************************************************************************/

#ifndef __FINLEY_REFERENCEELEMENTSETS_H__
#define __FINLEY_REFERENCEELEMENTSETS_H__

#include "ReferenceElements.h"

namespace finley {

///  A reference element set manages the reference elements for the full
///  and reduced integration order
struct ReferenceElementSet {
    ReferenceElementSet(ElementTypeId id, int order, int reduced_order)
    {
        const ReferenceElementInfo* id_info = ReferenceElement::getInfo(id);
        const ShapeFunctionInfo* bf_info = ShapeFunction::getInfo(
                                                    id_info->BasisFunctions);
        if (order<0)
            order=std::max(2*bf_info->numOrder, 0);

        referenceElement.reset(new ReferenceElement(id, order));
        if (reduced_order<0)
            reduced_order=std::max(2*(bf_info->numOrder-1), 0);
        referenceElementReducedQuadrature.reset(new ReferenceElement(id,
                                                             reduced_order));

        if (referenceElement->getNumNodes() != referenceElementReducedQuadrature->getNumNodes()) {
            throw escript::ValueError("ReferenceElementSet: numNodes in referenceElement and referenceElementReducedQuadrature don't match.");
        }
    }

    const_ShapeFunction_ptr borrowBasisFunctions(bool reducedShapefunction,
                                                 bool reducedIntegrationOrder) const
    {
        if (reducedShapefunction) {
            return (reducedIntegrationOrder ?
                    referenceElementReducedQuadrature->LinearBasisFunctions :
                    referenceElement->LinearBasisFunctions);
        }
        return (reducedIntegrationOrder ?
                referenceElementReducedQuadrature->BasisFunctions :
                referenceElement->BasisFunctions);
    }

    const_ShapeFunction_ptr borrowParametrization(bool reducedIntegrationOrder) const
    {
        return (reducedIntegrationOrder ?
                referenceElementReducedQuadrature->Parametrization :
                referenceElement->Parametrization);
    }

    const_ReferenceElement_ptr borrowReferenceElement(bool reducedIntOrder) const
    {
        return (reducedIntOrder ? referenceElementReducedQuadrature :
                                  referenceElement);
    }

    inline int getNumNodes() const { return referenceElement->getNumNodes(); }

    ReferenceElement_ptr referenceElementReducedQuadrature;
    ReferenceElement_ptr referenceElement;
};


typedef boost::shared_ptr<const ReferenceElementSet> const_ReferenceElementSet_ptr;


} // namespace finley

#endif // __FINLEY_REFERENCEELEMENTSETS_H__