DGtal 1.4.0
Loading...
Searching...
No Matches
PlaneProbingTetrahedronEstimator.h
1
17#pragma once
18
31#if defined(PlaneProbingTetrahedronEstimator_RECURSES)
32#error Recursive header files inclusion detected in PlaneProbingTetrahedronEstimator.h
33#else // defined(PlaneProbingTetrahedronEstimator_RECURSES)
35#define PlaneProbingTetrahedronEstimator_RECURSES
36
37#if !defined PlaneProbingTetrahedronEstimator_h
39#define PlaneProbingTetrahedronEstimator_h
40
42// Inclusions
43#include <iostream>
44#include <vector>
45#include "DGtal/base/Common.h"
46#include "DGtal/geometry/helpers/PlaneProbingEstimatorHelper.h"
47#include "DGtal/geometry/surfaces/estimation/PlaneProbingNeighborhood.h"
48#include "DGtal/kernel/CPointPredicate.h"
50
51namespace DGtal
52{
58 enum class ProbingMode
59 {
60 H,
61 R,
62 R1,
63 };
64
72 inline
73 std::ostream& operator<< (std::ostream& aOs, ProbingMode const& aMode)
74 {
75 switch (aMode)
76 {
77 case ProbingMode::H:
78 aOs << "H";
79 break;
80
81 case ProbingMode::R:
82 aOs << "R";
83 break;
84
85 case ProbingMode::R1:
86 aOs << "R1";
87 break;
88 }
89
90 return aOs;
91 }
92
94 // template class PlaneProbingTetrahedronEstimator
105 template <typename TPredicate, ProbingMode mode = ProbingMode::H>
107 {
109
110 // ----------------------- Public types ------------------------------
111 public:
113 using Predicate = TPredicate;
114 using Point = typename Predicate::Point;
115 using Vector = Point;
118 using Integer = typename Point::Coordinate;
120 using Permutation = typename PointOnProbingRay::Permutation;
124
125 // ----------------------- Standard services ------------------------------
126 public:
131
139 PlaneProbingTetrahedronEstimator (Point const& aPoint, Triangle const& aM, Predicate const& aPredicate);
140
145
151
157
164
171
172 // ----------------------- Plane Probing services ------------------------------
173 public:
178 Vector const& m (int aIndex) const;
179
183 Point const& q () const;
184
188 Point getOrigin () const;
189
194
198 std::pair<Vector, Vector> getBasis() const;
199
203 bool isReduced () const;
204
209
219 std::pair<bool, UpdateOperation> advance (std::vector<PointOnProbingRay> const& aNeighbors);
220
226 std::pair<bool, UpdateOperation> advance ();
227
234 Quantity compute (std::vector<PointOnProbingRay> const& aNeighbors);
235
242
247
253 void translateQ (Vector const& aTranslation);
254
259 void translateQ ();
260
267
268 // ----------------------- Interface --------------------------------------
269 public:
270
275 void selfDisplay ( std::ostream & out ) const;
280 bool isValid() const;
286 bool isProjectedInside (Triangle const& aTriangle) const;
290 bool isProjectedInside () const;
296 bool isInside() const;
302 bool isUnimodular() const;
303
304 // ------------------------- Protected Datas ------------------------------
305 protected:
306
307 // ------------------------- Private Datas --------------------------------
308 private:
314 std::vector<UpdateOperation> myOperations;
316 // ------------------------- Hidden services ------------------------------
317 protected:
318
319 // ------------------------- Internals ------------------------------------
320 private:
326 void update (UpdateOperation const& aOp);
327
328 }; // end of class PlaneProbingTetrahedronEstimator
329
330
337 template <typename TPredicate, ProbingMode mode>
338 std::ostream&
339 operator<< ( std::ostream & out, const PlaneProbingTetrahedronEstimator<TPredicate, mode> & object );
340} // namespace DGtal
341
342
344// Includes inline functions.
345#include "DGtal/geometry/surfaces/estimation/PlaneProbingTetrahedronEstimator.ih"
346
347// //
349
350#endif // !defined PlaneProbingTetrahedronEstimator_h
351
352#undef PlaneProbingTetrahedronEstimator_RECURSES
353#endif // else defined(PlaneProbingTetrahedronEstimator_RECURSES)
Aim: A base virtual class that represents a way to probe a neighborhood, used in the plane probing ba...
detail::PointOnProbingRay< Integer > PointOnProbingRay
Aim: A class that locally estimates a normal on a digital set using only a predicate "does a point x ...
void applyOperation(UpdateOperation const &aOp)
std::pair< bool, UpdateOperation > advance(std::vector< PointOnProbingRay > const &aNeighbors)
void translateQ(Vector const &aTranslation)
void update(UpdateOperation const &aOp)
bool isProjectedInside(Triangle const &aTriangle) const
BOOST_CONCEPT_ASSERT((concepts::CPointPredicate< TPredicate >))
typename PointOnProbingRay::Permutation Permutation
PlaneProbingTetrahedronEstimator & operator=(const PlaneProbingTetrahedronEstimator &other)=delete
PlaneProbingTetrahedronEstimator(const PlaneProbingTetrahedronEstimator &other)=delete
PlaneProbingTetrahedronEstimator(PlaneProbingTetrahedronEstimator &&other)=delete
std::pair< bool, UpdateOperation > advance()
std::pair< Vector, Vector > getBasis() const
typename Neighborhood::UpdateOperation UpdateOperation
Vector const & m(int aIndex) const
void selfDisplay(std::ostream &out) const
PlaneProbingTetrahedronEstimator(Point const &aPoint, Triangle const &aM, Predicate const &aPredicate)
Quantity compute(std::vector< PointOnProbingRay > const &aNeighbors)
typename Neighborhood::PointOnProbingRay PointOnProbingRay
DGtal is the top-level namespace which contains all DGtal functions and types.
std::ostream & operator<<(std::ostream &out, const ClosedIntegerHalfPlane< TSpace > &object)
Aim: Defines a predicate on a point.
const Point aPoint(3, 4)