Basix
Loading...
Searching...
No Matches
lattice.h
1// Copyright (c) 2020-2022 Chris Richardson and Garth N. Wells
2// FEniCS Project
3// SPDX-License-Identifier: MIT
4
5#pragma once
6
7#include "cell.h"
8#include <array>
9#include <concepts>
10#include <utility>
11#include <vector>
12
15{
20enum class type
21{
23 gll = 1,
25 gl = 4,
27 = 10,
29 = 11,
30};
31
34{
35 none = 0,
37 warp = 1,
39 isaac = 2,
46};
47
71template <std::floating_point T>
72std::pair<std::vector<T>, std::array<std::size_t, 2>>
73create(cell::type celltype, int n, lattice::type type, bool exterior,
75
76} // namespace basix::lattice
type
Cell type.
Definition cell.h:21
Lattices of points.
Definition lattice.h:15
type
The type of point spacing to be used in a lattice.
Definition lattice.h:21
@ equispaced
Definition lattice.h:22
@ gll
Definition lattice.h:23
@ chebyshev
Definition lattice.h:24
@ chebyshev_plus_endpoints
Definition lattice.h:26
@ gl_plus_endpoints
Definition lattice.h:28
@ gl
Definition lattice.h:25
simplex_method
The method used to generate points inside simplices.
Definition lattice.h:34
@ centroid
Definition lattice.h:42
@ none
Definition lattice.h:35
@ isaac
Definition lattice.h:39
@ warp
Definition lattice.h:37
std::pair< std::vector< T >, std::array< std::size_t, 2 > > create(cell::type celltype, int n, lattice::type type, bool exterior, lattice::simplex_method simplex_method=lattice::simplex_method::none)
Create a lattice of points on a reference cell optionally including the outer surface points.
Definition lattice.cpp:783