
The Dimensionally Extended 9-Intersection Model (DE-9IM) is a
topological model and a
standard used to describe the
spatial relation
A spatial relationD. M. Mark and M. J. Egenhofer (1994), "Modeling Spatial Relations Between Lines and Regions: Combining Formal Mathematical Models and Human Subjects Testing"PDF/ref> specifies how some object is located in space in relation to s ...
s of two regions (two
geometries in two-dimensions, R
2), in
geometry,
point-set topology,
geospatial topology, and fields related to
computer spatial analysis. The spatial relations expressed by the model are invariant to
rotation
Rotation, or spin, is the circular movement of an object around a '' central axis''. A two-dimensional rotating object has only one possible central axis and can rotate in either a clockwise or counterclockwise direction. A three-dimensional ...
,
translation and
scaling
Scaling may refer to:
Science and technology
Mathematics and physics
* Scaling (geometry), a linear transformation that enlarges or diminishes objects
* Scale invariance, a feature of objects or laws that do not change if scales of length, energ ...
transformations.
The matrix provides an approach for classifying geometry relations. Roughly speaking, with a true/false matrix domain, there are 512 possible 2D topologic relations, that can be grouped into ''binary classification schemes''. The English language contains about 10 schemes (relations), such as "intersects", "touches" and "equals". When testing two geometries against a scheme, the result is a ''spatial predicate'' named by the scheme.
The model was developed by Clementini and others based on the seminal works of Egenhofer and others.
It has been used as a basis for standards of ''
queries'' and ''
assertions'' in
geographic information systems
A geographic information system (GIS) is a type of database containing geographic data (that is, descriptions of phenomena for which location is relevant), combined with software tools for managing, analyzing, and visualizing those data. In a br ...
(GIS) and
spatial databases.
Matrix model
The DE-9IM model is based on a 3×3
intersection
In mathematics, the intersection of two or more objects is another object consisting of everything that is contained in all of the objects simultaneously. For example, in Euclidean geometry, when two lines in a plane are not parallel, their i ...
matrix
Matrix most commonly refers to:
* ''The Matrix'' (franchise), an American media franchise
** ''The Matrix'', a 1999 science-fiction action film
** "The Matrix", a fictional setting, a virtual reality environment, within ''The Matrix'' (franchis ...
with the form:
where is the
dimension of the
intersection
In mathematics, the intersection of two or more objects is another object consisting of everything that is contained in all of the objects simultaneously. For example, in Euclidean geometry, when two lines in a plane are not parallel, their i ...
(∩) of the
interior
Interior may refer to:
Arts and media
* ''Interior'' (Degas) (also known as ''The Rape''), painting by Edgar Degas
* ''Interior'' (play), 1895 play by Belgian playwright Maurice Maeterlinck
* ''The Interior'' (novel), by Lisa See
* Interior de ...
(I),
boundary (B), and
exterior (E) of geometries ''a'' and ''b''.
The terms ''interior'' and ''boundary'' in this article are used in the sense used in algebraic topology and manifold theory, not in the sense used in general topology: for example, the interior of a line segment is the line segment without its endpoints, and its boundary is just the two endpoints (in general topology, the interior of a line segment in the plane is empty and the line segment is its own boundary).
In the notation of topological space operators, the matrix elements can be expressed also as
The dimension of
empty set
In mathematics, the empty set is the unique set having no elements; its size or cardinality (count of elements in a set) is zero. Some axiomatic set theories ensure that the empty set exists by including an axiom of empty set, while in other ...
s (∅) are denoted as −1 or (false). The dimension of non-empty sets (¬∅) are denoted with the maximum number of dimensions of the intersection, specifically for
points
Point or points may refer to:
Places
* Point, Lewis, a peninsula in the Outer Hebrides, Scotland
* Point, Texas, a city in Rains County, Texas, United States
* Point, the NE tip and a ferry terminal of Lismore, Inner Hebrides, Scotland
* Point ...
, for
lines
Line most often refers to:
* Line (geometry), object with zero thickness and curvature that stretches to infinity
* Telephone line, a single-user circuit on a telephone communication system
Line, lines, The Line, or LINE may also refer to:
Arts ...
, for
areas. Then, the
domain
Domain may refer to:
Mathematics
*Domain of a function, the set of input values for which the (total) function is defined
**Domain of definition of a partial function
**Natural domain of a partial function
**Domain of holomorphy of a function
* Do ...
of the model is .
A simplified version of values are obtained mapping the values to (true), so using the
boolean domain . The matrix, denoted with operators, can be expressed as
The elements of the matrix can be named as shown below:
Both matrix forms, with dimensional and boolean domains, can be
serialized as "''DE-9IM string codes''", which represent them in a single-line string pattern. Since 1999 the ''string codes'' have a
standard[The "]OpenGIS
The Open Geospatial Consortium (OGC), an international voluntary consensus standards organization for geospatial content and location-based services, sensor web and Internet of Things, GIS data processing and data sharing. It originated in 19 ...
Simple Features Specification For SQL"
Revision 1.1
was released at May 5, 1999. It was the first international standard to establish the format conventions for ''DE-9IM string codes'', and the names of the "Named Spatial Relationship predicates based on the DE-9IM" (see section with this title). format.
For output checking or pattern analysis, a matrix value (or a string code) can be checked by a "
mask": a desired output value with optional
asterisk
The asterisk ( ), from Late Latin , from Ancient Greek , ''asteriskos'', "little star", is a typographical symbol. It is so called because it resembles a conventional image of a heraldic star.
Computer scientists and mathematicians often voc ...
symbols as
wildcards — that is, "" indicating output positions that the designer does not care about (free values or "don't-care positions").
The domain of the mask elements is , or for the boolean form.
The simpler models ''4-Intersection'' and ''9-Intersection'' were proposed before DE-9IM for expressing ''spatial relations''
[M. J. Egenhofer, J. Sharma, and D. Mark (1993)]
A Critical Comparison of the 4-Intersection and 9-Intersection Models for Spatial Relations: Formal Analysis
", In
. (and originated the terms ''4IM'' and ''9IM''). They can be used instead of the DE-9IM to optimize computation when input conditions satisfy specific constraints.
Illustration
Visually, for two overlapping polygonal geometries, the result of the function DE_9IM(''a'',''b'') looks like:
This matrix can be
serialized. Reading from left-to-right and top-to-bottom, the result is . So, in a compact representation as string code is ''.
Spatial predicates
Any
topological property based on a DE-9IM
binary spatial relation
A spatial relationD. M. Mark and M. J. Egenhofer (1994), "Modeling Spatial Relations Between Lines and Regions: Combining Formal Mathematical Models and Human Subjects Testing"PDF/ref> specifies how some object is located in space in relation to s ...
is a spatial predicate. For ease of use "named spatial predicates" have been defined for some common relations, which later became standard predicates.
The ''spatial predicate
functions'' that can be derived from DE-9IM include:
:Predicates defined with masks of domain :
:Predicates that can be obtained from the above by
logical negation
In logic, negation, also called the logical complement, is an operation that takes a proposition P to another proposition "not P", written \neg P, \mathord P or \overline. It is interpreted intuitively as being true when P is false, and false ...
or parameter inversion (
matrix transposition
In linear algebra, the transpose of a matrix is an operator which flips a matrix over its diagonal;
that is, it switches the row and column indices of the matrix by producing another matrix, often denoted by (among other notations).
The tr ...
), as indicated by the last column:
:Predicates that utilize the input dimensions, and are defined with masks of domain :
Notice that:
* The ''topologically equal'' definition does not imply that they have the same points or even that they are of the same class.
* The output of have the information contained in a list of all interpretable predicates about geometries ''a'' and ''b''.
* All predicates are computed by masks. Only ''Crosses'' and ''Overlaps'' have additional conditions about and .
* All mask string codes end with
*
. This is because ''EE'' is trivially true, and thus provides no useful information.
* The ''Equals'' mask,
T*F**FFF*
, is the "merge" of ''Contains'' (
T*****FF*
) and ''Within'' (
T*F**F***
): .
* The mask
T*****FF*
occurs in the definition of both ''Contains'' and ''Covers''. ''Covers'' is a more inclusive relation. In particular, unlike ''Contains'' it does not distinguish between points in the boundary and in the interior of geometries. For most situations, ''Covers'' should be used in preference to ''Contains''.
* Similarly, the mask
T*F**F***
occurs in the definition of both ''Within'' and ''CoveredBy''. For most situations, ''CoveredBy'' should be used in preference to ''Within''.
* Historically, other terms and other formal approaches have been used to express ''spatial predicates''; for example
region connection calculus was introduced in 1992 by Randell, Cohn and Cohn.
Properties
The spatial predicates have the following properties of
binary relations:
*
Reflexive: Equals, Contains, Covers, CoveredBy, Intersects, Within
*
Anti-reflexive: Disjoint
*
Symmetric: Equals, Intersects, Crosses, Touches, Overlaps
*
Transitive: Equals, Contains, Covers, CoveredBy, Within
Interpretation

The choice of terminology and semantics for the spatial predicates is based on reasonable conventions and the tradition of topological studies.
Relationships such as ''Intersects'', ''Disjoint'', ''Touches'', ''Within'', ''Equals'' (between two geometries ''a'' and ''b'') have an obvious semantic:
; ''Equals'': ''a'' = ''b'' that is (''a'' ∩ ''b'' = ''a'') ∧ (''a'' ∩ ''b'' = ''b'')
; ''Within'': ''a'' ∩ ''b'' = ''a''
; ''Intersects'': ''a'' ∩ ''b'' ≠ ∅
; ''Touches'': (''a'' ∩ ''b'' ≠ ∅) ∧ (''a''
ο ∩ ''b''
ο = ∅)
The predicates ''Contains'' and ''Within'' have subtle aspects to their definition which are contrary to intuition.
For example,
a line ''L'' which is completely contained in the boundary of a polygon ''P'' is ''not'' considered to be contained in ''P''. This quirk can be expressed as "Polygons do not contain their boundary". This issue is caused by the final clause of the ''Contains'' definition above: "at least one point of the interior of B lies in the interior of A". For this case, the predicate ''Covers'' has more intuitive semantics (see definition), avoiding boundary considerations.
For better understanding, the dimensionality of inputs can be used as justification for a gradual introduction of semantic complexity:
:
Coverage on possible matrix results
The number of possible results in a boolean ''9IM'' matrix is 2
9=512, and in a DE-9IM matrix is 3
9=6561. The percentage of these results that satisfy a specific predicate is determined as following,
On usual applications the geometries intersects ''a priori'', and the other relations are checked.
The composite predicates "''Intersects'' OR ''Disjoint''" and "''Equals'' OR ''Different''" have the sum 100% (always true predicates),
but "''Covers'' OR ''CoveredBy''" have 41%, that is not the sum, because they are not logical complements neither independent relations; idem "''Contains'' OR ''Within''", that have 21%. The sum 25%+12.5%=37.5% is obtained when ignoring overlapping of lines in "''Crosses'' OR ''Overlaps''", because the valid input sets are disjoints.
Queries and assertions
The ''DE-9IM'' offers a full descriptive assertion about the two input geometries. It is a mathematical function that represents a
complete set
Complete may refer to:
Logic
* Completeness (logic)
* Completeness of a theory, the property of a theory that every formula in the theory's language or its negation is provable
Mathematics
* The completeness of the real numbers, which implies ...
of all possible relations about two entities, like a
Truth table, the
Three-way comparison, a
Karnaugh map or a
Venn diagram. Each output value is like a truth table line, that represent relations of specific inputs.
As illustrated above, the output '212101212' resulted from ''DE-9IM''(''a'',''b'') is a complete description of all topologic relations between specific geometries ''a'' and ''b''. It says to us that .
By other hand, if we check predicates like ''Intersects''(''a'',''b'') or ''Touches''(''a'',''b'') — for the same example we have "''Intersects''= and ''Touches''=" — it is an incomplete description of "all topologic relations".
Predicates also do not say any thing about the dimensionality of the geometries (it doesn't matter if ''a'' and ''b'' are lines, areas or points).
This independence of geometry-type and the lack of
completeness, on ''predicates'', are useful for
general queries about two geometries:
:
For usual applications, the use of ''spatial predicates'' also is justified by being more
human-readable than ''DE-9IM'' descriptions: a typical user have better intuition about predicates (than a set of interiors/border/exterior intersections).
Predicates have useful
semantic
Semantics (from grc, σημαντικός ''sēmantikós'', "significant") is the study of reference, meaning, or truth. The term can be used to refer to subfields of several distinct disciplines, including philosophy, linguistics and comput ...
into usual applications, so it is useful the translation of a ''DE-9IM'' description into a list of all associated predicates,
[Note. Th]
Oracle's spatial funcion
do only a partial translation, internally, offering to user a mask for a or-list of predicates to be checked, instead the DE-9IM string. that is like a
casting process
Casting is a manufacturing process in which a liquid material is usually poured into a mold, which contains a hollow cavity of the desired shape, and then allowed to solidify. The solidified part is also known as a ''casting'', which is ejected ...
between the two different semantic types. Examples:
* The string codes "" and "" have the semantic of "''Intersects & Crosses & Overlaps''".
* The string code "" have the semantic of "''Equals''".
* The string codes "", "", "", "", and "" have the semantic of "''Intersects & Touches''".
Standards
The
Open Geospatial Consortium (OGC) has standardized the typical spatial predicates (Contains, Crosses, Intersects, Touches, etc.) as boolean functions, and the DE-9IM model,
["OpenGIS Implementation Specification for Geographic information - Simple feature access - Part 2: SQL option", OGC, http://www.opengeospatial.org/standards/sfs] as a function that returns a string (the DE-9IM code), with domain of , meaning =point, =line, =area, and ="empty set". This DE-9IM string code is a standardized format for data interchange.
The
Simple Feature Access
Simple Features (officially Simple Feature Access) is a set of standards that specify a common storage and access model of geographic feature made of mostly two-dimensional geometries (point, line, polygon, multi-point, multi-line, etc.) used by ...
(ISO 19125) standard,
[
Open Geospatial Consortium Inc. (2007), "OpenGIS® Implementation Standard for Geographic
information - Simple feature access - Part 2: SQL option"]
OGC document
''06-104r4'' version 1.2.1 (review of 2010-08-04). in the chapter 7.2.8, "SQL routines on type Geometry", recommends as supported routines the ''SQL/MM Spatial'' (ISO 13249-3 Part 3: Spatial) ''ST_Dimension'', ''ST_GeometryType'', ''ST_IsEmpty'', ''ST_IsSimple'', ''ST_Boundary'' for all Geometry Types.
The same standard, consistent with the definitions of relations in "Part 1, Clause 6.1.2.3"
of the SQL/MM, recommends (shall be supported) the function labels: ''ST_Equals'', ''ST_Disjoint'', ''ST_Intersects'', ''ST_Touches'', ''ST_Crosses'', ''ST_Within'', ''ST_Contains'', ''ST_Overlaps'' and ''ST_Relate''.
The DE-9IM in the OGC standards use the following definitions of Interior and Boundary, for the main OGC standard geometry types:
Implementation and practical use
Most spatial databases, such as
PostGIS, implements the ''DE-9IM()'' model by the standard functions:
ST_Relate
,
ST_Equals
,
ST_Intersects
, etc. The function
ST_Relate(a,b)
outputs the standard OGC's ''DE-9IM string code''.
Examples: two geometries, ''a'' and ''b'', that intersects and touches with a point (for instance with and ), can be
ST_Relate(a,b)='FF1F0F1F2'
or
ST_Relate(a,b)='FF10F0102'
or
ST_Relate(a,b)='FF1F0F1F2'
. It also satisfies
ST_Intersects(a,b)=true
and
ST_Touches(a,b)=true
.
When
ST_Relate(a,b)='0FFFFF212'
, the returned DE-9IM code have the semantic of "Intersects(a,b) & Crosses(a,b) & Within(a,b) & CoveredBy(a,b)", that is, returns
true
on the boolean expression
ST_Intersects(a,b) AND ST_Crosses(a,b) AND ST_Within(a,b) AND ST_Coveredby(a,b)
.
The use of is faster than direct computing of a set of correspondent predicates.
[Chapter 4. Using PostGIS: Data Management and Queries](_blank)
/ref> There are cases where using is the only way to compute a complex predicate — see the example of the code 0FFFFF0F2
,[JTS test case of "point A within one of B points", http://www.vividsolutions.com/jts/tests/Run1Case4.html ] of a point that not "crosses" a multipoint (a object that is a set of points), but predicate ''Crosses'' (when defined by a mask) returns ''true''.
It is usual to overload the by adding a mask parameter,
or use a returned string into the function.
When using , it returns a boolean. Examples:
* ST_Relate(a,b,'*FF*FF212')
returns ''true'' when ST_Relate(a,b)
is 0FFFFF212
or 01FFFF212
, and returns ''false'' when 01FFFF122
or 0FF1FFFFF
.
* ST_RelateMatch('0FFFFF212','*FF*FF212')
and ST_RelateMatch('01FFFF212','TTF*FF212')
are ''true'', ST_RelateMatch('01FFFF122','*FF*FF212')
is ''false''.
Synonyms
* "Egenhofer-Matrix" is a synonym for the ''9IM'' 3x3 matrix of boolean domain.["Encyclopedia of GIS", S. Shekhar, H. Xiong. .]
* "Clementini-Matrix" is a synonym for the DE-9IM 3x3 matrix of domain.
* "Egenhofer operators" and "Clementini operators" are sometimes a reference to matrix elements as ''II'', ''IE'', etc. that can be used in boolean operations. Example: the predicate "''G1'' contains ''G2''" can be expressed by "", that can be translated to mask syntax, T*****FF*
.
* Predicates "meets" is a synonym for ''touches''; "inside" is a synonym for ''within''
* Oracle's "ANYINTERACT" is a synonym for ''intersects'' and "OVERLAPBDYINTERSECT" is a synonym for ''overlaps''. Its "OVERLAPBDYDISJOINT" does not have a corresponding named predicate.
* In Region connection calculus operators offer some synonyms for predicates: ''disjoint'' is DC (disconnected), ''touches'' is EC (externally connected), ''equals'' is EQ. Other, like ''Overlaps'' as PO (partially overlapping), need context analysis or composition.
See also
References
{{Reflist
External links
Point Set Theory and the DE-9IM Matrix
Matrices
Geometric topology
Geographic data and information
Binary operations
Geometric intersection