Basix 0.8.0

Home     Installation     Demos     C++ docs     Python docs

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{
22 equispaced = 0,
23 gll = 1,
24 chebyshev = 2,
25 gl = 4,
27 = 10,
29 = 11,
30};
31
34{
35 none = 0,
37 warp = 1,
39 isaac = 2,
42 centroid = 3,
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
simplex_method
The method used to generate points inside simplices.
Definition: lattice.h:34
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:819