GEOS  3.14.0dev
geomgraph/Node.h
1 /**********************************************************************
2  *
3  * GEOS - Geometry Engine Open Source
4  * http://geos.osgeo.org
5  *
6  * Copyright (C) 2011 Sandro Santilli <strk@kbt.io>
7  * Copyright (C) 2005-2006 Refractions Research Inc.
8  * Copyright (C) 2001-2002 Vivid Solutions Inc.
9  *
10  * This is free software; you can redistribute and/or modify it under
11  * the terms of the GNU Lesser General Public Licence as published
12  * by the Free Software Foundation.
13  * See the COPYING file for more information.
14  *
15  **********************************************************************
16  *
17  * Last port: geomgraph/Node.java r411 (JTS-1.12+)
18  *
19  **********************************************************************/
20 
21 
22 #pragma once
23 
24 #include <geos/export.h>
25 #include <geos/geomgraph/GraphComponent.h> // for inheritance
26 #include <geos/geom/Coordinate.h> // for member
27 
28 #ifndef NDEBUG
29 #include <geos/geomgraph/EdgeEndStar.h> // for testInvariant
30 #include <geos/geomgraph/EdgeEnd.h> // for testInvariant
31 #endif // ndef NDEBUG
32 
33 #include <cassert>
34 #include <string>
35 
36 #ifdef _MSC_VER
37 #pragma warning(push)
38 #pragma warning(disable: 4251) // warning C4251: needs to have dll-interface to be used by clients of class
39 #endif
40 
41 // Forward declarations
42 namespace geos {
43 namespace geom {
44 class IntersectionMatrix;
45 }
46 namespace geomgraph {
47 class Node;
48 class EdgeEndStar;
49 class EdgeEnd;
50 class Label;
51 class NodeFactory;
52 }
53 }
54 
55 namespace geos {
56 namespace geomgraph { // geos.geomgraph
57 
59 class GEOS_DLL Node /* non-final */: public GraphComponent {
60  using GraphComponent::setLabel;
61 
62 public:
63 
64  friend std::ostream& operator<< (std::ostream& os, const Node& node);
65 
66  Node(const geom::Coordinate& newCoord, EdgeEndStar* newEdges);
67 
68  ~Node() override;
69 
70  const geom::Coordinate& getCoordinate() const;
71 
72  EdgeEndStar* getEdges();
73 
74  bool isIsolated() const override;
75 
79  void add(EdgeEnd* e);
80 
81  void mergeLabel(const Node& n);
82 
90  void mergeLabel(const Label& label2);
91 
92  void setLabel(uint8_t argIndex, geom::Location onLocation);
93 
98  void setLabelBoundary(uint8_t argIndex);
99 
108  geom::Location computeMergedLocation(const Label& label2, uint8_t eltIndex);
109 
110  std::string print() const;
111 
112  const std::vector<double>& getZ() const;
113 
114  void addZ(double);
115 
128 
129 protected:
130 
131  void testInvariant() const;
132 
133  geom::Coordinate coord;
134 
135  EdgeEndStar* edges;
136 
140  void
141  computeIM(geom::IntersectionMatrix& /*im*/) override {}
142 
143 private:
144 
145  std::vector<double> zvals;
146 
147  double ztot;
148 
149 };
150 
151 std::ostream& operator<< (std::ostream& os, const Node& node);
152 
153 inline void
154 Node::testInvariant() const
155 {
156 #ifndef NDEBUG
157  if(edges) {
158  // Each EdgeEnd in the star has this Node's
159  // coordinate as first coordinate
160  for(EdgeEndStar::iterator
161  it = edges->begin(), itEnd = edges->end();
162  it != itEnd; it++) {
163  EdgeEnd* e = *it;
164  assert(e);
165  assert(e->getCoordinate().equals2D(coord));
166  }
167  }
168 
169 #if 0
170  // We can't rely on numerical stability with FP computations
171  // ztot is the sum of doubnle sin zvals vector
172  double ztot_check = 0.0;
173  for(std::vector<double>::const_iterator
174  i = zvals.begin(), e = zvals.end();
175  i != e;
176  i++) {
177  ztot_check += *i;
178  }
179  assert(ztot_check == ztot);
180 #endif // 0
181 
182 #endif
183 }
184 
185 
186 } // namespace geos.geomgraph
187 } // namespace geos
188 
189 #ifdef _MSC_VER
190 #pragma warning(pop)
191 #endif
192 
Coordinate is the lightweight class used to store coordinates.
Definition: Coordinate.h:217
Implementation of Dimensionally Extended Nine-Intersection Model (DE-9IM) matrix.
Definition: IntersectionMatrix.h:51
A EdgeEndStar is an ordered list of EdgeEnds around a node.
Definition: EdgeEndStar.h:63
Models the end of an edge incident on a node.
Definition: EdgeEnd.h:54
A GraphComponent is the parent class for the objects' that form a graph.
Definition: geomgraph/GraphComponent.h:45
A Label indicates the topological relationship of a component of a topology graph to a given Geometry...
Definition: Label.h:57
The node component of a geometry graph.
Definition: geomgraph/Node.h:59
void mergeLabel(const Label &label2)
To merge labels for two nodes, the merged location for each LabelElement is computed.
void setLabelBoundary(uint8_t argIndex)
Updates the label of a node to BOUNDARY, obeying the mod-2 boundaryDetermination rule.
bool isIncidentEdgeInResult() const
Tests whether any incident edge is flagged as being in the result.
void add(EdgeEnd *e)
Add the edge to the list of edges at this node.
geom::Location computeMergedLocation(const Label &label2, uint8_t eltIndex)
void computeIM(geom::IntersectionMatrix &) override
Basic nodes do not compute IMs.
Definition: geomgraph/Node.h:141
Location
Constants representing the location of a point relative to a geometry.
Definition: Location.h:32
Basic namespace for all GEOS functionalities.
Definition: Angle.h:25