MFEM  v4.6.0
Finite element discretization library
segment.cpp
Go to the documentation of this file.
1 // Copyright (c) 2010-2023, Lawrence Livermore National Security, LLC. Produced
2 // at the Lawrence Livermore National Laboratory. All Rights reserved. See files
3 // LICENSE and NOTICE for details. LLNL-CODE-806117.
4 //
5 // This file is part of the MFEM library. For more information and source code
6 // availability visit https://mfem.org.
7 //
8 // MFEM is free software; you can redistribute it and/or modify it under the
9 // terms of the BSD-3 license. We welcome feedback and contributions, see file
10 // CONTRIBUTING.md for details.
11 
12 
13 #include "mesh_headers.hpp"
14 
15 namespace mfem
16 {
17 
18 Segment::Segment( const int *ind, int attr ) : Element(Geometry::SEGMENT)
19 {
20  attribute = attr;
21  for (int i=0; i<2; i++)
22  {
23  indices[i] = ind[i];
24  }
25 }
26 
27 Segment::Segment( int ind1, int ind2, int attr ) : Element(Geometry::SEGMENT)
28 {
29  attribute = attr;
30  indices[0] = ind1;
31  indices[1] = ind2;
32 }
33 
34 void Segment::SetVertices(const int *ind)
35 {
36  indices[0] = ind[0];
37  indices[1] = ind[1];
38 }
39 
41 {
42  v.SetSize( 2 );
43  for (int i=0; i<2; i++)
44  {
45  v[i] = indices[i];
46  }
47 }
48 
50 
51 }
Linear1DFiniteElement SegmentFE
Definition: segment.cpp:49
int indices[2]
Definition: segment.hpp:25
A 1D linear element with nodes on the endpoints.
int attribute
Element&#39;s attribute (specifying material property, etc).
Definition: element.hpp:33
void SetSize(int nsize)
Change the logical size of the array, keep existing entries.
Definition: array.hpp:687
virtual int * GetVertices()
Definition: segment.hpp:47
virtual void SetVertices(const int *ind)
Set the indices the element according to the input.
Definition: segment.cpp:34
Abstract data type element.
Definition: element.hpp:28