Lexicon
This article describes a few words commonly used in computational geometry and explains their meaning (and how they are used in this documentation). The list is going to be maintained and expanded.
Collinear
Sometimes spelled colinear. Three points are considered to be collinear if a single straight line can be drawn through all of them. Collinear points often lead to problems in algorithms since they do not form a triangle (or a triangle with zero area).
data:image/s3,"s3://crabby-images/7726d/7726dcd9eb1a8fa676a376c624897b19cf37613a" alt=""
Concave
A boundary is concave if it is not convex. In other words, a boundary, such that not every point inside can be connected to each other point by a simple straight line.
data:image/s3,"s3://crabby-images/f5266/f5266b5b1463525c4f58dec76aaf60e81bfe77ad" alt=""
Convex
A boundary (for example a polygon) is convex if from every point inside it, all other points are visible (and you can connect them with a straight line without ever intersecting the boundary)
data:image/s3,"s3://crabby-images/d3a67/d3a675b7b6a768b618e0203a8db717b24f762ca9" alt=""
Degenerate Case
Special cases in geometric algorithms that are encountered during the execution, usually due to ill-formed input (triangles with collinear points, zero-length lines, a circle with infinite radius etc.), precision problems or some form of limit is reached.
Dynamic
In the context of data structures in computational geometry, dynamic data structures and dynamic algorithms react well to the changes in the data. I.e. they are quick to update and do not need a complete reconstruction. Many problems in video game development are dynamic, as GameObjects and Entities move around the world.
Since both types of problems can occur (dynamic for moving object or static for non-moving object), choosing the right structure for the task at hand will improve the performance!
Euclidean Distance
The most common or “regular” way of measuring the distance between two points in space. For 2D, mathematically speaking, it looks like so:
data:image/s3,"s3://crabby-images/0b3d6/0b3d67654da0d1b5cda87d246c0406375662b3d3" alt=""
In Unity we do the same with the following code:
Vector2.Distance(a, b);
Manhatten Distance
Also called taxicab distance or city block distance. As the name would suggest, it is a measurement of distances within a “grid” i.e. in a space where you can only move along the axes and not along any diagonal.
data:image/s3,"s3://crabby-images/f647d/f647d616016d3a396a9f167cd49b05e5e72aca9c" alt=""
For 2D the distance metric is defined as . In Unity we can express the mathematical formula with the following code:
Mathf.Abs(a.x - b.x) + Mathf.Abs(a.y - b.y)
Nearest Neighbor Search
Abbreviated NN Search or NNS. A type of query that, given an input position, will return the nearest/closest point or shape that is inside of a spatial data structure. A variant called kNN Search return the k closest points or shapes to a given position.
Spatial Data Structure
A data structure specialized for sorting and finding geometric objects in an d-dimensional space fast. Examples of these are KD-Trees, Quadtrees, etc. The structures can be subtly different to handle for example dynamic or static objects better.
An example for structures that handle geometric objects that are not just points, is the Ball* Tree, that manages a collection of circles or spheres.
Sweep line algorithm
A category of algorithms were a line is “swept” through a geometric data set. It can be done in numerous ways, but usually goes from a “highest” point to a “lowest” point.
data:image/s3,"s3://crabby-images/ee641/ee641d04ae76e022cc187ce87df8aab532997db5" alt=""
This method combined with the right data structures can speed up some calculations dramatically. The strategy is not limited to lines, but can be extended to planes and higher dimensions in general.