-
-
Notifications
You must be signed in to change notification settings - Fork 118
Primitives and PrimitiveComputers
A "primitive" in discrete geometry is usually understood as some family of digital shapes with specific properties. Classical ones are digital straight lines and segments, digital planes, digital arcs, digital circles, etc. These objects can be sometimes summarized with a few coefficients. Furthermore, a lot of algorithms exist to recognize these primitives, meaning that, given a set of points, it detects if it belongs to this family and determines a correct instance.
A general approach to a primitive / shape family F is to define them as a function from subsets of a given set S to Bool. It is a function from the powerset of S to Bool, or equivalently an element of the powerset of S. In the finite case, it may also be seen as a subset of the lattice powerset.
Primitives are characterized by intra-properties. Some of this properties induces the presence of some operations, others are just semantic. Properties are tags either True or False.
- Increasing: For any T, T' subsets of S, T \subset T' => F(T) <= F(T'). Ex: sets with more than k elements.
- Decreasing: For any T, T' subsets of S, T \subset T' => F(T) >= F(T'). Ex: piece of digital plane (not necessarily connected)
- PartiallyDecreasing: For any T={a_i}{i=1..n} subset of S, there is a permutation s such that for all 1<=j<=n, F({a_s(i)}{i=1..j-1}) >= F({a_s(i)}_{i=1..j}). Ex: connected piece of digital plane
- LeftOrderedDecreasing: Given a strict ordering < on S, For any a_1 < a_2 < ... < a_n elements of S, F({a_i}{i=2..n}) >= F({a_i}{i=1..n}). Ex: connected digital straight segment.
- RightOrderedDecreasing: Given a strict ordering < on S, For any a_1 < a_2 < ... < a_n elements of S, F({a_i}{i=1..n-1}) >= F({a_i}{i=1..n}). Ex: connected digital straight segment.
- HasBottom: F(\emptyset) is true.
- HasTop: F(S) is true.
- OrderedSpace: S has a strict ordering (what about cyclic ordering ?)
Some are instance-properties (and implies operations).
- Enumerable: given a domain D, T such that F(T), then D \cap T is iterable (enumerate( Domain ): Range)
- Iterable: given T such that F(T), the elements of T can be visited with begin(), end()
- Bounded: any T such that F(T) has a bounding box. (lowerBound(): Point and upperBound(): Point
Some could be inter-properties (with another primitive G)
- Inclusion: for any T, F(T) <= G(T). Ex: connected digital straight segments are included in arbitrary digital straight segment. Naive planes are included in unconnected planes Connected digital straight segments are included in connected digital circular arcs.
- IsConvertible: Given any T with F(T), a T' with G(T') is computable.
The concept of primitive is thus very light:
-
CPrimitive
: Inner types- Space: the type of S
- Element: the type of each element of S
- should be Assignable, CopyConstructible.
- should be DefaultConstructible iff HasBottom.
Objects that determines if T satisfies F(T) might use properties of F. They may also offer a variety of services to check F(T): offline, incremental, dynamic, etc. These objects are called PrimitiveComputers.
-
CPrimitiveComputer
: Any PrimitiveComputer has a current state (which is a set T such that F(T)). It must also be able to provide the corresponding primitive instance. It has inner types:- Primitive: the type of each primitive
- Element: the type Primitive::Element
- Methods:
- primitive() const: Primitive. Returns T.
-
CFinitePrimitiveComputer
->CPrimitiveComputer
: The set T is finite. The object is also aCConstRange
.- This requires PrimitiveTraits::Iterable
- Do we need to force a method template create( ElementIt it, ElementIt itE ) : bool that creates F([it,itE]) ?
-
CSegmentComputer
->CFinitePrimitiveComputer
: A variant where S has a strict ordering.- This requires PrimitiveTraits::OrderedSpace
-
CIncrementalPrimitiveComputer
->CFinitePrimitiveComputer
: From T and F(T), this object can determine if F(T \cup t) for t \in S.- extend( Element ) : bool
- isExtendable( Element ) const : bool
- This requires PrimitiveTraits::PartiallyDecreasing ?
-
CAdditivePrimitiveComputer
->CIncrementalPrimitiveComputer
: From T and F(T), this object can determine if F(T \cup [it,itE]).- extend( it, itE ) : bool
- isExtendable( it, itE ) const : bool
- This requires PrimitiveTraits::PartiallyDecreasing ?