conspire/domain/fem/block/surface/
mod.rs

1use crate::{
2    fem::{
3        NodalReferenceCoordinates,
4        block::{Block, Connectivity, element::ElementNodalReferenceCoordinates},
5    },
6    math::Scalar,
7};
8
9const M: usize = 2;
10
11pub trait SurfaceFiniteElementBlock<C, F, const G: usize, const N: usize>
12where
13    Self: From<(C, Connectivity<N>, NodalReferenceCoordinates, Scalar)>,
14{
15}
16
17impl<C, F, const G: usize, const N: usize, const P: usize>
18    From<(C, Connectivity<N>, NodalReferenceCoordinates, Scalar)> for Block<C, F, G, M, N, P>
19where
20    F: From<(ElementNodalReferenceCoordinates<N>, Scalar)>,
21{
22    fn from(
23        (constitutive_model, connectivity, coordinates, thickness): (
24            C,
25            Connectivity<N>,
26            NodalReferenceCoordinates,
27            Scalar,
28        ),
29    ) -> Self {
30        let elements = connectivity
31            .iter()
32            .map(|nodes| {
33                <F>::from((
34                    nodes
35                        .iter()
36                        .map(|&node| coordinates[node].clone())
37                        .collect(),
38                    thickness,
39                ))
40            })
41            .collect();
42        Self {
43            constitutive_model,
44            connectivity,
45            coordinates,
46            elements,
47        }
48    }
49}
50
51impl<C, F, const G: usize, const N: usize, const P: usize> SurfaceFiniteElementBlock<C, F, G, N>
52    for Block<C, F, G, M, N, P>
53where
54    F: From<(ElementNodalReferenceCoordinates<N>, Scalar)>,
55{
56}