21 #include <geos/geom/Location.h>
23 #include <geos/export.h>
92 bool matches(
const std::string& requiredDimensionSymbols)
const;
107 char requiredDimensionSymbol);
121 static bool matches(
const std::string& actualDimensionSymbols,
122 const std::string& requiredDimensionSymbols);
156 void set(
const std::string& dimensionSymbols);
230 return matrix[
static_cast<size_t>(row)][
static_cast<size_t>(column)];
261 bool isTouches(
int dimensionOfGeometryA,
int dimensionOfGeometryB)
281 bool isCrosses(
int dimensionOfGeometryA,
int dimensionOfGeometryB)
307 bool isEquals(
int dimensionOfGeometryA,
int dimensionOfGeometryB)
323 bool isOverlaps(
int dimensionOfGeometryA,
int dimensionOfGeometryB)
368 static const int firstDim;
370 static const int secondDim;
373 std::array<std::array<int, 3>, 3> matrix;
Location
Constants representing the location of a point relative to a geometry.
Definition: Location.h:32
bool isTouches(int dimensionOfGeometryA, int dimensionOfGeometryB) const
Returns true if this IntersectionMatrix is FT*******, F**T***** or F***T****.
IntersectionMatrix(const IntersectionMatrix &other)
Copy constructor.
void set(const std::string &dimensionSymbols)
Changes the elements of this IntersectionMatrix to the dimension symbols in dimensionSymbols.
int get(geom::Location row, geom::Location column) const
Returns the value of one of this IntersectionMatrixs elements.
Definition: IntersectionMatrix.h:229
Basic namespace for all GEOS functionalities.
Definition: Angle.h:25
bool isCrosses(int dimensionOfGeometryA, int dimensionOfGeometryB) const
Returns true if this IntersectionMatrix is:
bool isCovers() const
Returns true if this IntersectionMatrix is T*****FF* or T****FF or ***T**FF* or ****T*FF*
IntersectionMatrix * transpose()
Transposes this IntersectionMatrix.
void setAtLeast(std::string minimumDimensionSymbols)
For each element in this IntersectionMatrix, changes the element to the corresponding minimum dimensi...
bool isCoveredBy() const
Returns true if this IntersectionMatrix is T*F**F*** *TF**F*** or **FT*F*** or **F*TF***
bool matches(const std::string &requiredDimensionSymbols) const
Returns whether the elements of this IntersectionMatrix satisfies the required dimension symbols.
bool isOverlaps(int dimensionOfGeometryA, int dimensionOfGeometryB) const
Returns true if this IntersectionMatrix is:
bool isWithin() const
Returns true if this IntersectionMatrix is T*F**F***.
void setAtLeastIfValid(Location row, Location column, int minimumDimensionValue)
If row >= 0 and column >= 0, changes the specified element to minimumDimensionValue if the element is...
void set(Location row, Location column, int dimensionValue)
Changes the value of one of this IntersectionMatrixs elements.
std::string toString() const
Returns a nine-character String representation of this IntersectionMatrix.
void setAll(int dimensionValue)
Changes the elements of this IntersectionMatrix to dimensionValue.
IntersectionMatrix(const std::string &elements)
Overriden constructor.
bool isContains() const
Returns true if this IntersectionMatrix is T*****FF*.
bool isIntersects() const
Returns true if isDisjoint returns false.
bool isDisjoint() const
Returns true if this IntersectionMatrix is FF*FF****.
void setAtLeast(Location row, Location column, int minimumDimensionValue)
Changes the specified element to minimumDimensionValue if the element is less.
Implementation of Dimensionally Extended Nine-Intersection Model (DE-9IM) matrix.
Definition: IntersectionMatrix.h:51
IntersectionMatrix()
Default constructor.
static bool matches(int actualDimensionValue, char requiredDimensionSymbol)
Tests if given dimension value satisfies the dimension symbol.
static bool matches(const std::string &actualDimensionSymbols, const std::string &requiredDimensionSymbols)
Returns true if each of the actual dimension symbols satisfies the corresponding required dimension s...
void add(IntersectionMatrix *other)
Adds one matrix to another.
bool isEquals(int dimensionOfGeometryA, int dimensionOfGeometryB) const
Returns true if this IntersectionMatrix is T*F**FFF*.