20 #ifndef INTERSECTION_LOCAL_H_ 21 #define INTERSECTION_LOCAL_H_ 35 template<
unsigned int dimA,
unsigned int dimB> std::ostream& operator<<(std::ostream& os, const IntersectionLocal<dimA,dimB>& il);
36 template<
unsigned int dimA,
unsigned int dimB> std::ostream& operator<<(std::ostream& os, const IntersectionPoint<dimA,dimB>& ip);
61 unsigned int bulk_element_idx);
71 typedef std::pair<unsigned int, IntersectionLocalBase*>
ILpair;
89 template<
unsigned int dimA,
unsigned int dimB>
100 IntersectionLocal(
unsigned int component_element_idx,
unsigned int bulk_element_idx);
117 unsigned int size()
const;
130 template<
unsigned int dimA,
unsigned int dimB>
132 {
return i_points_; }
134 template<
unsigned int dimA,
unsigned int dimB>
136 {
return i_points_; }
138 template<
unsigned int dimA,
unsigned int dimB>
141 return i_points_[index]; }
143 template<
unsigned int dimA,
unsigned int dimB>
145 {
return i_points_.size(); }
153 template<
unsigned int dimA,
unsigned int dimB>
171 IntersectionPoint(
const arma::vec::fixed<dimA> &comp_coords,
const arma::vec::fixed<dimB> &bulk_coords);
176 const arma::vec::fixed<dimA> &comp_coords()
const;
179 const arma::vec::fixed<dimB> &bulk_coords()
const;
196 template<
unsigned int dimA,
unsigned int dimB>
198 {
return comp_coords_; }
200 template<
unsigned int dimA,
unsigned int dimB>
202 {
return bulk_coords_; }
Common base for intersection object.
arma::vec::fixed< dimB > bulk_coords_
Local coordinates of an IP on simplex<dimB>.
Class represents intersection of two elements.
Class represents an intersection point of simplex<N> and simplex<M>. It contains barycentric coordina...
unsigned int size() const
Returns number of intersection points.
unsigned int bulk_ele_idx() const
Returns index of bulk element.
unsigned int component_ele_idx() const
Returns index of component element.
const arma::vec::fixed< dimA > & comp_coords() const
Returns local coordinates in the Simplex<N>.
const arma::vec::fixed< dimB > & bulk_coords() const
Returns local coordinates in the Simplex<M>.
std::pair< unsigned int, IntersectionLocalBase * > ILpair
First = element index, Second = pointer to intersection object.
arma::vec::fixed< dimA > comp_coords_
Local coordinates of an IP on simplex<dimA>.
unsigned int component_element_idx_
Index of intersecting element in the component.
std::vector< IntersectionPoint< dimA, dimB > > i_points_
Vector of intersection points.
Internal auxiliary class represents an intersection point of simplex<N> and simplex<M>.
std::vector< IntersectionPoint< dimA, dimB > > & points()
Returns intersection points by a reference.
Internal auxiliary class representing intersection object of simplex<dimA> and simplex<dimB>.
virtual double compute_measure() const =0
const IntersectionPoint< dimA, dimB > & operator[](unsigned int index) const
Returns intersection point of given index.
unsigned int bulk_element_idx_
Index of intersecting element in the bulk.