43requires(
const E e,
unsigned int codim)
45 requires E::mydimension == (E::dimension - E::codimension);
46 { e.level() } -> std::convertible_to<int>;
47 { e.partitionType() } -> std::same_as<Dune::PartitionType>;
48 { e.geometry() } -> std::same_as<typename E::Geometry>;
49 { e.type() } -> std::same_as<Dune::GeometryType>;
50 { e.subEntities(codim) } -> std::convertible_to<unsigned int>;
51 { e.seed() } -> std::same_as<typename E::EntitySeed>;
91requires(
const E e,
int maxLevel)
93 requires (E::codimension == 0);
94 { e.father() } -> std::same_as<E>;
95 { e.hasFather() } -> std::convertible_to<bool>;
96 { e.isLeaf() } -> std::convertible_to<bool>;
97 { e.isRegular() } -> std::convertible_to<bool>;
98 { e.geometryInFather() } -> std::same_as<typename E::LocalGeometry>;
99 { e.hbegin(maxLevel) } -> std::same_as<typename E::HierarchicIterator>;
100 { e.hend(maxLevel) } -> std::same_as<typename E::HierarchicIterator>;
101 { e.isNew() } -> std::convertible_to<bool>;
102 { e.mightVanish() } -> std::convertible_to<bool>;
103 { e.hasBoundaryIntersections() } -> std::convertible_to<bool>;
105 requires std::same_as<E, typename E::template Codim<0>::Entity>;
107Impl::EntityCodimExtended<E,0> &&
108requires (index_constant<1> from, index_constant<E::dimension+1> to) {
109 Impl::entityAllCodimsExtended<E>(range(from, to).to_integer_sequence());